Some Notes on Using git commit
Using git commit --all
The -a
or --all
option to git commit causes it to
automatically stage all unstaged, tracked file changesâincluding
removals of tracked files from the working copyâbefore it performs the
commit.
Letâs see how this works by setting up a few files with different staging characteristics:
# Modify file "ready" and "git add" it to the index # edit ready $git add ready
# Modify file "notyet", leaving it unstaged # edit notyet # Add a new file in a subdirectory, but don't add it $mkdir subdir
$echo Nope >> subdir/new
Use git status to see what a regular commit (without command-line options) would do:
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: ready
#
# Changed but not updated:
# (use "git add <file>..." to update what will be committed)
#
# modified: notyet
#
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# subdir/
Here, the index is prepared to commit just the one file named ready, because itâs the only file thatâs been staged.
However, if you run git commit --all, Git recursively traverses the entire repository; stages all known, modified files; and commits those. In this case, when your editor presents the commit message template, it should indicate that the modified and known file notyet will, in fact, be committed as well:
# Please enter the commit message for your changes. # (Comment lines starting with '#' will ...
Get Version Control with Git now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.