自定義提交信息, 協(xié)同開發(fā)人員太多的時候, 從提交信息里就能知道誰的代碼
進(jìn)入自己項(xiàng)目, 打開.git 文件, 找到hooks 文件夾, 新建一個文件, 命名 prepare-commit-msg , 如果不能這樣的命名, 就先隨便命名一個, 后續(xù)再改, 然后把以下文件內(nèi)容復(fù)制出來,
#!/bin/sh
#
# An example hook script to prepare the commit log message.
# Called by "git commit" with the name of the file that has the
# commit message, followed by the description of the commit
# message's source. The hook's purpose is to edit the commit
# message file. If the hook fails with a non-zero status,
# the commit is aborted.
#
# To enable this hook, rename this file to "prepare-commit-msg".
# This hook includes three examples. The first one removes the
# "# Please enter the commit message..." help message.
#
# The second includes the output of "git diff --name-status -r"
# into the message, just before the "git status" output. It is
# commented because it doesn't cope with --amend or with squashed
# commits.
#
# The third example adds a Signed-off-by line to the message, that can
# still be edited. This is rarely a good idea.
COMMIT_MSG_FILE=$1
COMMIT_SOURCE=$2
SHA1=$3
sed -i '' "1s/^/自己的名字| /" $COMMIT_MSG_FILE
/usr/bin/perl -i.bak -ne 'print unless(m/^. Please enter the commit message/..m/^#$/)' "$COMMIT_MSG_FILE"
# case "$COMMIT_SOURCE,$SHA1" in
# ,|template,)
# /usr/bin/perl -i.bak -pe '
# print "\n" . `git diff --cached --name-status -r`
# if /^#/ && $first++ == 0' "$COMMIT_MSG_FILE" ;;
# *) ;;
# esac
# SOB=$(git var GIT_COMMITTER_IDENT | sed -n 's/^\(.*>\).*$/Signed-off-by: \1/p')
# git interpret-trailers --in-place --trailer "$SOB" "$COMMIT_MSG_FILE"
# if test -z "$COMMIT_SOURCE"
# then
# /usr/bin/perl -i.bak -pe 'print "\n" if !$first_line++' "$COMMIT_MSG_FILE"
# fi
這是全部的文件代碼, 文件名 改為prepare-commit-msg
至此, 完成了第1步
要想實(shí)現(xiàn) 2 的樣子
接下來要讓這個文件在提交代碼的時候,起作用
進(jìn)入項(xiàng)目, 執(zhí)行
cd .git/hooks
指令然后執(zhí)行
chmod +x prepare-commit-msg
指令 沒有權(quán)限的話, 執(zhí)行 sudo
添加權(quán)限這樣, 文件類型, 就會變成可執(zhí)行文件類型,
打開自己的sourcetree , 就能看到自己的名字的提交記錄了