aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/attribute_methods/primary_key.rb
diff options
context:
space:
mode:
authorJon Leighton <j@jonathanleighton.com>2011-12-01 21:55:59 +0000
committerJon Leighton <j@jonathanleighton.com>2011-12-01 23:41:51 +0000
commite9fb6d04bdfbe3dfc4ba1a3cf442ec5d25764300 (patch)
tree9e6bb6b8c7fbcc4cdcf3cea1e5cacaf6c846ee54 /activerecord/lib/active_record/attribute_methods/primary_key.rb
parentf1a534af98950efd9969deea1540717c4516d673 (diff)
downloadrails-e9fb6d04bdfbe3dfc4ba1a3cf442ec5d25764300.tar.gz
rails-e9fb6d04bdfbe3dfc4ba1a3cf442ec5d25764300.tar.bz2
rails-e9fb6d04bdfbe3dfc4ba1a3cf442ec5d25764300.zip
Add test for read_attribute(:id) with non-standard PK.
Also make it actually work. It slows down all read_attribute accesses to map 'id' to whatever the PK actually is, inside read_attribute. So instead make sure the necessary methods are defined and that they redirect wherever they need to go.
Diffstat (limited to 'activerecord/lib/active_record/attribute_methods/primary_key.rb')
-rw-r--r--activerecord/lib/active_record/attribute_methods/primary_key.rb14
1 files changed, 14 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/attribute_methods/primary_key.rb b/activerecord/lib/active_record/attribute_methods/primary_key.rb
index 98aa1ed225..c756924186 100644
--- a/activerecord/lib/active_record/attribute_methods/primary_key.rb
+++ b/activerecord/lib/active_record/attribute_methods/primary_key.rb
@@ -25,6 +25,20 @@ module ActiveRecord
end
module ClassMethods
+ def define_method_attribute(attr_name)
+ super
+
+ if attr_name == primary_key && attr_name != 'id'
+ generated_attribute_methods.send(:alias_method, :id, primary_key)
+ generated_attribute_methods.module_eval <<-CODE, __FILE__, __LINE__
+ def self.attribute_id(v, attributes, attributes_cache, attr_name)
+ attr_name = '#{primary_key}'
+ send(:'attribute_#{attr_name}', attributes[attr_name], attributes, attributes_cache, attr_name)
+ end
+ CODE
+ end
+ end
+
def dangerous_attribute_method?(method_name)
super && !['id', 'id=', 'id?'].include?(method_name)
end