Christian Couder | b27a23e | 2008-05-24 20:56:44 +0200 | [diff] [blame] | 1 | gittutorial(7) |
| 2 | ============== |
| 3 | |
| 4 | NAME |
| 5 | ---- |
Thomas Ackermann | 022cf2b | 2014-11-11 20:13:36 +0100 | [diff] [blame] | 6 | gittutorial - A tutorial introduction to Git |
Christian Couder | b27a23e | 2008-05-24 20:56:44 +0200 | [diff] [blame] | 7 | |
| 8 | SYNOPSIS |
| 9 | -------- |
Martin von Zweigbergk | 7791a1d | 2011-07-01 22:38:26 -0400 | [diff] [blame] | 10 | [verse] |
Christian Couder | b27a23e | 2008-05-24 20:56:44 +0200 | [diff] [blame] | 11 | git * |
| 12 | |
| 13 | DESCRIPTION |
| 14 | ----------- |
Linus Torvalds | 8c7fa24 | 2005-05-31 19:50:34 -0700 | [diff] [blame] | 15 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 16 | This tutorial explains how to import a new project into Git, make |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 17 | changes to it, and share changes with other developers. |
Linus Torvalds | 8c7fa24 | 2005-05-31 19:50:34 -0700 | [diff] [blame] | 18 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 19 | If you are instead primarily interested in using Git to fetch a project, |
J. Bruce Fields | cd50aba | 2007-05-17 23:56:08 -0400 | [diff] [blame] | 20 | for example, to test the latest version, you may prefer to start with |
| 21 | the first two chapters of link:user-manual.html[The Git User's Manual]. |
| 22 | |
Jonathan Nieder | 46e56e8 | 2008-06-30 17:17:07 -0500 | [diff] [blame] | 23 | First, note that you can get documentation for a command such as |
Jonathan Nieder | 483bc4f | 2008-06-30 13:56:34 -0500 | [diff] [blame] | 24 | `git log --graph` with: |
Linus Torvalds | 8c7fa24 | 2005-05-31 19:50:34 -0700 | [diff] [blame] | 25 | |
Junio C Hamano | 8db9307 | 2005-08-30 13:51:01 -0700 | [diff] [blame] | 26 | ------------------------------------------------ |
Jonathan Nieder | 3861cd5 | 2008-06-30 17:10:25 -0500 | [diff] [blame] | 27 | $ man git-log |
Junio C Hamano | 8db9307 | 2005-08-30 13:51:01 -0700 | [diff] [blame] | 28 | ------------------------------------------------ |
Linus Torvalds | 8c7fa24 | 2005-05-31 19:50:34 -0700 | [diff] [blame] | 29 | |
Christian Couder | 6e702c2 | 2008-11-17 16:43:04 +0100 | [diff] [blame] | 30 | or: |
| 31 | |
| 32 | ------------------------------------------------ |
| 33 | $ git help log |
| 34 | ------------------------------------------------ |
| 35 | |
| 36 | With the latter, you can use the manual viewer of your choice; see |
| 37 | linkgit:git-help[1] for more information. |
| 38 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 39 | It is a good idea to introduce yourself to Git with your name and |
Nicolas Pitre | c14261e | 2007-01-14 22:44:18 -0500 | [diff] [blame] | 40 | public email address before doing any operation. The easiest |
| 41 | way to do so is: |
Junio C Hamano | 6658923 | 2006-11-29 00:17:01 -0800 | [diff] [blame] | 42 | |
| 43 | ------------------------------------------------ |
Tom Prince | e0d10e1 | 2007-01-28 16:16:53 -0800 | [diff] [blame] | 44 | $ git config --global user.name "Your Name Comes Here" |
| 45 | $ git config --global user.email you@yourdomain.example.com |
Junio C Hamano | 6658923 | 2006-11-29 00:17:01 -0800 | [diff] [blame] | 46 | ------------------------------------------------ |
| 47 | |
| 48 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 49 | Importing a new project |
Junio C Hamano | 2a29da7 | 2005-08-23 15:28:34 -0700 | [diff] [blame] | 50 | ----------------------- |
Junio C Hamano | 3eb5128 | 2005-07-15 11:40:56 -0700 | [diff] [blame] | 51 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 52 | Assume you have a tarball project.tar.gz with your initial work. You |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 53 | can place it under Git revision control as follows. |
Junio C Hamano | 3eb5128 | 2005-07-15 11:40:56 -0700 | [diff] [blame] | 54 | |
Junio C Hamano | c951734 | 2005-08-24 16:46:11 -0700 | [diff] [blame] | 55 | ------------------------------------------------ |
Junio C Hamano | dcc6e28 | 2006-01-22 22:43:59 -0800 | [diff] [blame] | 56 | $ tar xzf project.tar.gz |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 57 | $ cd project |
Nicolas Pitre | 515377e | 2007-01-07 12:31:29 -0500 | [diff] [blame] | 58 | $ git init |
Junio C Hamano | c951734 | 2005-08-24 16:46:11 -0700 | [diff] [blame] | 59 | ------------------------------------------------ |
| 60 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 61 | Git will reply |
Junio C Hamano | c951734 | 2005-08-24 16:46:11 -0700 | [diff] [blame] | 62 | |
Junio C Hamano | c951734 | 2005-08-24 16:46:11 -0700 | [diff] [blame] | 63 | ------------------------------------------------ |
Shawn O. Pearce | ef0a89a | 2006-12-15 00:44:58 -0500 | [diff] [blame] | 64 | Initialized empty Git repository in .git/ |
Junio C Hamano | c951734 | 2005-08-24 16:46:11 -0700 | [diff] [blame] | 65 | ------------------------------------------------ |
Junio C Hamano | 2a29da7 | 2005-08-23 15:28:34 -0700 | [diff] [blame] | 66 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 67 | You've now initialized the working directory--you may notice a new |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 68 | directory created, named ".git". |
| 69 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 70 | Next, tell Git to take a snapshot of the contents of all files under the |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 71 | current directory (note the '.'), with 'git add': |
Junio C Hamano | 2a29da7 | 2005-08-23 15:28:34 -0700 | [diff] [blame] | 72 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 73 | ------------------------------------------------ |
| 74 | $ git add . |
| 75 | ------------------------------------------------ |
| 76 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 77 | This snapshot is now stored in a temporary staging area which Git calls |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 78 | the "index". You can permanently store the contents of the index in the |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 79 | repository with 'git commit': |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 80 | |
| 81 | ------------------------------------------------ |
Junio C Hamano | 6658923 | 2006-11-29 00:17:01 -0800 | [diff] [blame] | 82 | $ git commit |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 83 | ------------------------------------------------ |
| 84 | |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 85 | This will prompt you for a commit message. You've now stored the first |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 86 | version of your project in Git. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 87 | |
J. Bruce Fields | 84dee6b | 2007-01-06 22:38:38 -0500 | [diff] [blame] | 88 | Making changes |
| 89 | -------------- |
| 90 | |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 91 | Modify some files, then add their updated contents to the index: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 92 | |
| 93 | ------------------------------------------------ |
J. Bruce Fields | 84dee6b | 2007-01-06 22:38:38 -0500 | [diff] [blame] | 94 | $ git add file1 file2 file3 |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 95 | ------------------------------------------------ |
| 96 | |
| 97 | You are now ready to commit. You can see what is about to be committed |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 98 | using 'git diff' with the --cached option: |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 99 | |
| 100 | ------------------------------------------------ |
| 101 | $ git diff --cached |
| 102 | ------------------------------------------------ |
| 103 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 104 | (Without --cached, 'git diff' will show you any changes that |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 105 | you've made but not yet added to the index.) You can also get a brief |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 106 | summary of the situation with 'git status': |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 107 | |
| 108 | ------------------------------------------------ |
| 109 | $ git status |
Stefan Naewe | 8942821 | 2014-11-13 10:40:07 +0000 | [diff] [blame] | 110 | On branch master |
| 111 | Changes to be committed: |
Martin Ågren | 7560f54 | 2017-08-23 19:49:35 +0200 | [diff] [blame] | 112 | Your branch is up to date with 'origin/master'. |
Nguyễn Thái Ngọc Duy | 80f537f | 2019-04-25 16:45:58 +0700 | [diff] [blame] | 113 | (use "git restore --staged <file>..." to unstage) |
Stefan Naewe | 8942821 | 2014-11-13 10:40:07 +0000 | [diff] [blame] | 114 | |
| 115 | modified: file1 |
| 116 | modified: file2 |
| 117 | modified: file3 |
| 118 | |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 119 | ------------------------------------------------ |
| 120 | |
| 121 | If you need to make any further adjustments, do so now, and then add any |
| 122 | newly modified content to the index. Finally, commit your changes with: |
| 123 | |
| 124 | ------------------------------------------------ |
Junio C Hamano | c1d179f | 2007-01-03 08:38:01 -0800 | [diff] [blame] | 125 | $ git commit |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 126 | ------------------------------------------------ |
| 127 | |
Fred Maranhão | 2feaf4e | 2008-06-11 19:09:48 -0400 | [diff] [blame] | 128 | This will again prompt you for a message describing the change, and then |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 129 | record a new version of the project. |
J. Bruce Fields | 84dee6b | 2007-01-06 22:38:38 -0500 | [diff] [blame] | 130 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 131 | Alternatively, instead of running 'git add' beforehand, you can use |
Junio C Hamano | 6658923 | 2006-11-29 00:17:01 -0800 | [diff] [blame] | 132 | |
| 133 | ------------------------------------------------ |
| 134 | $ git commit -a |
| 135 | ------------------------------------------------ |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 136 | |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 137 | which will automatically notice any modified (but not new) files, add |
| 138 | them to the index, and commit, all in one step. |
J. Bruce Fields | 84dee6b | 2007-01-06 22:38:38 -0500 | [diff] [blame] | 139 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 140 | A note on commit messages: Though not required, it's a good idea to |
| 141 | begin the commit message with a single short (less than 50 character) |
| 142 | line summarizing the change, followed by a blank line and then a more |
Jeremy White | 52ffe99 | 2012-09-13 17:27:09 -0500 | [diff] [blame] | 143 | thorough description. The text up to the first blank line in a commit |
| 144 | message is treated as the commit title, and that title is used |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 145 | throughout Git. For example, linkgit:git-format-patch[1] turns a |
Jeremy White | 52ffe99 | 2012-09-13 17:27:09 -0500 | [diff] [blame] | 146 | commit into email, and it uses the title on the Subject line and the |
| 147 | rest of the commit in the body. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 148 | |
Nicolas Pitre | 366bfcb | 2006-12-04 11:13:39 -0500 | [diff] [blame] | 149 | Git tracks content not files |
| 150 | ---------------------------- |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 151 | |
Jonathan Nieder | 483bc4f | 2008-06-30 13:56:34 -0500 | [diff] [blame] | 152 | Many revision control systems provide an `add` command that tells the |
| 153 | system to start tracking changes to a new file. Git's `add` command |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 154 | does something simpler and more powerful: 'git add' is used both for new |
J. Bruce Fields | 93f9cc6 | 2007-05-18 00:51:42 -0400 | [diff] [blame] | 155 | and newly modified files, and in both cases it takes a snapshot of the |
| 156 | given files and stages that content in the index, ready for inclusion in |
| 157 | the next commit. |
Nicolas Pitre | 366bfcb | 2006-12-04 11:13:39 -0500 | [diff] [blame] | 158 | |
J. Bruce Fields | 23c9ccb | 2007-06-10 16:20:34 -0400 | [diff] [blame] | 159 | Viewing project history |
| 160 | ----------------------- |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 161 | |
| 162 | At any point you can view the history of your changes using |
| 163 | |
| 164 | ------------------------------------------------ |
J. Bruce Fields | 67e6e5c | 2006-05-21 16:52:34 -0400 | [diff] [blame] | 165 | $ git log |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 166 | ------------------------------------------------ |
| 167 | |
| 168 | If you also want to see complete diffs at each step, use |
| 169 | |
| 170 | ------------------------------------------------ |
J. Bruce Fields | 67e6e5c | 2006-05-21 16:52:34 -0400 | [diff] [blame] | 171 | $ git log -p |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 172 | ------------------------------------------------ |
| 173 | |
Junio C Hamano | c1d179f | 2007-01-03 08:38:01 -0800 | [diff] [blame] | 174 | Often the overview of the change is useful to get a feel of |
| 175 | each step |
| 176 | |
| 177 | ------------------------------------------------ |
| 178 | $ git log --stat --summary |
| 179 | ------------------------------------------------ |
| 180 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 181 | Managing branches |
| 182 | ----------------- |
| 183 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 184 | A single Git repository can maintain multiple branches of |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 185 | development. To create a new branch named "experimental", use |
| 186 | |
| 187 | ------------------------------------------------ |
| 188 | $ git branch experimental |
| 189 | ------------------------------------------------ |
| 190 | |
| 191 | If you now run |
| 192 | |
| 193 | ------------------------------------------------ |
| 194 | $ git branch |
| 195 | ------------------------------------------------ |
| 196 | |
| 197 | you'll get a list of all existing branches: |
| 198 | |
| 199 | ------------------------------------------------ |
| 200 | experimental |
| 201 | * master |
| 202 | ------------------------------------------------ |
| 203 | |
| 204 | The "experimental" branch is the one you just created, and the |
| 205 | "master" branch is a default branch that was created for you |
| 206 | automatically. The asterisk marks the branch you are currently on; |
| 207 | type |
| 208 | |
| 209 | ------------------------------------------------ |
Nguyễn Thái Ngọc Duy | 328c6cb | 2019-03-29 17:39:19 +0700 | [diff] [blame] | 210 | $ git switch experimental |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 211 | ------------------------------------------------ |
| 212 | |
| 213 | to switch to the experimental branch. Now edit a file, commit the |
| 214 | change, and switch back to the master branch: |
| 215 | |
| 216 | ------------------------------------------------ |
| 217 | (edit file) |
| 218 | $ git commit -a |
Nguyễn Thái Ngọc Duy | 328c6cb | 2019-03-29 17:39:19 +0700 | [diff] [blame] | 219 | $ git switch master |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 220 | ------------------------------------------------ |
| 221 | |
| 222 | Check that the change you made is no longer visible, since it was |
| 223 | made on the experimental branch and you're back on the master branch. |
| 224 | |
| 225 | You can make a different change on the master branch: |
| 226 | |
| 227 | ------------------------------------------------ |
| 228 | (edit file) |
| 229 | $ git commit -a |
| 230 | ------------------------------------------------ |
| 231 | |
| 232 | at this point the two branches have diverged, with different changes |
Paolo Ciarrocchi | 5942706 | 2006-11-20 21:29:41 +0100 | [diff] [blame] | 233 | made in each. To merge the changes made in experimental into master, run |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 234 | |
| 235 | ------------------------------------------------ |
Nicolas Pitre | c14261e | 2007-01-14 22:44:18 -0500 | [diff] [blame] | 236 | $ git merge experimental |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 237 | ------------------------------------------------ |
| 238 | |
| 239 | If the changes don't conflict, you're done. If there are conflicts, |
| 240 | markers will be left in the problematic files showing the conflict; |
| 241 | |
| 242 | ------------------------------------------------ |
| 243 | $ git diff |
| 244 | ------------------------------------------------ |
| 245 | |
| 246 | will show this. Once you've edited the files to resolve the |
| 247 | conflicts, |
| 248 | |
| 249 | ------------------------------------------------ |
| 250 | $ git commit -a |
| 251 | ------------------------------------------------ |
| 252 | |
| 253 | will commit the result of the merge. Finally, |
| 254 | |
| 255 | ------------------------------------------------ |
| 256 | $ gitk |
| 257 | ------------------------------------------------ |
| 258 | |
| 259 | will show a nice graphical representation of the resulting history. |
| 260 | |
Santi Béjar | 9c9410e | 2007-01-03 13:53:27 +0100 | [diff] [blame] | 261 | At this point you could delete the experimental branch with |
| 262 | |
| 263 | ------------------------------------------------ |
| 264 | $ git branch -d experimental |
| 265 | ------------------------------------------------ |
| 266 | |
| 267 | This command ensures that the changes in the experimental branch are |
| 268 | already in the current branch. |
| 269 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 270 | If you develop on a branch crazy-idea, then regret it, you can always |
| 271 | delete the branch with |
| 272 | |
| 273 | ------------------------------------- |
| 274 | $ git branch -D crazy-idea |
Junio C Hamano | dc5f923 | 2005-12-05 00:57:48 -0800 | [diff] [blame] | 275 | ------------------------------------- |
| 276 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 277 | Branches are cheap and easy, so this is a good way to try something |
| 278 | out. |
Junio C Hamano | dc5f923 | 2005-12-05 00:57:48 -0800 | [diff] [blame] | 279 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 280 | Using Git for collaboration |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 281 | --------------------------- |
| 282 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 283 | Suppose that Alice has started a new project with a Git repository in |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 284 | /home/alice/project, and that Bob, who has a home directory on the |
| 285 | same machine, wants to contribute. |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 286 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 287 | Bob begins with: |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 288 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 289 | ------------------------------------------------ |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 290 | bob$ git clone /home/alice/project myrepo |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 291 | ------------------------------------------------ |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 292 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 293 | This creates a new directory "myrepo" containing a clone of Alice's |
| 294 | repository. The clone is on an equal footing with the original |
Horst H. von Brand | abda1ef | 2006-06-03 16:27:26 -0400 | [diff] [blame] | 295 | project, possessing its own copy of the original project's history. |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 296 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 297 | Bob then makes some changes and commits them: |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 298 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 299 | ------------------------------------------------ |
| 300 | (edit files) |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 301 | bob$ git commit -a |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 302 | (repeat as necessary) |
| 303 | ------------------------------------------------ |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 304 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 305 | When he's ready, he tells Alice to pull changes from the repository |
| 306 | at /home/bob/myrepo. She does this with: |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 307 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 308 | ------------------------------------------------ |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 309 | alice$ cd /home/alice/project |
| 310 | alice$ git pull /home/bob/myrepo master |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 311 | ------------------------------------------------ |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 312 | |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 313 | This merges the changes from Bob's "master" branch into Alice's |
J. Bruce Fields | 93ee782 | 2006-11-25 22:45:02 -0500 | [diff] [blame] | 314 | current branch. If Alice has made her own changes in the meantime, |
Miklos Vajna | c30e567 | 2009-01-23 19:02:29 +0100 | [diff] [blame] | 315 | then she may need to manually fix any conflicts. |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 316 | |
J. Bruce Fields | 93ee782 | 2006-11-25 22:45:02 -0500 | [diff] [blame] | 317 | The "pull" command thus performs two operations: it fetches changes |
| 318 | from a remote branch, then merges them into the current branch. |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 319 | |
Junio C Hamano | dc29bc8 | 2008-07-10 14:01:57 -0700 | [diff] [blame] | 320 | Note that in general, Alice would want her local changes committed before |
| 321 | initiating this "pull". If Bob's work conflicts with what Alice did since |
| 322 | their histories forked, Alice will use her working tree and the index to |
| 323 | resolve conflicts, and existing local changes will interfere with the |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 324 | conflict resolution process (Git will still perform the fetch but will |
Junio C Hamano | dc29bc8 | 2008-07-10 14:01:57 -0700 | [diff] [blame] | 325 | refuse to merge --- Alice will have to get rid of her local changes in |
| 326 | some way and pull again when this happens). |
| 327 | |
| 328 | Alice can peek at what Bob did without merging first, using the "fetch" |
| 329 | command; this allows Alice to inspect what Bob did, using a special |
| 330 | symbol "FETCH_HEAD", in order to determine if he has anything worth |
| 331 | pulling, like this: |
| 332 | |
| 333 | ------------------------------------------------ |
| 334 | alice$ git fetch /home/bob/myrepo master |
Paolo Ciarrocchi | 53d1589 | 2008-08-28 14:23:52 +0200 | [diff] [blame] | 335 | alice$ git log -p HEAD..FETCH_HEAD |
Junio C Hamano | dc29bc8 | 2008-07-10 14:01:57 -0700 | [diff] [blame] | 336 | ------------------------------------------------ |
| 337 | |
| 338 | This operation is safe even if Alice has uncommitted local changes. |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 339 | The range notation "HEAD..FETCH_HEAD" means "show everything that is reachable |
| 340 | from the FETCH_HEAD but exclude anything that is reachable from HEAD". |
Paolo Ciarrocchi | 53d1589 | 2008-08-28 14:23:52 +0200 | [diff] [blame] | 341 | Alice already knows everything that leads to her current state (HEAD), |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 342 | and reviews what Bob has in his state (FETCH_HEAD) that she has not |
| 343 | seen with this command. |
Paolo Ciarrocchi | 53d1589 | 2008-08-28 14:23:52 +0200 | [diff] [blame] | 344 | |
| 345 | If Alice wants to visualize what Bob did since their histories forked |
| 346 | she can issue the following command: |
| 347 | |
| 348 | ------------------------------------------------ |
| 349 | $ gitk HEAD..FETCH_HEAD |
| 350 | ------------------------------------------------ |
| 351 | |
| 352 | This uses the same two-dot range notation we saw earlier with 'git log'. |
| 353 | |
| 354 | Alice may want to view what both of them did since they forked. |
| 355 | She can use three-dot form instead of the two-dot form: |
| 356 | |
| 357 | ------------------------------------------------ |
| 358 | $ gitk HEAD...FETCH_HEAD |
| 359 | ------------------------------------------------ |
| 360 | |
| 361 | This means "show everything that is reachable from either one, but |
| 362 | exclude anything that is reachable from both of them". |
| 363 | |
| 364 | Please note that these range notation can be used with both gitk |
| 365 | and "git log". |
Junio C Hamano | dc29bc8 | 2008-07-10 14:01:57 -0700 | [diff] [blame] | 366 | |
| 367 | After inspecting what Bob did, if there is nothing urgent, Alice may |
| 368 | decide to continue working without pulling from Bob. If Bob's history |
| 369 | does have something Alice would immediately need, Alice may choose to |
| 370 | stash her work-in-progress first, do a "pull", and then finally unstash |
| 371 | her work-in-progress on top of the resulting history. |
| 372 | |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 373 | When you are working in a small closely knit group, it is not |
| 374 | unusual to interact with the same repository over and over |
| 375 | again. By defining 'remote' repository shorthand, you can make |
| 376 | it easier: |
| 377 | |
| 378 | ------------------------------------------------ |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 379 | alice$ git remote add bob /home/bob/myrepo |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 380 | ------------------------------------------------ |
| 381 | |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 382 | With this, Alice can perform the first part of the "pull" operation |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 383 | alone using the 'git fetch' command without merging them with her own |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 384 | branch, using: |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 385 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 386 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 387 | alice$ git fetch bob |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 388 | ------------------------------------- |
Junio C Hamano | 6f60300 | 2005-09-20 18:21:10 -0700 | [diff] [blame] | 389 | |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 390 | Unlike the longhand form, when Alice fetches from Bob using a |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 391 | remote repository shorthand set up with 'git remote', what was |
Matthieu Moy | 0e615b2 | 2010-11-02 16:31:20 +0100 | [diff] [blame] | 392 | fetched is stored in a remote-tracking branch, in this case |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 393 | `bob/master`. So after this: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 394 | |
| 395 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 396 | alice$ git log -p master..bob/master |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 397 | ------------------------------------- |
| 398 | |
| 399 | shows a list of all the changes that Bob made since he branched from |
| 400 | Alice's master branch. |
| 401 | |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 402 | After examining those changes, Alice |
Nicolas Pitre | c14261e | 2007-01-14 22:44:18 -0500 | [diff] [blame] | 403 | could merge the changes into her master branch: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 404 | |
| 405 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 406 | alice$ git merge bob/master |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 407 | ------------------------------------- |
| 408 | |
Matthieu Moy | 60109d0 | 2010-11-02 16:31:21 +0100 | [diff] [blame] | 409 | This `merge` can also be done by 'pulling from her own remote-tracking |
| 410 | branch', like this: |
J. Bruce Fields | 93ee782 | 2006-11-25 22:45:02 -0500 | [diff] [blame] | 411 | |
| 412 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 413 | alice$ git pull . remotes/bob/master |
J. Bruce Fields | 93ee782 | 2006-11-25 22:45:02 -0500 | [diff] [blame] | 414 | ------------------------------------- |
| 415 | |
Junio C Hamano | c1ff284 | 2007-01-17 01:10:14 +0100 | [diff] [blame] | 416 | Note that git pull always merges into the current branch, |
Brian Hetro | 0278307 | 2007-08-23 20:44:13 -0400 | [diff] [blame] | 417 | regardless of what else is given on the command line. |
J. Bruce Fields | 93ee782 | 2006-11-25 22:45:02 -0500 | [diff] [blame] | 418 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 419 | Later, Bob can update his repo with Alice's latest changes using |
| 420 | |
| 421 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 422 | bob$ git pull |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 423 | ------------------------------------- |
| 424 | |
| 425 | Note that he doesn't need to give the path to Alice's repository; |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 426 | when Bob cloned Alice's repository, Git stored the location of her |
J. Bruce Fields | d66409f | 2006-12-31 18:47:38 -0500 | [diff] [blame] | 427 | repository in the repository configuration, and that location is |
| 428 | used for pulls: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 429 | |
| 430 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 431 | bob$ git config --get remote.origin.url |
Alecs King | 8960b5a | 2007-07-06 00:21:16 +0800 | [diff] [blame] | 432 | /home/alice/project |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 433 | ------------------------------------- |
| 434 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 435 | (The complete configuration created by 'git clone' is visible using |
Jonathan Nieder | 483bc4f | 2008-06-30 13:56:34 -0500 | [diff] [blame] | 436 | `git config -l`, and the linkgit:git-config[1] man page |
J. Bruce Fields | d66409f | 2006-12-31 18:47:38 -0500 | [diff] [blame] | 437 | explains the meaning of each option.) |
| 438 | |
| 439 | Git also keeps a pristine copy of Alice's master branch under the |
| 440 | name "origin/master": |
| 441 | |
| 442 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 443 | bob$ git branch -r |
J. Bruce Fields | d66409f | 2006-12-31 18:47:38 -0500 | [diff] [blame] | 444 | origin/master |
| 445 | ------------------------------------- |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 446 | |
| 447 | If Bob later decides to work from a different host, he can still |
| 448 | perform clones and pulls using the ssh protocol: |
| 449 | |
| 450 | ------------------------------------- |
Ian Katz | 5d5e88a | 2008-07-10 14:27:30 -0400 | [diff] [blame] | 451 | bob$ git clone alice.org:/home/alice/project myrepo |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 452 | ------------------------------------- |
| 453 | |
Jeff King | 0d0bac6 | 2016-01-30 02:21:26 -0500 | [diff] [blame] | 454 | Alternatively, Git has a native protocol, or can use http; |
Dan McGee | 5162e69 | 2007-12-29 00:20:38 -0600 | [diff] [blame] | 455 | see linkgit:git-pull[1] for details. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 456 | |
| 457 | Git can also be used in a CVS-like mode, with a central repository |
Dan McGee | 5162e69 | 2007-12-29 00:20:38 -0600 | [diff] [blame] | 458 | that various users push changes to; see linkgit:git-push[1] and |
Jonathan Nieder | 6998e4d | 2008-06-30 17:01:21 -0500 | [diff] [blame] | 459 | linkgit:gitcvs-migration[7]. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 460 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 461 | Exploring history |
| 462 | ----------------- |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 463 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 464 | Git history is represented as a series of interrelated commits. We |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 465 | have already seen that the 'git log' command can list those commits. |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 466 | Note that first line of each git log entry also gives a name for the |
| 467 | commit: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 468 | |
| 469 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 470 | $ git log |
| 471 | commit c82a22c39cbc32576f64f5c6b3f24b99ea8149c7 |
| 472 | Author: Junio C Hamano <junkio@cox.net> |
| 473 | Date: Tue May 16 17:18:22 2006 -0700 |
| 474 | |
| 475 | merge-base: Clarify the comments on post processing. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 476 | ------------------------------------- |
| 477 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 478 | We can give this name to 'git show' to see the details about this |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 479 | commit. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 480 | |
| 481 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 482 | $ git show c82a22c39cbc32576f64f5c6b3f24b99ea8149c7 |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 483 | ------------------------------------- |
| 484 | |
Junio C Hamano | c1d179f | 2007-01-03 08:38:01 -0800 | [diff] [blame] | 485 | But there are other ways to refer to commits. You can use any initial |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 486 | part of the name that is long enough to uniquely identify the commit: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 487 | |
| 488 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 489 | $ git show c82a22c39c # the first few characters of the name are |
| 490 | # usually enough |
| 491 | $ git show HEAD # the tip of the current branch |
| 492 | $ git show experimental # the tip of the "experimental" branch |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 493 | ------------------------------------- |
| 494 | |
Santi Béjar | 9c9410e | 2007-01-03 13:53:27 +0100 | [diff] [blame] | 495 | Every commit usually has one "parent" commit |
| 496 | which points to the previous state of the project: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 497 | |
| 498 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 499 | $ git show HEAD^ # to see the parent of HEAD |
| 500 | $ git show HEAD^^ # to see the grandparent of HEAD |
| 501 | $ git show HEAD~4 # to see the great-great grandparent of HEAD |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 502 | ------------------------------------- |
| 503 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 504 | Note that merge commits may have more than one parent: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 505 | |
| 506 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 507 | $ git show HEAD^1 # show the first parent of HEAD (same as HEAD^) |
| 508 | $ git show HEAD^2 # show the second parent of HEAD |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 509 | ------------------------------------- |
| 510 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 511 | You can also give commits names of your own; after running |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 512 | |
| 513 | ------------------------------------- |
Jonathan Nieder | b1889c3 | 2008-06-30 01:09:04 -0500 | [diff] [blame] | 514 | $ git tag v2.5 1b2e1d63ff |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 515 | ------------------------------------- |
| 516 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 517 | you can refer to 1b2e1d63ff by the name "v2.5". If you intend to |
| 518 | share this name with other people (for example, to identify a release |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 519 | version), you should create a "tag" object, and perhaps sign it; see |
Dan McGee | 5162e69 | 2007-12-29 00:20:38 -0600 | [diff] [blame] | 520 | linkgit:git-tag[1] for details. |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 521 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 522 | Any Git command that needs to know a commit can take any of these |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 523 | names. For example: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 524 | |
| 525 | ------------------------------------- |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 526 | $ git diff v2.5 HEAD # compare the current HEAD to v2.5 |
| 527 | $ git branch stable v2.5 # start a new branch named "stable" based |
| 528 | # at v2.5 |
| 529 | $ git reset --hard HEAD^ # reset your current branch and working |
Francis Daly | 3742506 | 2006-06-07 13:56:45 +0100 | [diff] [blame] | 530 | # directory to its state at HEAD^ |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 531 | ------------------------------------- |
| 532 | |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 533 | Be careful with that last command: in addition to losing any changes |
| 534 | in the working directory, it will also remove all later commits from |
| 535 | this branch. If this branch is the only branch containing those |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 536 | commits, they will be lost. Also, don't use 'git reset' on a |
Junio C Hamano | a9d1836 | 2007-02-02 22:40:49 -0800 | [diff] [blame] | 537 | publicly-visible branch that other developers pull from, as it will |
| 538 | force needless merges on other developers to clean up the history. |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 539 | If you need to undo changes that you have pushed, use 'git revert' |
Robin Rosenberg | 6e2e1cf | 2007-02-04 17:16:39 +0100 | [diff] [blame] | 540 | instead. |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 541 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 542 | The 'git grep' command can search for strings in any version of your |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 543 | project, so |
| 544 | |
| 545 | ------------------------------------- |
| 546 | $ git grep "hello" v2.5 |
| 547 | ------------------------------------- |
| 548 | |
Horst H. von Brand | abda1ef | 2006-06-03 16:27:26 -0400 | [diff] [blame] | 549 | searches for all occurrences of "hello" in v2.5. |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 550 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 551 | If you leave out the commit name, 'git grep' will search any of the |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 552 | files it manages in your current directory. So |
| 553 | |
| 554 | ------------------------------------- |
| 555 | $ git grep "hello" |
| 556 | ------------------------------------- |
| 557 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 558 | is a quick way to search just the files that are tracked by Git. |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 559 | |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 560 | Many Git commands also take sets of commits, which can be specified |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 561 | in a number of ways. Here are some examples with 'git log': |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 562 | |
| 563 | ------------------------------------- |
| 564 | $ git log v2.5..v2.6 # commits between v2.5 and v2.6 |
| 565 | $ git log v2.5.. # commits since v2.5 |
| 566 | $ git log --since="2 weeks ago" # commits from the last 2 weeks |
| 567 | $ git log v2.5.. Makefile # commits since v2.5 which modify |
| 568 | # Makefile |
| 569 | ------------------------------------- |
| 570 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 571 | You can also give 'git log' a "range" of commits where the first is not |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 572 | necessarily an ancestor of the second; for example, if the tips of |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 573 | the branches "stable" and "master" diverged from a common |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 574 | commit some time ago, then |
| 575 | |
| 576 | ------------------------------------- |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 577 | $ git log stable..master |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 578 | ------------------------------------- |
| 579 | |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 580 | will list commits made in the master branch but not in the |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 581 | stable branch, while |
| 582 | |
| 583 | ------------------------------------- |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 584 | $ git log master..stable |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 585 | ------------------------------------- |
| 586 | |
| 587 | will show the list of commits made on the stable branch but not |
Thadeu Lima de Souza Cascardo | 21d777f | 2009-06-29 12:13:58 -0300 | [diff] [blame] | 588 | the master branch. |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 589 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 590 | The 'git log' command has a weakness: it must present commits in a |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 591 | list. When the history has lines of development that diverged and |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 592 | then merged back together, the order in which 'git log' presents |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 593 | those commits is meaningless. |
| 594 | |
Henrik Austad | c7719fb | 2009-01-05 16:25:36 +0100 | [diff] [blame] | 595 | Most projects with multiple contributors (such as the Linux kernel, |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 596 | or Git itself) have frequent merges, and 'gitk' does a better job of |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 597 | visualizing their history. For example, |
| 598 | |
| 599 | ------------------------------------- |
| 600 | $ gitk --since="2 weeks ago" drivers/ |
| 601 | ------------------------------------- |
| 602 | |
| 603 | allows you to browse any commits from the last 2 weeks of commits |
J. Bruce Fields | 2be1bc4 | 2006-05-29 19:31:32 -0400 | [diff] [blame] | 604 | that modified files under the "drivers" directory. (Note: you can |
| 605 | adjust gitk's fonts by holding down the control key while pressing |
| 606 | "-" or "+".) |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 607 | |
| 608 | Finally, most commands that take filenames will optionally allow you |
| 609 | to precede any filename by a commit, to specify a particular version |
J. Bruce Fields | 3857386 | 2006-05-29 19:31:33 -0400 | [diff] [blame] | 610 | of the file: |
J. Bruce Fields | f1fe384 | 2006-05-21 16:54:05 -0400 | [diff] [blame] | 611 | |
| 612 | ------------------------------------- |
| 613 | $ git diff v2.5:Makefile HEAD:Makefile.in |
| 614 | ------------------------------------- |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 615 | |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 616 | You can also use 'git show' to see any such file: |
J. Bruce Fields | 3857386 | 2006-05-29 19:31:33 -0400 | [diff] [blame] | 617 | |
| 618 | ------------------------------------- |
Santi Béjar | 9c9410e | 2007-01-03 13:53:27 +0100 | [diff] [blame] | 619 | $ git show v2.5:Makefile |
J. Bruce Fields | 3857386 | 2006-05-29 19:31:33 -0400 | [diff] [blame] | 620 | ------------------------------------- |
| 621 | |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 622 | Next Steps |
| 623 | ---------- |
| 624 | |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 625 | This tutorial should be enough to perform basic distributed revision |
| 626 | control for your projects. However, to fully understand the depth |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 627 | and power of Git you need to understand two simple ideas on which it |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 628 | is based: |
| 629 | |
| 630 | * The object database is the rather elegant system used to |
| 631 | store the history of your project--files, directories, and |
| 632 | commits. |
| 633 | |
| 634 | * The index file is a cache of the state of a directory tree, |
| 635 | used to create commits, check out working directories, and |
| 636 | hold the various trees involved in a merge. |
| 637 | |
Jonathan Nieder | 6998e4d | 2008-06-30 17:01:21 -0500 | [diff] [blame] | 638 | Part two of this tutorial explains the object |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 639 | database, the index file, and a few other odds and ends that you'll |
Thomas Ackermann | 2de9b71 | 2013-01-21 20:17:53 +0100 | [diff] [blame] | 640 | need to make the most of Git. You can find it at linkgit:gittutorial-2[7]. |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 641 | |
J. Bruce Fields | cd50aba | 2007-05-17 23:56:08 -0400 | [diff] [blame] | 642 | If you don't want to continue with that right away, a few other |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 643 | digressions that may be interesting at this point are: |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 644 | |
Dan McGee | 5162e69 | 2007-12-29 00:20:38 -0600 | [diff] [blame] | 645 | * linkgit:git-format-patch[1], linkgit:git-am[1]: These convert |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 646 | series of git commits into emailed patches, and vice versa, |
Henrik Austad | c7719fb | 2009-01-05 16:25:36 +0100 | [diff] [blame] | 647 | useful for projects such as the Linux kernel which rely heavily |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 648 | on emailed patches. |
| 649 | |
Dan McGee | 5162e69 | 2007-12-29 00:20:38 -0600 | [diff] [blame] | 650 | * linkgit:git-bisect[1]: When there is a regression in your |
J. Bruce Fields | 927a503 | 2006-01-22 23:57:25 -0500 | [diff] [blame] | 651 | project, one way to track down the bug is by searching through |
| 652 | the history to find the exact commit that's to blame. Git bisect |
| 653 | can help you perform a binary search for that commit. It is |
| 654 | smart enough to perform a close-to-optimal search even in the |
| 655 | case of complex non-linear history with lots of merged branches. |
| 656 | |
Thomas Rast | 801a011 | 2009-06-06 15:11:07 +0200 | [diff] [blame] | 657 | * linkgit:gitworkflows[7]: Gives an overview of recommended |
| 658 | workflows. |
| 659 | |
Philip Oakley | 673151a | 2014-10-10 22:25:37 +0100 | [diff] [blame] | 660 | * linkgit:giteveryday[7]: Everyday Git with 20 Commands Or So. |
J. Bruce Fields | e31952d | 2006-05-21 19:49:34 -0400 | [diff] [blame] | 661 | |
Jonathan Nieder | 6998e4d | 2008-06-30 17:01:21 -0500 | [diff] [blame] | 662 | * linkgit:gitcvs-migration[7]: Git for CVS users. |
Christian Couder | b27a23e | 2008-05-24 20:56:44 +0200 | [diff] [blame] | 663 | |
| 664 | SEE ALSO |
| 665 | -------- |
| 666 | linkgit:gittutorial-2[7], |
| 667 | linkgit:gitcvs-migration[7], |
Christian Couder | 497c833 | 2008-05-29 19:21:46 +0200 | [diff] [blame] | 668 | linkgit:gitcore-tutorial[7], |
| 669 | linkgit:gitglossary[7], |
Christian Couder | 6e702c2 | 2008-11-17 16:43:04 +0100 | [diff] [blame] | 670 | linkgit:git-help[1], |
Thomas Rast | 801a011 | 2009-06-06 15:11:07 +0200 | [diff] [blame] | 671 | linkgit:gitworkflows[7], |
Philip Oakley | 673151a | 2014-10-10 22:25:37 +0100 | [diff] [blame] | 672 | linkgit:giteveryday[7], |
Christian Couder | b27a23e | 2008-05-24 20:56:44 +0200 | [diff] [blame] | 673 | link:user-manual.html[The Git User's Manual] |
| 674 | |
| 675 | GIT |
| 676 | --- |
Stefan Beller | 941b9c5 | 2017-02-08 17:29:30 -0800 | [diff] [blame] | 677 | Part of the linkgit:git[1] suite |