使用tortoisesvn提交更新时,提示某个文件已过时,请更新工作副本
我在使用Tortoisesvn进行代码的版本管理,有时候在提交更新时,失败,提示:需要更新的代码已过时,请更新工作副本。后来发现是我更新的代码不是基于最新版本的代码修改的...
我在使用Tortoisesvn进行代码的版本管理,有时候在提交更新时,失败,提示:需要更新的代码已过时,请更新工作副本。后来发现是我更新的代码不是基于最新版本的代码修改的,而是在之前的某个版本上做的修改然后提交更新,就提示上诉错误。请问大家是怎么处理这个问题的,我经常需要返回到以前某个版本修改,而不是在最新的版本上修改,谢谢。
展开
3个回答
2013-03-31
展开全部
svn是采用一个服务器端和多个客户端的方式来进行版本管理的,每一个客户端都有自己的workcopy,即每个用户都可以取得文件的编辑权限。这样如果你和你的同事同时对一个文件做编辑(假设你们此时都是基于版本1做修改),如果你同事向服务器端提交的话,此时的版本为2,这样你提交的时候就会出现错误,因为你基于的版本1已经过期。解决办法有两个,一个是代码的merge功能(rapidsvn支持该功能),还有一种就是采用svn底层的lock机制的(默认不lock),你可以采用该机制来进行版本管理:当有人获取某文件的编辑权限时,服务器端上该文件被lock,这样其他用户都无法获取该文件的编辑权限,只有你释放权限(修改提交或者revert),别人才能获得编辑权限,也就是说你的文件将采取串行修改而非并行修改的方式(rapidsvn有详细的介绍,你可以去查查相关的资料,这个工具是开源的,应该很容易获取)
展开全部
使用tortoisesvn提交更新时,提示某个文件已过时,请更新工作副本?问题在于,你进行提交的目录已经不是最新的版本。
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的。svn是采用一个服务器端和多个客户端的方式来进行版本管理的,每一个客户端都有自己的workcopy,即每个用户都可以取得文件的编辑权限。这样如果你和你的同事同时对一个文件做编辑(假设你们此时都是基于版本1做修改),如果你同事向服务器端提交的话,此时的版本为2,这样你提交的时候就会出现错误,因为你基于的版本1已经过期。解决办法有两个,一个是代码的merge功能(rapidsvn支持该功能),还有一种就是采用svn底层的lock机制的(默认不lock),你可以采用该机制来进行版本管理:当有人获取某文件的编辑权限时,服务器端上该文件被lock,这样其他用户都无法获取该文件的编辑权限,只有你释放权限(修改提交或者revert),别人才能获得编辑权限,也就是说你的文件将采取串行修改而非并行修改的方式(rapidsvn有详细的介绍,你可以去查查相关的资料,这个工具是开源的,应该很容易获取)
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的。svn是采用一个服务器端和多个客户端的方式来进行版本管理的,每一个客户端都有自己的workcopy,即每个用户都可以取得文件的编辑权限。这样如果你和你的同事同时对一个文件做编辑(假设你们此时都是基于版本1做修改),如果你同事向服务器端提交的话,此时的版本为2,这样你提交的时候就会出现错误,因为你基于的版本1已经过期。解决办法有两个,一个是代码的merge功能(rapidsvn支持该功能),还有一种就是采用svn底层的lock机制的(默认不lock),你可以采用该机制来进行版本管理:当有人获取某文件的编辑权限时,服务器端上该文件被lock,这样其他用户都无法获取该文件的编辑权限,只有你释放权限(修改提交或者revert),别人才能获得编辑权限,也就是说你的文件将采取串行修改而非并行修改的方式(rapidsvn有详细的介绍,你可以去查查相关的资料,这个工具是开源的,应该很容易获取)
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
问题在于,你进行提交的目录已经不是最新的版本。
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的
比如,代码的目录是这样的。SVN是主要文件夹,其下有两个子文件夹user1和user2;
如果你在user1进行代码的修改,你的同事在user2进行代码的修改。你们各自不去修改对方的代码,在自己的文件夹里面提交是不会出问题的。如果你到上一层目录,SVN里面进行代码提交,而你的同事,在你之前已经往User2更新的代码,这样的话,就不允许提交了。如果,你仅仅在自己的user1里面进行提交是没有问题的
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询