Then, on each machine on which you intend to use git (which could just be one), you should set up your identity and some preferences doing something like this:
git config --global user.name "Abe Lincoln" git config --global user.email abe@whitehouse.gov git config --global core.editor "vi -f" git config --global alias.co checkoutThe last step (making "co" an alias for "checkout") is optional, but it hints at the fact that you can set up a swarm of aliases for common git commands if you want to (br for branch, ci for commit, st for status, ...)
To place an existing project under Git, you first do this:
cd project git initThis sets up an empty local repository. Before you put your project into it, you probably want to set up a .gitignore file which has explicit filenames and patterns for files to be excluded from git control.
To place the project under git, you do:
git add . git commit -m "initial" git status git log
The last two commands are optional "status" commands.
At this point your project is in your local repository, but has not yet been pushed to a central repository. You might never even want to push to a central repository, but most likely you do.
This is a key point with git as compared to svn. With svn there is no local repository, only a central repository. The fact that git first works with a local repository and only pushes to a remote repository when you tell it to is what makes git a distributed version control system, and this is very much a good thing.
You can push the changes in your local git repository to a remote server (which you of course must first set up) via:
git remote add origin URL git push origin masterThere are a variety of ways to specify the URL of the remote repository, and that is the subject of the next section.
There are lots of ways to specify the URL of your remote repository. The following are the sort that I always use:
The second is what I use when I want to use ssh to contact a repository on machine that really is remote. Note that there is no explicit mention of ssh.
The business of having a directory with a name ending in ".git" is a convention, but a handy one that makes it easy to recognize a git repository (as distinguished from a working copy).
Also, if you have a project of you own and have pushed it to a remote repository, the way to get a working copy on another machine is to use "git clone".
This is the equivalent of SVN checkout for you old SVN hacks out there.
git clone git://github.com/wally/goose.gitThis would create a local directory called goose containing a local repository and a working copy of the cloned project.
git commit -a -m "fiddled with stuff" git push origin master
Note that the "-m message" is optional. The commit with the -a option is a shorthand for git add followed by git commit, but I don't usually do it, and I let git prompt me for the message also.
I usually do the following:
git add . git status git commit git push origin masterDoing the status before the commit lets you see what the add has staged for commit and prevents you from commiting a bunch of binary files or something you will just have to remove immediately.
When you add new files, you must use git add to tell git to put them under control.
Another scenario is that you know there are changes in the remote repository that you need (i.e. your working copy is out of date). To bring those changes into your working copy, you do this:
git pullOr this:
git fetch origin git merge origin/masterThere are fine points here that I do not fully understand. I read an essay somewhere that said mean and nasty things about using git pull and said you should always fetch and merge. For most of what I do, this is just needless hassle. Doing the fetch and merge might be the smart thing if you had a branch in your working copy and changes that did not pertain to your branch or some more complex scenario. In any event it doesn't just automatically merge in the changes and would give you more control in complex situations.
git checkout -b branch_for_testThis checks out the current repository as a new branch and it makes this the active branch.
git branchThe git branch command is just a status command that shows you all branches and which branch is current.
Merging changed from a branch back to the master:
git checkout master git merge branch_for_testThe checkout command just switches to the master branch, then the merge command pulls in the changes.
git branch -d branch_for_test
To get information about what is staged and what is not, use:
git status git diffIt is pretty common to do a bunch of edits and then want to commit all changes. To avoid having to "git add" each file and then do a "git commit" you can do:
git commit -a -m "fixed that nasty bug"To get rid of a file (to make git stop wanting to track it, and to actually delete the working copy too). Nothing actually happens till you commit though.
git rm fileTo rename a file (git will notice if you just do a rename and you can work it out after the fact by hand), you should do:
git mv old newTo find out a history of what has gone on, use "git log", which has thousands of options.
To pull a specific file out of the repository, use:
git checkout file
git remote add xyz git://yada.com/xyz/project.git git fetch xyzThe fetch pulls all data that you do not yet have in your local repository. The command "git fetch origin" is what you use to keep a cloned project up to date. It only updates the local repository though, not your working files, you need to merge to do that. Git pull will try to fetch and merge both. See this article:
When you have everything in your local repository the way you like it, you use git push to distribute it to the central repository. If somebody else has pushed changes while you have been working, your push is rejected - you have to pull their changes, merge them into what you are doing, and then you can push.
git push origin masterThe above command pushes your master branch.
git tag git tag -a v2.03 -m "My version 2.03" git show v2.03If you omit the -a and -m you get a lightweight tag.
Tags must get pushed explicitly to a remote server:
git push origin v2.03
ssh server cd /shared/git_repos mkdir project.git cd project.git ( or cd $! ) git --bare init or maybe: git init --bare --sharedThen you can push into this empty repository:
Once this is done, how do you access this as a remote repository? You have many choices. The easy and lazy way, if you have an NFS mount shared by a team, is to use the git local protocol. This boils down to simply using the path to the repository directory:
git remote rm origin git remote add origin /shared/git_repos/project.git git push origin master
If you are going to access this remotely through ssh, you would want to change one line in the above to:
git remote add origin myname@myhost/shared/git_repos/project.git
Notice in the above that there is no explicit mention of ssh.
Another way to do things is to clone your project and then copy the clone to your server:
cd my_project cd .. git clone --bare my_project my_project.git scp -r my_project.git gituser@server.com:/shared/git_repos git clone gituser@server.com:/shared/git_repos/my_project.git
Tom's Computer Info / tom@mmto.org