Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

パターンマッチのドキュメントを ruby/ruby の rdoc を翻訳する形で追加 #2773

Merged
merged 43 commits into from
May 31, 2024

Conversation

sanfrecce-osaka
Copy link
Contributor

@sanfrecce-osaka sanfrecce-osaka commented Jan 2, 2023

翻訳元の原文

pattern_matching.rd の配置に関して

rurema/doctree の refm/doc/spec 配下と ruby/ruby の doc/syntax 配下が似たようなファイル構成になっているため、 pattern_matching.rd も refm/doc/spec に配置しました
また今後可能なら doc 配下のファイルやクラス・モジュール・ライブラリのヘッドラインに rdoc へのリンクを追加したいと思っていて、その場合にディレクトリ・ファイル構成を ruby/ruby に寄せておくほうが実装しやすいのではという思惑もあります

翻訳の方針

  • 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残しています
  • unpack という単語は Python に「アンパック」という用語があるのでとりあえずそのまま「アンパック」と訳しています
  • パターンの名称にアルファベットが含まれる場合は頭文字大文字で統一しています
  • respond to に関しては「実装もオブジェクト自体が持つ」のと「応答できる」だと意味が異なり、どのように翻訳するか迷ったんですが注記を追加し Object#respond_to? へのリンクを追加することで respond to の意味での『〜を持つ』だということを説明してみました
  • rest に関しては rest parameter の日本語名に合わせて「残余」と訳しました
  • Ruby 3.2 ではおそらくこの節は不要ですがまだ ruby/ruby 側でマージされていないため分岐は入れていません
  • bitclust で利用できないタグや装飾は以下のように置き換えています
    • code タグ => 二重かぎ括弧(『』)
    • _em タグ (イタリック体) => かぎ括弧(「」)
    • + (タイプライター体) => 削除

やっていないこと

  • バージョンごとの差分の反映
    • 一旦このプルリクエストでは対応していません
    • 別途プルリクエストを出すつもりですが、デプロイの際に各バージョンごとの対応が必須ならこのプルリクエスト内で対応します 🙇

挙動確認方法

レビュー時に挙動確認する場合、以下の手順で実行してください

  • bitclust update で利用される BitClust::RRDParser#parse_level1_header が Ruby の定数が前提になっているため doc 配下のファイルに対して利用できない
  • なので bitclust setup でデータベースを更新するしかない
  • ただし、bitclust setup はローカルの rurema/doctree のソースコードを指定できないのでローカルに rurema/bitclust を clone してきて lib/bitclust/subcommands/setup_command.rb を以下のように修正してください
          @update = true
+         @doctreedir = nil
          @parser.banner = "Usage: #{File.basename($0, '.*')} setup [options]"
          @parser.on('--no-update', 'Do not update document repository') {
            @update = false
          }
+         @parser.on('--doctreedir=DOCTREE_DIR_PATH', "doctree's path") {|path|
+           @doctreedir = path
+         }
        def prepare
          home_directory = Pathname(ENV["HOME"]).expand_path
          config_dir = home_directory + ".bitclust"
          config_dir.mkpath
          config_path = config_dir + "config"
