为每个分支保留不同的配置文件(未跟踪)

时间:2014-08-29 15:03:16

标签: git gitignore

在git存储库中,我有两个文件:config/conf.yaml.sample(由git跟踪,但在我的程序启动时被忽略)和一个名为config/conf.yaml的副本(由git忽略) ,但是当我的程序启动时它会被读取。)

当我从分支A切换到分支BI时,总是有相同的配置文件(因为config/conf.yaml未跟踪),这意味着,例如,每个分支与同一个数据库,相同的端口等相关

我希望为每个分支保留不同的config/conf.yaml,以便在切换分支时更改,但我不想让git跟踪它(例如,因为它包含访问数据库的名称和密码)。

我该怎么做?

1 个答案:

答案 0 :(得分:3)

似乎Git的post-checkout hook正好在你的小巷里:

  

在更新工作树后运行git checkout时调用此挂钩。钩子被赋予三个参数:前一个HEAD的引用,新HEAD的引用(可能已经或可能没有改变),以及一个标志,指示结账是否是分支结账(更改branches,flag = 1)或文件签出(从索引中检索文件,flag = 0)。此挂钩不会影响git checkout的结果。

     

除非使用--no-checkout-n)选项,否则它也会在git clone之后运行。赋给钩子的第一个参数是null-ref,第二个参数是新HEAD的ref,而标志总是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