この記事では私が個人的にMarkdownよりAsciiDocが好きな理由を述べたいと思います。
定義リストが標準で使える
AsciiDocは言語仕様に定義リストが含まれています。
|
|
これは以下のようなHTMLになります。
|
|
MarkdownでもPandocのMarkdownなどの一部の方言では定義リストが使えますが、オリジナルのMarkdown、CommonMark、GFMなどは非対応なのでこれらではHTMLを直接書く必要があります。
リストのネストをマーカーの個数で表現する
Markdownではリストをネストするときはインデントで表します。
|
|
AsciiDocではリストをネストするときはマーカーの個数で表します。
|
|
インデントを気にしなくていいので、個人的にはAsciiDocの書き方の方が好みです。
他のファイルを取り込める
AsciiDocはinclude
命令で他のファイルを取り込むことができます。
プログラムのソースコードなどのAsciiDoc以外のテキストファイルでも取り込めます。
|
|
この機能は複数のドキュメントに共通の部分を含む場合や、プログラムのソースコードをドキュメントの一部として取り込みたいときに便利です。
Markdownの方が良いところ
普及率
Markdownは普及率が高いからか対応ツールが多く、効率的に綺麗なドキュメントを書けるように思います。
他のフォーマットに綺麗に変換できる
AsciidoctorはAsciiDocを様々なフォーマットに変換できますが、対応していないフォーマットもあります。 そのような場合、PandocはAsciiDocを入力フォーマットとして対応していないので以下のように一度やHTMLに変換する必要があります。
|
|
MarkdownはPandocの対応する入力フォーマットなので以下のようにPandocだけで変換できます。
|
|
個人的にはAsciidoctorとPandocでAsciiDocを任意のフォーマットに変換する場合よりも、PandocだけでMarkdownを任意のフォーマットに変換するときの方がより綺麗に変換できることが多いように思いました。