执行svn cleanup 时报错,
大意是:在svn checkout时,如果文件名中存在无法识别的符号,那么checkout操作会阻塞后面的其他操作——包括cleanup。此时我们只有采用其他方式来清理掉“to-do” list(操作列表)中这次失败的checkout操作,才能让svn继续工作雅思听力标准。
从svn1.7之前,SVN采用众多的小文件来保存版本相关信息。但1.7之后,SVN使用一个集中式的SQLite 数据库来替代之前的下文件方式,该数据库位于.svn文件夹中,名字叫做wc.db。
SVN的操作列表就存放在SQLite数据库的WORK_QUEUE表中。
因此,现在方向已经明确了——我们只需要将数据库SQLite中这次失败的checkout操作删除就万事大吉了。可是具体该怎么操作呢?
要打开wc.db这个数据库,我们需要用到一个shell脚本——sqlite3,这可以从其官网 http://www.sqlite.org下载最新版。(如果不能翻墙,大家可以从这里下载2018最新版)
将解压过后将sqlit3拷贝到.svn文件夹下:
接着执行如下查询语句
sqlite3 wc.db “select * from work_queue”
来查看操作队列中阻塞的操作:
可以看到有一条操作记录,接着执行下面的命令删除该操作:
sqlite3 wc.db “delete from work_queue”
这一步执行成功后没有任何提示:
大功告成!此时便可以执行svn cleanup了: