Text
Page: 1
Ruby リファレンスマニュアル改善計画
2022 進捗報告
Kazuhiro NISHIYAMA
株式会社 Ruby 開発
第 90 回 Ruby 関西 勉強会
2023-03-25
Powered by Rabbit 3.0.1
Page: 2
self.introduction
西山 和広
Ruby のコミッター
twitter, github など: @znz
株式会社 Ruby 開発 www.ruby-dev.jp
1/29
Page: 3
agenda
るりまについて
Ruby リファレンスマニュアル改善計画 2022 について
歴史
目標
2/29
Page: 4
What is rurema (るりま)?
Japanese Ruby reference manual
Rubyリファレンスマニュアル刷新計画
https://github.com/rurema
rurema/doctree
ドキュメント
rurema/bitclust
独自のドキュメントシステム
3/29
Page: 5
るりま != るびま
Rubyist Magazine
https://magazine.rubyist.net/
https://github.com/rubima
似ているけど無関係
FAQより
Q. るびま、って「ネギま!」のぱくりですか?
A. 違います。多分。「るびま」を考えた人たちは「ネギま!」
を知りませんでした ( または、言われるまで気付かなかった ) 。
4/29
Page: 6
Ruby リファレンスマニュアル改善計画
2022 とは ?
Ruby リファレンスマニュアル を Markdown 記法に対応させる計
画
5/29
Page: 7
現状の予定
bitclust に Markdown 対応を追加
doctree でいくつかのドキュメントを Markdown で書いてみる
( 現状は上 2 点の途中 )
問題点をみつけて直しつつ、既存のドキュメントも移行してい
く
RD のドキュメントを削除して bitclust からも RD 対応を削除し
て移行完了
6/29
Page: 8
Markdown 変換の進捗
簡単なサンプルを作成して実現可能性を検証
kramdown-parser-gfm でほぼ RD と同じように変換可能
分割処理を RD から流用
→ code block の中のコメントを見出しと誤認識する問題発生
実現可能性の検証用実装を捨てて Kramdown のパース結果を利
用するように作り直し中
7/29
Page: 9
歴史
なぜこういう状況なのかという歴史の話
8/29
Page: 10
るりまより前
Ruby 1.4.6 以前
https://ftp.ruby-lang.org/pub/ruby/doc/
ドキュメントは RD で書かれていた
English: ruby-man-1.4.6.tar.gz
Japanese: ruby-man-1.4.6-jp.tar.gz
( 中の HTML ファイルは iso-2022-jp なので文字化けに注意 )
Ruby 1.6 から 1.8 の時代
RWiki で編集・公開
RWiki はいくつかの拡張機能つきの RD を使った Wiki
9/29
Page: 11
るりまが始まった頃
Ruby 1.8 時代
Rubyリファレンスマニュアル刷新計画が開始
bitclust という RD ベースの独自記法のシステム
bitclust は RDtool (https://rubygems.org/gems/rdtool) を使っていな
い
RWiki で編集していたドキュメントを取り込んだ
10/29
Page: 12
ドキュメントのライセンス
RWiki の編集フォームにライセンスの変更手順を書いておいた
(freeml の rubyist ML での合意で変更可能とした)
Creative Commons — Attribution 3.0 Unported に変更
https://github.com/rurema/doctree/blob/master/refm/doc/
license.rd
11/29
Page: 13
bitclust 時代になってからの改善点
EUC-JP から UTF-8 に
コードの色付け (#@samplecode)
#@ で始まる行はプリプロセッサ
chm, ePub に出力可能
あまり使われていないので動かない可能性あり
デフォルトは静的 HTML (docs.ruby-lang.org もこれ )
12/29
Page: 14
るりまプロジェクトの現状
ドキュメント改善のサブプロジェクト
Rubyの新しいバージョン対応
https://rurema-review.connpass.com/
13/29
Page: 15
ドキュメント改善ノサブプロジェクト
https://github.com/rurema/doctree/issues/433
コピペ可能なサンプルコードを整備する
サンプルコードの色付け
→ ほとんど完了したからか現在はほぼ停止中
14/29
Page: 16
Rubyの新しいバージョン対応
そこそこ対応
メソッドの変更 ( 追加、引数や機能の変更、削除 )
ほとんど対応できていない
文法の変更 ( パターンマッチ , &., …)
どこに書けばいいのかはっきりしていない
15/29
Page: 17
rurema-review
https://rurema-review.connpass.com/
毎週火曜の夜
るりまレビュー会 → るりまもくもく会
鹿児島 Ruby 会議 01 をきっかけに開始
たくさんの pull request をマージ
→ 現在は活動できている人がいない
16/29
Page: 18
協力者募集
こういう状況なので協力者を増やしたい
GitHub issues や ruby-jp slack の #rurema
https://github.com/rurema/doctree/issues
https://ruby-jp.github.io/
17/29
Page: 19
目標
短期目標
中期目標
長期目標
18/29
Page: 20
RD ベース → Markdown ベース
最重要短期目標
RD より Markdown の方が馴染みがある人が多い
貢献してくれる人が増えるはず
Ruby リファレンスマニュアル改善計画 2022 で作業開始
19/29
Page: 21
現在の記法
#@ はプリプロセッサ要の行
--- は RD の MethodList
#@since 3.1
--- intersect?(other)
-> bool
other と共通の要素が少なくとも1個あれば true を、なければ false を返します。
#@samplecode 例
a = [ 1, 2, 3 ]
b = [ 3, 4, 5 ]
c = [ 5, 6, 7 ]
a.intersect?(b)
a.intersect?(c)
#@end
#@end
# => true
# => false
20/29
Page: 22
プリプロセッサの移行
バージョン分岐や include など
エディタや GitHub.com でのサポートも気にしたい
→ Jekyll でも使われている Liquid を採用
21/29
Page: 23
MethodList
MethodList の代用案
現在の記法は def m(args) ベース
ブロックの書き方は揺れがある
{|x| ... }, {|x| block }, &block
返り値は書いてあるが有効活用はあまりされていない
22/29
Page: 24
MethodList の移行
### def m(args) -> nil 形式
最初は単純に既存の記法を Markdown にするだけ
将来は RBS 形式もサポート予定
23/29
Page: 25
他の記法
#@samplecode → code block
リンク
[[c:String]] → [c:String]
Markdown の記法に合わせて [] が1段減る
細かい問題は臨機応変に対応予定
24/29
Page: 26
他の短期目標と問題
使われていないファイルや古いファイルの削除
ChangeLog, setup.rb, …
tools のファイルがまだ使えるかどうかはっきりしない
使い方のドキュメント不足
これが最重要の課題
再現可能なビルド
container? devcontainer?
25/29
Page: 27
中期目標 ( 他のツールとの連携 )
RBS連携
例 : signatures の連携
IRB連携
rdoc の代わりに rurema を表示したい
26/29
Page: 28
中期目標 ( ドキュメント )
WASMでサンプルコードを実行可能にしたい
hanachin さんが試したものがある https://github.com/hanachin/bitclust/
commit/1ae60bfabd09c0d241e6966a6800e27a797ce175 https://
github.com/rurema/doctree/issues/2730
標準添付から外れたライブラリや古いドキュメントの整理
いくつかは https://github.com/rurema/historical-documents に移動済
27/29
Page: 29
長期目標
I18n 対応
rdoc と ruerema は記法だけに限らず、ドキュメントの書き方が違いすぎて
統一しにくい
gettext か何かを使う?
英語ベースの方が良さそうなので遠い将来の夢になりそう
28/29
Page: 30
end
RD から Markdown への移行開始中
進捗があれば github や slack で報告予定
ご協力よろしくお願いします
Powered by Rabbit 3.0.1
29/29