1879
コメント:
|
5911
|
削除された箇所はこのように表示されます。 | 追加された箇所はこのように表示されます。 |
行 3: | 行 3: |
= 要件 = * 何でもいいから最低限動くものを作ってみる |
= 資料 = == Xlib == 古くから用いられているXクライアント作成用のCのライブラリ。各種言語へのバインディングもある。いい加減古いライブラリなので今は推奨されていない(が、これで書かれているWMはそれなりに存在する) |
行 6: | 行 7: |
= 資料 = == X Window プログラミング == |
とりあえず、カテゴリ別の詳しい仕様は以下のPDFが基本。 |
行 9: | 行 9: |
* Xlibの仕様 * 「プログラミング X Window」 |
書籍もある。 * Xlib Programming Manual Volume One * O'Reillyが動物本シリーズを出し始める前に手がけたものらしい。邦訳なし * 残念ながらX11R5対応の版(1994年)が最新なので、R6以降は要補完。また、各種の拡張についても触れられていない * 大学図書館の洋書架にX11R4対応版がある。あとJEDにもあった気がする(確か禁帯出) * Xlibを用いたプログラミングについて系統的に書かれている本はこれが唯一と言って良い。WMについても一章が割かれており、サンプルコードもある * Volume Twoは単なるXlibのリファレンスなので、上記のPDFで事足りる * どうやら何かのOSの/usr/docなりに入ってたか何かしたようで、何処かの誰かによってそれがそのままWeb上で公開されてたりもする(O'Reilly公式ではない) その他、Xlibについては検索すればそれなりに出てくる。 |
行 13: | 行 20: |
* 「X Window ハンドブック」 == 規格 == |
== XCB(X C Bindings) == Xlibを置き換えることを目的として作られた比較的新しめのライブラリ。Xlibよりダイレクトにプロトコルを扱う感じらしい(Xlibは裏で色々やってるが、XCBはプロトコルとAPIがほぼ一対一対応している)。(適切に使えば)Xlibよりかなりパフォーマンスが良い模様。また、Xlibは設計上マルチスレッド下での使用に問題がある(使えない訳ではない)が、XCBはマルチスレッドでも使える。 * http://xcb.freedesktop.org/ xcbはとにかく資料が少なくて辛い。そもそもlibxcbの実装自体がXMLで記述された仕様から自動生成されているらしいので、分からなかったらXプロトコルの仕様を読めばだいたいOK。 * http://xcb.freedesktop.org/tutorial/ * チュートリアル * http://xcb.freedesktop.org/manual/index.html * doxygenで生成されたドキュメント * http://xcb.freedesktop.org/Publications/ * 各種文書。awesomeをXlibからXCBに移植する話などもある * awesomeの実装 * 有名どころでxcbを使っているのはこれか == 各種規格 == UIについてX自体では規定されていないため、クライアント間通信は規格とは別にICCCMやEWMHで定められた約束事(コンベンション)に則ったものになる。例えば、全く別々のWMとタスクバーが協調動作しうるのは双方が同じ約束に従っているため。 |
行 16: | 行 37: |
* EWMH | * Extended Window Manager Hints(EWMH)。歴史的経緯によりNetWMとも呼ばれ、使用するアトム名などにその名残りが見られる |
行 18: | 行 39: |
* ICCCM。現在では古く適さないものもあるとのこと | * Inter-Client Communication Conventions Manual(ICCCM)。EWMHで上書きされている部分もあることに注意 Xは拡張が多い上に、現在の利用シーンではそれが当たり前となっているようなものが多いので個別に追う必要がある。 |
行 20: | 行 42: |
* XRandRの仕様 == 参考とする実装 == |
* XRandR(動的に画面解像度を設定できるようにするための拡張。マルチディスプレイ拡張で先行するのがXinerama) * http://keithp.com/~keithp/render/Xft.tutorial * Xft(スケーラブルフォントを扱うための拡張)のチュートリアル == 既存のWMに関するメモ == WMのリストは[[http://xwinman.org/|この辺]]とか[[http://en.wikibooks.org/wiki/Guide_to_X11/Window_Managers#Using_X11_Without_a_Window_Manager|この辺]]が掲載数が多くて良い。 |
行 23: | 行 49: |
* タイル型 * ソースが1つしかないのでとっつきやすいが、細かく追おうとすると読みづらい * ソースコードを2000行程度に維持するという原則のためか、コメントも少なめ |
* タイル型。2000行程度ソースが1つしかないのでとっつきやすいが、細かく追おうとすると読みづらい。コメントも少なめ |
行 27: | 行 51: |
* ICCCM/EWMH対応は最低限を抑えているといった感じ | |
行 28: | 行 53: |
* evilという名だがコードはすごく親切で読みやすい | * 名前の割にコードはすごく親切で読みやすい |
行 31: | 行 56: |
* 設定はコマンドラインオプションで | |
行 33: | 行 57: |
* dwmよりさらにコードが短いタイル型 * コーディングスタイルはdwmに似ているが、よりシンプルな作りでコメントも豊富なので読みやすい |
* dwmよりさらにコードが短いタイル型。スタイルはdwmに似ているが、よりシンプルな作りでコメントも豊富なので読みやすい * dwmから色々取っ払って部分的に機能を増した印象。ちゃんと読んでない * openbox * DEの一部になっているWMの中ではおそらく小さい方 * 本体が3万行ほど、さらに周辺のライブラリやツールを加えれば5万行くらいあるか * twm * 古き良き堅牢なWM。設計というかポリシーが古いのは否めない。ルートウィンドウへの枠の描画あたりは参考になるか * X標準のWMなので、「twmがこうしてるから」という強力な言い訳に使える |
行 36: | 行 66: |
* 最小のWM。最低限何をすればいいかが分かる = 廃墟 = * プロトタイプ1: tinywmのデッドコピー * プロトタイプ2: 全画面型 |
* 最小。最低限何をすればいいかが分かる * winman * Xlib Programming Manual Volume Oneに載ってるサンプルコード。twmから色々な機能を除いた感じ? |
ウィンドウマネージャ開発メモ
資料
Xlib
古くから用いられているXクライアント作成用のCのライブラリ。各種言語へのバインディングもある。いい加減古いライブラリなので今は推奨されていない(が、これで書かれているWMはそれなりに存在する)
とりあえず、カテゴリ別の詳しい仕様は以下のPDFが基本。
書籍もある。
- Xlib Programming Manual Volume One
- O'Reillyが動物本シリーズを出し始める前に手がけたものらしい。邦訳なし
残念ながらX11R5対応の版(1994年)が最新なので、R6以降は要補完。また、各種の拡張についても触れられていない
大学図書館の洋書架にX11R4対応版がある。あとJEDにもあった気がする(確か禁帯出)
- Xlibを用いたプログラミングについて系統的に書かれている本はこれが唯一と言って良い。WMについても一章が割かれており、サンプルコードもある
- Volume Twoは単なるXlibのリファレンスなので、上記のPDFで事足りる
- どうやら何かのOSの/usr/docなりに入ってたか何かしたようで、何処かの誰かによってそれがそのままWeb上で公開されてたりもする(O'Reilly公式ではない)
その他、Xlibについては検索すればそれなりに出てくる。
XCB(X C Bindings)
Xlibを置き換えることを目的として作られた比較的新しめのライブラリ。Xlibよりダイレクトにプロトコルを扱う感じらしい(Xlibは裏で色々やってるが、XCBはプロトコルとAPIがほぼ一対一対応している)。(適切に使えば)Xlibよりかなりパフォーマンスが良い模様。また、Xlibは設計上マルチスレッド下での使用に問題がある(使えない訳ではない)が、XCBはマルチスレッドでも使える。
xcbはとにかく資料が少なくて辛い。そもそもlibxcbの実装自体がXMLで記述された仕様から自動生成されているらしいので、分からなかったらXプロトコルの仕様を読めばだいたいOK。
http://xcb.freedesktop.org/tutorial/
- チュートリアル
http://xcb.freedesktop.org/manual/index.html
- doxygenで生成されたドキュメント
http://xcb.freedesktop.org/Publications/
- 各種文書。awesomeをXlibからXCBに移植する話などもある
- awesomeの実装
- 有名どころでxcbを使っているのはこれか
各種規格
UIについてX自体では規定されていないため、クライアント間通信は規格とは別にICCCMやEWMHで定められた約束事(コンベンション)に則ったものになる。例えば、全く別々のWMとタスクバーが協調動作しうるのは双方が同じ約束に従っているため。
http://standards.freedesktop.org/wm-spec/wm-spec-latest.html
- Extended Window Manager Hints(EWMH)。歴史的経緯によりNetWMとも呼ばれ、使用するアトム名などにその名残りが見られる
http://www.x.org/docs/ICCCM/icccm.pdf (pdf)
- Inter-Client Communication Conventions Manual(ICCCM)。EWMHで上書きされている部分もあることに注意
Xは拡張が多い上に、現在の利用シーンではそれが当たり前となっているようなものが多いので個別に追う必要がある。
http://cgit.freedesktop.org/xorg/proto/randrproto/tree/randrproto.txt
- XRandR(動的に画面解像度を設定できるようにするための拡張。マルチディスプレイ拡張で先行するのがXinerama)
http://keithp.com/~keithp/render/Xft.tutorial
- Xft(スケーラブルフォントを扱うための拡張)のチュートリアル
既存のWMに関するメモ
- dwm
- タイル型。2000行程度ソースが1つしかないのでとっつきやすいが、細かく追おうとすると読みづらい。コメントも少なめ
- C99使ってる
- ICCCM/EWMH対応は最低限を抑えているといった感じ
- evilwm
- 名前の割にコードはすごく親切で読みやすい
- EWMH対応が参考になる。ソースファイルが分割されていて(ewmh.c)、対応状況もテキストファイルにまとまっている
- ウィンドウの装飾はないがちゃんとre-parentしている
- monsterwm
- dwmよりさらにコードが短いタイル型。スタイルはdwmに似ているが、よりシンプルな作りでコメントも豊富なので読みやすい
- dwmから色々取っ払って部分的に機能を増した印象。ちゃんと読んでない
- openbox
- DEの一部になっているWMの中ではおそらく小さい方
- 本体が3万行ほど、さらに周辺のライブラリやツールを加えれば5万行くらいあるか
- twm
- 古き良き堅牢なWM。設計というかポリシーが古いのは否めない。ルートウィンドウへの枠の描画あたりは参考になるか
- X標準のWMなので、「twmがこうしてるから」という強力な言い訳に使える
- tinywm
- 最小。最低限何をすればいいかが分かる
- winman
- Xlib Programming Manual Volume Oneに載ってるサンプルコード。twmから色々な機能を除いた感じ?
日記
- clear/wm_devel/2011-08-13
- clear/wm_devel/2011-08-16
- clear/wm_devel/2011-08-23
- clear/wm_devel/2012-01-06
- clear/wm_devel/2012-04-25
- clear/wm_devel/2012-04-27
- clear/wm_devel/2012-04-30
- clear/wm_devel/2012-08-18
- clear/wm_devel/2012-09-05
- clear/wm_devel/2012-10-26
- clear/wm_devel/2012-11-12
- clear/wm_devel/2012-12-11
- clear/wm_devel/2012-12-14
- clear/wm_devel/2012-12-23
- clear/wm_devel/2013-01-11
- clear/wm_devel/2013-01-14
- clear/wm_devel/2013-01-26
- clear/wm_devel/2013-02-09
- clear/wm_devel/2013-02-10
- clear/wm_devel/2013-02-11
- clear/wm_devel/2013-02-18
- clear/wm_devel/2013-02-19
- clear/wm_devel/2013-02-28
- clear/wm_devel/2013-03-02
- clear/wm_devel/2013-03-06
- clear/wm_devel/2013-03-08
- clear/wm_devel/2013-03-12