Class: PuppetLint::Configuration

Inherits:
Object
  • Object
show all
Defined in:
lib/puppet-lint/configuration.rb

Overview

Public: A singleton class to store the running configuration of puppet-lint.

Class Method Summary collapse

Instance Method Summary collapse

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method, *args, &block) ⇒ Object

Public: Catch situations where options are being set for the first time and create the necessary methods to get & set the option in the future.

args - An Array of values to set the option to. method - The String name of the option. block - Unused.

Returns nothing.

Signature

<option>=(value)


52
53
54
55
56
57
58
59
60
# File 'lib/puppet-lint/configuration.rb', line 52

def method_missing(method, *args, &block)
  if method.to_s =~ /^(\w+)=$/
    option = $1
    add_option(option.to_s) if settings[option].nil?
    settings[option] = args[0]
  else
    nil
  end
end

Class Method Details

.add_check(check) ⇒ Object

Internal: Add helper methods for a new check to the PuppetLint::Configuration object.

check - The String name of the check.

Returns nothing.

Signature

<check>_enabled?
disable_<check>
enable_<check>


17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/puppet-lint/configuration.rb', line 17

def self.add_check(check)
  # Public: Determine if the named check is enabled.
  #
  # Returns true if the check is enabled, otherwise return false.
  define_method("#{check}_enabled?") do
    settings["#{check}_disabled"] == true ? false : true
  end

  # Public: Disable the named check.
  #
  # Returns nothing.
  define_method("disable_#{check}") do
    settings["#{check}_disabled"] = true
  end

  # Public: Enable the named check.
  #
  # Returns nothing.
  define_method("enable_#{check}") do
    settings["#{check}_disabled"] = false
  end
end

.add_option(option) ⇒ Object

Public: Add an option to the PuppetLint::Configuration object from outside the class.

option - The String name of the option.

Returns nothing.

Signature

<option>
<option>=(value)


88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# File 'lib/puppet-lint/configuration.rb', line 88

def self.add_option(option)
  # Public: Set the value of the named option.
  #
  # value - The value to set the option to.
  #
  # Returns nothing.
  define_method("#{option}=") do |value|
    settings[option] = value
  end

  # Public: Get the value of the named option.
  #
  # Returns the value of the option.
  define_method(option) do
    settings[option]
  end
end

Instance Method Details

#add_check(check, klass) ⇒ Object

Internal: Register a new check.

check - The String name of the check klass - The Class containing the check logic.

Returns nothing.



112
113
114
115
# File 'lib/puppet-lint/configuration.rb', line 112

def add_check(check, klass)
  self.class.add_check(check)
  check_object[check] = klass
end

#add_option(option) ⇒ Object

Internal: Add options to the PuppetLint::Configuration object from inside the class.

option - The String name of the option.

Returns nothing.

Signature

<option>
<option>=(value)


73
74
75
# File 'lib/puppet-lint/configuration.rb', line 73

def add_option(option)
  self.class.add_option(option)
end

#check_objectObject

Internal: Access the internal storage for check method blocks.

Returns a Hash containing all the check blocks.



127
128
129
# File 'lib/puppet-lint/configuration.rb', line 127

def check_object
  @check_object ||= {}
end

#checksObject

Public: Get a list of all the defined checks.

Returns an Array of String check names.



134
135
136
# File 'lib/puppet-lint/configuration.rb', line 134

def checks
  check_object.keys
end

#defaultsObject

Public: Clear the PuppetLint::Configuration storage and set some sane default values.

Returns nothing.



142
143
144
145
146
147
148
149
150
151
# File 'lib/puppet-lint/configuration.rb', line 142

def defaults
  settings.clear
  self.with_filename = false
  self.fail_on_warnings = false
  self.error_level = :all
  self.log_format = ''
  self.with_context = false
  self.fix = false
  self.show_ignored = false
end

#settingsObject

Internal: Access the internal storage for settings.

Returns a Hash containing all the settings.



120
121
122
# File 'lib/puppet-lint/configuration.rb', line 120

def settings
  @settings ||= {}
end