Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up
for free
Introduction of creating Emacs Lisp Package
Syohei YOSHIDA
April 09, 2015
Programming
1
63
Introduction of creating Emacs Lisp Package
Syohei YOSHIDA
April 09, 2015
Tweet
Share
More Decks by Syohei YOSHIDA
See All by Syohei YOSHIDA
syohex
15
8k
syohex
1
230
syohex
0
140
syohex
2
3k
syohex
2
710
syohex
1
430
syohex
0
1.1k
Other Decks in Programming
See All in Programming
bkuhlmann
2
310
rarous
0
170
nkjzm
1
200
danilop
0
230
heistak
2
130
tarugoconf
1
1.6k
boriswilhelms
0
160
grapecity_dev
0
180
korosuke613
2
260
legalforce
PRO
0
640
joergneumann
0
130
raulh82vlc
1
270
Featured
See All Featured
geoffreycrofte
21
930
marktimemedia
7
400
samanthasiow
56
6.4k
myddelton
109
11k
vanstee
117
4.9k
michaelherold
225
8.5k
keathley
20
710
imathis
479
150k
chriscoyier
779
240k
tanoku
86
8.6k
rmw
11
810
lara
590
61k
Transcript
パッケージ作成
はじめに • “info elisp” の Packaging の章を読みましょう
チェック項目 • ヘッダ , フッタは適正か • メタ情報は適切か • 必要最低限の環境でどうさするか •
バイトコンパイル時に警告 , エラーが出ないか
ヘッダ / フッタ • 1 行目は ファイル名 --- 概要 概要は
M-x list-packages Desription カラムに表示 される • 最終行は ;;; ファイル名 ends here
メタ情報 • 作者 • バージョン • 依存関係 • パッケージコメント
必要最低限の環境で動作するか • Cask を使おう (el-get でも可 ) – bundler 的なもの
– 依存関係を記述 • cask exec emacs -Q -l my-package.el としてエラーが出なければ依存関係は適切 ( 特定の関数実行時にロードする場合は除く )
Cask ファイル例 ;; repository (source gnu) (source melpa) ;; read
dependencies from helm-ag.el (package-file "helm-ag.el") (development (depends-on "ert") (depends-on "helm-projectile"))
バイトコンパイル • 変数名 , 関数名の typo の検知 • lexical-binding が有効だと未使用変数も指摘
• deprecated, obsoleted な関数 , 変数の指摘 • バイトコンパイル時も cask exec emacs -Q
名前付け ( 関数 , マクロ , 変数 ) • Emacs
には名前空間が一つしかない – 安易な名前は容易に衝突する • パッケージ名を各名前のプレフィックスに使う • 名前が長くなるが , 補完を使えば耐えられる – 重複するパッケージがないか事前に確認仕様 • melpa, el-get のレシピ名を確認
•遅延ロード対応 • 必要な関数に autoload cookie をつける ;;;###autoload ← 該当する S
式の前に追加する
テスト • テストパッケージは標準 • travis-ci 等の CI サービスの利用も難しくない
Enjoy Emacs Lisp Hacking