关于不同分支上的.gitignore

2012-05-03 14:26:35 +08:00
 sd4399340
有三个不同分支,假设就叫1、2、3
我现在在分支2上开发,新增了文件夹a,然后有个.gitignore文件,忽略文件夹a里面的一些文件
我在分支2上commit以后,切换到分支1、3,然后git status,都提示这个新增的文件夹a是untracked file,这个怎么解决呢?

一般各个分支上的.gitignore文件是不是应该一摸一样啊?
还有,我只在分支2上开发,那我在分支2上push怎么也会影响其他分支呢?
5707 次点击
所在节点    git
12 条回复
ShadowStar
2012-05-03 14:48:10 +08:00
各个分支是独立的,包括所属的.gitignore文件
分支2上push不会影响其他分支,除了push --all把其他的也push了。
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
2012-05-03 15:07:49 +08:00
@henryzhou 明白了,那我在branch2上面pull一下,会把服务器上所有分支的更新都给pull下来吗?
Paranoid
2012-05-03 15:31:02 +08:00
@sd4399340 不会。 pull 指定 origin name (默认 master), origin name 这个得看你是怎么更新的。
sd4399340
2012-05-03 15:32:09 +08:00
@Paranoid 对啊,这个我给忘了,我pull和push的时候都是走默认的。。。谢谢啦
jsz
2012-05-03 17:45:41 +08:00
.gitignore 最好不要 commit 到源码库里吧。
NemoAlex
2012-05-03 17:54:34 +08:00
@jsz 开什么玩笑...
sd4399340
2012-05-03 17:54:57 +08:00
@jsz 那换台电脑开发,clone下来以后,再push岂不是会多push文件,这个还是需要commit的吧
NemoAlex
2012-05-03 17:59:06 +08:00
@sd4399340 clone 下来的话,.gitignore 文件是会下来的,可是那些被 ignore 掉的文件不会下来啊
jsz
2012-05-03 19:14:05 +08:00
@NemoAlex 不开玩笑啊,我从来不把 .gitignore 加到源码库里,因为 gitignore 属于开发者比较私人的偏好,没必要进行 track。而且我甚至把 .gitignore 本身都加到 .gitignore 里。

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

而且别人clone你的源,也要重写一遍.gitignore。。。一行两行倒无所谓,一个大项目不可避免就会生成很多不能进版本库的temp文件,重新写遍gitignore么
jsz
2012-05-04 18:43:57 +08:00
@9hills 嗯,对

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/34482

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX