Rabbit Slide Show

Ruby リファレンスマニュアル改善計画 2022 進捗報告

2023-03-25

Description

[2022 年度 Ruby アソシエーション開発助成](https://www.ruby.or.jp/ja/news/20221027)でやっている「Ruby リファレンスマニュアル改善計画 2022」の進捗の報告と、Ruby リファレンスマニュアルの改善に参加してくれる人の募集をしたいと思っています。

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

Other slides