Class: Puppet::Pops::Issues::MessageData Private
- Defined in:
- lib/puppet/pops/issues.rb
Overview
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
Provides a binding of arguments passed to Issue.format to method names available in the issue’s message producing block.
Instance Method Summary collapse
- #format(hash, &block) ⇒ Object private
-
#initialize(*argnames) ⇒ MessageData
constructor
private
A new instance of MessageData.
-
#label(*args) ⇒ LabelProvider, String
private
Obtains the label provider given as a key ‘:label` in the hash passed to #format.
-
#label_provider ⇒ LabelProvider
private
Returns the label provider given as key ‘:label` in the hash passed to #format.
-
#semantic ⇒ Object
private
Returns the label provider given as a key in the hash passed to #format.
Constructor Details
#initialize(*argnames) ⇒ MessageData
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of MessageData.
63 64 65 66 67 68 69 70 |
# File 'lib/puppet/pops/issues.rb', line 63 def initialize *argnames singleton = class << self; self end argnames.each do |name| singleton.send(:define_method, name) do @data[name] end end end |
Instance Method Details
#format(hash, &block) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
72 73 74 75 |
# File 'lib/puppet/pops/issues.rb', line 72 def format(hash, &block) @data = hash instance_eval &block end |
#label(*args) ⇒ LabelProvider, String
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Obtains the label provider given as a key ‘:label` in the hash passed to #format. The label provider is return if no arguments are given. If given an argument, returns the result of calling #label on the label provider.
84 85 86 |
# File 'lib/puppet/pops/issues.rb', line 84 def label(*args) args.empty? ? label_provider : label_provider.label(args[0]) end |
#label_provider ⇒ LabelProvider
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns the label provider given as key ‘:label` in the hash passed to #format.
91 92 93 94 95 96 |
# File 'lib/puppet/pops/issues.rb', line 91 def label_provider label_provider = @data[:label] #TRANSLATORS ":label" is a keyword and should not be translated raise Puppet::Error, _('Label provider key :label must be set to produce the text of the message!') unless label_provider label_provider end |
#semantic ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns the label provider given as a key in the hash passed to #format.
100 101 102 103 104 |
# File 'lib/puppet/pops/issues.rb', line 100 def semantic #TRANSLATORS ":semantic" is a keyword and should not be translated raise Puppet::Error, _('Label provider key :semantic must be set to produce the text of the message!') unless @data[:semantic] @data[:semantic] end |