Class: Puppet::Util::Feature
Overview
Created by Luke Kanies on 2006-11-07.
Copyright (c) 2006. All rights reserved.
Instance Attribute Summary collapse
-
#path ⇒ Object
readonly
Returns the value of attribute path.
Instance Method Summary collapse
-
#add(name, options = {}) ⇒ Object
Create a new feature test.
-
#initialize(path) ⇒ Feature
constructor
Create a new feature collection.
- #load ⇒ Object
- #method_missing(method, *args) ⇒ Object
-
#test(name, options) ⇒ Object
Actually test whether the feature is present.
Constructor Details
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method, *args) ⇒ Object
45 46 47 48 49 50 51 52 |
# File 'lib/puppet/util/feature.rb', line 45 def method_missing(method, *args) return super unless method.to_s =~ /\?$/ feature = method.to_s.sub(/\?$/, '') @loader.load(feature) respond_to?(method) && self.send(method) end |
Instance Attribute Details
#path ⇒ Object (readonly)
Returns the value of attribute path.
5 6 7 |
# File 'lib/puppet/util/feature.rb', line 5 def path @path end |
Instance Method Details
#add(name, options = {}) ⇒ Object
Create a new feature test. You have to pass the feature name, and it must be unique. You can either provide a block that will get executed immediately to determine if the feature is present, or you can pass an option to determine it. Currently, the only supported option is ‘libs’ (must be passed as a symbol), which will make sure that each lib loads successfully.
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/puppet/util/feature.rb', line 14 def add(name, = {}) method = name.to_s + "?" raise ArgumentError, "Feature #{name} is already defined" if self.class.respond_to?(method) if block_given? begin result = yield rescue Exception => detail warn "Failed to load feature test for #{name}: #{detail}" result = false end @results[name] = result end (method) do @results[name] = test(name, ) unless @results.include?(name) @results[name] end end |
#load ⇒ Object
41 42 43 |
# File 'lib/puppet/util/feature.rb', line 41 def load @loader.loadall end |
#test(name, options) ⇒ Object
Actually test whether the feature is present. We only want to test when someone asks for the feature, so we don’t unnecessarily load files.
57 58 59 60 61 62 63 64 65 66 67 |
# File 'lib/puppet/util/feature.rb', line 57 def test(name, ) return true unless ary = [:libs] ary = [ary] unless ary.is_a?(Array) ary.each do |lib| return false unless load_library(lib, name) end # We loaded all of the required libraries true end |