Module: ActiveRecord::ConnectionAdapters::CockroachDB::PostgreSQLColumnMonkeyPatch

Included in:
PostgreSQLColumn
Defined in:
lib/active_record/connection_adapters/cockroachdb/column.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#geographicObject (readonly) Also known as: geographic?

Returns the value of attribute geographic.



41
42
43
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 41

def geographic
  @geographic
end

#geometric_typeObject (readonly)

Returns the value of attribute geometric_type.



41
42
43
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 41

def geometric_type
  @geometric_type
end

#has_mObject (readonly) Also known as: has_m?

Returns the value of attribute has_m.



41
42
43
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 41

def has_m
  @has_m
end

#has_zObject (readonly) Also known as: has_z?

Returns the value of attribute has_z.



41
42
43
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 41

def has_z
  @has_z
end

#sridObject (readonly)

Returns the value of attribute srid.



41
42
43
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 41

def srid
  @srid
end

Instance Method Details

#initialize(name, default, sql_type_metadata = nil, null = true, default_function = nil, collation: nil, comment: nil, serial: nil, spatial: nil) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 7

def initialize(name, default,  = nil, null = true,
               default_function = nil, collation: nil, comment: nil,
               serial: nil, spatial: nil)
  @sql_type_metadata = 
  @geographic = !!(.sql_type =~ /geography\(/i)

  if spatial
    # This case comes from an entry in the geometry_columns table
    set_geometric_type_from_name(spatial[:type])
    @srid = spatial[:srid].to_i
    @has_z = !!spatial[:has_z]
    @has_m = !!spatial[:has_m]
  elsif @geographic
    # Geographic type information is embedded in the SQL type
    @srid = 4326
    @has_z = @has_m = false
    build_from_sql_type(.sql_type)
  elsif sql_type =~ /geography|geometry|point|linestring|polygon/i
    build_from_sql_type(.sql_type)
  elsif .sql_type =~ /geography|geometry|point|linestring|polygon/i
    # A geometry column with no geometry_columns entry.
    # @geometric_type = geo_type_from_sql_type(sql_type)
    build_from_sql_type(.sql_type)
  end
  super(name, default, , null, default_function,
    collation: collation, comment: comment, serial: serial)
  if spatial? && @srid
    @limit = { srid: @srid, type: to_type_name(geometric_type) }
    @limit[:has_z] = true if @has_z
    @limit[:has_m] = true if @has_m
    @limit[:geographic] = true if @geographic
  end
end

#limitObject



51
52
53
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 51

def limit
  spatial? ? @limit : super
end

#serial?Boolean

Returns:

  • (Boolean)


59
60
61
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 59

def serial?
  default_function == 'unique_rowid()'
end

#spatial?Boolean

Returns:

  • (Boolean)


55
56
57
# File 'lib/active_record/connection_adapters/cockroachdb/column.rb', line 55

def spatial?
  %i[geometry geography].include?(@sql_type_metadata.type)
end