123456789_123456789_123456789_123456789_123456789_

Class: ActiveRecord::Migration::Compatibility::V5_0

Do not use. This class is for internal use only.

Instance Method Summary

Instance Method Details

#add_belongs_to(table_name, ref_name, **options)

Alias for #add_reference.

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 422

alias :add_belongs_to :add_reference

#add_column(table_name, column_name, type, **options)

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 409

def add_column(table_name, column_name, type, **options)
  if type == :primary_key
    type = :integer
    options[:primary_key] = true
  elsif type == :datetime
    options[:precision] ||= nil
  end
  super
end

#add_reference(table_name, ref_name, **options) Also known as: #add_belongs_to

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 419

def add_reference(table_name, ref_name, **options)
  super(table_name, ref_name, type: :integer, **options)
end

#compatible_table_definition(t) (private)

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 425

def compatible_table_definition(t)
  t.singleton_class.prepend(TableDefinition)
  super
end

#create_join_table(table_1, table_2, column_options: {}, **options)

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 404

def create_join_table(table_1, table_2, column_options: {}, **options)
  column_options.reverse_merge!(type: :integer)
  super
end

#create_table(table_name, **options)

[ GitHub ]

  
# File 'activerecord/lib/active_record/migration/compatibility.rb', line 381

def create_table(table_name, **options)
  if connection.adapter_name == "PostgreSQL"
    if options[:id] == :uuid && !options.key?(:default)
      options[:default] = "uuid_generate_v4()"
    end
  end

  unless ["Mysql2", "Trilogy"].include?(connection.adapter_name) && options[:id] == :bigint
    if [:integer, :bigint].include?(options[:id]) && !options.key?(:default)
      options[:default] = nil
    end
  end

  # Since 5.1 PostgreSQL adapter uses bigserial type for primary
  # keys by default and MySQL uses bigint. This compat layer makes old migrations utilize
  # serial/int type instead -- the way it used to work before 5.1.
  unless options.key?(:id)
    options[:id] = :integer
  end

  super
end