summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorChris Price <chris@puppetlabs.com>2013-04-02 15:13:08 -0700
committerChris Price <chris@puppetlabs.com>2013-04-02 15:13:08 -0700
commit389531a6f5ca829c949bf68c3cfd347b0d347a9e (patch)
tree695249bc2888be30452bdb2121f22777f1b317a9 /lib
parent6e318317fb578158b229b2456dcb9908d7571230 (diff)
parent6c245ef674316f4fbddb79698552138fe9f1e69a (diff)
downloadpuppet-inifile-389531a6f5ca829c949bf68c3cfd347b0d347a9e.tar.gz
puppet-inifile-389531a6f5ca829c949bf68c3cfd347b0d347a9e.tar.bz2
Merge pull request #33 from bodepd/doc_update
Update Modulefile and Changelog, prepping for 0.10.0 release
Diffstat (limited to 'lib')
-rw-r--r--lib/puppet/provider/ini_setting/ruby.rb17
1 files changed, 17 insertions, 0 deletions
diff --git a/lib/puppet/provider/ini_setting/ruby.rb b/lib/puppet/provider/ini_setting/ruby.rb
index af7a073..e57ffe2 100644
--- a/lib/puppet/provider/ini_setting/ruby.rb
+++ b/lib/puppet/provider/ini_setting/ruby.rb
@@ -3,6 +3,15 @@ require File.expand_path('../../../util/ini_file', __FILE__)
Puppet::Type.type(:ini_setting).provide(:ruby) do
def self.instances
+ # this code is here to support purging and the query-all functionality of the
+ # 'puppet resource' command, on a per-file basis. Users
+ # can create a type for a specific config file with a provider that uses
+ # this as its parent and implements the method
+ # 'self.file_path', and that will provide the value for the path to the
+ # ini file (rather than needing to specify it on each ini setting
+ # declaration). This allows 'purging' to be used to clear out
+ # all settings from a particular ini file except those included in
+ # the catalog.
if self.respond_to?(:file_path)
# figure out what to do about the seperator
ini_file = Puppet::Util::IniFile.new(file_path, '=')
@@ -50,14 +59,22 @@ Puppet::Type.type(:ini_setting).provide(:ruby) do
end
def section
+ # this method is here so that it can be overridden by a child provider
resource[:section]
end
def setting
+ # this method is here so that it can be overridden by a child provider
resource[:setting]
end
def file_path
+ # this method is here to support purging and sub-classing.
+ # if a user creates a type and subclasses our provider and provides a
+ # 'file_path' method, then they don't have to specify the
+ # path as a parameter for every ini_setting declaration.
+ # This implementation allows us to support that while still
+ # falling back to the parameter value when necessary.
if self.class.respond_to?(:file_path)
self.class.file_path
else