在 git 存储库中,我有两个文件:(config/conf.yaml.sample由 git 跟踪,但在我的程序启动时被忽略)和它的副本config/conf.yaml(被 git 忽略,但在我的程序启动时读取)。
当我从分支 A 切换到分支 BI 时,总是具有相同的配置文件(因为config/conf.yaml未跟踪),这意味着,例如,每个分支都与相同的数据库、相同的端口等相关。
我想config/conf.yaml为每个分支保留一个不同的,以便在切换分支时它会发生变化,但我不想让 git 跟踪它(例如,因为它包含访问数据库的名称和密码)。
我该怎么做?
看起来 Git 的结帐后钩子正合你的胃口:
git checkout当更新工作树后运行a 时,将调用此挂钩。该钩子被赋予三个参数:前一个的 refHEAD、新的 refHEAD(可能已更改或未更改)以及一个指示签出是分支签出(更改分支,flag=1)还是文件的标志checkout(从索引检索文件,flag=0)。这个钩子不能影响 的结果git checkout。它也会在 git clone 之后运行,除非使用
--no-checkout( ) 选项。-n给予钩子的第一个参数是 null-ref,第二个参数是 new 的 refHEAD,并且标志始终为 1。此挂钩可用于执行存储库有效性检查、自动显示与之前版本的差异
HEAD(如果不同)或设置工作目录元数据属性。
以下脚本(必须使其可执行)应该可以帮助您入门;修改它以满足您的需要并将其另存为.git/hooks/post-checkout:
#!/bin/sh
#
# An example post-checkout hook script to perform an action conditionally on
# the branch (if any) just checked out.
#
# Test whether a branch was just checked out
if [ "$3" -eq 1 ]; then
# Save the value of HEAD (do not issue an error if HEAD is detached)
symrefHEAD=`git symbolic-ref --quiet HEAD`
if [ "$symrefHEAD" = "refs/heads/master" ]; then
# Do something useful for master, e.g.
# cp config/conf_master.yaml config/conf.yaml
printf " --- test: You just checked out master. ---\n"
elif [ "$symrefHEAD" = "refs/heads/develop" ] ; then
# Do something useful for develop, e.g.
# cp config/conf_develop.yaml config/conf.yaml
printf "--- test: You just checked out develop. ---\n"
else
# default case
printf "You just checked out some other branch.\n"
fi
else
printf "No branch was checked out\n"
fi
Run Code Online (Sandbox Code Playgroud)