aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2013-12-12 21:10:03 -0700
committerJeremy Kemper <jeremy@bitsweat.net>2013-12-12 21:10:03 -0700
commit0b142a6f842051e3f1f3c146d1e1318050274352 (patch)
tree525e83b0d925617f0634e3f7f38a84e885abfe34 /activerecord/lib
parentb474d06d5ea646c8145b07c8acbf1181c9e0b2aa (diff)
downloadrails-0b142a6f842051e3f1f3c146d1e1318050274352.tar.gz
rails-0b142a6f842051e3f1f3c146d1e1318050274352.tar.bz2
rails-0b142a6f842051e3f1f3c146d1e1318050274352.zip
Add a bunch of Relation -> Array delegate methods to the whitelist. This won't last - aim to switch back to a blacklist for mutator methods.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/relation/delegation.rb16
1 files changed, 12 insertions, 4 deletions
diff --git a/activerecord/lib/active_record/relation/delegation.rb b/activerecord/lib/active_record/relation/delegation.rb
index 603e5a9df5..87f5e8e684 100644
--- a/activerecord/lib/active_record/relation/delegation.rb
+++ b/activerecord/lib/active_record/relation/delegation.rb
@@ -36,10 +36,18 @@ module ActiveRecord
# may vary depending on the klass of a relation, so we create a subclass of Relation
# for each different klass, and the delegations are compiled into that subclass only.
- delegate :&, :+, :[], :all?, :collect, :detect, :each, :each_cons,
- :each_with_index, :flat_map, :group_by, :include?, :length,
- :map, :none?, :one?, :reverse, :sample, :second, :sort, :sort_by,
- :to_ary, :to_set, :to_xml, :to_yaml, :to => :to_a
+ # TODO: This is not going to work. Brittle, painful. We'll switch to a blacklist
+ # to disallow mutator methods like map!, pop, and delete_if instead.
+ ARRAY_DELEGATES = [
+ :+, :-, :|, :&, :[],
+ :all?, :collect, :detect, :each, :each_cons, :each_with_index,
+ :exclude?, :find_all, :flat_map, :group_by, :include?, :length,
+ :map, :none?, :one?, :partition, :reject, :reverse,
+ :sample, :second, :sort, :sort_by, :third,
+ :to_ary, :to_set, :to_xml, :to_yaml
+ ]
+
+ delegate *ARRAY_DELEGATES, to: :to_a
delegate :table_name, :quoted_table_name, :primary_key, :quoted_primary_key,
:connection, :columns_hash, :to => :klass