Module: MigrationComments::ActiveRecord::ConnectionAdapters::AbstractAdapter::SchemaCreation

Defined in:
lib/migration_comments/active_record/connection_adapters/abstract_adapter/schema_creation.rb

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.included(base) ⇒ Object



3
4
5
6
7
8
9
# File 'lib/migration_comments/active_record/connection_adapters/abstract_adapter/schema_creation.rb', line 3

def self.included(base)
  base.class_eval do
    alias_method_chain :column_options, :migration_comments
    alias_method_chain :visit_TableDefinition, :migration_comments
    alias_method_chain :visit_ColumnDefinition, :migration_comments
  end
end

Instance Method Details

#column_options_with_migration_comments(o) ⇒ Object



11
12
13
14
15
# File 'lib/migration_comments/active_record/connection_adapters/abstract_adapter/schema_creation.rb', line 11

def column_options_with_migration_comments(o)
  column_options = o.primary_key? ? {} : column_options_without_migration_comments(o)
  column_options[:comment] = o.comment.comment_text if o.comment
  column_options
end

#visit_ColumnDefinition_with_migration_comments(o) ⇒ Object



29
30
31
32
33
34
35
36
37
38
# File 'lib/migration_comments/active_record/connection_adapters/abstract_adapter/schema_creation.rb', line 29

def visit_ColumnDefinition_with_migration_comments(o)
  if @conn.inline_comments?
    sql_type = type_to_sql(o.type.to_sym, o.limit, o.precision, o.scale)
    column_sql = "#{quote_column_name(o.name)} #{sql_type}"
    add_column_options!(column_sql, column_options(o))
    column_sql
  else
    visit_ColumnDefinition_without_migration_comments(o)
  end
end

#visit_TableDefinition_with_migration_comments(o) ⇒ Object



17
18
19
20
21
22
23
24
25
26
27
# File 'lib/migration_comments/active_record/connection_adapters/abstract_adapter/schema_creation.rb', line 17

def visit_TableDefinition_with_migration_comments(o)
  if @conn.inline_comments?
    create_sql = "CREATE#{' TEMPORARY' if o.temporary} TABLE "
    create_sql << "#{quote_table_name(o.name)}#{o.table_comment} ("
    create_sql << o.columns.map { |c| accept c }.join(', ')
    create_sql << ") #{o.options}"
    create_sql
  else
    visit_TableDefinition_without_migration_comments(o)
  end
end