1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 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 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
module Hashie
module Extensions
module Mash
module DefineAccessors
def self.included(klass)
klass.class_eval do
mod = Ext.new
include mod
end
end
def self.extended(obj)
included(obj.singleton_class)
end
class Ext < Module
def initialize
mod = self
define_method(:method_missing) do |method_name, *args, &block|
key, suffix = method_name_and_suffix(method_name)
case suffix
when '='.freeze
mod.define_writer(key, method_name)
when '?'.freeze
mod.define_predicate(key, method_name)
when '!'.freeze
mod.define_initializing_reader(key, method_name)
when '_'.freeze
mod.define_underbang_reader(key, method_name)
else
mod.define_reader(key, method_name)
end
send(method_name, *args, &block)
end
end
def define_reader(key, method_name)
define_method(method_name) do |&block|
if key? method_name
self.[](method_name, &block)
else
self.[](key, &block)
end
end
end
def define_writer(key, method_name)
define_method(method_name) do |value = nil|
if key? method_name
self.[](method_name, &proc)
else
assign_property(key, value)
end
end
end
def define_predicate(key, method_name)
define_method(method_name) do
if key? method_name
self.[](method_name, &proc)
else
!!self[key]
end
end
end
def define_initializing_reader(key, method_name)
define_method(method_name) do
if key? method_name
self.[](method_name, &proc)
else
initializing_reader(key)
end
end
end
def define_underbang_reader(key, method_name)
define_method(method_name) do
if key? method_name
self.[](key, &proc)
else
underbang_reader(key)
end
end
end
end
end
end
end
end
|