1git-add(1) 2========== 3 4NAME 5---- 6git-add - Add file contents to the index 7 8SYNOPSIS 9-------- 10[verse] 11'git-add' [-n] [-v] [-f] [--interactive | -i] [-u] [--refresh] 12 [--] <filepattern>... 13 14DESCRIPTION 15----------- 16This command adds the current content of new or modified files to the 17index, thus staging that content for inclusion in the next commit. 18 19The "index" holds a snapshot of the content of the working tree, and it 20is this snapshot that is taken as the contents of the next commit. Thus 21after making any changes to the working directory, and before running 22the commit command, you must use the 'add' command to add any new or 23modified files to the index. 24 25This command can be performed multiple times before a commit. It only 26adds the content of the specified file(s) at the time the add command is 27run; if you want subsequent changes included in the next commit, then 28you must run 'git add' again to add the new content to the index. 29 30The 'git status' command can be used to obtain a summary of which 31files have changes that are staged for the next commit. 32 33The 'git add' command will not add ignored files by default. If any 34ignored files were explicitly specified on the command line, 'git add' 35will fail with a list of ignored files. Ignored files reached by 36directory recursion or filename globbing performed by Git (quote your 37globs before the shell) will be silently ignored. The 'add' command can 38be used to add ignored files with the `-f` (force) option. 39 40Please see gitlink:git-commit[1] for alternative ways to add content to a 41commit. 42 43 44OPTIONS 45------- 46<filepattern>...:: 47 Files to add content from. Fileglobs (e.g. `*.c`) can 48 be given to add all matching files. Also a 49 leading directory name (e.g. `dir` to add `dir/file1` 50 and `dir/file2`) can be given to add all files in the 51 directory, recursively. 52 53-n, \--dry-run:: 54 Don't actually add the file(s), just show if they exist. 55 56-v, \--verbose:: 57 Be verbose. 58 59-f:: 60 Allow adding otherwise ignored files. 61 62-i, \--interactive:: 63 Add modified contents in the working tree interactively to 64 the index. 65 66-u:: 67 Update only files that git already knows about. This is similar 68 to what "git commit -a" does in preparation for making a commit, 69 except that the update is limited to paths specified on the 70 command line. If no paths are specified, all tracked files are 71 updated. 72 73\--refresh:: 74 Don't add the file(s), but only refresh their stat() 75 information in the index. 76 77\--:: 78 This option can be used to separate command-line options from 79 the list of files, (useful when filenames might be mistaken 80 for command-line options). 81 82 83Configuration 84------------- 85 86The optional configuration variable 'core.excludesfile' indicates a path to a 87file containing patterns of file names to exclude from git-add, similar to 88$GIT_DIR/info/exclude. Patterns in the exclude file are used in addition to 89those in info/exclude. See link:repository-layout.html[repository layout]. 90 91 92EXAMPLES 93-------- 94git-add Documentation/\\*.txt:: 95 96 Adds content from all `\*.txt` files under `Documentation` 97 directory and its subdirectories. 98+ 99Note that the asterisk `\*` is quoted from the shell in this 100example; this lets the command to include the files from 101subdirectories of `Documentation/` directory. 102 103git-add git-*.sh:: 104 105 Considers adding content from all git-*.sh scripts. 106 Because this example lets shell expand the asterisk 107 (i.e. you are listing the files explicitly), it does not 108 consider `subdir/git-foo.sh`. 109 110Interactive mode 111---------------- 112When the command enters the interactive mode, it shows the 113output of the 'status' subcommand, and then goes into its 114interactive command loop. 115 116The command loop shows the list of subcommands available, and 117gives a prompt "What now> ". In general, when the prompt ends 118with a single '>', you can pick only one of the choices given 119and type return, like this: 120 121------------ 122 *** Commands *** 123 1: status 2: update 3: revert 4: add untracked 124 5: patch 6: diff 7: quit 8: help 125 What now> 1 126------------ 127 128You also could say "s" or "sta" or "status" above as long as the 129choice is unique. 130 131The main command loop has 6 subcommands (plus help and quit). 132 133status:: 134 135 This shows the change between HEAD and index (i.e. what will be 136 committed if you say "git commit"), and between index and 137 working tree files (i.e. what you could stage further before 138 "git commit" using "git-add") for each path. A sample output 139 looks like this: 140+ 141------------ 142 staged unstaged path 143 1: binary nothing foo.png 144 2: +403/-35 +1/-1 git-add--interactive.perl 145------------ 146+ 147It shows that foo.png has differences from HEAD (but that is 148binary so line count cannot be shown) and there is no 149difference between indexed copy and the working tree 150version (if the working tree version were also different, 151'binary' would have been shown in place of 'nothing'). The 152other file, git-add--interactive.perl, has 403 lines added 153and 35 lines deleted if you commit what is in the index, but 154working tree file has further modifications (one addition and 155one deletion). 156 157update:: 158 159 This shows the status information and gives prompt 160 "Update>>". When the prompt ends with double '>>', you can 161 make more than one selection, concatenated with whitespace or 162 comma. Also you can say ranges. E.g. "2-5 7,9" to choose 163 2,3,4,5,7,9 from the list. You can say '*' to choose 164 everything. 165+ 166What you chose are then highlighted with '*', 167like this: 168+ 169------------ 170 staged unstaged path 171 1: binary nothing foo.png 172* 2: +403/-35 +1/-1 git-add--interactive.perl 173------------ 174+ 175To remove selection, prefix the input with `-` 176like this: 177+ 178------------ 179Update>> -2 180------------ 181+ 182After making the selection, answer with an empty line to stage the 183contents of working tree files for selected paths in the index. 184 185revert:: 186 187 This has a very similar UI to 'update', and the staged 188 information for selected paths are reverted to that of the 189 HEAD version. Reverting new paths makes them untracked. 190 191add untracked:: 192 193 This has a very similar UI to 'update' and 194 'revert', and lets you add untracked paths to the index. 195 196patch:: 197 198 This lets you choose one path out of 'status' like selection. 199 After choosing the path, it presents diff between the index 200 and the working tree file and asks you if you want to stage 201 the change of each hunk. You can say: 202 203 y - add the change from that hunk to index 204 n - do not add the change from that hunk to index 205 a - add the change from that hunk and all the rest to index 206 d - do not the change from that hunk nor any of the rest to index 207 j - do not decide on this hunk now, and view the next 208 undecided hunk 209 J - do not decide on this hunk now, and view the next hunk 210 k - do not decide on this hunk now, and view the previous 211 undecided hunk 212 K - do not decide on this hunk now, and view the previous hunk 213+ 214After deciding the fate for all hunks, if there is any hunk 215that was chosen, the index is updated with the selected hunks. 216 217diff:: 218 219 This lets you review what will be committed (i.e. between 220 HEAD and index). 221 222 223See Also 224-------- 225gitlink:git-status[1] 226gitlink:git-rm[1] 227gitlink:git-reset[1] 228gitlink:git-mv[1] 229gitlink:git-commit[1] 230gitlink:git-update-index[1] 231 232Author 233------ 234Written by Linus Torvalds <torvalds@osdl.org> 235 236Documentation 237-------------- 238Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>. 239 240GIT 241--- 242Part of the gitlink:git[7] suite