diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-04-07 09:07:51 -0500 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2014-04-07 09:07:51 -0500 |
commit | 013b7c19c81b95583cb537fd2b4330f6860c8502 (patch) | |
tree | 9f83543d7b4ea0599e6d322b7a375c54f8980638 /activerecord/lib | |
parent | 67e67063a4a39530ec0f49d979edb7c2897b8280 (diff) | |
parent | bbe7fe41692e5a2c869f812616d0c99a2bfcb39c (diff) | |
download | rails-013b7c19c81b95583cb537fd2b4330f6860c8502.tar.gz rails-013b7c19c81b95583cb537fd2b4330f6860c8502.tar.bz2 rails-013b7c19c81b95583cb537fd2b4330f6860c8502.zip |
Merge pull request #14609 from evanwhalen/enums_inheritance
Make enums distinct per class
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/enum.rb | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/activerecord/lib/active_record/enum.rb b/activerecord/lib/active_record/enum.rb index 4aa323fb00..167f8b7a49 100644 --- a/activerecord/lib/active_record/enum.rb +++ b/activerecord/lib/active_record/enum.rb @@ -65,10 +65,13 @@ module ActiveRecord # # Where conditions on an enum attribute must use the ordinal value of an enum. module Enum - DEFINED_ENUMS = {} # :nodoc: + def self.extended(base) + base.class_attribute(:defined_enums) + base.defined_enums = {} + end def enum_mapping_for(attr_name) # :nodoc: - DEFINED_ENUMS[attr_name.to_s] + defined_enums[attr_name.to_s] end def enum(definitions) @@ -122,9 +125,8 @@ module ActiveRecord klass.send(:detect_enum_conflict!, name, value, true) klass.scope value, -> { klass.where name => i } end - - DEFINED_ENUMS[name.to_s] = enum_values end + defined_enums[name.to_s] = enum_values end end |