Sphinxでドキュメントを生成する(PDF編)

Sphinxは、HTMLだけではなく他の形式でも出力可能だ。今回はPDFを生成出来るようにしてみた。

Windowsでの導入方法については下記のエントリが詳しい。

今回はMacで試してみた。動作環境は下記の通り

rst2pdf

% sudo /opt/local/bin/easy_install-2.6 rst2pdf
  • make pdfコマンドを叩いたら、下記のエラーが発生した。
[ERROR] styles.py:308 Error processing font VL-Gothic-Regular: too many values to unpack
% make pdf

画像ファイルも取り込まれているし、相互参照のリンクは有効だし、日本語の表示も問題ない。同じソースを使ってHTMLやPDFなど、異なる出力方法を選べるのは大変便利だ。

しかしながら、PDFの内容を確認してみると下記の問題が見つかった。

writing Foo... [WARNING] basenodehandler.py:163 Unkn. node (self.elemdispatch): sphinxcontrib.blockdiag.blockdiag [near line UNKNOWN in file UNKNOWN]
[WARNING] basenodehandler.py:163 Unkn. node (self.elemdispatch): sphinxcontrib.seqdiag.seqdiag [near line UNKNOWN in file UNKNOWN]
  • 日本語の箇条書きが折り返されない(下記はPDFの画面キャプチャ)。英語の箇条書だと折り返されるので(ハイフネーションの問題は有るけど)、日本語(CJK)特有の問題らしい。rst2pdfのIssueリストには関連する問題が上がっていた。



関連