2011年10月31日星期一

为tolua的deb包作一个补丁

近日在学习tolua时发现在Kubuntu 11.10 amd64平台下将其链接到so时报告如下错误:
... relocation R_X86_64_32 against '.rodata' can not be used when making a shared object; recompile with -fPIC

为此,我决定在其原deb基础上加一个补丁,这样生成的新包可以安装到其他开发机器上,省去了每次重编译tolua的重复劳动。


  1. 为构建和修改deb安装必要的工具(配置quilt):
    sudo apt-get install build-essential debhelper quilt


  2. 下载libtolua-dev的源码,创建补丁add-fpic-O2-for-amd64.patch,并将config文件加入其中:
    apt-get source libtolua-dev
    cd tolua-5.1.3
    mkdir -p debian/patches
    quilt new add-fpic-O2-for-amd64.patch
    quilt add config


  3. 将config文件中,如下内容
    CFLAGS= -g $(WARN) $(INC)
    CPPFLAGS= -g $(WARN) $(INC)
    替换为
    CFLAGS= -fPIC -O2 -pipe -g $(WARN) $(INC)
    CPPFLAGS= -fPIC -O2 -pipe  -g $(WARN) $(INC)


  4. 生成补丁add-fpic-O2-for-amd64.patch
    quilt refresh

    为补丁增加描述信息
    quilt header -e

    其具体内容如下:
    Description: Fix relocation R_X86_64_32 against '.rodata' can not be used when making a shared object
    Author: Like Ma <likemartinma@gmail.com>
    
      * config: add -fPIC -O2 -pipe to CFLAGS and CPPFLAGS


  5. 在debian/changelog顶部增加日志信息:
    tolua (5.1.3-2) unstable; urgency=low
    
      * Fix relocation R_X86_64_32 against '.rodata' can not be used when making a shared object
    
    -- Like Ma <likemartinma@gmail.com> Mon, 31 Oct 2011 15:23:09 +0800
    


  6. 构建libtolua-dev_5.1.3-2_amd64.deb:
    dpkg-buildpackage -d -uc -us -rfakeroot

blogger的代码加亮

作为一个程序员,没有代码加亮的世界是多么苍白。在上一篇博客中,我利用vim的代码html转换功能来美化代码部分。这个办法实在太笨了,它花了我不少时间来编辑上一篇博客,以至于让我失去了写博客的兴趣。

最近,我无意中发现了一篇如何利用google-code-prettify来加亮代码的文章——Code highlighting on blogger。该文章并没有讲述不同语言的加亮方法,官方网站的README描述了相关解决办法。

我马上将其应用在前一篇博客中,然而默认效果并不令我满意。由于我长期使用vim的黑底系列的颜色方案,我需要一种类似的代码颜色方案来美化博客。

让人欣喜的是官方网站的themes gallery正好提供了我需要的颜色方案sunburst,这只需要简单将上文提及的
http://google-code-prettify.googlecode.com/svn/trunk/src/prettify.css
替换为
http://google-code-prettify.googlecode.com/svn/trunk/styles/sunburst.css
另外,我还专门为我的博客换了主题,每切换一次主题需要我重新将代码加亮的相关css和js重新手动加上。为此我用sed一个脚本来简化这个过程,具体内容如下:
#!/bin/sed -f

/<\/head>/i \
<link href='http://google-code-prettify.googlecode.com/svn/trunk/styles/sunburst.css' rel='stylesheet' type='text/css'/> \
<script src='http://google-code-prettify.googlecode.com/svn/trunk/src/prettify.js' type='text/javascript'/>

/<body[[:blank:]]/ {
s/>/ onload='prettyPrint()'>/
}
具体的使用办法为:
  1. 在Design页面中,下载当前的template
  2. 利用上述脚本处理下载的template,从而生成新的template
  3. 在Design页面上传新的template