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
# File 'lib/puppet-lint/configuration.rb', line 52

def method_missing(method, *args, &_block)
  super unless method.to_s =~ %r{^(\w+)=?$}

  option = Regexp.last_match(1)
  add_option(option.to_s) if settings[option].nil?
  settings[option] = args[0] unless args.empty?
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)


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

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.



114
115
116
117
# File 'lib/puppet-lint/configuration.rb', line 114

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)


75
76
77
# File 'lib/puppet-lint/configuration.rb', line 75

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.



129
130
131
# File 'lib/puppet-lint/configuration.rb', line 129

def check_object
  @check_object ||= {}
end

#checksObject

Public: Get a list of all the defined checks.

Returns an Array of String check names.



136
137
138
# File 'lib/puppet-lint/configuration.rb', line 136

def checks
  check_object.keys
end

#defaultsObject

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

Returns nothing.



144
145
146
147
148
149
150
151
152
153
154
155
# File 'lib/puppet-lint/configuration.rb', line 144

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.json = false
  self.show_ignored = false
  self.ignore_paths = ['vendor/**/*.pp']
end

#respond_to_missing?(method) ⇒ Boolean

Returns:

  • (Boolean)


60
61
62
# File 'lib/puppet-lint/configuration.rb', line 60

def respond_to_missing?(method, *)
  method.to_s =~ %r{^\w+=?$} || super
end

#settingsObject

Internal: Access the internal storage for settings.

Returns a Hash containing all the settings.



122
123
124
# File 'lib/puppet-lint/configuration.rb', line 122

def settings
  @settings ||= {}
end