V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
git
Pro Git
Atlassian Git Tutorial
Pro Git 简体中文翻译
GitX
sd4399340
V2EX  ›  git

关于不同分支上的.gitignore

  •  
  •   sd4399340 · 2012-05-03 14:26:35 +08:00 · 5773 次点击
    这是一个创建于 4591 天前的主题,其中的信息可能已经有所发展或是发生改变。
    有三个不同分支,假设就叫1、2、3
    我现在在分支2上开发,新增了文件夹a,然后有个.gitignore文件,忽略文件夹a里面的一些文件
    我在分支2上commit以后,切换到分支1、3,然后git status,都提示这个新增的文件夹a是untracked file,这个怎么解决呢?

    一般各个分支上的.gitignore文件是不是应该一摸一样啊?
    还有,我只在分支2上开发,那我在分支2上push怎么也会影响其他分支呢?
    12 条回复    1970-01-01 08:00:00 +08:00
    ShadowStar
        1
    ShadowStar  
       2012-05-03 14:48:10 +08:00
    各个分支是独立的,包括所属的.gitignore文件
    分支2上push不会影响其他分支,除了push --all把其他的也push了。
    henryzhou
        2
    henryzhou  
       2012-05-03 14:49:29 +08:00
    如果是我的话,我的.gitignore在不同branch上根据实际情况可能相同可能不同(取决于具体环境)

    至于你说的你在branch 2上push会影响其他branch,你的意思是不是指你的文件夹a是untracked file?那是因为未commit的文件在切换branch的时候不会被wipe(否则误操作后岂不是丢东西了)而是保持原样。你的这些文件在branch2上因为.gitignore所以不被track但在其他分支上没被exclude所以会被认为是untracked file,解决方法你自己也说了,就是在其他branch上也有.gitignore去exclude这些文件
    sd4399340
        3
    sd4399340  
    OP
       2012-05-03 15:07:49 +08:00
    @henryzhou 明白了,那我在branch2上面pull一下,会把服务器上所有分支的更新都给pull下来吗?
    Paranoid
        4
    Paranoid  
       2012-05-03 15:31:02 +08:00
    @sd4399340 不会。 pull 指定 origin name (默认 master), origin name 这个得看你是怎么更新的。
    sd4399340
        5
    sd4399340  
    OP
       2012-05-03 15:32:09 +08:00
    @Paranoid 对啊,这个我给忘了,我pull和push的时候都是走默认的。。。谢谢啦
    jsz
        6
    jsz  
       2012-05-03 17:45:41 +08:00
    .gitignore 最好不要 commit 到源码库里吧。
    NemoAlex
        7
    NemoAlex  
       2012-05-03 17:54:34 +08:00
    @jsz 开什么玩笑...
    sd4399340
        8
    sd4399340  
    OP
       2012-05-03 17:54:57 +08:00
    @jsz 那换台电脑开发,clone下来以后,再push岂不是会多push文件,这个还是需要commit的吧
    NemoAlex
        9
    NemoAlex  
       2012-05-03 17:59:06 +08:00
    @sd4399340 clone 下来的话,.gitignore 文件是会下来的,可是那些被 ignore 掉的文件不会下来啊
    jsz
        10
    jsz  
       2012-05-03 19:14:05 +08:00
    @NemoAlex 不开玩笑啊,我从来不把 .gitignore 加到源码库里,因为 gitignore 属于开发者比较私人的偏好,没必要进行 track。而且我甚至把 .gitignore 本身都加到 .gitignore 里。

    @sd4399340 那怎么会多 push 文件呢...
    9hills
        11
    9hills  
       2012-05-04 17:43:36 +08:00
    @jsz 换台电脑岂不是要重新写一遍.gitignore...

    而且别人clone你的源,也要重写一遍.gitignore。。。一行两行倒无所谓,一个大项目不可避免就会生成很多不能进版本库的temp文件,重新写遍gitignore么
    jsz
        12
    jsz  
       2012-05-04 18:43:57 +08:00
    @9hills 嗯,对
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1047 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 21:32 · PVG 05:32 · LAX 13:32 · JFK 16:32
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.