git add * (asterisk) vs git add . (period)

GitVersion ControlGit Add

Git Problem Overview


I'm new to git and I have a question about adding files in git. I have found multiple stackoverflow questions about the difference between git add . and git add -a, git add --all, git add -A, etc. But I've been unable to find a place that explains what git add * does. I've even looked at the git add man page, but it didn't help. I've been using it in place of git add . and my co-worker asked me why. I didn't have an answer. I've just always used git add *.

Are git add . and git add * the same? Does one add changed files from the current directory only, while the other adds files from the current directory and subdirectories (recursively)?

There's a great chart listed on one of the other stack questions that shows the difference between git add -A git add . and git add -u, but it doesn't have git add *.

enter image description here

Note: I understand what it means to use the asterisk as a wildcard (add all files with a given extension). For example, git add *.html would add all files that have a .html extension (but ignore .css, .js, etc).

Thanks for the help!

Git Solutions


Solution 1 - Git

add * means add all files in the current directory, except for files whose name begin with a dot. This is your shell functionality and Git only ever receives a list of files.

add . has no special meaning in your shell, and thus Git adds the entire directory recursively, which is almost the same, but including files whose names begin with a dot.

Solution 2 - Git

* is not part of git - it's a wildcard interpreted by the shell. * expands to all the files in the current directory, and is only then passed to git, which adds them all. . is the current directory itself, and git adding it will add it and the all the files under it.

Solution 3 - Git

For clarity, I put the answer in the table below:

enter image description here

Additional notes (inspired by the @reka18 comment):

Note 1. git add -A and git add -u commands performed without additional parameters would be additional refinement (subdirectory or mask indication for the file name) work in the range of the entire working directory (also if we execute the command in the working subdirectory of the directory).

Note 2. The . and * are respectively the directory path (current directory) and the wildcard, which clarify the path of the command. For example, if the git add . or git add * command is executed in some subdirectory of a working directory, then their action is only used within this subdirectory, not the entire working directory.

Note 3. The git add -A and git add -u commands can be further refined by adding a path or mask for files, for example, git add -A app/controllers or git add -u app\styles\*.

Solution 4 - Git

  • git add -A (--all) Adds everything, so that everything in your folder on disk is represented in the staging area

  • git add . Stages everything, but does not remove files that have been deleted from the disk

  • git add * Stages everything, but not files that begin with a dot & does not remove files that have been deleted from the disk

  • git add -u (--update) Stages only Modified Files, removes files that have been deleted from disk, does not add new

  • git add <file name 1> <file name 2> Adds only certain file(s)

Solution 5 - Git

Using the dot . in the shell usually means "the current directory".

When you use the asterisk * on a shell a feature called file-globbing is utilized. E.g. on bash the function glob() is doing just that. The manpage for glob (man 7 glob) states:

> DESCRIPTION > > Long ago, in UNIX V6, there was a program /etc/glob that would expand > wildcard patterns. Soon afterward this became a shell built-in. > These days there is also a library routine glob(3) that will perform this > function for a user program. > Wildcard matching > > A string is a wildcard pattern if it contains one of the characters '?', '*' or '['. Globbing

> Globbing is the operation that expands a wildcard pattern > into the list of pathnames matching the pattern.

That means when you pass arguments to any program on the commandline that contain '?', '*'or '[', first globbing expands the wildcard pattern into a list of files and then gives these files as an argument to the program itself.

The difference in meaning between 'git add .' and 'git add *'is clearly described by [Denis][1]:

git add expects a list of files to be added. In the above example the shell expands * or . respectively and gives the result as a parameter to git add. Now the difference is that with git add . git will expand to the current directory whereas git add * triggers file globbing and such expands to all files and directories that do not start with a dot.

[1]: https://stackoverflow.com/a/26042555/1399018 "Denis"

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionTyler YoungbloodView Question on Stackoverflow
Solution 1 - GitDenisView Answer on Stackoverflow
Solution 2 - GitMureinikView Answer on Stackoverflow
Solution 3 - GitsimhumilecoView Answer on Stackoverflow
Solution 4 - GitSteffenView Answer on Stackoverflow
Solution 5 - GitcodingdaveView Answer on Stackoverflow