git不能管理空目录,需要通过在空目录下增加placeholder 文件来达到管理空目录的目录。而svn可以管理空目录。
git-svn 的mkdirs命令,就是用来创建svn中的空目录的。
但是有例外。发现问题的过程:
我用git svn clone 命令从SVN库创建了GIT库后,发现有的空目录已经创建了,而有的却没有。
当我用 git svn clone -r71 来clone最新版本时,所有空目录都被创建了,好奇怪啊! 而且发现缺少的空目录,在SVN中是通过这种操作产生的(.keep是dirA下的唯一文件):
1) add dirA/.keep
2) del dirA/.keep
而git svn 能创建的目录,是通过这种操作产生的:
1) add dirA/
通过查资料,终于了解到了原因。
一、git svn mkdir 怎样工作
.git/svn/refs/remotes/origin/trunk/unhandled.log 中保存了空目录的创建与删除信息。当某个版本N创建了空目录,该文件中会有:
-
rN:
- +empty_dir: <创建的空目录>
当某个版本N创建了空目录,该文件中会有:
-
rN:
- -empty_dir: <删除的空目录>
当删除某个目录下唯一的文件时,该文件中会有:
-
rN:
- -empty_dir: <目录>/<该目录下的唯一文件>
git-svn mkdir 就是通过扫描unhandled.log来判断需要创建哪些目录的
二、为什么clone全部时没有空目录而clone最新版本时有
-
如果操作过程这样:
r11:
-
add trunk/bin/.keep
r12:
- del trunk/bin/.keep r13:
- …
那么:
如果执行 git svn clone -r11:13
, unhandled.log中就会有:
r11
r12
-empty_dir: trunk/bin/.keep
r13
没有+empty_dir的条目,所以mkdirs 不能创建该目录
如果执行git svn clone -r13
, 因为SVN库r13中有该空目录,所以unhandled.log中就会有:
r13
+empty_dir: trunk/bin
所以,git svn mkdirs
能创建该空目录!
三、解决方法
在这种情况下,有两种方法可以使git svn mkdirs
创建空目录:
- 从r12开始clone
- 修改unhandled.log文件,把
-empty_dir: trunk/bin/.keep
改为
+empty_dir: trunk/bin
———-end ———