Make "git commit" handle initial commits too

No need to confuse ex-CVS users with a complex initial commit sequence.
This commit is contained in:
Linus Torvalds 2005-06-14 10:20:14 -07:00
parent de4971b500
commit 96069cf03a

View File

@ -1,16 +1,35 @@
#!/bin/sh #!/bin/sh
: ${GIT_DIR=.git} : ${GIT_DIR=.git}
PARENTS="HEAD" if [ ! -d $GIT_DIR ]; then
if [ -f $GIT_DIR/MERGE_HEAD ]; then echo Not a git directory 1>&2
echo "#" exit 1
echo "# It looks like your may be committing a MERGE." fi
echo "# If this is not correct, please remove the file" PARENTS="-p HEAD"
echo "# $GIT_DIR/MERGE_HEAD" if [ ! -r $GIT_DIR/HEAD ]; then
echo "# and try again" if [ -z "$(git-ls-files)" ]; then
echo "#" echo Nothing to commit 1>&2
PARENTS="HEAD -p MERGE_HEAD" exit 1
fi > .editmsg fi
git-status-script >> .editmsg (
echo "#"
echo "# Initial commit"
echo "#"
git-ls-files | sed 's/^/# New file: /'
echo "#"
) > .editmsg
PARENTS=""
else
if [ -f $GIT_DIR/MERGE_HEAD ]; then
echo "#"
echo "# It looks like your may be committing a MERGE."
echo "# If this is not correct, please remove the file"
echo "# $GIT_DIR/MERGE_HEAD"
echo "# and try again"
echo "#"
PARENTS="-p HEAD -p MERGE_HEAD"
fi > .editmsg
git-status-script >> .editmsg
fi
if [ "$?" != "0" ] if [ "$?" != "0" ]
then then
cat .editmsg cat .editmsg
@ -20,6 +39,6 @@ ${VISUAL:-${EDITOR:-vi}} .editmsg
grep -v '^#' < .editmsg | git-stripspace > .cmitmsg grep -v '^#' < .editmsg | git-stripspace > .cmitmsg
[ -s .cmitmsg ] || exit 1 [ -s .cmitmsg ] || exit 1
tree=$(git-write-tree) || exit 1 tree=$(git-write-tree) || exit 1
commit=$(cat .cmitmsg | git-commit-tree $tree -p $PARENTS) || exit 1 commit=$(cat .cmitmsg | git-commit-tree $tree $PARENTS) || exit 1
echo $commit > $GIT_DIR/HEAD echo $commit > $GIT_DIR/HEAD
rm -f -- $GIT_DIR/MERGE_HEAD rm -f -- $GIT_DIR/MERGE_HEAD