Class: Module
- Inherits:
-
Object
- Object
- Module
- Defined in:
- lib/aliasing.rb,
lib/attribute_accessors.rb
Overview
:nodoc:
Instance Method Summary collapse
-
#alias_attribute(new_name, old_name) ⇒ Object
Allows you to make aliases for attributes, which includes getter, setter, and query methods.
-
#alias_method_chain(target, feature) {|aliased_target, punctuation| ... } ⇒ Object
Encapsulates the common pattern of:.
- #mattr_accessor(*syms) ⇒ Object
- #mattr_reader(*syms) ⇒ Object
- #mattr_writer(*syms) ⇒ Object
Instance Method Details
#alias_attribute(new_name, old_name) ⇒ Object
Allows you to make aliases for attributes, which includes getter, setter, and query methods.
Example:
class Content < ActiveRecord::Base
# has a title attribute
end
class Email < ActiveRecord::Base
alias_attribute :subject, :title
end
e = Email.find(1)
e.title # => "Superstars"
e.subject # => "Superstars"
e.subject? # => true
e.subject = "Megastars"
e.title # => "Megastars"
81 82 83 84 85 86 87 |
# File 'lib/aliasing.rb', line 81 def alias_attribute(new_name, old_name) module_eval " def \#{new_name}; \#{old_name}; end\n def \#{new_name}?; \#{old_name}?; end\n def \#{new_name}=(v); self.\#{old_name} = v; end\n STR\nend\n", __FILE__, __LINE__+1 |
#alias_method_chain(target, feature) {|aliased_target, punctuation| ... } ⇒ Object
Encapsulates the common pattern of:
alias_method :foo_without_feature, :foo
alias_method :foo, :foo_with_feature
With this, you simply do:
alias_method_chain :foo, :feature
And both aliases are set up for you.
Query and bang methods (foo?, foo!) keep the same punctuation:
alias_method_chain :foo?, :feature
is equivalent to
alias_method :foo_without_feature?, :foo?
alias_method :foo?, :foo_with_feature?
so you can safely chain foo, foo?, and foo! with the same feature.
53 54 55 56 57 58 59 60 |
# File 'lib/aliasing.rb', line 53 def alias_method_chain(target, feature) # Strip out punctuation on predicates or bang methods since # e.g. target?_without_feature is not a valid method name. aliased_target, punctuation = target.to_s.sub(/([?!=])$/, ''), $1 yield(aliased_target, punctuation) if block_given? alias_method "#{aliased_target}_without_#{feature}#{punctuation}", target alias_method target, "#{aliased_target}_with_#{feature}#{punctuation}" end |
#mattr_accessor(*syms) ⇒ Object
75 76 77 78 |
# File 'lib/attribute_accessors.rb', line 75 def mattr_accessor(*syms) mattr_reader(*syms) mattr_writer(*syms) end |
#mattr_reader(*syms) ⇒ Object
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/attribute_accessors.rb', line 35 def mattr_reader(*syms) syms.each do |sym| next if sym.is_a?(Hash) class_eval(" unless defined? @@\#{sym}\n @@\#{sym} = nil\n end\n \n def self.\#{sym}\n @@\#{sym}\n end\n\n def \#{sym}\n @@\#{sym}\n end\n EOS\n end\nend\n", __FILE__, __LINE__) |
#mattr_writer(*syms) ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
# File 'lib/attribute_accessors.rb', line 54 def mattr_writer(*syms) = syms.last.is_a?(Hash) ? syms.pop : {} syms.each do |sym| class_eval(" unless defined? @@\#{sym}\n @@\#{sym} = nil\n end\n \n def self.\#{sym}=(obj)\n @@\#{sym} = obj\n end\n \n \#{\"\n def \#{sym}=(obj)\n @@\#{sym} = obj\n end\n \" unless options[:instance_writer] == false }\n EOS\n end\nend\n", __FILE__, __LINE__) |