- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了 Subversion 客户端无法使用“svn update”进行更新的情况,用户必须删除其工作副本并查看新的副本,或者像 this question他们必须首先恢复。
为什么会发生这种情况?当这种情况发生时,所有应该处于干净/未修改状态的文件都显示为“已添加(+)”,即使用户没有添加它们?客户端人员没有做任何事情来弄脏他的工作副本。服务器端发生了更改,但是在服务器端,有人可能合并、提交,然后将分支从 /branches/featurebranch3/component/X
复制到 /trunk/component/X
。
没有进行此合并并且仅拥有工作副本并尝试每天跟踪主干和更新的开发人员,无法“更新”他的工作副本,并且必须手动备份任何未提交的文件,然后要么破坏整个文件工作副本,或执行 revert -R
然后再次更新。何时、为何发生这种情况,它与服务器端合并、移动和复制有何关系?我知道两者是相关的,但我不明白到底发生了什么。
如果没有人在服务器上移动、删除或复制文件夹,那么此问题的发生率就会减少。
我怀疑服务器端重命名/移动可能会造成混合修订情况,但我不知道如何。
一组可以可靠地重现这种损坏的工作副本的步骤:
创建一个文件夹 /branch/test1/components/component1
,进行一些合并并进入此分支。
删除现有文件夹/trunk/components/component1
将文件夹 /branch/test1/components/component1
复制到 /trunk/components/component1
恢复似乎不足以解决此问题,每次在服务器上完成此类删除+复制时,都必须删除工作副本并重新开始。
更新期间客户端上的消息有时没有错误,只是静默不执行任何操作,有时 TortoiseSVN 在更新中显示“已跳过,无版本控制的父级”,而文件仍保持状态“正常(+)”。该工作副本无法更新,也无法恢复,并且卡在“中间”。
客户端:1.8.5 SlikSvn 或 TortoiseSVN 1.8.5,内部版本 25224。
SVN服务器:1.8.8
最佳答案
我想对这个问题给出自己的答案,希望对大家有所帮助。
当您用其他新对象替换文件夹对象并替换先前的对象时,似乎没有链接这两个文件夹对象的修订图信息。因此,无法跟踪和更新基于先前工作文件夹的工作副本。
虽然“C:\Folder1\Folder2\Folder3”对您来说是同一个对象,但在 Subversion 的术语中它不是同一个对象。 Subversion 的工作是将对象存储在其数据库(客户端上的 SQLITE,或服务器上的 FSFS 存储)中,这些对象可以具有无限多个具有相同确切名称的对象,甚至在 YOUR 中具有相同的确切文件夹或有效的完全限定路径名。工作副本,但是,它永远不会将第一个文件夹 3 与第二个文件夹 3 等同起来。这是这个有意决定的结果(允许存储文件夹并使它们成为 SVN 系统中的第一类实体,而不是源代码文件的内容,可能编码为 DIFF 文件,正如您在 CVS 和 Mercurial 中看到的那样) ,它根本不跟踪文件夹,并且不能生成同等损坏的工作副本),这会导致工作副本实际上变得无效并且不再可更新,这是我上面描述的问题的根源。
Subversion 完全损坏的唯一一致症状是 TortoiseSVN 中数百或数千个正常(+) 状态指示器。 “跳过,无版本控制的父级”并不总是被发出,但当它被输出时,这是一个好兆头,你也很无聊。
某些情况可以通过使用 SVN SWITCH、SVN REVERT、SVN UPDATE 来解决,但许多情况则不能。
简而言之:
A.不要这样做。不要更换物体。因为 subversion 无法处理它,也不会警告你,它只会破坏所有用户并破坏他们的所有工作副本。
B. Subversion 不是一个基于文件的版本控制系统(如 git、mercurial 和 cvs),它是一个容器版本控制系统,它的容器看起来像文件夹,直到您真正尝试合并,然后它们就不再像您想象的那样。 Subversion 版本容器不仅包含您的文件,而且看起来很像文件夹,它们也是各种 Subversion 自己的版本控制元数据的元数据容器,并且有很多方法可以打破链条,并呈现您的版本。工作副本无形地损坏了。 Git、Mercurial 和 CVS 处理文件内容,这是程序员关心的。 Subversion 版本文件夹并创建“树冲突”,这对开发人员没有用处,因为文件夹只是组织源代码的一种方式,并且(在 git 开发人员看来)不是模糊的不可见元数据的所有者。Subversion 甚至无法大声告诉你发生了什么事,因为模型已经损坏了,没有任何简单的英语错误消息可以让你很容易地知道如何修复它。
关于svn - 服务器端文件夹重命名(移动)是否会在 Subversion 中创建损坏的工作副本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22566462/
我在使用NetBeans 6.8时遇到以下问题。我通过项目属性->库->编译选项卡->添加JAR /文件夹添加带有jar的文件夹。在下一个窗口中,我选择文件夹,然后选择“复制到库文件夹”。但是,我仍然
我的网站有一个域别名。我想知道如何将 domainA.ext 的请求重定向到 https://domainA.ext/folderA和对 domainB.ext 的请求到 http://domainB
我应该在 Eclipse 中构建的 Android 项目中创建自己的自定义菜单文件夹吗?例如,我想创建一种出现在所有 Activity 中的标题。我知道菜单应该在 res/menu 文件夹中的 XML
我正在使用 VS2008 和 .net 3.5。我在我的解决方案中创建了一个类库(Myproject.Controllers)。在这个类下,我添加了一个 Controllers 文件夹。在文件夹中我添
我有一个包含生成后步骤的 Visual Studio 2012 扩展项目,我想在其中将 .dll 和 .AddIn 文件复制到当前用户的 Visual Studio 2012 AddIns 文件夹中。
我在专有的 linux 发行版中有一些自动下载。 他们去临时暂存盘。我想在它们完成后将它们 move 到主 RAID 阵列。我能看到的最好方法是检查磁盘上的文件夹,看看内容是否在最后一分钟发生了变化。
我目前正在使用 SVN 对我的软件项目进行版本控制。在一个正在进行的项目中,我有主干,用于客户的共同功能和规范以及分支,用于客户特定的。 有没有办法在每次执行此类操作时标记一些不应合并到分支中的文
这个问题在这里已经有了答案: How to exclude a directory in find . command (45 个回答) 8 年前关闭。 如何删除文件夹中的所有内容并排除特定文件夹和文
如何在特定目录中创建具有当前日期和时间的文件夹或文件? DateTimeFormatter f = DateTimeFormatter.ofPattern("uuuuMMdd HHmmss") ; L
有没有办法在系统文件资源管理器的左侧“文件夹”栏中打开文件或文件夹?如果没有这个,我必须打开文件资源管理器并一直导航到该文件夹所在的位置才能操作文件,这确实很不方便。对于大多数带有这样导航栏的工具
预期:我使用 go get 安装包,它在 src 文件夹中创建了所有必要的文件夹,但它们只出现在 pkg/mod 文件夹中,我不能使用它们。 现实:它说它正在下载,完成,然后什么都没有。 一切都在 W
说 foo.zip包含: a b c |- c1.exe |- c2.dll |- c3.dll 哪里a, b, c是文件夹。 如果我 Expand-Archive .\foo.zip -Destin
不久前我正在删除 var 文件夹中 Magento 的缓存。我可能是错的,但我认为我犯了一个错误,而不是删除 var/cache 中的所有内容,而是意外删除了 var 中的所有内容。 Magento
我在 svn 存储库的单独文件夹中有一些代码项目。 现在我在删除文件时遇到一些问题:大多数时候一切顺利,但有时当我从磁盘删除文件或文件夹时, checkin 过程会出现各种错误。 所以我想知道:在sv
有没有什么方法可以用很少的R命令行自动删除所有文件或文件夹?我知道 unlink() 或 file.remove() 函数,但对于这些函数,您需要定义一个字符向量,其中包含您想要的文件的所有名称删除。
用于在文件夹中查找不符合Get-Childitem的LastWriteTime过滤器日期范围标准的文件的powershell命令是什么? 因此,请检查目录中是否包含不包含在01/10/2012(十月1
我正在为我工作的公司内部使用的应用程序之一编写 NSIS 安装程序,安装过程工作正常,所有 REG 键都已创建,文件夹和服务也没有问题,该应用程序使用。出于某种我无法理解的原因,卸载过程不起作用。
我有一个 Excel 文件,并且在同一文件夹中还有一个包含我想要包含的 CSV 文件的文件夹。使用“来自文件夹”查询,第一步将给出以下查询: = Folder.Files("D:\OneDrive\D
我在docker中玩ScyllaDB。为了使ScyllaDB在docker生产设置中最有效地运行,它需要一个XFS格式的磁盘。 您知道如何在Linux和MacO中创建XFS容器卷,磁盘文件吗? 谢谢
我应该编写一个函数,其中包含之前每次与该数字相乘的乘积 基本上是这样的: > productFromLeftToRight [2,3,4,5] [120,60,20,5] 我应该使用高阶函数,例如折叠
我是一名优秀的程序员,十分优秀!