80
68

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

MarkdownとRe:VIEWで高品質な技術同人誌を書こう

Last updated at Posted at 2019-08-10

ごきげんよう。erukitiです。

皆さん、技術同人誌を書いていますか?

技術同人誌専門の大型イベントとしては年内に残り2つが予定されています。

2019年9月22日(日曜)に池袋で開催される技術書典7と、2019年12月14日(土曜)に人形町で開催される技書博2です。

技術同人誌の執筆には Re:VIEW+TeXLiveか、MarkdownやHTMLとCSS組版などといった組み合わせがよく使われています。

過去にQiitaでも技術書同人誌を書きましょう! - Qiitaという記事や本文212Pの分厚い薄い本の共同執筆を支える技術 - Qiitaという記事を書いたりしましたが、今回、新しく導入した執筆環境について解説します。

筆者も度々Re:VIEW+TeXLiveを使っていますが、2019年7月27日(日曜)に開催された技書博では、Markdown(正確には、Markdown+Re:VIEW+TeXLive)を使って原稿を書きました。

世界の標準言語はMarkdownです。QiitaもはてなブログもGitHubもMarkdownで文書をやりとりできますが、本という形にする場合、Re:VIEW形式に変換するか、未だ不完全で発展途上のCSS組版を使うしかありません。

Re:VIEWを使えばLaTeXを経由してPDFに変換されるため、印刷クォリティは圧倒的に高いです。ただし、MarkdownをRe:VIEW形式に変換しようとしても、Markdown側の機能不足によって、結局Re:VIEWソースを編集せざるを得ません。

そこで開発したのが、GFM(CommonMark)などの拡張記法を使ってRe:VIEWの持つフル機能をそのままMarkdownで記述し、なんならRe:VIEWのソースと混ぜてもかまわないという easybooks というソフトウェアです。

オリジナルの記法ではなく、既存の拡張記法に乗っかった形です。

easybooks

easybooksはTypeScriptで書かれたnpmパッケージです。気が向いたら、Windows/Mac/Linux向けのワンバイナリも提供するかもしれません。

$ yarn add easybooks
$ yarn exec easybooks <設定JSON>

or 

$ npm i easybooks
$ npx easybooks <設定JSON>

で起動可能です。

Dockerを使う場合は、

docker run -t --rm -v $(pwd):/book vvakame/review /bin/bash -ci "cd /book && yarn && yarn build"

で可能です。

.reviewというディレクトリにRe:VIEWでコンパイルするときに必要なファイルが生成(もしくはコピー)されて、コンパイルされてPDFが生成されます。

さて、起動する前に設定ファイルを書く必要があります。この設定ファイルはRe:VIEWでいうconfig.ymlとcatalog.ymlを混ぜ合わせたようなものです。

{
  "bookname": "Onestop-app-dev",
  "booktitle": "Onestopアプリ開発",
  "aut": [],
  "language": "ja",
  "toc": true,
  "rights": "(C) 2019 親方Project",
  "colophon": true,
  "history": [["2019-xx-xx xxxxxx"]],
  "prt": "株式会社 栄光",
  "pbl": "親方Project",
  "edt": "親方Project",
  "secnolevel": 3,
  "titlepage": true,
  "review_version": 3.0,
  "texstyle": ["reviewmacro"],
  "texdocumentclass": [
    "review-jsbook",
    "media=ebook,paper=b5,serial_pagination=true,hiddenfolio=nikko-pc,openany,fontsize=10pt,baselineskip=15.4pt,line_length=40zw,number_of_lines=35,head_space=30mm,headsep=10mm,headheight=5mm,footskip=10mm"
  ],
  "sty_templates": {
    "url": "https://github.com/TechBooster/ReVIEW-Template/archive/2cde584d33e8a6f5e6cf647e62fb6b3123ce4dfa.zip",
    "dir": "ReVIEW-Template-2cde584d33e8a6f5e6cf647e62fb6b3123ce4dfa/articles/sty/"
  },
  "templates": ["images"],
  "catalog": {
    "PREDEF": ["preface.re"],
    "CHAPS": ["chap-placeholder.md", "chap-software-design.md", "chap-ui-design.md"],
    "POSTDEF": ["contributors.re", "postscript.re"]
  }
}

