summaryrefslogtreecommitdiffstats
path: root/lib/puppet/interface/documentation.rb
diff options
context:
space:
mode:
authorDaniel Pittman <daniel@puppetlabs.com>2011-06-07 16:52:56 -0700
committerDaniel Pittman <daniel@puppetlabs.com>2011-06-07 16:52:56 -0700
commit54632867f7e2b97b47b0a6855196a52eb64ea92a (patch)
tree443b28b20b8b8b25f133c20853aaff41cc2c8c25 /lib/puppet/interface/documentation.rb
parentb4e9791df5c01183ff037a346361ed3667e67552 (diff)
parent0ae4732fd9058c2ae67f664c545dbd1846cef2df (diff)
downloadpuppet-54632867f7e2b97b47b0a6855196a52eb64ea92a.tar.gz
puppet-54632867f7e2b97b47b0a6855196a52eb64ea92a.tar.xz
puppet-54632867f7e2b97b47b0a6855196a52eb64ea92a.zip
Merge branch 'bug/2.7rc/7828-face-synopsis-generators-ram-options-together' into 2.7rc
Diffstat (limited to 'lib/puppet/interface/documentation.rb')
-rw-r--r--lib/puppet/interface/documentation.rb31
1 files changed, 31 insertions, 0 deletions
diff --git a/lib/puppet/interface/documentation.rb b/lib/puppet/interface/documentation.rb
index fcaec2568..47e478a44 100644
--- a/lib/puppet/interface/documentation.rb
+++ b/lib/puppet/interface/documentation.rb
@@ -61,6 +61,37 @@ class Puppet::Interface
end
attr_doc :description
+
+ def build_synopsis(face, action = nil, arguments = nil)
+ output = PrettyPrint.format do |s|
+ s.text("puppet #{face}")
+ s.text(" #{action}") unless action.nil?
+ s.text(" ")
+
+ options.each do |option|
+ option = get_option(option)
+ wrap = option.required? ? %w{ < > } : %w{ [ ] }
+
+ s.group(0, *wrap) do
+ option.optparse.each do |item|
+ unless s.current_group.first?
+ s.breakable
+ s.text '|'
+ s.breakable
+ end
+ s.text item
+ end
+ end
+
+ s.breakable
+ end
+
+ if arguments then
+ s.text arguments.to_s
+ end
+ end
+ end
+
end
module FullDocs