ActiveSupport::OrderedOptions (original) (raw)

Ordered Options

OrderedOptions inherits from Hash and provides dynamic accessor methods.

With a Hash, key-value pairs are typically managed like this:

h = {}
h[:boy] = 'John'
h[:girl] = 'Mary'
h[:boy]  # => 'John'
h[:girl] # => 'Mary'
h[:dog]  # => nil

Using OrderedOptions, the above code can be written as:

h = ActiveSupport::OrderedOptions.new
h.boy = 'John'
h.girl = 'Mary'
h.boy  # => 'John'
h.girl # => 'Mary'
h.dog  # => nil

To raise an exception when the value is blank, append a bang to the key name, like:

h.dog! # => raises KeyError: :dog is blank

Methods

D

E

I

M

R

Instance Public methods

Source: show | on GitHub

def []=(key, value) super(key.to_sym, value) end

Source: show | on GitHub

def dig(key, *identifiers) super(key.to_sym, *identifiers) end

Source: show | on GitHub

def inspect "#<#{self.class.name} #{super}>" end

Source: show | on GitHub

def method_missing(method, *args) if method.end_with?("=") self[method.name.chomp("=")] = args.first elsif method.end_with?("!") name_string = method.name.chomp("!") self[name_string].presence || raise(KeyError.new(":#{name_string} is blank")) else self[method.name] end end

Source: show | on GitHub

def respond_to_missing?(name, include_private) true end