git-svn mkdirs 没有创建空目录的原因

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 ———

你可能感兴趣的:(git,linux使用,git-svn,空目录)