Commit and automatically add all untracked files

后端 未结 5 1876
南方客
南方客 2020-12-23 09:07

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 ha

相关标签:
5条回答
  • 2020-12-23 09:25

    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.

    0 讨论(0)
  • 2020-12-23 09:42

    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.

    0 讨论(0)
  • 2020-12-23 09:45

    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'
    
    0 讨论(0)
  • 2020-12-23 09:45

    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.

    0 讨论(0)
  • 2020-12-23 09:49

    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.

    0 讨论(0)
提交回复
热议问题