自定義提交信息, 協(xié)同開(kāi)發(fā)人員太多的時(shí)候, 從提交信息里就能知道誰(shuí)的代碼
進(jìn)入自己項(xiàng)目, 打開(kāi).git 文件, 找到hooks 文件夾, 新建一個(gè)文件, 命名 prepare-commit-msg , 如果不能這樣的命名, 就先隨便命名一個(gè), 后續(xù)再改, 然后把以下文件內(nèi)容復(fù)制出來(lái),
#!/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

image.png
至此, 完成了第1步
要想實(shí)現(xiàn) 2 的樣子
接下來(lái)要讓這個(gè)文件在提交代碼的時(shí)候,起作用
進(jìn)入項(xiàng)目, 執(zhí)行
cd .git/hooks指令然后執(zhí)行
chmod +x prepare-commit-msg指令 沒(méi)有權(quán)限的話, 執(zhí)行 sudo添加權(quán)限這樣, 文件類型, 就會(huì)變成可執(zhí)行文件類型,
打開(kāi)自己的sourcetree , 就能看到自己的名字的提交記錄了

image.png