aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/migration/command_recorder.rb
diff options
context:
space:
mode:
authorAster Ryan <astersamazing@gmail.com>2015-05-20 10:05:51 -0400
committerAster Ryan <astersamazing@gmail.com>2015-06-11 19:24:46 -0400
commita186663b3d274b7aa648683f3fdf7a816fe90763 (patch)
tree0312dff8c6a3f0563809cfb57004511c09af4114 /activerecord/lib/active_record/migration/command_recorder.rb
parente2dfa54db881fceae92bdf793d5545c3f0e22898 (diff)
downloadrails-a186663b3d274b7aa648683f3fdf7a816fe90763.tar.gz
rails-a186663b3d274b7aa648683f3fdf7a816fe90763.tar.bz2
rails-a186663b3d274b7aa648683f3fdf7a816fe90763.zip
Add an invert method for remove_foreign_key
Diffstat (limited to 'activerecord/lib/active_record/migration/command_recorder.rb')
-rw-r--r--activerecord/lib/active_record/migration/command_recorder.rb10
1 files changed, 10 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/migration/command_recorder.rb b/activerecord/lib/active_record/migration/command_recorder.rb
index 36256415df..ee4545ed71 100644
--- a/activerecord/lib/active_record/migration/command_recorder.rb
+++ b/activerecord/lib/active_record/migration/command_recorder.rb
@@ -184,6 +184,16 @@ module ActiveRecord
[:remove_foreign_key, [from_table, options]]
end
+ def invert_remove_foreign_key(args)
+ from_table, to_table, remove_options = args
+ raise ActiveRecord::IrreversibleMigration, "remove_foreign_key is only reversible if given a second table" if to_table.nil? || to_table.is_a?(Hash)
+
+ reversed_args = [from_table, to_table]
+ reversed_args << remove_options if remove_options
+
+ [:add_foreign_key, reversed_args]
+ end
+
# Forwards any missing method call to the \target.
def method_missing(method, *args, &block)
if @delegate.respond_to?(method)