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
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.
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.
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'
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.
Here are a few options:
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);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.