これはちょうど先日リポジトリを作成したワンストップ!アプリケーションを開発しようで使っている設定ファイルです。ちなみにまだリポジトリを作ったばかりでREADMEの修正などもまだですが、執筆者を絶賛募集中です。

booknameからtexdocumentclassまではRe:VIEWのconfig.ymlに書かれている内容です。

sty_templatesは、Re:VIEWで使われるLaTeXのstyマクロのテンプレート指定です(ややこしい)。標準で使われるTechBooster様のReVIEW-TemplateのGitHubでのURLとリビジョンを指定しています。

男気のある人はmasterブランチをそのまま使ってもいいでしょう。ただしその場合は、テンプレートのアップデートの影響を受けてしまうので、URLの指定に関しては注意深く行った方がいいでしょう。

ただTeXは大体難儀なヤツで度々執筆者を悩ませているため、アップデートはなるべくした方がいいので、原稿の余裕があるタイミングでバージョン調査をしておくべきでしょう。

templatesは、Re:VIEWでコンパイルするときに必要なファイルのあるディレクトリを指定します。このディレクトリはそのまま.review内にコピーされるため、参照する画像ファイルやTeXの独自マクロなどをコピーするといいでしょう。

catalogは、Re:VIEWのcatalog.ymlの設定そのままです。ここでは、preface.reというRe:VIEWファイルとchap-placeholder.mdというMarkdownの双方のファイルが指定されています。

.reファイルはそのまま.reviewディレクトリにコピーされ、.mdはMarkdownからRe:VIEW形式に変換されて.reviewディレクトリに吐き出されます。

easybooksにおけるMarkdown記法

ひとまず、https://github.com/onestop-techbook/app-dev/blob/master/chap-easybooks.md をご覧ください。今後、あれこれ追記していく予定です。

Re:VIEWチートシートのeasybooksバージョンについても作成予定です。

どうやって実現しているか?

JavaScriptでMarkdownを操作するときの定番パッケージがremark@types/mdastおよびunifiedです。

unifiedは、テキストをAST(抽象構文木)で扱う汎用的な仕組みで、remarkは、それを使ったMarkdownプラグインです。また@types/mdastremarkで使われているAST表現をTypeScriptの型で定義したものです。

大体のソフトがremarkを使っているため互換性も高く、それなりに安全といえるでしょう。また、様々な拡張表現も利用可能です。

easybooksでは、Re:VIEWのunifiedプラグインを作成して変換をしています。正確には、unifiedのプラグインのうち、Re:VIEWへの書き出しの機能のみを実装したものです。

今回の記事は本を書くのがメインであるため、それ以上の説明は省略しますが、興味のある方は是非 easybooks のリポジトリをご覧ください。

今後の予定

easybooksは、筆者が使う機能を中心に実装しているため、Re:VIEWのフル機能を実装できているわけではありません。最終的にはフル機能対応を予定しています。

また、unifiedのRe:VIEWプラグインのうち、読み込みに関しても対応したいと考えています。

他にも書籍作成で便利な機能をあれこれ考えていますが、ちょうど今は、9月22日の技術書典7に向けて本を書いているところなので、そちらを優先しつつ、様々な機能を実装したいと考えています。

告知

easybooksを使って書いた、Effective React Hooks は、Effective React Hooks - 東京ラビットハウス - BOOTH にて、電子版を頒布中です。

ちなみに一部未完成な部分もあり、アップデート予定です。

技術書典7では、Effective React Hooks 第二版、(間に合えば)TypeScriptでクリーンアーキテクチャ本、を予定しています。

80
68
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
80
68

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?