class ActiveRecord::ConnectionAdapters::PostgreSQL::SchemaDumper

:nodoc:

def default_primary_key?(column)

def default_primary_key?(column)
  schema_type(column) == :bigserial
end

def explicit_primary_key_default?(column)

def explicit_primary_key_default?(column)
  column.type == :uuid || (column.type == :integer && !column.serial?)
end

def extensions(stream)

def extensions(stream)
  extensions = @connection.extensions
  if extensions.any?
    stream.puts "  # These are extensions that must be enabled in order to support this database"
    extensions.sort.each do |extension|
      stream.puts "  enable_extension #{extension.inspect}"
    end
    stream.puts
  end
end

def extract_expression_for_virtual_column(column)

def extract_expression_for_virtual_column(column)
  column.default_function.inspect
end

def prepare_column_options(column)

def prepare_column_options(column)
  spec = super
  spec[:array] = "true" if column.array?
  if @connection.supports_virtual_columns? && column.virtual?
    spec[:as] = extract_expression_for_virtual_column(column)
    spec[:stored] = true
    spec = { type: schema_type(column).inspect }.merge!(spec)
  end
  spec[:enum_type] = "\"#{column.sql_type}\"" if column.enum?
  spec
end

def schema_expression(column)

def schema_expression(column)
  super unless column.serial?
end

def schema_type(column)

def schema_type(column)
  return super unless column.serial?
  if column.bigint?
    :bigserial
  else
    :serial
  end
end

def types(stream)

def types(stream)
  types = @connection.enum_types
  if types.any?
    stream.puts "  # Custom types defined in this database."
    stream.puts "  # Note that some types may not work with other database engines. Be careful if changing database."
    types.sort.each do |name, values|
      stream.puts "  create_enum #{name.inspect}, #{values.split(",").inspect}"
    end
    stream.puts
  end
end