Git: merging public and private branches while while keeping certain files intact in both branches

后端 未结 4 651
梦毁少年i
梦毁少年i 2020-12-01 05:52

I\'ve read a few git questions here, but could not find an answer to this one:

I have a public and a private branches where I want to allow certain files to diverge.

相关标签:
4条回答
  • 2020-12-01 06:01

    Keep passwords under version control is the worst idea ever. You need CVS, not git, to work with separate files. Git as many other modern DVCS working with the entire tree, not with separate files.

    0 讨论(0)
  • 2020-12-01 06:11

    This only appears to work if there are merge conflicts detected. Merging back and forth between branches the file does get overwritten. Unless I set something up wrong. Of course this in on windows msysgit git version 1.6.5.1.1367.

    0 讨论(0)
  • 2020-12-01 06:18

    To be on the safe side, you can add a git attribute (see here for an example) for those private files.

    That way, you can define a script (a "merge manager") which will ensure the file including private informations will remain empty (or with a public content) if merged on the public branch, while keeping its local content if merged to the private branch.
    It means you can merge/rebase without thinking about that file.

    0 讨论(0)
  • 2020-12-01 06:19

    One way to do this is with git rebase. By keeping your private changes as a few commits off the end of your master, you can commit public stuff to the master branch (or whatever you choose your working branch to be), and then rebase your private branch against master whenever you want to update.

    Another way to handle this is to keep template configuration files in Git, such as frobozz.config.template. In your working directory, copy frobozz.config.template to the (unversioned) frobozz.config and modify. Just be sure to back up your working directory too, if you need your local changes to be backed up.

    0 讨论(0)
提交回复
热议问题