论坛讨论请见:
http://community.csdn.net/Expert/topic/3492/3492097.xml?temp=.1520502
IDEA的CVS是我见过功能最强,最好用的CVS客户端,其与IDEA工程的整合几乎达到了天衣无缝的地步。一个团队如果统一使用IDEA,则仅在CVS工具这一方面就会大大减轻团队成员的学习负担。
IDEA的CVS插件支持两种编码方式: UTF8和ASCII。本来是弥补了CVS系统本身不支持国际化的缺陷。但是在实际使用中,却发现这两种编码方式有些“高不成低不就”。
在UTF8编码方式下,当Commit的log信息为中文时,IDEA会将其进行UTF8编码再发送给服务器,而一般的CVS服务器(比如我用的CVSNT)会不进行任何转化的将其保存到CVS仓库中。这样的结果就是IDEA自己能够看到各个版本的log信息,而其他工具如WinCVS, TortoriseCVS以及CVSTracNT等跟踪软件都无法正确的解码。反之,如果用其他CVS客户端提交了中文log的话,IDEA里的ShowHistory命令就会报错。让人最为不解的是,仅仅只有log信息是被编码过的,源文件中如果含有中文,则仍然采用GB的编码方式。如果你是CVS的管理员,会在xxxxx.java, v文件中同时发现GB编码和UTF8编码的中文。怎能不乱?
此外在UTF8编码方式下,当源文件中含有中文字符时,Annotate功能是不能使用的。
如果不使用UTF8编码,即使用ASCII编码的时候,Annotate功能是没有问题,但是Commit的时候无法提交中文log信息,报编码错误。ShowHistory时看外界提交的中文log是乱码。
说了这么多,一句话,中文编码问题。如何解决呢?上面的帖子发了半年也没有结,在IDEA官方论坛上也问过,但是因为都是老外,最后还是没有理想的答案。我于几日前得到了Irida版本,发现CVS插件的jar包并没有混淆(4.5版本是混淆的, 要读简直是不可能的),于是进行了反编译(呵呵不要告我),经过分析发现,最终的问题出在org\netbeans\lib\cvsclient\io目录下的AsciiOutputStreamWriter和AsciiInputStreamReader中。经过简单的修改(只要解决过Java的中文编码问题,这个修改不是什么难事),终于把这个问题搞定了!
请于http://www.jroller.com/resources/WarBaby/CvsPatchForIrida.zip下载这个补丁,打开%IDEAHOME%\plugins\cvsIntegration\lib\cvsIntegration.jar,用补丁里的class文件覆盖org\netbeans\lib\cvsclient\io下的同名文件即可。这是Irida的修改方法,4.5版本的稍有不同,这里只点一句,
org\netbeans\lib\cvsclient\io\AsciiOutputStreamWriter.java == org\a\a\a\b\f.java
org\netbeans\lib\cvsclient\io\AsciiInputStreamReader.java == org\a\a\a\b\c.java
请爱好者自己反编译再编译就好了。
修改后,请!不要!选中UTF-8 encoding,上面的问题就完全解决了。对于以前用IDEA提交的中文log,现在是显示乱码的,但是如果选中UTF-8 encoding则和以前的IDEA完全一样。所以请放心使用。
只有一点需要说明一下,我在AsciiInputStreamReader中,为了效率问题,建了几个静态变量,可能会线性不安全。但是我看见IDEA操作CVS的时候,窗口是模态的,无法进行其他操作。万一有问题请自行处理吧。