aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2019-03-13 14:08:54 -0400
committerRafael Mendonça França <rafaelmfranca@gmail.com>2019-03-13 14:17:31 -0400
commite5f1b363d2b9983ad42b7d32185a6a731f5e383c (patch)
treeed309028ba80393db88b1760c3bfecd98ffea17b /activerecord/lib
parenta2bd669ed240bec739074188d61ff125e07fa8d1 (diff)
downloadrails-e5f1b363d2b9983ad42b7d32185a6a731f5e383c.tar.gz
rails-e5f1b363d2b9983ad42b7d32185a6a731f5e383c.tar.bz2
rails-e5f1b363d2b9983ad42b7d32185a6a731f5e383c.zip
Revert "Remove Marshal support from SchemaCache"
This reverts commit 65f2eeaaf5774f0891fff700f4defb0b90a05789.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/connection_adapters/schema_cache.rb11
1 files changed, 11 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/schema_cache.rb b/activerecord/lib/active_record/connection_adapters/schema_cache.rb
index 5b598620d3..07453b4403 100644
--- a/activerecord/lib/active_record/connection_adapters/schema_cache.rb
+++ b/activerecord/lib/active_record/connection_adapters/schema_cache.rb
@@ -114,6 +114,17 @@ module ActiveRecord
@indexes.delete name
end
+ def marshal_dump
+ # if we get current version during initialization, it happens stack over flow.
+ @version = connection.migration_context.current_version
+ [@version, @columns, @columns_hash, @primary_keys, @data_sources, @indexes]
+ end
+
+ def marshal_load(array)
+ @version, @columns, @columns_hash, @primary_keys, @data_sources, @indexes = array
+ @indexes = @indexes || {}
+ end
+
private
def prepare_data_sources
connection.data_sources.each { |source| @data_sources[source] = true }