|
Git is a version-control system which lets an entire group work on a project without Also, it lets you roll back to any version you previously committed (which can be handy even if you're the only one working on the project).
Additional resources:
Old version control systems (CVS, subversion) were inherently centralized: there is one central repository (“repo”), and each person checks out files, works on them, and then checks them back in (after merging with any updates made to the central repository since the check-out, resolving any conflicts made to the same part of individual files, and double-checking that everything still runs).
More recently, distributed version control systems (“DVCS” — e.g. git, mercurial (“Hg”)) have no inherent central repository. Every team member has their own repo, and they swap patches back and forth.
Even when using git, the simplest model is the “centralized workflow” — all team members update one canonical repository. Even so, it's not quite the same as the inherently-centralized versions, because each team member has a full, bona fide repository sitting on their own machine. They might commit several different checkpoints to their own repository before merging their changes with the canonical repository; this lets them roll back to their own intermediate checkpoints if needed. (It's also valuable when working while traveling w/o an internet connection.) We'll give some information here; see also references such as www.atlassian.com/git/workflows#!workflow-centralized.
Note that it's not unusual that a developer might even have multiple repositories of the same project on their computer: perhaps one copy to work on, one "reference copy" to see what the current behavior is, one to build/run under a different OS or VM to check compatability, and one to experiment wildly with. Also, it's not unusual to re-set things by deleting your entire project directory and re-cloning the canonical repo from scratch.
hint: For this class, I recommend having a “canonical” repository on bitbucket.org, and then “distribute” your project to your team's project-account on rucs by simply logging on to the project-account, and pulling the latest version of your project to the dynamic_php/ directory.
Distributed version control systems also have a strong social element — programmers are able to make their projects public, and web-searchable. Git has become the most prominent DVCS. There are two particularly prominent sites which are used to host git projects: github.com, and bitbucket.org. Both offer limited free projects, and let you pay for more features/projects. Github has somewhat more users, but bitbucket is also very popular. We'll use bitbucket since it lets us make private repositories for free (as long as they have no more than five users or so).
The centralized workflow mantra is: “pull, commit, pull, push”.
Once you have a project set up, your day-to-day workflow is to cd to the project directory, then:
When using git, I focus on three different copies of the files:
Of course, there are more files, even aside from other people's repos: each repo contains [enough information to create] every previous commit'd version of the files (the history), and there is also a “staging area” which can exist temporarily, between your working copy and the local repo.
A game, Oh my git!
.
If you try it out, let me know what you think!
Download and install2 command-line git locally.
Note that if you don't have your own machine (or don't want to download git onto it), you can do all these steps on rucs; git is already installed there.
After doing this, you should have an empty directory on your home machine.
…Okay, that's enough work for now; let's save our project to the repo:
Tell git that this file is one that you want to include in the repository: git add foo.txt.
You might wonder why git doesn't automatically add your new files to the repo; it's because often there are generated-files that you don't want in the repository — for example, you might add Foo.java but not Foo.class.
Commit the file to your local repository:
Alternately, if you don't want to open a text-editor to create the message:
run
“
Finally, push the changes to our canonical repo: git push. Note that by default, it is pushed back to the repo that you cloned this from. (You could push your changes back to a different repo by providing additional arguments. In practice, you tend to only push back to the one canonical repo.)
The first time you push, you might get a warning about setting an option. I recommend following the suggested git config command to use the simple push. (This means using the centralized workflow.)
In step d, if there were a conflict, then our local working copy of the file (say, “foo.txt”) will be changed so that the conflicting regions are indicated:
This line is the same in both versions. <<<<<<< Updated upstream hello, there. ======= hello another line! >>>>>>> Stashed changes This line is also the same in both versions.If this happens, git won't let you commit or push until you fix the conflict:
(Once I got an error “fatal: cannot do a partial commit during a merge.”. The suggested-advice didn't help; to fix it I had to git commit --include file-with-conflict.txt, followed by git pull, and then repeating the fix via the steps above. (Perhaps you can also avoid the “partial commit” by doing commit -a to commit all files?)
Really, git is a suite of commands — e.g. “git push” or “git status”. There are about 30 such verbs, but only 4 or 5 are needed for routine use. You can download command-line tools for Unix (including OS X) and Windows.
hint: There are also GUI clients available, as well as plug-ins for all major IDEs, like eclipse. But I strongly recommend learning to use the command-line tools, to learn the basics, and to understand what those other clients are doing for you (and, what they're capable of doing).
It's worth knowing that git keeps old copies of files in a subdirectory named .git/, inside each directory in your project. (Technically, it keeps enough information to be able to re-create old files.) You don't need to mess with the files inside .git/, but it's convenient that they are just regular files (and can be copied, backed up, etc.). Git also tracks content by a file's SHA-1 hash; you'll see them when downloading patches. So two files with the same contents will be recognized has having the same content.
There are ways to configure defaults through preference files, either on a per-project-directory basis (./.git/config), a per-user basis (~/.gitconfig), or a per-system basis (/etc/gitconfig).
For full information, see Pro Git (free; formerly “the git book”).
When you first install git (or, when running it for the first time), you'll want to provide values for your name and email — these get used in the log files:
When doing git log, I like to see (a) the name of the file(s) changed per commit (not just the description), and (b) I prefer date in the ISO format. Thus: git log --name-only --date=iso.
Moreover, I would like those to be the default behavior.
This page licensed CC-BY 4.0 Ian Barland Page last generated | Please mail any suggestions (incl. typos, broken links) to ibarlandradford.edu |