- Open Command Prompt.
- Navigate to where you want your project to be.
- Clone the existing repository.
git clone [link to repo - this will end in ".git"]
- CD into the project folder.
cd [name of project folder]
- If you want to see the local branches:
git branch
Or if you want to see all branches, including remote:
git branch -a
- If the branch you want to work on already exists, switch to it.
git checkout [branch name]
Or create a new branch and switch to it.
git checkout -b [branch name]
- Work on your code! :)
- Check the status if you want to see which files have been changed.
git status
- Add the files you've changed to the staging area.
git add [file name]
- Commit your changes (don't forget to add a commit message)!
git commit -m "[commit message]"
If you forget to add a commit message, you can exit Vim by typing ":wq" at the bottom and pressing enter.
- Make sure that your version of the project is up to date (i.e. that no one has pushed any changes between when you last pulled and now) by pulling again.
git pull
Note: Use "git pull" on the master branch. A common problem that people have run into during the projects is that they've typed "git pull" on a specific branch, and then when it's asked for more information they've typed "git pull origin [current branch name]" and only pulled the current branch. You want to pull the whole project.
- (Switch back to the relevant branch if you moved to master in the last step.) Push your changes.
git push origin [branch name]
Sometimes you'll want to create the project in IntelliJ and set up Maven etc. instead of starting from something that's cloned from GitHub. This also applies to situations where you've started on a project and only decide to push it to GitHub later (no judgement, I promise).
- Create a project in IntelliJ; set up Maven, etc.
- Create the repo on GitHub. If it's your first time linking an existing project with a GitHub repo, I recommend initialising the project without a readme, gitignore or license (so that the version on GitHub is empty) to avoid extra steps.
- Navigate to the project folder in the terminal.
- The following command initialises the local version of your project as a GitHub repository:
git init
- Now you need to link your local repository to the remote repository. Find the link to the GitHub repo; it's the same link as if you were cloning it. The following command will set your local repo up to push to your GitHub repo:
git remote add origin [link to remote repo]
If you set up an empty GitHub repo, you're now ready to add/commit/push changes as normal! If the GitHub repo has files that you need to pull (README.md, .gitignore, LICENSE.md etc.), you'll need to do a little more.
- Set your local master branch to track its remote counterpart.
git branch --set-upstream-to=origin/master master
- Typing "git pull" on its own may cause it to say "fatal: refusing to merge unrelated histories." If it does, type the following:
git pull origin master --allow-unrelated-histories
The default commit message to merge the changes is fine. Use the arrows to get to the bottom of the window; type the following and press enter:
:wq
- You can now push your changes.
git push origin master
-
"It's saying I've changed files that I haven't."
- Try "git diff" to see the changes. That will shed some light on whether it's just your linter (if you have one), or if maybe you didn't merge some changes that you thought you did, etc.
git diff
- To see changes in files you've already staged:
git diff --staged
-
"Why does it keep saying I've changed RabbitProject.iml?"
- I don't know.
(Okay, fine, see below.)
-
"Why can't I see the branches I expect to see?"
- You may be looking at local branches specifically. This is the command to also see remote branches:
git branch -a
- You may have an old version of the repo that doesn't have the branch. Pull the most recent version.
git pull
-
"What if I have changes that I don't want to commit, but I want a clean working tree?"
- You can stash changes, and an upside of this is that it doesn't actually delete them.
git stash
-
"I accidentally staged a file that I didn't mean to."
- To remove a file from the staging area:
git reset [file name]
-
"I've started a project on IntelliJ, created a repo on GitHub, remembered to add the origin, set the branch to track the correct branch... anyway, it says "fatal: refusing to merge unrelated histories" when I try to merge."
- Git doesn't like that the two repos have different commit histories. If you're sure that it's basically just that your local version has the project while the remote repo just has the files you initialised it with (a .gitignore, a README.md, a license etc.), then you can reassure it (i.e. tell it to shut up) with the following:
git pull origin master --allow-unrelated-histories
-
"Where did [person] go?!"
- They're probably peeing, but try sending another message in all caps this time.
- Sometimes it's really easy to miss that the command line is telling you that it has run into a problem. The text will be calm and white, but it will (for example) be telling you that the merge you just attempted actually failed, so when you next start the process of adding and committing, it will tell you that a whole bunch of files have changed, and you won't know why. Or you'll end up in a situation where you'll be very convinced that you have the latest version of the project, when you actually don't. That's why we have to be super careful about reading what the terminal says! :)
- Regarding .iml files, we just need to decide (at the beginning) whether or not they go in the .gitignore and be consistent about it. In general, if it says you've made changes to a file (and the terminal's complaining about potentially overwriting it) but you don't see any (using git diff) and you're sure you didn't actually change it, just stash the changes or something; no one cares. It'll be fine.
- Sometimes people have been very confused about why they don't seem to have the whole project, when they've only pulled one branch. "git pull origin [branch name]" will only pull the specified branch.