-         rubydoc_dir = config_dir + "rubydoc"
+         rubydoc_dir = !!@doctreedir ? Pathname(@doctreedir).expand_path : (config_dir + "rubydoc")
          @config = {

上記の修正は別途 rurema/bitclust にプルリクエストを投げる予定です 🙇

  • 以下の環境変数とオプションを指定して bitclust setup を実行してください
    • 必須: BITCLUST_PATH でローカルに clone してきた bitclust のパス
    • 任意: HOME.bitclust を生成するパス
    • 必須: --doctreedir でデータベース生成の際に使用する doctree のパス
    • 任意: --no-update
      • これを指定しないと git pull --rebase が実行されてしまうため(リモートブランチと差分がないなら指定の必要なし)

実行例

$ BITCLUST_PATH=/Users/XXX/rurema/bitclust HOME=/Users/XXX/rurema/doctree bundle exec bitclust setup --doctreedir=/Users/XXX/rurema/doctree --no-update
  • bitclust staticfile で挙動を確認
    • bitclust htmlfile はタイトルが Ruby の定数でない場合に (uninitialized) になったり目次のリンクのテキストが id での表記になってしまうため doc 配下の修正である今回はおすすめしません 🙏
    • このとき BITCLUST_PATHHOMEbitclust setup で指定したものと同じものを指定してください

実行例

$ BITCLUST_PATH=/Users/XXX/rurema/bitclust HOME=/Users/XXX/rurema/doctree bundle exec bitclust --target=3.1.0 statichtml -o ./output

申し送り事項

ruby-jp でメッセージを頂いた shuichi さんから Suggested Change の形でこのプルリクエストに翻訳修正の提案があるかと思います 🐱

cf. https://ruby-jp.slack.com/archives/CLQUG7B3M/p1672641969966319?thread_ts=1668382164.602709&cid=CLQUG7B3M

### 原文の場所

- pattern_matching.rd
  - cf. https://github.com/ruby/ruby/blob/v3_2_0/doc/syntax/pattern_matching.rdoc
- control.rd
  - cf. ruby/ruby@281b350

### pattern_matching.rd の配置に関して

## pattern_matching.rd の配置に関して

rurema/doctree の `refm/doc/spec` 配下と ruby/ruby の `doc/syntax` 配下が似たようなファイル構成になっているため、 pattern_matching.rd も `refm/doc/spec` に配置した
また今後可能なら doc 配下のファイルやクラス・モジュール・ライブラリのヘッドラインに rdoc へのリンクを追加したいと思っているが、その場合にディレクトリ・ファイル構成を ruby/ruby に寄せておくほうが実装しやすいのではという思惑もある
素の rdoc と bitclust の文法の違いを反映するため

- サンプルコード・整形済みテキストの行頭の余分なインデントを削除
- 箇条書きのスタイルを適用するためインデントを追加
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- unpack は Python に「アンパック」という用語があるのでとりあえずそのまま「アンパック」と訳している
  - cf. https://docs.python.org/ja/3/tutorial/datastructures.html#tuples-and-sequences
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- パターンの名称にアルファベットが含まれる場合は頭文字大文字で統一している
- respond to に関しては「実装もオブジェクト自体が持つ」のと「応答できる」だと意味が異なり、どのように翻訳するか迷ったが注記を追加し Object#respond_to? へのリンクを追加することで respond to の意味での『〜を持つ』だということを説明した
- rest に関しては rest parameter の日本語名に合わせて「残余」と訳した
  - cf. https://secret-garden.hatenablog.com/entry/2022/03/11/210246
  - ただ「残余」とだけ書かれていても分かりづらいため、カッコつきで rest も併記してみた
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- パターンの名称にアルファベットが含まれる場合は頭文字大文字で統一している
- rest に関しては rest parameter の日本語名に合わせて「残余」と訳した
  - cf. https://secret-garden.hatenablog.com/entry/2022/03/11/210246
  - ただ「残余」とだけ書かれていても分かりづらいため、カッコつきで rest も併記してみた
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
…のマッチング) を翻訳

- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- パターンの名称にアルファベットが含まれる場合は頭文字大文字で統一している
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- Ruby 3.2 ではおそらくこの節は不要だがまだ ruby/ruby 側でマージされていないため分岐は入れていない
  - cf. ruby/ruby#7052
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
- 翻訳する際、原文は対応箇所を把握しやすくするため bitclust のコメント機能を使って残している
素の rdoc と bitclust の文法の違いを反映するため
素の rdoc と bitclust の文法の違いを反映するため
- 見出しレベル2だと見た目の主張が強すぎるため
- 他のドキュメントでも見出しレベル2を飛ばして見出しレベル3を利用するケースが多そうだった
  - cf. https://github.com/rurema/doctree/blob/a770b9a74b1e8d1e0918e97fc390f9ae00cfec19/refm/doc/spec/control.rd
  - https://github.com/rurema/doctree/blob/a770b9a74b1e8d1e0918e97fc390f9ae00cfec19/refm/doc/spec/def.rd
@shu-i-chi
Copy link

shu-i-chi commented Jan 4, 2023

@sanfrecce-osaka ありがとうございます!

幾つかの観点でsugesstionさせていただきたいのですが、まずは、議論したいところについて投稿します。
方針が決まったら、それに沿ったsuggestionを投げさせていただきたいです。

議論したいこと

「翻訳の方針」に記載いただいた項目に関して

  1. respond to foobarのような部分は、「foobar メソッドを持つオブジェクト」「オブジェクトに foobar メソッドを定義する」と直接的に表現するのはどうだろうか(そして注釈を削除し、respond toの香りを無くす)

    • respond toをあまり大事にする必要がないと思うため:
      • トレイトやインターフェイスのないRubyでは、ダックタイピング的に実装することになるが、そこまでくると、直接的に「メソッドを持つ」でいいと感じる
      • ココをうまく使いこなすのに、内部の挙動であるObject#respond_to?まで踏み込んで理解する必要性は薄く(個人的見解)、却って(初心者寄りの読者は特に)混乱を招きそう
  2. rest(**)の日本語訳は、もう少しわかりやすい用語を検討してもいいかもしれない

