| 
									
										
										
										
											2016-09-28 03:28:20 -07:00
										 |  |  | #:  * `man` [`--fail-if-changed`]: | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #:    Generate Homebrew's manpages. | 
					
						
							| 
									
										
										
										
											2016-09-28 03:28:20 -07:00
										 |  |  | #: | 
					
						
							|  |  |  | #:    If `--fail-if-changed` is passed, the command will return a failing | 
					
						
							|  |  |  | #:    status code if changes are detected in the manpage outputs. | 
					
						
							|  |  |  | #:    This can be used for CI to be notified when the manpages are out of date. | 
					
						
							| 
									
										
										
										
											2016-10-01 12:19:51 +01:00
										 |  |  | #:    Additionally, the date used in new manpages will match those in the existing | 
					
						
							|  |  |  | #:    manpages (to allow comparison without factoring in the date). | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  | require "formula" | 
					
						
							| 
									
										
										
										
											2016-04-17 05:33:21 +02:00
										 |  |  | require "erb" | 
					
						
							| 
									
										
										
										
											2016-04-19 19:43:32 +08:00
										 |  |  | require "ostruct" | 
					
						
							| 
									
										
										
										
											2018-03-24 21:26:16 +05:30
										 |  |  | require "cli_parser" | 
					
						
							| 
									
										
										
										
											2018-07-30 18:25:38 +05:30
										 |  |  | require "dev-cmd/audit" | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | require "dev-cmd/bottle" | 
					
						
							|  |  |  | require "dev-cmd/bump-formula-pr" | 
					
						
							|  |  |  | require "dev-cmd/create" | 
					
						
							|  |  |  | require "dev-cmd/edit" | 
					
						
							| 
									
										
										
										
											2018-10-08 22:48:52 -04:00
										 |  |  | require "dev-cmd/extract" | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | require "dev-cmd/formula" | 
					
						
							|  |  |  | require "dev-cmd/irb" | 
					
						
							|  |  |  | require "dev-cmd/linkage" | 
					
						
							|  |  |  | require "dev-cmd/mirror" | 
					
						
							| 
									
										
										
										
											2018-10-08 22:48:52 -04:00
										 |  |  | require "dev-cmd/prof" | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | require "dev-cmd/pull" | 
					
						
							|  |  |  | require "dev-cmd/release-notes" | 
					
						
							| 
									
										
										
										
											2018-10-08 22:48:52 -04:00
										 |  |  | require "dev-cmd/ruby" | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | require "dev-cmd/tap-new" | 
					
						
							| 
									
										
										
										
											2018-10-08 22:48:52 -04:00
										 |  |  | require "dev-cmd/test" | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | require "dev-cmd/tests" | 
					
						
							|  |  |  | require "dev-cmd/update-test" | 
					
						
							| 
									
										
										
										
											2014-09-20 15:30:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | module Homebrew | 
					
						
							| 
									
										
										
										
											2016-09-26 01:44:51 +02:00
										 |  |  |   module_function | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   SOURCE_PATH = HOMEBREW_LIBRARY_PATH/"manpages" | 
					
						
							| 
									
										
										
										
											2016-09-19 19:58:39 +01:00
										 |  |  |   TARGET_MAN_PATH = HOMEBREW_REPOSITORY/"manpages" | 
					
						
							|  |  |  |   TARGET_DOC_PATH = HOMEBREW_REPOSITORY/"docs" | 
					
						
							| 
									
										
										
										
											2014-09-20 15:30:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-30 18:25:38 +05:30
										 |  |  |   def man_args | 
					
						
							|  |  |  |     Homebrew::CLI::Parser.new do | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |       usage_banner <<~EOS | 
					
						
							| 
									
										
										
										
											2018-10-15 15:06:33 -04:00
										 |  |  |         `man` [<options>] | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |         Generate Homebrew's manpages. | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  |       switch "--fail-if-changed", | 
					
						
							|  |  |  |         description: "Return a failing status code if changes are detected in the manpage outputs. This "\ | 
					
						
							|  |  |  |                      "can be used for CI to be notified when the manpages are out of date. Additionally, "\ | 
					
						
							|  |  |  |                      "the date used in new manpages will match those in the existing manpages (to allow "\ | 
					
						
							|  |  |  |                      "comparison without factoring in the date)." | 
					
						
							|  |  |  |       switch "--link", | 
					
						
							| 
									
										
										
										
											2018-10-08 22:49:03 -04:00
										 |  |  |         description: "This is now done automatically by `brew update`." | 
					
						
							| 
									
										
										
										
											2018-03-25 17:48:22 +05:30
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-07-30 18:25:38 +05:30
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def man | 
					
						
							|  |  |  |     man_args.parse | 
					
						
							| 
									
										
										
										
											2018-03-24 21:26:16 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |     raise UsageError unless ARGV.named.empty? | 
					
						
							| 
									
										
										
										
											2015-06-15 12:41:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-05 18:40:01 +05:30
										 |  |  |     if args.link? | 
					
						
							| 
									
										
										
										
											2016-08-24 10:08:54 +01:00
										 |  |  |       odie "`brew man --link` is now done automatically by `brew update`." | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-09-28 03:28:20 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-23 18:48:51 +00:00
										 |  |  |     regenerate_man_pages | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 21:37:09 +00:00
										 |  |  |     if system "git", "-C", HOMEBREW_REPOSITORY, "diff", "--quiet", "docs/Manpage.md", "manpages" | 
					
						
							| 
									
										
										
										
											2016-09-28 03:28:20 -07:00
										 |  |  |       puts "No changes to manpage output detected." | 
					
						
							| 
									
										
										
										
											2018-05-05 18:40:01 +05:30
										 |  |  |     elsif args.fail_if_changed? | 
					
						
							| 
									
										
										
										
											2016-09-28 03:28:20 -07:00
										 |  |  |       Homebrew.failed = true | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def regenerate_man_pages | 
					
						
							| 
									
										
										
										
											2017-05-07 17:28:39 +01:00
										 |  |  |     Homebrew.install_gem_setup_path! "ronn" | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 03:04:27 +02:00
										 |  |  |     markup = build_man_page | 
					
						
							| 
									
										
										
										
											2017-03-22 21:37:09 +00:00
										 |  |  |     convert_man_page(markup, TARGET_DOC_PATH/"Manpage.md") | 
					
						
							| 
									
										
										
										
											2016-04-17 03:04:27 +02:00
										 |  |  |     convert_man_page(markup, TARGET_MAN_PATH/"brew.1") | 
					
						
							| 
									
										
										
										
											2016-08-20 16:36:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-23 01:22:54 -04:00
										 |  |  |     cask_markup = (SOURCE_PATH/"brew-cask.1.md").read | 
					
						
							| 
									
										
										
										
											2016-08-20 16:36:34 +01:00
										 |  |  |     convert_man_page(cask_markup, TARGET_MAN_PATH/"brew-cask.1") | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-05 21:46:40 +01:00
										 |  |  |   def path_glob_commands(glob) | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |     Pathname.glob(glob) | 
					
						
							| 
									
										
										
										
											2018-10-06 00:36:30 -04:00
										 |  |  |             .sort_by { |source_file| sort_key_for_path(source_file) } | 
					
						
							| 
									
										
										
										
											2017-10-07 00:31:28 +02:00
										 |  |  |             .map(&:read).map(&:lines) | 
					
						
							|  |  |  |             .map { |lines| lines.grep(/^#:/).map { |line| line.slice(2..-1) }.join } | 
					
						
							|  |  |  |             .reject { |s| s.strip.empty? || s.include?("@hide_from_man_page") } | 
					
						
							| 
									
										
										
										
											2016-09-05 21:46:40 +01:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def build_man_page | 
					
						
							|  |  |  |     template = (SOURCE_PATH/"brew.1.md.erb").read | 
					
						
							|  |  |  |     variables = OpenStruct.new | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-05 21:46:40 +01:00
										 |  |  |     variables[:commands] = path_glob_commands("#{HOMEBREW_LIBRARY_PATH}/cmd/*.{rb,sh}") | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     variables[:developer_commands] = generate_cmd_manpages("#{HOMEBREW_LIBRARY_PATH}/dev-cmd/*.{rb,sh}") | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  |     variables[:global_options] = global_options_manpage_lines | 
					
						
							| 
									
										
										
										
											2016-09-20 09:31:06 +01:00
										 |  |  |     readme = HOMEBREW_REPOSITORY/"README.md" | 
					
						
							| 
									
										
										
										
											2018-09-02 16:15:09 +01:00
										 |  |  |     variables[:lead_maintainer] = | 
					
						
							|  |  |  |       readme.read[/(Homebrew's lead maintainer .*\.)/, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							|  |  |  |     variables[:leadership] = | 
					
						
							|  |  |  |       readme.read[/(Homebrew's project leadership committee .*\.)/, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							|  |  |  |     variables[:brew_maintainers] = | 
					
						
							|  |  |  |       readme.read[%r{(Homebrew/brew's other current maintainers .*\.)}, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							|  |  |  |     variables[:linux_maintainers] = | 
					
						
							|  |  |  |       readme.read[%r{(Homebrew/brew's Linux support \(and Linuxbrew\) maintainers are .*\.)}, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							|  |  |  |     variables[:core_maintainers] = | 
					
						
							|  |  |  |       readme.read[%r{(Homebrew/homebrew-core's other current maintainers .*\.)}, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							|  |  |  |     variables[:former_maintainers] = | 
					
						
							|  |  |  |       readme.read[/(Former maintainers .*\.)/, 1] | 
					
						
							|  |  |  |             .gsub(/\[([^\]]+)\]\([^)]+\)/, '\1') | 
					
						
							| 
									
										
										
										
											2016-06-14 21:01:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-15 16:25:14 +00:00
										 |  |  |     variables[:homebrew_bundle] = help_output(:bundle) | 
					
						
							|  |  |  |     variables[:homebrew_services] = help_output(:services) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |     ERB.new(template, nil, ">").result(variables.instance_eval { binding }) | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 09:36:48 +02:00
										 |  |  |   def sort_key_for_path(path) | 
					
						
							|  |  |  |     # Options after regular commands (`~` comes after `z` in ASCII table). | 
					
						
							|  |  |  |     path.basename.to_s.sub(/\.(rb|sh)$/, "").sub(/^--/, "~~") | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 03:04:27 +02:00
										 |  |  |   def convert_man_page(markup, target) | 
					
						
							| 
									
										
										
										
											2016-10-01 11:49:39 +01:00
										 |  |  |     manual = target.basename(".1") | 
					
						
							|  |  |  |     organisation = "Homebrew" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Set the manpage date to the existing one if we're checking for changes. | 
					
						
							|  |  |  |     # This avoids the only change being e.g. a new date. | 
					
						
							| 
									
										
										
										
											2018-05-05 18:40:01 +05:30
										 |  |  |     date = if args.fail_if_changed? && | 
					
						
							| 
									
										
										
										
											2016-10-01 11:49:39 +01:00
										 |  |  |               target.extname == ".1" && target.exist? | 
					
						
							|  |  |  |       /"(\d{1,2})" "([A-Z][a-z]+) (\d{4})" "#{organisation}" "#{manual}"/ =~ target.read | 
					
						
							| 
									
										
										
										
											2017-06-10 20:23:20 +03:00
										 |  |  |       Date.parse("#{Regexp.last_match(1)} #{Regexp.last_match(2)} #{Regexp.last_match(3)}") | 
					
						
							| 
									
										
										
										
											2016-10-01 11:49:39 +01:00
										 |  |  |     else | 
					
						
							|  |  |  |       Date.today | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     date = date.strftime("%Y-%m-%d") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |     shared_args = %W[
 | 
					
						
							|  |  |  |       --pipe | 
					
						
							| 
									
										
										
										
											2016-10-01 11:49:39 +01:00
										 |  |  |       --organization=#{organisation} | 
					
						
							| 
									
										
										
										
											2016-08-20 16:36:34 +01:00
										 |  |  |       --manual=#{target.basename(".1")} | 
					
						
							| 
									
										
										
										
											2016-10-01 11:49:39 +01:00
										 |  |  |       --date=#{date} | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |     ] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     format_flag, format_desc = target_path_to_format(target) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     puts "Writing #{format_desc} to #{target}" | 
					
						
							| 
									
										
										
										
											2016-04-17 03:04:27 +02:00
										 |  |  |     Utils.popen(["ronn", format_flag] + shared_args, "rb+") do |ronn| | 
					
						
							|  |  |  |       ronn.write markup | 
					
						
							|  |  |  |       ronn.close_write | 
					
						
							| 
									
										
										
										
											2017-04-02 10:13:38 +01:00
										 |  |  |       ronn_output = ronn.read | 
					
						
							| 
									
										
										
										
											2018-07-20 09:47:28 +01:00
										 |  |  |       odie "Got no output from ronn!" unless ronn_output | 
					
						
							| 
									
										
										
										
											2018-10-02 21:56:00 -04:00
										 |  |  |       if format_flag == "--markdown" | 
					
						
							| 
									
										
										
										
											2018-10-06 00:31:10 -04:00
										 |  |  |         ronn_output = ronn_output.gsub(%r{<var>(.*?)</var>}, "*`\\1`*") | 
					
						
							| 
									
										
										
										
											2018-10-02 21:56:00 -04:00
										 |  |  |       elsif format_flag == "--roff" | 
					
						
							| 
									
										
										
										
											2018-10-03 10:19:46 +05:30
										 |  |  |         ronn_output = ronn_output.gsub(%r{<code>(.*?)</code>}, "\\fB\\1\\fR") | 
					
						
							|  |  |  |                                  .gsub(%r{<var>(.*?)</var>}, "\\fI\\1\\fR") | 
					
						
							| 
									
										
										
										
											2018-10-02 21:56:00 -04:00
										 |  |  |                                  .gsub(/(^\[?\\fB.+): /, "\\1\n    ") | 
					
						
							| 
									
										
										
										
											2018-10-02 19:54:22 +05:30
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2017-04-02 10:13:38 +01:00
										 |  |  |       target.atomic_write ronn_output | 
					
						
							| 
									
										
										
										
											2016-04-17 03:04:27 +02:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-15 16:25:14 +00:00
										 |  |  |   def help_output(command) | 
					
						
							|  |  |  |     tap = Tap.fetch("Homebrew/homebrew-#{command}") | 
					
						
							|  |  |  |     tap.install unless tap.installed? | 
					
						
							|  |  |  |     command_help_lines(which("brew-#{command}.rb", Tap.cmd_directories)) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |   def target_path_to_format(target) | 
					
						
							|  |  |  |     case target.basename | 
					
						
							| 
									
										
										
										
											2017-03-22 21:37:09 +00:00
										 |  |  |     when /\.md$/    then ["--markdown", "markdown"] | 
					
						
							| 
									
										
										
										
											2016-04-17 02:28:58 +02:00
										 |  |  |     when /\.\d$/    then ["--roff", "man page"] | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       odie "Failed to infer output format from '#{target.basename}'." | 
					
						
							| 
									
										
										
										
											2014-09-20 15:30:44 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |   def generate_cmd_manpages(glob) | 
					
						
							| 
									
										
										
										
											2018-10-10 14:41:50 +01:00
										 |  |  |     cmd_paths = Pathname.glob(glob).sort | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |     man_page_lines = [] | 
					
						
							| 
									
										
										
										
											2018-10-24 01:17:38 +05:30
										 |  |  |     man_args = Homebrew.args | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |     cmd_paths.each do |cmd_path| | 
					
						
							|  |  |  |       begin | 
					
						
							|  |  |  |         cmd_parser = Homebrew.send(cmd_arg_parser(cmd_path)) | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  |         man_page_lines << cmd_manpage_lines(cmd_parser).join | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |       rescue NoMethodError | 
					
						
							| 
									
										
										
										
											2018-10-03 10:19:46 +05:30
										 |  |  |         man_page_lines << path_glob_commands(cmd_path.to_s).first | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2018-10-24 01:17:38 +05:30
										 |  |  |     Homebrew.args = man_args | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |     man_page_lines | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def cmd_arg_parser(cmd_path) | 
					
						
							| 
									
										
										
										
											2018-10-02 19:54:22 +05:30
										 |  |  |     "#{cmd_path.basename.to_s.gsub(".rb", "").tr("-", "_")}_args".to_sym | 
					
						
							| 
									
										
										
										
											2018-09-28 21:39:52 +05:30
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  |   def cmd_manpage_lines(cmd_parser) | 
					
						
							| 
									
										
										
										
											2018-10-02 19:54:22 +05:30
										 |  |  |     lines = [format_usage_banner(cmd_parser.usage_banner_text)] | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  |     lines += cmd_parser.processed_options.map do |short, long, _, desc| | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  |       next if !long.nil? && cmd_parser.global_option?(cmd_parser.option_to_name(long)) | 
					
						
							|  |  |  |       generate_option_doc(short, long, desc) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     lines | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def global_options_manpage_lines | 
					
						
							|  |  |  |     lines = ["These options are applicable across all sub-commands.\n"] | 
					
						
							|  |  |  |     lines += Homebrew::CLI::Parser.global_options.values.map do |names, _, desc| | 
					
						
							|  |  |  |       short, long = names | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  |       generate_option_doc(short, long, desc) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     lines | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def generate_option_doc(short, long, desc) | 
					
						
							| 
									
										
										
										
											2018-10-15 14:55:58 -04:00
										 |  |  |     comma = (short && long) ? ", " : "" | 
					
						
							|  |  |  |     "* #{format_short_opt(short)}" + comma + "#{format_long_opt(long)}:" + "\n  " + desc + "\n" | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def format_short_opt(opt) | 
					
						
							| 
									
										
										
										
											2018-10-15 14:55:58 -04:00
										 |  |  |     "`#{opt}`" unless opt.nil? | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def format_long_opt(opt) | 
					
						
							| 
									
										
										
										
											2018-10-15 14:55:58 -04:00
										 |  |  |     "`#{opt}`" unless opt.nil? | 
					
						
							| 
									
										
										
										
											2018-09-08 22:21:04 +05:30
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |   def format_usage_banner(usage_banner) | 
					
						
							| 
									
										
										
										
											2018-10-06 00:31:10 -04:00
										 |  |  |     usage_banner.sub(/^/, "### ") | 
					
						
							| 
									
										
										
										
											2018-10-02 14:44:38 +05:30
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2014-09-20 15:30:44 +01:00
										 |  |  | end |