aka Git for Dummies
- You already have git installed as a command line tool
- You already have your git config set up with your identity
- Go to https://github.com/ACEmulator/ACE, log in, and click fork. Next, grab the URL for your fork. It should be something like this: https://github.com/YourGitName/ACE
- Open your command line tool of choice, and make sure "git" is in your path. You can verify this by typing "git --version".
- Change into a directory you want to use as the parent folder to your codebase. For example, "c:\dev".
- Clone your repository/fork of ACE. To do this, type
You should now have an "ACE" folder in your current directory, and all the source should be downloaded. To get the project started, go back to the Readme.md for more information.
Any time you want to do work on ACE, you need to work in a separate branch. Here is the basic command:
- git checkout -b branch-name-with-no-spaces-that-describes-your-changes origin/master
Let's break this down. "Checkout" is the command used to switch branches. But you have to create a new one! Well, that's what the "-b" does, followed by the name. The "origin/master" tells git what the source branch is. In this case, you're telling it to use your fork of ACE on github.
If for some reason, you already have saved, but uncommitted, changes in your master branch, you can do a "git stash" before you do the checkout (the checkout will probably have failed). After the checkout, do a "git stash pop" to pull your changes into your new branch.
This is pretty straightforward, but here's the git commands to do it:
- git checkout master
- git pull https://github.com/ACEmulator/ACE
- git push
So, you've got something you want to add? Great! This is a team effort - thanks for helping out. After you have all your changes working locally, here's how you get that code to us.
- "Stage" all your changes. This is basically telling git what all files are changed. 99% of the time, it's everything you've changed. At the command line in the ACE folder, type
- git add .
- Commit your changes. This creates a changeset that is what will eventually become your pull request.
- git commit -m 'your message without single quotes here'
- Push your changes up to github.
- git push origin your-branch-name-here
- Go to https://github.com/ACEmulator/ACE, pull request tab, and hit the big green "New pull request" button. Find the "compare across forks" link in the upper right. Find your fork and branch in the drop downs below, add in whatever comments are appropriate, and click the green "Create pull request" button.
Oh the dreaded rebase. Sometimes you'll get hit with a "Merge conflict" change in your pull request. You need to rebase. If you did all the setup above, you're in good shape.
- Commit any uncommited work. See steps 1 and 2 of "Creating a Pull Request" above.
- Get the latest stuff from the head ACEmulator master branch as above.
- Rebase your branch
- git checkout your-branch-name
- git pull --rebase
- Resolve merge conflicts, if any. Using Visual Studio is the best way to do this. Your git command prompt will tell you if you have any conflicts, and you may be prompted to resolve them multiple times. After each time in Visual Studio, return to the command prompt and type "git rebase --continue" after you've resolved the conflicts.
- Rebuild, retest, etc.
- Commit any uncommitted changes (there should be some if there was anything to rebase at all).
- Push up to github. If you already had an open PR on that branch, it will be updated automatically.