その他

  1. 未定義の用語である、カタカナ「サブパターン」は避けたい

    原文中で『sub-pattern』としているところは、具体的にArrayパターン、Findパターン、Hashパターンの構文で指定されている<subpattern>の場所そのものを指していると思われるが、これをどう翻訳するか。
    具体的には、プルリクファイル「refm/doc/spec/pattern_matching.rd」の312, 393, 506行目らへんなど。

    私の、この「<subpattern>の場所そのものを指していると思われる」が正しいと仮定して...

    • カタカナで『サブパターン』とすると、原文と違い、字面が別物なので「パターン構文のあの場所に相当するところかぁ」という気持ちにならない。説明なく現れて消える用語になってしまい、混乱するので、使用を避けたい
    • 文脈的に、「構文部分の<subpattern>のことだね、ウンウン」を意識する必要性自体は薄そう(「まあ、マッチに使うパターンの部分のことやろ」と察せられる)
    • 変更案(例)
      • いっそ、全部バッサリ「パターン(部分)」などにしてしまう
      • 丁寧に...312, 393行目は本文中で余裕もあるので、「サブパターン(Array/Find/Hashパターン構文の<subpattern>の部分)」とし、506行目はコードコメントなので「パターン」にする
  2. 用語『束縛』に対しては、「(Rubyでは)代入と読み替えていいよ」という注釈をつけるか、いっそ『代入』に書き換えるか、をした方が親切に思う

    • 個人的には、パターンマッチの文脈で他の言語に触れた際の『束縛』に橋渡しできるので、注釈を一発入れて『束縛』という用語は残していいかも
  3. 『unpack』は、わかりやすい日本語をひねり出せたら嬉しい

    • 例えば、「値を取り出す(unpacking)」など...?(あまり深く考えてないです)

@shu-i-chi
Copy link

shu-i-chi commented Jan 5, 2023

次に、その他の変更提案を投稿します。それぞれについて、この後suggestionをそれぞれあらかじめ投げます。もし問題ないと感じるものであれば、それぞれacceptいただけますと幸いです。

その他変更提案

るりまの他のページに表現をあわせる

  1. FooBarErrorがraiseされる -> 例外FooBarErrorが発生する
  2. カッコ -> 括弧
  3. key -> キー(ハッシュの文脈で)
  4. マッチング -> マッチ

Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(うまくコレ消せません、ごめんなさい)

Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

るりまの他のページに表現をあわせる

  1. FooBarErrorがraiseされる -> 例外FooBarErrorが発生する

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

るりまの他のページに表現をあわせる

  1. カッコ -> 括弧

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

るりまの他のページに表現をあわせる

  1. key -> キー(ハッシュの文脈で)

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

るりまの他のページに表現をあわせる

  1. マッチング -> マッチ

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
@shu-i-chi
Copy link

shu-i-chi commented Jan 5, 2023

@sanfrecce-osaka さん
残り、

  • コードコメント部分の全体的な変更提案
  • 訳がないところへの提案
    • コードコメント部分
    • 本文 -> 対象なし
  • ここはこういう意味ではないでしょうか提案
    • コードコメント部分
    • 本文
  • 日本語こうしたほうがわかりやすいのではないか、どうでしょうか提案
  • ここは原文にプラスしてこう補足したいです提案
    • コードコメント部分
    • 本文

があるのですが、ここまでの「議論したいこと」「その他変更提案」とダブる箇所も一部ある=suggestionがコンフリクトしちゃう?ため、まだ投下しません。
一旦、ここまでのsuggestionをご確認いただきたいです!(既存提案の処遇決定後に、残りを投下していくつもりです。)

Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

コードコメント部分の翻訳について、変更提案を投稿します。もし問題ないと感じるものであれば、それぞれacceptいただけますと幸いです。

コードコメント部分

翻訳の方針

  • 短さのために、常体(not 丁寧語)に
  • 能動態を中心に使う
  • ~が出力されます -> ~と出力

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

もし問題ないと感じるものであれば、それぞれacceptいただけますと幸いです。

原文の解釈に関する変更

「ここはこういう意味じゃないかしら」と思ったところに関する、変更提案です。
念のため:私の解釈が誤っている可能性もあります。

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
===[a:variable_pinning] 変数のピン留め

#@# Due to the variable binding feature, existing local variable can not be straightforwardly used as a sub-pattern:
変数の束縛の機能では存在しているローカル変数をサブパターンとしてそのまま利用することはできません。

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

「変数の束縛の機能」の話ではなく、「変数の束縛の機能の存在のせいで、制限が生まれる」という話だと思われます。

そもそも原文(Due to the variable binding feature, ...)に対して、あんまり親切とは言えない・無くなっても困らないレベルの中途半端な言及の仕方だなぁと感じているので、変更案では、ちょっと手厚めにしています。

Suggested change
変数の束縛の機能では存在しているローカル変数をサブパターンとしてそのまま利用することはできません。
既に存在しているローカル変数は、サブパターンとして変数の値をそのまま使うことができません。(これは、変数への束縛の機能を実現するための制限です。)

