コードハイライトを楽にする emacs-lisp
また、Emacs の手放せない私としては文章書くとき、ちょっと長い文章であれば Emacs で書いて貼り付けてます。ブログ書くときもいったん html-mode で書いて、ブラウザに貼り付けた後文字の修飾などやって書いています。
Emacs を使っていてめんどくさいことがあればどうするか。もちろん lisp を書きます。
そこで、貼り付けたときに自動で置換してくれる Emacs の lisp を作ったので、紹介します。
設定
後で拡張しやすいように minor mode で機能を作りました。
以下のファイルをダウンロードして、パスの通っているところにおいてください。
ex-html-mode.el
.emacs.el に以下のコードを追加すると html-mode にしたときに ex-html-mode にもなるようになります。
(autoload 'ex-html-mode "ex-html-mode" "Minor mode for html edit" t)
(add-hook 'html-mode-hook 'ex-html-mode)
特に html-mode でなくてもかまわないので、そのときは add-hook で変更して下さい。
使用
ex-html-mode にすると以下のキーで機能を呼び出せます。
- C-c C-y
- コードの貼り付け
- C-c C-q
- 選択領域のクオート
C-c C-y で貼り付けた場合、コードの言語を聞いてくるので指定するとコード指定した <pre> をつけて中身をクオートして貼り付けます。
言語に何も指定しないと pre とクオートのみ行います。
コードハイライトを変える
ex-html-mode のコードの貼り付けはデフォルトでは SHJS 用ですが、変えることも出来ます。
例えば SyntaxHighlighter を使う場合は .emacs.el に以下の行も書いておきます。
(setq ex-html-code-class-alist
'(("c", "cpp") ("cpp", "cpp") ("csharp", "csharp") ("java", "java")
("pascal", "pascal") ("python", "python") ("ruby", "ruby")
("js", "js") ("php", "php") ("css", "css") ("xml", "xml") ("html", "xml")))
(setq ex-html-code-class-format "name=\"code\" class=\"%s\"")
- 関連記事
-
- コードハイライトを楽にする emacs-lisp
- Emacs で何でもハイライト
- ex-html-mode リンク挿入機能追加
- ex-html-mode エスケープ文字やリストなどの入力機能追加
- yafm.el - コンパイル、grep を使いやすくする emacs-lisp
Facebook コメント
コメント