質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.63%

[質問] ruby optparse helpのoption説明 複数行時の説明開始桁位置を揃えるスマートな記述

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 487

roswell

score 13

~$ uname -a
CYGWIN_NT-6.1 JPC20316739 2.10.0(0.325/5/3) 2018-02-02 15:16 x86_64 
Cygwin
~$ ruby --version
ruby 2.3.6p384 (2017-12-14 revision 9808) [x86_64-cygwin]
last_commit=ruby 2.3.3


の環境で、
optparse ライブラリの help
https://docs.ruby-lang.org/ja/2.3.0/library/optparse.html#help
「OptionParser#on の引数にそのオプションの説明を加えると --help の 出力に反映されます。」 の部分で、
説明を複数行に渡って表示させる際、ソースのコメント(*)部分のようにすれば、
前の行の説明文の開始位置と改行後の説明文の開始位置が一致するのですが、
もっとスマートな記述が出来ないものでしょうか?

なにかよい方法があれば、ご教示お願いします。

[ソース]

~$ cat optparse.rb
#! /usr/bin/env ruby

# coding: utf-8
require 'optparse'
opt = OptionParser.new

help_d = <<'HELP_D'
bar
hoge
HELP_D

opt.on('-a','foo') {|v| v }
opt.on('-b',"bar\nhoge") {|v| v } # 2行目の説明文が行頭からになる fail
opt.on('-c',\
"bar
                                    hoge") {|v| v } # (*) 2行目の説明文が、1行目の説明文の開始位置と合うが…
opt.parse(ARGV)

[実行結果]

~$ ./optparse.rb --help
Usage: optparse [options]
   -a                               foo
   -b                               bar
hoge
   -c                               bar
                                    hoge
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

require 'optparse'

opt = OptionParser.new

opt.on('-b', 'bar', 'hoge'){|v| v}
opt.on('-c', *<<~DESC.split){|v| v}
  bar
  hoge
DESC

opt.parse(ARGV)

コレはドキュメント読むだけだと分かりづらい仕様ですね
一応、
https://docs.ruby-lang.org/ja/latest/method/OptionParser/i/on.html

on(short, *rest) {|v| ...} -> self
[PARAM] rest:
可能な引数を列挙した配列やハッシュを与えます。文字列を与えた場合は、 サマリに表示されるオプションの説明と見なします。

あたりから推測できるようなできないような

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/03 23:06

    asm さん、ご教示大変ありがとうございます。
    マニュアル見落としていました。が... 私の理解力では無理でした。
    望み通りです。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.63%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る