前几天 @刘鑫-MarchLiu 在微博上发布了一个给给文本加引号的插件:http://weibo.com/1729408273/eDcC8e8w6aD。不过用起来有点小问题:
- 两头都只能插入一个字符,因此不能用于添加 XML 标签;
- 光标控制上有个 bug,每次执行后光标会往左移动一个字符。
我自己刚刚也实现了一下,不过我的实现灵活性比较差(前后的符号必须由用户手工输入,不能以参数形式传递):
(defun wrap-thing (thing)
"Wrap the thing at point.
THING is a symbol which specifies the kind of syntactic entity you want.
Possibilities include `region', `symbol', `list', `sexp', `defun', `filename',
`url', `email', `word', `sentence', `whitespace', `line', `page' and so on."
(interactive)
(let ((range (if (eq thing 'region)
(cons (region-beginning) (region-end))
(bounds-of-thing-at-point thing)))
(wrapper (cons (read-string "Left: ")
(read-string "Right: "))))
(save-excursion
(goto-char (cdr range))
(insert (cdr wrapper))
(goto-char (car range))
(insert (car wrapper)))))
(defmacro make-wrap-for (&rest things)
"A tool for define wrap-region, wrap-word etc."
(let ((exp '()))
(dolist (e things)
(push `(defun ,(intern (concat "wrap-" (symbol-name e))) ()
(interactive)
(wrap-thing (quote ,e))) exp))
(push 'progn exp)))
(make-wrap-for region symbol list sexp defun
filename url email word sentence
whitespace lint page)
(global-set-key (kbd "C-.") 'wrap-region
把上面的代码放到你的 .emacs 文件中,就能用 C-. 来调用了。如果有需要,你还可以再将 wrap-word、wrap-sentence 等绑定到其他键。
2011-08-23
今天重新实现了 make-wrap-for 这个宏,虽然物理行数还多了一行,但我觉得这个实现更优雅:
(defmacro make-wrap-for (&rest things)
"A tool for define wrap-region, wrap-word etc."
`(progn
,@(mapcar
(lambda (e)
`(defun ,(intern (concat "wrap-" (symbol-name e))) ()
(interactive)
(wrap-thing ',e)))
things)))
为方便其他朋友提问和指正,转载是请保持文章完整性,并以超链接形式注明原始作者“redraiment”和主站点地址,谢谢。
我的邮箱,欢迎来信(redraiment@gmail.com)
我的CSDN博客(梦婷轩):http://blog.csdn.net/redraiment
我的百度空间(梦婷轩):http://hi.baidu.com/redraiment