分类:代码

码农是第一生产力。

迁移到 spacemacs

spacemacs 是 emacs 社区最近比较火的话题,水木上有不少相关讨论。我目前使用的 emacs 配置是几年积累下来的结果,本不想折腾,要迁移过去,想想都麻烦。

禁不住好奇,还是从 github 上下载了安装包试一试,前几次安装并不顺利,没能顺利用起来。有这样几个问题:

  • 提示找不到某个 package。查看了包目录,此包已经下载,但个别文件大小为 0。解决方法是把此包删除,重新启动 emacs 下载安装。
  • 下载包时提示找不到,这是网络问题,挂上 vpn 就行。

解决这两个小问题后,就能用上了。启用有点慢,在我 i5 的 PC 上,大约十多秒。我原来的 emacs 配置启动较快,大约在两秒左右。默认仅加载很少几个包,但使用 orgmode 编辑时,lazy 加载 helm 会比较慢,也需要 6 秒左右。 Spacemacs 优点还是很多的,我觉得这几点做得不错:

  • 快捷键归类不错,提示也很好。快捷键设计成三键式,第一键又叫 leader 键,是空格键。第二键是功能归类键,比如:file 相关的快捷键在 f 键下, buffer 相关的在 b 键下,搜索相关的在 s 键下。第三键是具体功能健,比如删除 buffer 是 d。每次按键后,mini-buffer 中有详细的按键提示,告诉你下一步按什么键是什么对应的功能。基本不用专门记忆,用几次就熟悉了。
  • 即插即用式的安装,多平台支持,方便迁移。在远程 vps 服务器上,下载安装包后,安装 spacemacs-base 就可以使用了。快捷键和基本编辑方式不用重新学习,比 emacs 裸奔强太多了,也不用把自已的配置文件全部搬过来,还没那么多平台差异问题。
  • 最小化个人配置。自带的包配置非常全面,个人只要做些微小的定制修改就能直接使用。版本管理时, .emacs.d 直接使用 github 上 spacemacs 的 develop 分支,不做任何改动。自已的配置修改提交到私人 repo,比起原来 50 多兆的配置文件,这样迷你多了。

目前已经把 orgmode 和 org2blog 配置完成,写博客是没有问题了。c-c++模式也启动了,但还没有详细定制,有时间再看看。

orgmode 导出 html 的换行处理

我之前还奇怪,在 org2blog 中设置保留换行符时,为什么可以正确处理中文的自动换行 ,今天查看了 orgmode 配置,才发现有个 advice

;;;###autoload
(defadvice org-html-paragraph (before fsh-org-html-paragraph-advice
                                      (paragraph contents info) activate)
  "Join consecutive Chinese lines into a single long line without
unwanted space when exporting org-mode to html."
  (let*
      ((orig-contents (ad-get-arg 1))
       (reg-han "[[:multibyte:]]")
       (fixed-contents (replace-regexp-in-string
                        (concat "\\(" reg-han "\\) *\n *\\(" reg-han "\\)")
                        "\\1\\2" orig-contents)))
    (ad-set-arg 1 fixed-contents)))

这段代码是从 水木 emacs 版 抄过来的,作用是修改 html 导出函数 org-html-paragraph 的第一个参数,将两个汉字中间的换行符去掉。

org2blog 的使用

当初建立这个博客就是为了试一试 org2blog ,使用一段时间后,建立了一套使用方法。把所有博客写在文件 blog.org 中,级别 1 用于区分文章,级别 1 标题是文章标题,属性是文章属性。从级别 2 开始,是文章的子标题。下面列出了一些功能点需要花时间配置的。

自动登陆

每次启动 emacs 后,需要执行一次 org2blog/wp-login 命令登陆。登录信息在 emacs 关闭后不会记录,下次启动 emacs 后,还需要再次登录,次数多了会觉得不方便。org2blog 可以通过配置实现自动登陆,具体配置可参考官方网站。

subtree 的 post-and-publish 功能

不知道出于哪方面考虑,org2blog 不提供 subtree 的 post-and-publish 功能,只有 post 接口。在配置文件中加入下面函数,可实现 post-and-publish 功能。

;;;###autoload
(defun org2blog/wp-post-subtree-and-publish ()
  "Publish the current subtree as a page."
  (interactive)
  (org2blog/wp-post-subtree t))

多余窗口处理

每次发布文章后,org2blog 会弹出一个新窗口,可能是临时 buffer,没什么意义,总要手动关闭。下面这段代码可以在发布文章后取消弹出窗口。

(defadvice org2blog/wp-upload-files-replace-urls
    (after fj/org2blog/wp-upload-files-replace-urls (text) activate)
  (delete-window))

换行处理

使用 org2blog 过程中,发现对换行处理不太好:如果将 org2blog/wp-keep-new-lines 设置成 t ,中文换行处理基本没有问题,能识别自动换行还是硬换行,对于自动换行会在转换后连接成一行。而英文处理会有问题,所有的自动换行都被识别成了段硬换行。如果将 org2blog/wp-keep-new-lines 设置成 nil , 中文处理会有问题,列表中后必要的换行会被删除。

麻烦是的, org2blog/wp-keep-new-lines 是全局配置,无法根据一篇文章进行换行调整。我设计了一个解决方法,如果在属性中添加了 ENGLISH 描述,则不保留换行符,适用于英文文章。如果没有这个属性,则保留换行符,适用于中文文章。这需要通过写代码来实现,修改代码的方法不可取,因为库会经常升级,覆盖这些修改。较好的方法是用 defadvice

(defadvice org2blog/wp--parse-subtree-entry
    (before fj/org2blog/wp--parse-subtree-entry () activate)
  (let* ((keep-new-lines (org-entry-get (point) "ENGLISH")))
    (if keep-new-lines
  (setq keep-new-lines nil)
      (setq keep-new-lines org2blog/wp-keep-new-lines))
    (plist-put org2blog/wp-export-options :wp-keep-new-lines keep-new-lines)))

liteide代码分析

结构

主目录

  • api: 接口定义,所有组件通过api相互访问
  • liteide/liteapp: 主程序,构造界面,构造各种manager
  • plugins: 插件,编译成dll,单独加载
  • 3rdparty: 第三方库,编译成静态lib
  • util: 工具类,编译成静态lib

主程序

  • liteapp
    • 包含主界面,对话框
    • 包含各种manager,manager构造函数参数含有liteapp指针
  • manager可以通过m_liteapp->other_manager方式访问其它manager

插件

  • plugin构造函数参数含有liteapp指针,可以通过虚接口访问liteapp所有功能
  • plugin初始化时,自已注册action,用于plugin启动

hexo 博客安装

hexo 基于 node.js,下载安装 node.js 后,用 npm 包管理系统安装 hexo。npm 有很多镜像站点可用,设置一个国内镜像可以提高下载速度。修改文件 D:\nodejs\node_modules\npm\npmrc ,增加一行:

registry = http://npm.cbyun.com/

hexo 的安装使用方法官网有详细说明: http://hexo.io/

部署方法,网上讲得比较多的是 github 部署,如果是个人博客,要用到 rsync 工具。下面是 rsync 配置:

deploy:
  type: rsync
  host: www.hostname.com
  user: username
  root: ~/html/hostname
  port: 22
  delete: true