summaryrefslogtreecommitdiffstats
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
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
-rw-r--r--lib/puppet/interface.rb21
-rw-r--r--lib/puppet/interface/action.rb23
-rw-r--r--lib/puppet/interface/documentation.rb31
-rwxr-xr-xspec/unit/interface/documentation_spec.rb34
4 files changed, 67 insertions, 42 deletions
diff --git a/lib/puppet/interface.rb b/lib/puppet/interface.rb
index 10e2ec8d7..6be8b6930 100644
--- a/lib/puppet/interface.rb
+++ b/lib/puppet/interface.rb
@@ -76,26 +76,7 @@ class Puppet::Interface
# splits out this should merge into a module that both the action and face
# include. --daniel 2011-04-17
def synopsis
- output = PrettyPrint.format do |s|
- s.text("puppet #{name} <action>")
- s.breakable
-
- 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
- end
- end
+ build_synopsis self.name, '<action>'
end
diff --git a/lib/puppet/interface/action.rb b/lib/puppet/interface/action.rb
index 748888c2e..185302b07 100644
--- a/lib/puppet/interface/action.rb
+++ b/lib/puppet/interface/action.rb
@@ -48,28 +48,7 @@ class Puppet::Interface::Action
attr_doc :returns
attr_doc :arguments
def synopsis
- output = PrettyPrint.format do |s|
- s.text("puppet #{@face.name}")
- s.text(" #{name}") unless default?
- s.breakable
-
- 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
- end
- s.text(" #{arguments}") if arguments
- end
+ build_synopsis(@face.name, default? ? nil : name, arguments)
end
########################################################################
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
diff --git a/spec/unit/interface/documentation_spec.rb b/spec/unit/interface/documentation_spec.rb
new file mode 100755
index 000000000..6865b9073
--- /dev/null
+++ b/spec/unit/interface/documentation_spec.rb
@@ -0,0 +1,34 @@
+#!/usr/bin/env rspec
+require 'spec_helper'
+require 'puppet/interface'
+require 'puppet/interface/option'
+require 'puppet/interface/documentation'
+
+class Puppet::Interface::TinyDocs::Test
+ include Puppet::Interface::TinyDocs
+ attr_accessor :name, :options
+ def initialize
+ self.name = "tinydoc-test"
+ self.options = []
+ end
+
+ def get_option(name)
+ Puppet::Interface::Option.new(nil, "--#{name}")
+ end
+end
+
+describe Puppet::Interface::TinyDocs do
+ subject { Puppet::Interface::TinyDocs::Test.new }
+
+ context "#build_synopsis" do
+ before :each do
+ subject.options = [:foo, :bar]
+ end
+
+ it { should respond_to :build_synopsis }
+
+ it "should put a space between options (#7828)" do
+ subject.build_synopsis('baz').should =~ /#{Regexp.quote('[--foo] [--bar]')}/
+ end
+ end
+end