Module: Chickpea

Defined in:
lib/chickpea.rb,
lib/chickpea/stash.rb,
lib/chickpea/version.rb

Defined Under Namespace

Classes: Stash, TypeError

Constant Summary collapse

VERSION =
'0.2.2'.freeze

Class Method Summary collapse

Class Method Details

.check_type(obj, nv) ⇒ Object



24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/chickpea.rb', line 24

def check_type(obj, nv)
  case obj
  when true, false
    unless nv == true || nv == false
      raise(TypeError.new(nv, :Boolean))
    end
  else
    unless nv.is_a?(obj.class)
      raise(TypeError.new(nv, obj.class.name))
    end
  end
end

.def_accessors(klass, key, nv) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/chickpea.rb', line 11

def def_accessors(klass, key, nv)
  (
    case nv
    when true, false
      [[:"#{key}?", -> { nv }]]
    else
      []
    end + [[:"#{key}", -> { nv }]]
  ).each do |(meth, block)|
    klass.define_method(meth, &block)
  end
end

.make_stash(hash) ⇒ Object Also known as: new



37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# File 'lib/chickpea.rb', line 37

def make_stash(hash)
  klass = Class.new

  hash.each do |key, val|
    obj =
      if val.is_a?(Hash)
        make_stash(val)
      else
        klass.define_method(:"#{key}=") do |nv|
          Chickpea.check_type(val, nv)

          Chickpea.def_accessors(klass, key, nv)
        end

        val
      end

    Chickpea.def_accessors(klass, key, obj)
  end

  klass.define_method(:to_h) do
    hash.map do |k, v|
      [k, send(k).then { |r| v.is_a?(Hash) ? r.to_h : r }]
    end.to_h
  end

  klass.define_method(:merge!) do |hash|
    hash.each do |k, v|
      v.is_a?(Hash) ? send(k).merge!(v) : send(:"#{k}=", v)
    end
  end

  klass.new
end