Copy link
Contributor Author

@sanfrecce-osaka sanfrecce-osaka Feb 4, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

修正案は approve なんですが ed29996 で該当行を修正していて Outdated になっているので別途 f924b97 で対応しました 🙏

#@end

#@# +keys+ are passed to +deconstruct_keys+ to provide a room for optimization in the matched class: if calculating a full hash representation is expensive, one may calculate only the necessary subhash. When the <code>**rest</code> pattern is used, +nil+ is passed as a +keys+ value:
keys はマッチしたクラスの中で最適化の余地を残して deconstruct_keys へと渡されます。もし全てのハッシュの表現の計算に高い負荷がかかる場合、必要なサブハッシュのみ計算されるかもしれません。『**rest』 パターンが使われている場合、keys の値として nil が渡されます。
Copy link

@shu-i-chi shu-i-chi Jan 6, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
keys はマッチしたクラスの中で最適化の余地を残して deconstruct_keys へと渡されます。もし全てのハッシュの表現の計算に高い負荷がかかる場合、必要なサブハッシュのみ計算されるかもしれません。『**rest』 パターンが使われている場合、keys の値として nil が渡されます
deconstruct_keys メソッドに引数 keys を渡すのは、マッチを行うクラスの実装側に最適化の余地を残すためです。もし、ハッシュのすべての要素を計算するのが重い処理になる場合には、keys で指定された、マッチに必要になる部分のみを計算するように実装しても良いでしょう
**rest』 パターンが使われた場合には、keys の値として nil が渡されます。

(しれっと改行を入れています。原文にも改行があったほうがいいと思う)

Copy link
Contributor Author

@sanfrecce-osaka sanfrecce-osaka Feb 4, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

訳は approve なんですが bitclust の仕様上段落内の改行は取り除かれてしまうため、改行したい場合は空行を挟む必要がありますね 😺

deconstruct_keys メソッドに引数 keys を渡すのは、マッチを行うクラスの実装側に最適化の余地を残すためです。もし、ハッシュのすべての要素を計算するのが重い処理になる場合には、keys で指定された、マッチに必要になる部分のみを計算するように実装しても良いでしょう。

『**rest』 パターンが使われた場合には、keys の値として nil が渡されます。

cf. https://github.com/rurema/doctree/wiki/ReferenceManualFormatDigest#%E6%96%87%E7%AB%A0%E3%81%AE%E6%9B%B8%E3%81%8D%E6%96%B9

こちらは別途 c6bc5e0 で対応しました 🙏

refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
refm/doc/spec/pattern_matching.rd Outdated Show resolved Hide resolved
Copy link

@shu-i-chi shu-i-chi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

「議論したいこと」にごちゃごちゃ書いたことがわかりやすいように、変更提案の形で具体的なイメージを共有させてください。
(一応、もし『これでいいや』という場合は、そのままacceptいただいても問題ありません)

議論したいことに関する変更提案

1. respond to

respond to foobarのような部分は、「foobar メソッドを持つオブジェクト」「オブジェクトに foobar メソッドを定義する」と直接的に表現する&注釈を削除し、respond toの香りを無くす

の実装例です。

Array/Find/Hash パターンの中に 『<subpattern>』 と書かれている場所では任意のパターンをネストさせることができます。

#@# Array patterns and find patterns match arrays, or objects that respond to +deconstruct+ (see below about the latter).
Array パターン と Find パターン は配列か deconstruct を持つオブジェクトにマッチします。(deconstruct については後ほど説明します)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Array パターン と Find パターン は配列か deconstruct を持つオブジェクトにマッチします。(deconstruct については後ほど説明します)
Array パターン と Find パターン は、配列か、deconstruct メソッド(後述)を持つオブジェクトにマッチします。

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

b00f3fcb00f3fc で対応しました 😺

Array パターン と Find パターン は配列か deconstruct を持つオブジェクトにマッチします。(deconstruct については後ほど説明します)

#@# Hash patterns match hashes, or objects that respond to +deconstruct_keys+ (see below about the latter). Note that only symbol keys are supported for hash patterns.
Hash パターン はハッシュか deconstruct_keys を持つオブジェクトにマッチします。(deconstruct_keys については後ほど説明します) Hash パターン で利用できるキーはシンボルのみです。

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Hash パターン はハッシュか deconstruct_keys を持つオブジェクトにマッチします。(deconstruct_keys については後ほど説明します) Hash パターン で利用できるキーはシンボルのみです
Hashパターンは、ハッシュか、deconstruct_keys メソッド(後述)を持つオブジェクトにマッチします。Hash パターン で利用できるキーは、シンボルのみです

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

b00f3fc7bffd47 で対応しました 😺

