一、TortoiseSVN常见的16个使用问题与解决方法
TortoiseSVN常见的16个使用问题:
1、鼠标右键点击文件时CPU占用100%
每次右键点击文件,CPU飙升到100%(同时右键菜单被显示。)如果从菜单中选择某项,则CPU又恢复正常;如果在空白处点击右键,CPU将不会有问题,到底是怎么回事?
XP包含了一个已知的bug,当你在特定的配置文件下访问上下文菜单会引起cpu占用上升到100%。这个bug会使文件**暂停,使网络连接缓慢,流媒体(声音,视频)扭曲。为了工作在包含这个 bug的环境下,你需要通过以下操作禁止图形界面的传输效果:
控制面板-》显示
选择外表栏
点击效果,然后清空“为菜单和工具提示使用以下过渡效果”栏
点击确定关闭所有的对话框。
另一种解决方法是在点击右键显示上下文菜单前点击一次左键。
2、是否可以创建一个本地的版本库到网络文件夹?
不能创建 Berkeley DB版本库到共享的网络地址!
BDB版本库不能存在于远程文件系统,比如NFS,AFS,或者Windows SMB。 BDB要求文件系统运行在严格的POSIX语义环境,更重要的是,将文件直接映射到进程内存的能力。很多没有网络的文件系统都提供了这个功能。如果你尝试在网络共享中使用BDB,结局是不可预知的。你可能会立刻看到诡异的错误,或者在几个月以后,你发现版本库隐约被毁坏。
你可以使用 FSFS格式的版本库但只有一个用户可以访问本地硬盘,接下来的FAQ项目会讲到为什么共享版本库是一个坏想法。除非你真的有迫切的原因让你的文件放到网络共享,通常来说,最好的办法就是避免这样做。
如果你真的需要通过网络共享访问FSFS版本库,你应该按照下面的其中一点来做:
用下面的语法规则来映射网络驱动器:
将//server/shared映射到S:
file:///S:/repos(盘符前有三个斜杠)
通过下面的格式指定一个UNC直接路径:
Subversion》= 1.2
file://server/shared/repos(2个斜杠)
Subversion《 1.2(奇怪的语法,我们知道)
file://///server/shared/repos(5个斜杠)
file:///server/shared/repos(3个斜杠+反斜杠)
但是不要说我们没有提醒过你……
3、是否可以将版本库保存在网络共享驱动器来代替创建服务器?
如果你需要多个电脑访问版本库,在理论上你可以创建 FSFS版本库(但不能是 BDB版本库)在网络共享驱动器上,通过已下格式访问 file:// protocol。事实上这里有三个不推荐的原因:
你将给所有用户直接访问权限,所以他们会有可能偶然的删除或者破换版本库文件系统。
并不是所有的网络共享协议都支持Subversion要求的锁定。总有一天你会发现你的版本库被悄悄的破坏。
你不得不设置正确的访问权限,SAMBA在这一点上特别难以满足。
更好的办法是创建一个真正的服务器进程(像Apache,svnserve),存储版本库到当地的文件系统上,使版本库服务器可以在网络上有效,可以被访问。这也许会比你想的要简单。Subversion书中第6章服务器配置有详细的方法说明。
4、是否可以使用不同的Subversion客户端来操作同一个工作拷贝?
可以,客户端只是用来控制你的工作拷贝,以及工作拷贝与版本库之间的交互。工作拷贝里的元数据对于不同的客户端来说都是一样的。
但是,必须是使用同一版本Subversion库的客户端。TortoiseSVN所使用的Subversion版本会在安装文件的文件名里标明,其它的客户端也会有类似说明。版本号的头两位数一致的客户端才能通用。例如,所有使用Subversion1.5.x的客户端都可通用(‘x’表示此位数字不影响兼容性)
你还必须确保这些客户端都是为同一个操作系统编译的。客户端兼容的前提是必须是同一种操作系统,并且元数据的表示方式可能发生变化。你不可以对同一个工作拷贝同时使用Windows的原生客户端和Cygwin的客户端。如果是通过网络共享的工作拷贝,你不可以同时使用Windows的客户端和Linux的客户端。
5、TortoiseSVN能实时自动转换文本文件中的换行符吗?
请到查看Subversion书中关于svn:eol-style属性的内容。比如说,如果你将此属性设置为‘native’,在 Linux下它就会以LF作为换行符, Windows下则是 CRLF。想了解如何通过TortoiseSVN设置这些属性,请到这里阅读我们的文档。
6、如果冲突是在一个文件夹的属性里,怎样找到它呢?
在属性有冲突的文件夹里,有一个dir_conflicts.prej文件,用文本编辑器打开它,你会看到有冲突的属性,用你想保留的属性覆盖有冲突的。
7、我误删了一个文件,怎么找回来?
如果你还没提交,你可以在被删除的文件/文件夹的父文件夹作还原操作。
如果你已经提交了删除文件,你可以使用版本库浏览器,回到那文件还存在时的版本,然后在上下文菜单中使用拷贝到……命令,输入你工作拷贝的路径作为目标路径,被删除的文件就会从版本库**到你的的工作拷贝。
用这个方法也可以恢复被删除的目录。
如果用这个方法恢复文件/目录后,日志对话框无法显示它的修改历史,别担心,历史信息还在的。在 SVN中**一个文件时,它的历史信息会同时被**。但TortoiseSVN的查看日志功能默认是“Stop on copy”,即当你查看的日志是由分支点开始的。之所以这么做是因为当查看一个真正的分支时,你多数只是想知道那个分支的历史信息。如果要看完整的历史信息,你可以不选‘Stop on copy’,而把‘Get All’选上。
8、为什么我右击一个链接的时候有几个TortoiseSVN菜单?
这是正常的,其中一个是针对链接本身(.lnk-file文件),另外一个针对它指向的文件。这样既可以对一个链接文件进行版本控制,又可以对它指向的目标进行控制。事实上在文件菜单里你会有多达三个菜单(上下文菜单只显示二个)。
9、能不能像 Visual Source Safe一样使用‘共享文件’?
Subversion中不能共享一个文件,但可以共享一个文件夹。请查看 Subversion Book中外部定义一章。
10、没有服务器,可以单独使用 TortoiseSVN吗?
可以,你可以用file://协议来访问你的本地版本库。
11、使用TortoiseProc时可以发送用户名和密码吗?
TortoiseSVN是一个图形化客户端,它会在需要的时候提示你输入用户名和密码。如果你想以非交互方式访问版本库,可以使用命令行客户端。
12、版本分支图是怎么一回事?
版本分支图跟TortoiseSVN的其它功能不一样。它可以显示一个文件或文件夹的所有历史修订,包括拷贝、移动、分支和加标记操作。
我们经常会被问到“为什么要把版本库根目录的日志也拿下来”,或者是“为什么会需要取由第一次修订到最新一次修订的全部日志呢”
我得澄清一点:这可不是因为我们太懒,或是笨到不会优化——尽管你们有些人似乎就是这么暗示的。我们这么做其实是有必要的。
版本分支图是通过查找针对某个对象的所有修订,来呈现它的历史的,这需要用到所有的可用信息。
如果查看选定文件/文件夹的日志,在日志对话框的下半部分你可以看到选中的修订影响到的所有路径,这就是在版本分支图用到的信息。如果查看/trunk的日志,你会发现里面没有记录加标记或分支的日志,就算是对/trunk本身加标记、作分支也不会有。--》这就是取版本库根目录日志的用意:只有版本库根目录日志才包含这些所需信息,包括一个目录何时曾被**、分支、打标记或移动到何处。
沿用前面的例子,如果我们不取所有修订的日志,而只取一部分的,那就有可能丢失/trunk作分支、打标记的日志。而且即使那些分支、标记本身做过修改,或者那些日志也在取下的部分里,版本分支图也无法知道那些分支、标记操作是在/trunk还是别的路径发生的。这意味着,版本分支图不单是不完整的,还有可能是错的。
因此我们不会去做所谓的“优化”,如果这个图一时正确一时错误,而且你还无从判断它是否正确、什么时候正确,这比完全没用的东西更糟糕。
13、通过 svn+ssh提交时,为什么日志里没有‘作者’信息?
二、如何使用tortoisesvn
方法/步骤
如果没有TortoiseSVN客户端,可以去这里下载:tortoisesvn.net/downloads.html,根据自己的实际情况下载对应版本。
下载后安装,在开始菜单中就能见到下面的图标,说明安装成功,现在就可以开始使用TortoiseSVN了。
选定本地的一个文件夹存放从服务器下载的代码。
然后右击这个文件夹,选择“SVN CheckOut...”。
填写仓库地址(URL)。其他地方可以不用修改。Version处可以修改,表示从指定的版本号开始。
点击“OK”按钮就开始下载了。
下载成功后,可以看到下图这样的文件夹,前面会有个绿色的对号。
如果文件修改了图标上会变成叹号。
如果要提交修改的文件,可以右击该文件或者选中多个修改的文件,选择“SVN Commit”,在弹出的对话框中必须填写注释信息Message,否则会提交失败。
7
新添加的文件或者文件夹前面会是问号。
如果要提交这样的文件,可右击文件,选择TortoiseSVN->Add,也需要填写Message项。
三、详细使用TortoiseSVN的步骤
TortoiseSVN是一个SVN的客户端,下面是我以前不知道从哪**的大致使用,希望对你有用:
五.客户端的使用
1.Checkout Repository
首先要Checkout服务器端的Repository,
所谓的Checkout就是指获得服务器端指定的Repository存储的所有文件。
这个Checkout和Visual Source Safe的Checkout意义完全不一样,
VSS的Checkout指的是锁定某个文件,如果你以前使用过VSS,
在学习Subversion时这个问题一定要注意。
Checkout的具体方式是:
在客户端新建一个空目录,比如:F:\Project1
在该目录上单击右键,在弹出式菜单中选中SVN Checkout...,
之后在“URL of Repository”文本框中填入你想要连接的Repository的地址,
这个URL地址可以用浏览方式加入。
对于在本教程第二节建立的Repository,
URL应该是“svn://xxx/project1”
(xxx可以是服务器端主机名,也可以是服务器端的ip地址)。
然后点OK,会弹出一个认证对话框,
输入在教程第三节设置的用户名和密码。
点OK后就完成了对Repository的Checkout。
比如:在服务器端Repository中有一个a.txt文件,
那么Checkout之后F:\Project1目录下也会出现一个a.txt文件。
在本例中由于服务器端的Repository还未添加任何文件,
所以在客户端的F:\Project1下没有文件被Checkout。
执行Checkout除了会在F:\Project1产生Repository存储的文件及目录外,
还会产生了一个“.svn”的隐含目录,该目录是由subversion管理的,
不要删除或者手工改动其中的文件和目录。
现在F:\Project1中的文件和目录就叫做Repository的“Working Copy”简写“WC”
(这个简写...汗)。
以后对Repository中文件和目录的修改,添加,删除的操作,
都是通过对这个“Working Copy”的操作实现的。
Checkout执行完后,
会发现F:\Project1目录的图标的左下角附着了一个小的状态图标
(当F:\Project1目录中的文件改变时,这个状态图标也会随之变化),
它表示F:\Project1是一个Repository的“Working Copy”,
F:\Project1内的所有文件和目录也会有类似的状态图标。
2.添加文件
将要添加的文件或者目录拷贝到F:\Project1下,
然后在该文件或目录上单击右键,TortoiseSVN->Add,点OK。
如果添加了不止一个文件或目录,
则鼠标不要在F:\Project1中点中任何文件,
然后单击右键,TortoiseSVN->Add,
就可以添加多个文件或目录。
这时文件的状态图标会发生变化。
Add命令只是告诉本地的“Working Copy”将该文件纳入版本管理,
并没有将这个改变提交到服务器端,
如果想要别人也看见你对Repository的修改,你需要
在F:\Project1下单击右键,SVN Commit...,
将你所做的修改提交到Repository。
文件的状态图标也会更新。
不管你在“Working Copy”内添加、修改、删除文件后,
要想其他人也看见你的修改,
都必须用Commit命令将所做修改递交到服务器端的Repository。
3.修改文件
用文本编辑器或IDE对文件修改后,
文件的状态图标会变化,
然后单击右键,SVN Commit...
提交修改,只有当执行Commit提交修改后,
你所作的修改才会反映到服务器端的Repository中。
4.删除文件
删除文件时,选中要删除的文件或目录,
单击右键,TortoiseSVN->Delete,提交修改。
注意千万不要用“Delete”键来删除文件,否则将无法提交你的修改。
这一点对目录的删除来说尤为重要。
5.放弃修改
当你添加、修改、删除文件后,决定放弃修改,
你可以单击右键,TortoiseSVN->Revert,
本地的“Working Copy”中的文件和目录会恢复到你修改前的状态。
6.获取Repository的最新版本
当一个团队合作开发项目时,
每一个人都在不断的对Repository进行更新,
你需要不断的更新自己的“Working Copy”,
以获取项目最新的文件。
当第一次获得最新Repository的文件时,
我们用Checkout命令,前面已经介绍了,
以后再获取最新文件时就不用Checkout了。
而改用Update命令。
接着前面的例子,这时F:\Project1已经成为一个“Working Copy”了
(通过执行Checkout命令),现在其他人已经对Repository进行了修改,
我想将别人的修改反映到我的“Working Copy”中,
具体的方法是:在F:\Project1目录上单击右键,
SVN Update。这时F:\Project1中的文件就是最新的版本了。
注意,如果当你的“Working Copy”中有被修改的文件,
或者有被删除的文件,并且还未提交这些修改时,
这些文件在执行Update过程中是不会被更新的。
比如你修改了F:\Project1下a.txt文件,
还未提交修改,那么,
当你对F:\Project1进行Update时,
a.txt文件是不会更新为Repository上的a.txt文件的。
所以如果想放弃当前的所有修改,
并将F:\Project1下所有文件及目录更新到最新版本,
应该先对F:\Project1执行Revert命令再执行Update命令。
7.subversion的版本控制模型
当你用subversion进行版本控制时,
Subversion会记录你对Repository进行的每一次修改(包括添加,修改,删除等等),
每修改一次Repository都会产生一个新的Revision(修订版本号),
不同的Revision代表了不同时刻Repository的状态,
因此我们可以用这个Revision回朔任意时刻Repository的状态,
就像时间机器一样,也就是说某一Revision
就是Repository在某一时刻的一个“快照”。
注意:Revision不是针对某一个文件或者目录,
而是针对整个Repository而言的。
每修改一次Repository,Revision都会增加1。
Subversion的版本控制模型是一种叫做Copy-Modify-Merge
(拷贝-修改-合并)的模型。
考虑这种情况:
张三和李四是公司同一个部门的同事,
他们共同维护一个文本文件a.txt,
并且对该文件进行版本控制,
因此他们把这个文件放到一个Repository上共同维护该文件。
周一上午9点,张三和李四同时想对a.txt文件进行修改,
于是他们同时从Repository上取得该文件的最新版本(Revision 10),
然后进行修改。过了三分钟,张三首先完成了修改,
他在该文件的第五行修改了一个单词的拼写(将Typo改为Type),
于是张三对修改后的文件执行Commit命令,
将修改提交到服务器端的Repository中。
这时Repository的Revision变为11。
六分钟过后,李四也完成了他的修改,
他修改了该文件第十行上的一个单词拼写(将He改为She),
于是他也对修改后的文件执行Commit命令,
这时Subversion在提交修改时会发现,
李四修改的文件是Revision10的a.txt文件,
而不是最新的Revision 11的a.txt文件。
于是,Subversion提示李四在提交修改前,
应该先将Working Copy更新到最新版本,
李四执行Update命令将Working Copy更新到Revision 11,
这时Subversion会提示已经完成合并,
李四的a.txt文件的第五行的“Typo”已经变为了“Type”,
第十行还是“She”,就是说Subversion已经将张三的修改“合并”到李四的a.txt文件中了。
之后,李四再执行Commit命令,就能将他对第十行的修改(将He改为She)
提交到服务器端的Repository中了(生成Revision 12)。
但是这种合并在某些情况下会变得复杂一些,
比如:李四对a.txt文件的修改并不是第十行,
而是与张三同样修改第五行的单词,
李四将“Typo”改为“Typr”,并且提交修改,
这时Subversion会提示李四在提交修改前,
应该先将Working Copy更新到最新版本,
李四执行Update命令将Working Copy更新到Revision 11,
这时Subversion将Revision11的a.txt文件与
李四修改的a.txt文件进行合并时发现李四修改的同样是第五行,
于是Subversion就无法判断是李四的修改(“Tpyr”)
正确还是张三的修改(“Type”)正确,
因为他们都是在Revision10的a.txt基础上作的修改。
这种情况叫做Conflict(冲突),
a.txt文件的图标会变成一个黄色三角。
这时,只能依靠李四自己去判断到底第三行应该修改为“Typr”还是“Type”。
当李四确定修改之后,在a.txt文件上单击右键,TortoiseSVN->Resolved
告诉Subversion已经解决了Conflict。
这时再执行Commit命令就能提交修改(生成Revision 12)。
Subversion这种控制方式保证了你对文件所作的修改都是基于文件的最新版本。
8.“.svn”目录
在客户端Working Copy的每一层目录中都会有一个“.svn”目录,
该目录是Subversion进行管理用的目录。
不要手动修改其中的文件。
该目录存储了Working Copy的一个副本
(实际存储副本的地方是F:\project1\.svn\text-base目录),
比如:F:\Project1是一个Working Copy,
该目录下有两个文件a.txt和b.txt还有一个子目录ccc,
子目录ccc中还有一个d.txt文件。
“.svn”目录中存储的是你最近一次执行完Update或者Commit命令之后当前目录中文件的副本,
比如:F:\project1\.svn\text-base中存储的a.txt和b.txt
是最近一次执行完Update或者Commit命令之后F:\project1下的a.txt和b.txt的拷贝。
也就是说你所作的修改都是基于“.svn”目录存储的那些文件。
这种机制可以让我们在不连接网络的情况下,
将Working Copy中的文件恢复到修改之前的状态。
Subversion的Revert命令就是利用了这种机制来实现的。
比如你修改了F:\project1\a.txt文件,
这时你又改变了主意想放弃对该文件的修改,
你可以单击右键,TortoiseSVN->Revert,
修改过的F:\project1\a.txt文件
就会被F:\project1\.svn\text-base中a.txt文件的副本所替代,
使得a.txt恢复到修改前的状态。
Working Copy中每一个子目录下都会有一个“.svn”目录,
并不是只有最上层目录才有“.svn”目录。
所以,F:\project1\ccc下也有一个“.svn”目录,
该目录存储的是F:\project1\ccc\d.txt的副本
(d.txt的副本位于F:\project1\ccc\.svn\text-base)。
也就是说每个“.svn”目录只存储同级目录中的“文件”副本,
而不存储“目录”副本。“.svn”目录存有许多重要的内容,
所以前面说在删除文件或目录时,
必须用TortoiseSVN->Delete,
而不能用“Delete”键来删除文件或目录,尤其是对于目录的删除。
9.混合版本
Subversion的Working Copy被设计成一种能够包含不同版本的文件共存的形式。
比如F:\Project1是一个Working Copy,
该目录下有两个文件a.txt和b.txt。
执行Update命令,将Working Copy更新到最新版本(Revision 24)。
这时,a.txt和b.txt的Revision都是24
(其实对于单个文件来说并不存在Revision,
Revision是对于整个Repository而言的,
这里所指的是Repository的Revision24所存储的a.txt和b.txt,
但为了方便而采用这种描述方式,请注意,下同)。
之后,你的同事修改了a.txt,并且提交了修改,
这时Repository的Revision就变成25了。
注意,这时你没有再次执行Update,
因此你的Working Copy的Revision还是24。
这时你修改了b.txt文件,并提交修改。
因为Revision25并没有对b.txt文件进行修改,
因此你对b.txt文件的修改是基于b.txt文件最新的版本,
所以不会出现Conflict。
当你提交b.txt的修改后,产生Revision26。
这时你会发现你的Working Copy中的a.txt文件并不是Revision25中的a.txt文件,
它还是Revision24的a.txt文件,而你的b.txt文件是Revision26的b.txt文件。
也就是说当你Commit时,你的Working Copy中只有你提交的那些文件是最新版本,
而其他没有修改的文件并不会更新为最新版本。
这样就造成了你的Working Copy由不同的Revision文件所组成
(Revision24的a.txt文件和Revision26的b.txt文件)。
前面说过在提交修改前必须保证你是在文件的最新版本基础上修改,
如果在这种混合版本的情况下,
怎样才能知道当前Working Copy中的文件是否为最新版本?
在前面所说的“.svn”目录中有一个文件名为“entries”的文件,
该文件记录了当前Working Copy中的每一个文件的Revision,
因此当你Commit时,Subversion会从该文件中取得你提交文件的Revision,
再与Repository的最新Revision一比较就可以知道你修改的文件是否基于该文件的最新版本。
10.文件的锁定
前面说过Subversion的版本控制模型是一种叫做Copy-Modify-Merge
(拷贝-修改-合并)的模型。
该模型在对文本文件进行版本控制时工作的很好,
但是有些需要进行版本控制的文件并不是文本文件,
比如说图像文件,这种模型在这种情况下就不能正常工作了,
因为文本文件可以合并,而二进制文件则无法合并。
所以Subversion从1.2开始支持一种叫Lock-Modify-Unlock
(锁定-修改-解锁)的版本控制模型。
在Windows下最常用的版本控制软件Visual Source Safe(VSS)就是采用这种模型。
这种模型要求在对一个文件修改前首先要锁定这个文件,
然后才能修改,这时,别人将无法对该文件进行修改,
当修改完后再释放锁,使其他人可以对该文件进行锁定,然后修改。
锁定文件的方法是:TortoiseSVN->Get Lock...再点OK按钮,
这时就完成了对文件的锁定。
这时,如果其他人想对文件进行锁定时,
Subversion会对他提示该文件已经被别人锁定。
当你修改完文件后,然后单击右键,SVN Commit...,
将修改提交,默认情况下,提交的时候就会对该文件解锁,
如果你想仍然锁定该文件,请在commit时弹出的对话框中选中keep lock复选框。
11.文件的附加属性
在Subversion中,每个文件可以拥有一种叫做附加属性的东西。
附加属性描述了该文件所拥有的一些特性。
Subversion已经预定义了一些附加属性
(这里只是指Subversion已经定义了一些附加属性的“名称”,
并不是指已经将这些属性附加在文件上了,
比如默认情况下文本文件一开始不含任何属性,
直到人为的对该文件添加附加属性),
并且你可以对文件添加自定义的属性。
Subversion对待附加属性就像对待文件内容一样,
当修改了一个文件的附加属性(添加,改变,删除附加属性),
即使没有对文件的内容进行修改,
同样可以Commit该文件,就像更改了文件内容那样,
Repository也会生成新的Revision,
所以从某种意义上来说,
Subversion不区别对待文件的附加属性的修改和文件的内容的修改,
文件的附加属性可以看成是一种特殊的文件内容。
Subversion预定义了若干个附加属性,
这里只讨论“svn:needs-lock”属性,
因为它与我们上面的文件锁定会产生的一个问题有关。
其他的属性可以参考Subversion自带的帮助文档。
考虑这种情况,
张三和李四同时想对一个图片文件a.jpg作修改,
张三在修改时先将该文件锁定,然后进行修改,
同时李四也开始对该文件进行修改,
但李四忘记了对非文本文件进行修改时应该先锁定该文件。
张三首先对该文件修改完毕,于是张三向服务器提交了他的修改。
之后,李四也完成了修改,当他提交修改时,
Subversion提示李四的文件版本不是最新的,
在Commit之前应先更新a.jpg到最新版本,
由于图片文件无法合并,
这就意味着张三和李四之间必定有一个人的修改会作废。
应用“svn:needs-lock”属性可以避免这个问题。
当一个文件拥有“svn:needs-lock”属性时,
该文件在没有锁定时,文件的图标是灰色的,
表示该文件是一个只读文件(该文件的Windows只读属性的复选框为选中),
这个灰色的图标就会提醒想对该文件进行修改的人,
在修改该文件之前应该首先锁定该文件。
锁定该文件之后,文件的只读属性就会去掉了,
一旦释放掉锁,文件的图标又会变成灰色,
文件也会变成只读的了。
李四在这种情况下就会避免在没有锁定文件时对文件进行修改。
对非文本文件添加“svn:needs-lock”
属性应该在将该文件第一次添加到Repository时就设置,
当然,一个文件可以在任意时刻添加附加属性,
这样做是为了减少李四所遇到的那个问题发生的几率。
具体的方法是:
首先将a.jpg文件拷贝到Working Copy中,
然后在该文件上单击右键,
TortoiseSVN->Add,告诉Subversion要将该文件纳入版本控制,
接着在该文件上单击右键并选中属性,
在弹出的属性对话框中选中Subversion页。
在下拉框中选中“svn:needs-lock”,
并在下面的文本框中填入“*”
(其实这里填什么都无所谓,只要文件有“svn:needs-lock”附加属性就行),
之后点Set按钮,“svn:needs-lock”附加属性就设置好了。
然后执行Commit命令提交修改。
这时当其他人执行Update时,
a.jpg就会添加到他们的Working Copy中,
并且文件的附加属性也会随文件一起被得到。
可以看到a.jpg此时的图标就是灰色的,
文件的Windows属性也是只读的。
12.回到以前的版本
由于Subversion会记录你对Repository的每一次修改,
因此能够很容易的获得Repository以前某一时刻的状态。
比如:现在Repository的最新Revision是56,
这时我想看看Repository在Revision24时的状态,
可以在本地的Working Copy中单击右键,
TortoiseSVN->Update to Revision...,
然后输入你想要回复到的Revision号,点OK按钮。
回到以前的版本还有一种情况是我想将Repository的
最新Revision的状态与以前某一个Revision的状态一模一样,
上面那种方法就不适合,
上面的那种方法只是将本地的Working Copy回复到以前的状态,
而服务器端的Repository并没有回到以前的状态。
将Repository的最新Revison的状态回复到以前某个Revision的状态具体的方法是:
先执行Update命令将Working Copy更新到最新的Revision,
然后在Working Copy中单击右键,
TortoiseSVN->Show Log,
弹出的Log Messages窗口中会显示该Repository的所有Revision,
选中最新的Revision,之后按住Shift键,
再单击你想回复到的Revision+1的那个Revision
(比如Repository的最新Revision是30,
你想将Repository的状态回复到Revision16,
那么就选中Revision30,再按住Shift键,
选中Revision17,
就是说选中Revision17到Revision30之间的所有Revision)。
然后在选中的Revision上单击右键,
选中“Revert changes from these revision”。
再点Yes按钮,就可以将Working Copy的状态回复到目标Revision。
注意,此时只是Working Copy回复到目标Revision,
之后应该用Commit提交修改,
这样Repository最新状态就与目标Revision的状态一样了。
这两种回复到以前版本的方式截然不同,
第一种方式是将整个Working Copy回复到某个Revision,
也就是说这种方式Working Copy中的“.svn”目录所存的文件副本也与目标Revision的一模一样,
如果这时你没有修改文件,你将不能执行Commit命令。
而第二种方式客户端Working Copy中的
“.svn”目录所存的副本始终是最新的Revision的文件副本
(这里我们基于一个假设:在Update之后没有其他人对Repository做修改)。
这种方式就像是我们自己手工将Working Copy的文件状态修改为目标Revision,
在修改之后提交修改一样。
13.查看修改
有时我们对Working Copy的许多文件进行了修改,
这些文件位于不同的子目录,我们就可以在Working Copy的最上层目录单击右键,
TortoiseSVN->Check For Modifications,
弹出的对话框就会显示你所做的所有修改明细。
还有一种情况是我们的Working Copy已经很久没有执行Update命令,
我们想看看Working Copy中有哪些文件已经发生修改了,
这时就可以在Working Copy的最上层目录单击右键,
TortoiseSVN->Check For Modifications,
在弹出的对话框点击Check Repository按钮后,
就会显示服务器端已经修改了的文件。
该方法还有一个用途就是查看文件的锁定,
当你想锁定一个文件时,你想先看看这个文件有没有被别人锁定,
点击Check Repository按钮会显示服务器端Repository所有被锁定的文件,
如果你想锁定的文件不在这里面,那就说明该文件目前没有人锁定。
感谢您的阅读!希望本文对解决您关于【网络学习】对TortoiseSVN的基本了解及简单操作的问题有所帮助。如果您还有其他疑问,欢迎随时向我们提问。