aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrancesco Rodriguez <lrodriguezsanc@gmail.com>2012-05-07 12:39:41 -0500
committerFrancesco Rodriguez <lrodriguezsanc@gmail.com>2012-05-07 12:39:41 -0500
commit7b487e5dc16bcf7f94c031cc1411f940df8c0fc8 (patch)
treeb81e1701c0b04f5da2e52a544f6311b0ca057241
parent17ef794299ae10c2a7b8ce7a2da68258267c9720 (diff)
downloadrails-7b487e5dc16bcf7f94c031cc1411f940df8c0fc8.tar.gz
rails-7b487e5dc16bcf7f94c031cc1411f940df8c0fc8.tar.bz2
rails-7b487e5dc16bcf7f94c031cc1411f940df8c0fc8.zip
added docs to cattr_accessor method
-rw-r--r--activesupport/lib/active_support/core_ext/class/attribute_accessors.rb62
1 files changed, 50 insertions, 12 deletions
diff --git a/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb b/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb
index 4f8866ce9d..72a918f839 100644
--- a/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb
+++ b/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb
@@ -7,21 +7,21 @@ require 'active_support/core_ext/array/extract_options'
# also change the value for parent class. Similarly if parent class changes the value
# then that would change the value of subclasses too.
#
-# class Person
-# cattr_accessor :hair_colors
-# end
+# class Person
+# cattr_accessor :hair_colors
+# end
#
-# Person.hair_colors = [:brown, :black, :blonde, :red]
-# Person.hair_colors # => [:brown, :black, :blonde, :red]
-# Person.new.hair_colors # => [:brown, :black, :blonde, :red]
+# Person.hair_colors = [:brown, :black, :blonde, :red]
+# Person.hair_colors # => [:brown, :black, :blonde, :red]
+# Person.new.hair_colors # => [:brown, :black, :blonde, :red]
#
-# class Female < Person
-# end
+# class Female < Person
+# end
#
-# Female.hair_colors << :pink
-# Female.hair_colors # => [:brown, :black, :blonde, :red, :pink]
-# Female.new.hair_colors # => [:brown, :black, :blonde, :red, :pink]
-# Person.hair_colors # => [:brown, :black, :blonde, :red, :pink]
+# Female.hair_colors << :pink
+# Female.hair_colors # => [:brown, :black, :blonde, :red, :pink]
+# Female.new.hair_colors # => [:brown, :black, :blonde, :red, :pink]
+# Person.hair_colors # => [:brown, :black, :blonde, :red, :pink]
#
# To opt out of the instance writer method, pass :instance_writer => false.
# To opt out of the instance reader method, pass :instance_reader => false.
@@ -83,6 +83,44 @@ class Class
end
end
+ # Defines class and instance accessors for class attributes.
+ #
+ # class Person
+ # cattr_accessor :hair_colors
+ # end
+ #
+ # Person.hair_colors = [:brown, :black, :blonde, :red]
+ # Person.hair_colors # => [:brown, :black, :blonde, :red]
+ # Person.new.hair_colors # => [:brown, :black, :blonde, :red]
+ #
+ # If a subclass changes the value then that would also change the value for
+ # parent class. Similarly if parent class changes the value then that would
+ # change the value of subclasses too.
+ #
+ # class Male < Person
+ # end
+ #
+ # Male.hair_colors << :blue
+ # Person.hair_colors # => [:brown, :black, :blonde, :red, :blue]
+ #
+ # To opt out of the instance writer method, pass <tt>:instance_writer => false</tt>.
+ # To opt out of the instance reader method, pass <tt>:instance_reader => false</tt>.
+ #
+ # class Person
+ # cattr_accessor :hair_colors, :instance_writer => false, :instance_reader => false
+ # end
+ #
+ # Person.new.hair_colors = [:brown] # => NoMethodError
+ # Person.new.hair_colors # => NoMethodError
+ #
+ # Or pass <tt>:instance_accessor => false</tt>, to opt out both instance methods.
+ #
+ # class Person
+ # cattr_accessor :hair_colors, :instance_accessor => false
+ # end
+ #
+ # Person.new.hair_colors = [:brown] # => NoMethodError
+ # Person.new.hair_colors # => NoMethodError
def cattr_accessor(*syms, &blk)
cattr_reader(*syms)
cattr_writer(*syms, &blk)