66

I often forgot that I have some new files and directly do,

git commit -a -m "My commit message"

This only commits changed files, and I have to do add the remaining files in a new commit. This means that there are two separate commits although logically they are part of the same task.

The easiest way I know to include untracked files in the commit via two consecutive commands:

git add -A
git commit -a -m "My commit message"

Is it possible to have the same effect like the above in one command?

3
  • 7
    Why not git commit --amend the previous commit once you add the untracked files? Commented Apr 21, 2013 at 5:05
  • git add -A has this message in the man page: If no <pathspec> is given, the current version of Git defaults to "."; in other words, update all files in the current directory and its subdirectories. This default will change in a future version of Git, hence the form without <pathspec> should not be used. Commented Dec 12, 2016 at 23:42
  • you can always use git add -A && git commit -a -m "my message" Commented Dec 29, 2020 at 17:08

5 Answers 5

23

Create a file in your execution path called (no extension): git-add-commit-untracked

Put this in it:

#!/bin/bash
message=${0}
git add -A
git commit -am "$message"

Then: git-add-commit-untracked "Commit message"

You can use a shorter name for the file though. I left it lengthy for illustrative purposes.

Sign up to request clarification or add additional context in comments.

2 Comments

This could be done simpler as a git alias. See my answer here: stackoverflow.com/questions/16068968/…
the git add -A is useful to know in of itself
21

You can define an alias to add all before commit. Just put this lines into your ~/.gitconfig file :

[alias]
        ca = !sh -c 'git add -A && git commit -m \"$1\"' -

Then use your alias like this :

$ git ca 'Your commit message'

1 Comment

THIS. Absolutely perfect.
8

Here are a few options:

  • Use git commit --amend so that you end up with only one commit after adding the untracked files (but not if you've already pushed the previous commit);
  • Use git commit --interactive;
  • Create an alias or script that automatically adds new files (examples in other answers). Here are two aliases that I use for exactly this purpose:

    [alias]
        untracked = ls-files --other --exclude-standard
        add-untracked = !git add $(git untracked)
    
  • Squash your two commits using git rebase -i, git reset <commit prior to first commit> and git commit, or git merge --squash onto another branch.

However, you cannot override a builtin command such as commit with an alias, so it is still up to you to remember to add the files that you want to the index before committing.

Unfortunately as well, you cannot specify paths along with git commit -a; I just tried git commit -a $(git untracked) and it told me fatal: Paths with -a does not make sense. So to answer your basic question, I think a git script would be the only non-interactive way.

4 Comments

However useful this is, it does answer different question then the auhor has asked.
@gorn I'm not sure what question you think was asked, but this answer provides several options and refers to other answers as well.
Question is quite clear "Is it possible to have the same effect like the above in one command?", so basically "How to do the whole action in one command and avoid the mistake of not adding some files" and this answere adresses "How to repair consequences after the mistake has been done". I think is is confusing to newcomeres and that is why I comment here.
@gorn Sometimes, the answer is 'no', or 'try a different approach.'
0

It's not possible using the default git interface. However, git supports aliases.

Using an alias, it's possible to invoke a different git command, or even run arbitrary shell scripts. Create a script containing the two commands, and alias it.

See the wiki for more information on aliases, and this question for this specific scenario.

Edit: note that this is not such a good idea. The chances are you'll end up adding unnecessary files by mistake, or having a useless alias due to non-versioned files in the tree.

Comments

0

Yeah, I had the same problem like you in the past. I preferred to use git command, but I got a big troubles because the guard in rails changed many files without alert :)

So now, whenever i commit new code, I try to use the UI to do this (git gui) and keep in mind never use git commit -a because you don't sure which files were modified! After rebase new code, please you gitk to view the git tree, so you can know the lasted commitment, committers, commit files and so on.

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.