Class: Puppet::Settings::Values
- Extended by:
- Forwardable
- Defined in:
- lib/puppet/settings.rb
Instance Attribute Summary collapse
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Instance Method Summary collapse
-
#initialize(name, defaults) ⇒ Values
constructor
A new instance of Values.
- #inspect ⇒ Object
- #set(name, value) ⇒ Object
Constructor Details
#initialize(name, defaults) ⇒ Values
Returns a new instance of Values.
1493 1494 1495 1496 1497 |
# File 'lib/puppet/settings.rb', line 1493 def initialize(name, defaults) @name = name @values = {} @defaults = defaults end |
Instance Attribute Details
#name ⇒ Object (readonly)
Returns the value of attribute name.
1491 1492 1493 |
# File 'lib/puppet/settings.rb', line 1491 def name @name end |
Instance Method Details
#inspect ⇒ Object
1525 1526 1527 |
# File 'lib/puppet/settings.rb', line 1525 def inspect %Q{<#{self.class}:#{self.object_id} @name="#{@name}" @values="#{@values}">} end |
#set(name, value) ⇒ Object
1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 |
# File 'lib/puppet/settings.rb', line 1502 def set(name, value) default = @defaults[name] if !default raise ArgumentError, _("Attempt to assign a value to unknown setting %{name}") % { name: name.inspect } end # This little exception-handling dance ensures that a hook is # able to check whether a value for itself has been explicitly # set, while still preserving the existing value if the hook # throws (as was existing behavior) old_value = @values[name] @values[name] = value begin if default.has_hook? default.handle(value) end rescue Exception => e @values[name] = old_value raise e end end |