Comment on lines 117 to 118
#@# 原文にないが補足のため追加
※ deconstruct や deconstruct_keys を扱う際の『〜を持つ』の定義は [[m:Object#respond_to?]] と同様です。

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#@# 原文にないが補足のため追加
deconstructdeconstruct_keys を扱う際の『〜を持つ』の定義は [[m:Object#respond_to?]] と同様です。

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

b00f3fc で対応しました 😺

#@end

#@# == Matching non-primitive objects: +deconstruct+ and +deconstruct_keys+
===[a:matching_non_primitive_objects] プリミティブなオブジェクト以外とのマッチ: deconstruct と deconstruct_keys

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
===[a:matching_non_primitive_objects] プリミティブなオブジェクト以外とのマッチ: deconstruct deconstruct_keys
===[a:matching_non_primitive_objects] 非プリミティブなオブジェクトのマッチ: deconstruct メソッドと deconstruct_keys メソッド

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

7a533e0d04656c で対応しました 😺

===[a:matching_non_primitive_objects] プリミティブなオブジェクト以外とのマッチ: deconstruct と deconstruct_keys

#@# As already mentioned above, array, find, and hash patterns besides literal arrays and hashes will try to match any object implementing +deconstruct+ (for array/find patterns) or +deconstruct_keys+ (for hash patterns).
既に先述されている通り、配列リテラルやハッシュリテラルの他に Array, Find, Hash パターンは deconstruct (これは Array/Find パターンで利用されます) か deconstruct_keys (これは Hash パターンで利用されます) が実装されたオブジェクトにマッチします。

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
既に先述されている通り、配列リテラルやハッシュリテラルの他に Array, Find, Hash パターンは deconstruct (これは Array/Find パターンで利用されます) か deconstruct_keys (これは Hash パターンで利用されます) が実装されたオブジェクトにマッチします
既に述べたように、Array/Find/Hash パターンは、配列やハッシュのリテラルの他に、deconstruct メソッド(Array/Find パターン)あるいは deconstruct_keys メソッド(Hash パターン)を定義しているオブジェクトに対しても、マッチを試みます

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

7a533e03702378 で対応しました 😺

#@end

#@# Number of +deconstruct+, +deconstruct_keys+ method calls:
#@samplecode deconstruct や deconstruct_keys が呼び出された回数

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#@samplecode deconstruct deconstruct_keys が呼び出された回数
#@samplecode deconstruct メソッドや deconstruct_keys メソッドが呼び出された回数

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

7a533e0 で対応しました 😺

@shu-i-chi
Copy link

shu-i-chi commented Jan 6, 2023

「こいつ、いつまで変更提案出してくるんだ...」と感じられると思うので、進捗チェック表をここに共有させてください。

変更提案進捗

  • コードコメント部分の全体的な変更提案
  • 訳がないところへの提案
    • コードコメント部分
    • 本文 -> 対象なし
  • ここはこういう意味ではないでしょうか提案
    • コードコメント部分
    • 本文
  • 日本語こうしたほうがわかりやすいのではないか、どうでしょうか提案
  • ここは原文にプラスしてこう補足したいです提案
    • コードコメント部分
    • 本文

議論したいこと

  • 1. respond to foobarの表現について
    「foobar メソッドを持つオブジェクト」「オブジェクトに foobar メソッドを定義する」と直接的に表現&注釈を削除し、respond toの香りを無くしてはどうか

    • どうするか
    • 変更提案(する場合)
  • 2. rest(**)の、、もっとわかりやすい日本語訳はないかしら

    • 検討結果
    • 変更提案(する場合)
  • 3. 未定義の用語である、カタカナ「サブパターン」は避けたい

    • 検討結果
    • 変更提案(する場合)
  • 4. 用語『束縛』に対しては、「(Rubyでは)代入と読み替えていいよ」という注釈をつけるか、いっそ『代入』に書き換えるか

    • 検討結果
    • 変更提案(する場合)
  • 5. 『unpack』は、わかりやすい日本語をひねり出せたら嬉しい

    • 検討結果
    • 変更提案(する場合)

config = {db: {user: 'admin', password: 'abc123'}}

#@# config => {db: {user:}} # will raise if the config's structure is unexpected
config => {db: {user:}} # config の構造が予期しないものだった場合は例外が発生します
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

CIが落ちている原因がこの行にありそうです。

samplecode ではるりまが対応しているRubyのバージョンでSyntaxErrorになるような構文が書けなかったと思います。現在はRuby 2.7 ~ 3.3 が対応バージョンなので、2.7でSyntaxErrorになって落ちてそうです。
samplecode ではなく //emlist{ ... } を使うか、3.0以上の分岐を入れるかが必要そうです。

$ docker run -it --rm rubylang/all-ruby ./all-ruby -e "config = {db: {user: 'admin', password: 'abc123'}}; config => {db: {user:}}"

(snip)

ruby-2.7.0-preview1   -e:1: syntax error, unexpected =>, expecting end-of-input
                      ...password: 'abc123'}}; config => {db: {user:}}
                      ...                             ^~
                  exit 1
ruby-2.7.0-preview2   -e:1: syntax error, unexpected =>, expecting end-of-input
                      ...password: 'abc123'}}; config => {db: {user:}}
                      ...                             ^~
                  exit 1
