您的位置:首页 > 编程语言

vagrant rsync-auto 代码同步失败报错:UndefinedConversionError

2015-03-03 20:46 190 查看
今天使用vagrant ,代码同步:vagrant rsync-auto 发现代码同步失效了,几次重启之后发现启动报错:



有点疑惑,因为1h之前还同步过修改的代码,现在突然报错,目前仍然不明原因(这1h之内没有做过任何编码设置/修改的操作,仍然诡异,留待大神研究吧~)以下直接说重点

报错的原因

vagrant的源码使用Ruby实现的,Ruby 转码的方法:encode 有转码兼容,GBK转码为UTF-8不兼容,所以报错,报错行的源代码:

data << io.readpartial(READ_CHUNK_SIZE).encode(“UTF-8”, Encoding.default_external)

解决方法

思路:将参数用 force_encoding方法 强制转换成UTF-8编码即可

方法:找到报错的目录:C:\HashiCorp\Vagrant\embedded\gems\gems\vagrant-1.7.2\lib\vagrant\util io.rb文件找到line 32,将代码修改为:

data << io.readpartial(READ_CHUNK_SIZE).force_encoding(‘UTF-8’)

然后vagrant reload 没有报错,重启成功,代码同步成功。这是vagrant的一个bug。

说说这里面的曲折过程,最开始发现这个错误以后,我将错误提示:”from GBK to UTF-8”理解成:

要转码为UTF-8必须要求原编码是GBK,所以我改了io.rb中出错的源码成这个样子:

str = io.readpartial(READ_CHUNK_SIZE).force_encoding(‘GBK’) //强制转换为GBK

data << str .encode(“UTF-8”, Encoding.default_external) //将GBK转换为UTF-8

这样还是报错,然后我看到转码的encode有编码兼容,所以使用强制转换的方式转换为UTF-8,果然还是简单粗暴比较好呀~~

附上一句:解决了这个问题我好开心呀,离大神又进了一步~~
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