记排查octopress生成时的编码错误

前些日子经若亮童鞋提醒,我在其余推荐的页面中增长了对 Dropbox 和 Linode 等工具的推荐,一来分享这些好用的产品,二来指望刚接触这些工具的好心的朋友能够不吝啬时间用个人推荐码注册,让我得到一些分享的回报。css

改过页面内容后,照常的使用rake preview命令生成预览页面,打开浏览器,获得的倒是一行孤零零的node

Sorry, I can not find /git

rake generate后的结果更悲惨:github

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
biaobiaoqi.github.com git:(source) ✗ rake generate ## Generating Site with Jekyll unchanged sass/screen.scss Configuration from /Users/shenyapeng/Development/biaobiaoqi.github.com/_config.yml Building site: source -> public /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/raw.rb:11:in `gsub': invalid byte sequence in UTF-8 (ArgumentError)  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/raw.rb:11:in `unwrap'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/octopress_filters.rb:18:in `post_filter'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/octopress_filters.rb:33:in `post_render'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/post_filters.rb:124:in `block in post_render'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/post_filters.rb:123:in `each'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/post_filters.rb:123:in `post_render'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/post_filters.rb:151:in `transform'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/convertible.rb:88:in `do_layout'  from /Users/shenyapeng/Development/biaobiaoqi.github.com/plugins/post_filters.rb:167:in `do_layout'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/page.rb:100:in `render'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/site.rb:204:in `block in render'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/site.rb:203:in `each'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/site.rb:203:in `render'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/lib/jekyll/site.rb:41:in `process'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/gems/jekyll-0.12.1/bin/jekyll:264:in `<top (required)>'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/bin/jekyll:23:in `load'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/bin/jekyll:23:in `<main>'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/bin/ruby_executable_hooks:15:in `eval'  from /Users/shenyapeng/.rvm/gems/ruby-1.9.3-p545/bin/ruby_executable_hooks:15:in `<main>’

彷佛是编码的问题:invalid byte sequence in UTF-8,可是我只是修改了普普统统的几行文字而已,怎么会有编码问题呢。chrome

恰逢本身刚由于 SSD 损坏重装了系统,编程环境也是刚刚配好,并且使用 rvm 安装 ruby1.9.3 的时候,提示文字中也有一些 warning。我开始怀疑是否是 ruby1.9.3 没编译好的缘由。编程

设立对照实验,我在另一台 Ubuntu 机器上 clone 下一个博客的 repo,rake generate,结果居然一切顺利。一切彷佛都在说明就是开发环境的问题。vim

我删除了以前的 ruby1.9.3,甚至是 rvm,重装后结果依旧。浏览器

不能在一棵树上吊死,我不科学的将目标从新定位到 markdown 页面中的编码错误上(没想到后来事实证实奏效了……)。sass

在 git 中新开启测试分支,在上面作回滚,测试修改页面内容前源码可否 generateruby

1
2
3
4
5
#>git branch checkError #>git checkout checkError  #>git log #找到修改前的提交码 #>git reset --hard xxx #xxx 为相应的提交码 

而后rake generate居然能成功= =#!,看来真的是修改的页面掺入了错误的编码。

接下来是回到原来的分支上,经过 diff 命令定位错误代码:

1
2
3
4
#>git checkout source #>git branch -d checkError #删除测试分支  #>git diff xxx #xxx 为相应的提交码 

比较结果以下图,果真是有一个奇怪的字符。 img

查了下,这是左至右符号。莫非是从 chrome 浏览器复制地址时,不当心复制了它?

进一步尝试发现,这个字符若是不与)相邻,是不会形成编码问题的。与)相邻时,一旦他们被 markdown 解析后,就出现了这个 bug。

有意思的是,另外一台 Ubuntu 服务器上这个有编码隐患的 repo 时可以正常rake generate的。以下图,左边是 mac 上用 vim 打开包含隐患字符的文件截图,右边是 Ubuntu 上的截图。 img

谁能告诉我理解这一现象的思路呢 ><…

相关文章
相关标签/搜索