...
ruby-2.7.7            -e:1: syntax error, unexpected =>, expecting end-of-input
                      ...password: 'abc123'}}; config => {db: {user:}}
                      ...                             ^~
                  exit 1
ruby-3.0.0-preview1   -e:1: syntax error, unexpected '}'
                      ...c123'}}; config => {db: {user:}}
                      ...                              ^
                  exit 1
ruby-3.0.0-preview2   -e:1: warning: One-line pattern matching is experimental, and the behavior may change in future versions of Ruby!
...
ruby-3.0.5            -e:1: warning: One-line pattern matching is experimental, and the behavior may change in future versions of Ruby!
ruby-3.1.0-preview1
...
ruby-3.2.0

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ima1zumi

ありがとうございます〜 🙏
実は原因は自分の方でも把握していてローカルで対応しているところでした 😺 (反応遅くなってすみません 😹 )
ただ、分岐が入ると訳のレビューがやりづらいと思われるため先に最新の状態のみでレビューしてもらっています 🙏

@sanfrecce-osaka
Copy link
Contributor Author

@shu-i-chi

大変遅くなりました 🙏
先に 議論したいこと に対して返信します 🐶

  1. respond_to に関して

提案いただいた方針で修正しようと思います 🚀

  1. rest に関して
  1. rest(**)の日本語訳は、もう少しわかりやすい用語を検討してもいいかもしれない

rest変数 という案をいただいたんですが、以下のようにパターンとしてはマッチさせるけど変数への束縛は行わないケースもあるので 変数 といっていいのかは迷いがあります 🐈
restパターン とかはありかと一瞬思ったんですが公式(rdoc) に「パターン」として記載されていないものをパターンと呼称するのはどうなのかという気もしていてまだ回答は出てないです 🙏

case { a: 1, b: 2 }
in { a:, ** } then p a # この節にマッチする
in { a:, b: } then p a, b
end
# => 1
  1. サブパターンに関して

提案いただいた方針で修正しようと思います 🚀

  1. 束縛に関して

「(Rubyでは)代入と読み替えていいよ」

とあるんですがこれは

「(Rubyでは 値の束縛といいつつ再代入ができるので )代入と読み替えていいよ」

という解釈で合っていますか? 👀

  1. unpack に関して

今のところ他に思い浮かばず提案頂いた「値を取り出す」がいいかなぁと思いつつ、もう少し考えさせてください 🙏

Co-authored-by: shuichi <[email protected]>

cf. rurema#2773 (review)

- 短さのために、常体(not 丁寧語)に
- 能動態を中心に使う
- ~が出力されます -> ~と出力
Co-authored-by: shuichi <[email protected]>

cf. rurema#2773 (comment)

> 『**nil』 を指定する方法以外はないので
>
> 元々の翻訳いただいた文章を活かす場合、
>
> > また、パターンで明示的に指定されたキー以外にキーが存在しないケースにマッチングさせたい場合**のために**、『**nil』 を指定する方法もあります。」
>
> のようにできると思いますが、ここは原文の文体を維持するよりも、「こういうときは、こうする」という書き方に寄せています。
Co-authored-by: shuichi <[email protected]>

cf. rurema#2773 (comment)

> 「変数の束縛の機能」の話ではなく、「変数の束縛の機能の存在のせいで、制限が生まれる」という話だと思われます。
>
> そもそも原文(Due to the variable binding feature, ...)に対して、あんまり親切とは言えない・無くなっても困らないレベルの中途半端な言及の仕方だなぁと感じているので、変更案では、ちょっと手厚めにしています。
@shu-i-chi
Copy link

@sanfrecce-osaka ご回答いただきありがとうございます🙏

議論したいところに書かせていただいたところのうち、残っているところについて返信させていただきます:

2. rest

2-1. 議論対象の整理

ここ、改めて見直して気づいたのですが、議論の対象は「**」のみではなく、正確には:

  • Arrayパターンにおける*
  • Hashパターンにおける**

でした...すみません💦

(原文の該当箇所――プルリクのファイルですと183行目辺り――を引用します)

Both array and hash patterns support "rest" specification:

  case [1, 2, 3]
  in [Integer, *]
    "matched"
  else
    "not matched"
  end
  #=> "matched"

  case {a: 1, b: 2, c: 3}
  in {a: Integer, **}
    "matched"
  else
    "not matched"
  end
  #=> "matched"

2-2. 「rest変数」の訳語提案について

Findパターンの構文のところに揃えたのでした

「rest変数」の訳語ですが、これは、「パターン」項の一番最初の、パターンの種類&構文の箇条書きをしているところで、以下のようにFindパターンの構文中に「*variable」という語があり、この "variable" との兼ね合いの提案なのでした(忘れてました...)。

(原文の該当箇所――プルリクのファイルですと99, 100行目辺り――を引用します)

find pattern: <code>[*variable, <subpattern>, <subpattern>, <subpattern>, ..., *variable]</code>; (<em>Find pattern</em>)

(ここの部分、仮に『rest変数』を使うとなった場合、「*(rest変数)」というsuggestionをするつもりでした。)

「変数」と呼んで良いのか

...以下のようにパターンとしてはマッチさせるけど変数への束縛は行わないケースもあるので 変数 といっていいのかは迷いがあります 🐈
...

case { a: 1, b: 2 }
in { a:, ** } then p a # この節にマッチする
in { a:, b: } then p a, b
end
# => 1

こちらですが、束縛自体は行っていて、その値の利用をしていないだけ...だと思っています。

そして、束縛した値を利用したい場合は、「名前付きrest変数」のようなことをすれば良い、というのが、プルリクファイルの335行目辺りで説明されている、という流れだと思っています。

(該当行の原文を引用)

The "rest" part of a pattern also can be bound to a variable:

  case [1, 2, 3]
  in a, *rest
    "matched: #{a}, #{rest}"
  else
    "not matched"
  end
  #=> "matched: 1, [2, 3]"

  case {a: 1, b: 2, c: 3}
  in a:, **rest
    "matched: #{a}, #{rest}"
  else
    "not matched"
  end
  #=> "matched: 1, {:b=>2, :c=>3}"

束縛した値を再利用できないなら、「変数」呼ばわりはどうなの(『名前付きrest変数』と呼んだものがそれじゃないの)、というのはあります...が、このあと4. 用語『束縛』についてでも言及するように、関数型言語のimmutableな変数(的なもの)を背景とした用語・表現を忠実に守るよりかは、「Ruby風の」言い換えとして、思い切って「変数」呼ばわりしちゃっていいんじゃないかなと思っています。

(全然ずれたことを言っていたらすみません💦)

Findパターンの*variableと同じものなのそもそも?

(一応言及)本文中では、Arrayパターンの*とHashパターンの**を中心に説明されていますが、Findパターンでも以下のように、同様の動作をする(前後の値を束縛して、かつ名前を付けると利用できる)ことが確認できます:

case ["a", 1, "b", "c", 2]
in [*foo, String, String, *bar]
  puts "foo: #{foo}, bar: #{bar}"
else
  puts "not matched"
end
#=> foo: ["a", 1], bar: [2]

2-3. 訳語「restパターン」について

restパターン とかはありかと一瞬思ったんですが公式(rdoc) に「パターン」として記載されていないものをパターンと呼称するのはどうなのかという気もしていてまだ回答は出てないです 🙏

@sanfrecce-osaka さんと同じ理由で、私も「restパターン」は避けたほうがいいかなと感じます。

(念のため)プルリクファイル528行目で次のようなsuggestionを以前出させていただいて、取り込んでいただいています:

『**rest』 パターンが使われた場合には、keys の値として nil が渡されます。

が、ここに関してはdeconstruct_keysメソッドの引数keysの動きの話をしている文脈で、コード例も直後にあり、「やや、新しいパターンかい?」という誤解は生みづらいかなぁと思っています。

4. 用語『束縛』について

「(Rubyでは)代入と読み替えていいよ」

とあるんですがこれは

「(Rubyでは 値の束縛といいつつ再代入ができるので )代入と読み替えていいよ」

という解釈で合っていますか? 👀

そう...なのですが、私の大元の意図の記載について言及し忘れておりまして、このパターンマッチのドキュメントは、「特に他のプログラミング言語の知識がないRubyユーザが読んでも理解できるドキュメント」であるべきかなぁと考えておりました。

となったときに、「関数型言語のimmutableな変数(らしきもの)に代入(らしきことをする)動作」と詳しく対応させる&そのためにそれらの言語を知る必要性を、前提に置くことなしに、読めてほしいなと思います。

また、Rubyに置き換える際には、言語の仕組みが違うので、正確に1対1の用語の射影はできない=いわゆる妥協をする必要があると思っています。

...ということを込めて、

「『束縛』は、パターンマッチの輸入元である関数型言語なんかの用語で、ここでも使っているんだけども、(Rubyでは)代入と読み替えていいよ」

というのは、

「『束縛』は、パターンマッチの輸入元である関数型言語なんかの用語で、ここでも使っているんだけども、(ここで『束縛』って初耳です、なぁにそれ、という方々、細かいことは考えなくていい!)『束縛』は(Rubyでは)代入と読み替えていいよ (勿論、ホントは関数型言語における『束縛』との比較などの細かい話はあるけれども、だ)

みたいな意味合いでした...😅

(私の場合、Lispや不慣れなHaskellの知識ぐらいしかないので、ここで言っていることが頓珍漢な可能性があります;Lispは『関数型言語』の文脈で出すべきかはアレですが)

5. unpack に関して

今のところ他に思い浮かばず提案頂いた「値を取り出す」がいいかなぁと思いつつ、もう少し考えさせてください 🙏

私も、まだいい表現が思い浮かんでおりません......

Co-authored-by: shuichi <[email protected]>

cf. rurema#2773 (comment)

> 4. 用語『束縛』に対しては、「(Rubyでは)代入と読み替えていいよ」という注釈をつけるか、いっそ『代入』に書き換えるか、をした方が親切に思う
>   - 個人的には、パターンマッチの文脈で他の言語に触れた際の『束縛』に橋渡しできるので、注釈を一発入れて『束縛』という用語は残していいかも

cf. rurema#2773 (comment)

> ## 4. 用語『束縛』について
> > > 「(Rubyでは)代入と読み替えていいよ」
> >
> >
> > とあるんですがこれは
> > > 「(Rubyでは 値の束縛といいつつ再代入ができるので )代入と読み替えていいよ」
> >
> >
> > という解釈で合っていますか? 👀
>
> そう...なのですが、私の大元の意図の記載について言及し忘れておりまして、このパターンマッチのドキュメントは、「特に他のプログラミング言語の知識がないRubyユーザが読んでも理解できるドキュメント」であるべきかなぁと考えておりました。
>
> となったときに、「関数型言語のimmutableな変数(らしきもの)に代入(らしきことをする)動作」と詳しく対応させる&そのためにそれらの言語を知る必要性を、前提に置くことなしに、読めてほしいなと思います。
>
> また、Rubyに置き換える際には、言語の仕組みが違うので、正確に1対1の用語の射影はできない=いわゆる妥協をする必要があると思っています。
>
> ...ということを込めて、
>
> > 「『束縛』は、パターンマッチの輸入元である関数型言語なんかの用語で、ここでも使っているんだけども、(Rubyでは)代入と読み替えていいよ」
>
> というのは、
>
> > 「『束縛』は、パターンマッチの輸入元である関数型言語なんかの用語で、ここでも使っているんだけども、**(ここで『束縛』って初耳です、なぁにそれ、という方々、細かいことは考えなくていい!)**『束縛』は(Rubyでは)代入と読み替えていいよ **(勿論、ホントは関数型言語における『束縛』との比較などの細かい話はあるけれども、だ)** 」
>
> みたいな意味合いでした...😅
>
> (私の場合、Lispや不慣れなHaskellの知識ぐらいしかないので、ここで言っていることが頓珍漢な可能性があります;Lispは『関数型言語』の文脈で出すべきかはアレですが)
@sanfrecce-osaka
Copy link
Contributor Author

sanfrecce-osaka commented Jun 2, 2023

@shu-i-chi

だいぶ期間が空いての返信ですみません 🙏

  1. rest

考えてみると英文故にダブルクォーテーションで囲っているだけであまり大きな意味はなく訳す場合は単に「残りの」と訳せば良い気がしてきたのですがどうでしょう? 👀

  1. 用語『束縛』について

d261348 で対応してみました〜 😸

  1. unpack に関して

Gem::Installer#unpack で「展開」という単語が使われているのでこれでどうでしょう? 😺

https://docs.ruby-lang.org/ja/3.1/method/Gem=3a=3aInstaller/i/unpack.html

与えられたディレクトリに Gem を展開します。

cf. rurema#2773 (comment)

以下のコミットの内容を分岐に取り込んだ

cf. [DOC Update pattern matching docs for 3.2](ruby/ruby@ce0f3de)
cf. [Allow omission of parentheses in one line pattern matching](ruby/ruby@ecb6d6a)
cf. [
Add pattern matching pin support for instance/class/global variables](ruby/ruby@fa87f72)
cf. [Pattern matching pin operator against expression](ruby/ruby@2186347)
cf. [
Update documentation for pattern matching](ruby/ruby@4902f96)
cf. [Reintroduce expr in pat](ruby/ruby@88f3ce1)
cf. [Pattern matching is no longer experimental](ruby/ruby@b601532)
@ohai ohai merged commit 4bb59c0 into rurema:master May 31, 2024
8 checks passed
@ohai
Copy link
Member

ohai commented May 31, 2024

マージしました!

まあ何か問題があったらまた修正しましょう。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants