Class: ActiveRecord::ConnectionAdapters::PostgreSQL::OID::Point
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Instance Chain:
|
|
Inherits: |
ActiveModel::Type::Value
|
Defined in: | activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb |
Class Method Summary
::ActiveModel::Type::Value
- Inherited
.new | Initializes a type with three basic configuration settings: precision, limit, and scale. |
Instance Attribute Summary
::ActiveModel::Type::Helpers::Mutable
- Included
::ActiveModel::Type::Value
- Inherited
#limit, #precision, #scale, | |
#binary? | These predicates are not documented, as I need to look further into their use, and see if they can be removed entirely. |
#mutable?, #serialized? |
Instance Method Summary
- #cast(value)
- #serialize(value)
- #type
- #type_cast_for_schema(value)
- #build_point(x, y) private
- #number_for_point(number) private
::ActiveModel::Type::Helpers::Mutable
- Included
#cast, | |
#changed_in_place? |
|
::ActiveModel::Type::Value
- Inherited
#==, #as_json, #assert_valid_value, | |
#cast |
|
#changed? | Determines whether a value has changed for dirty checking. |
#changed_in_place? | Determines whether the mutable value has been modified since it was read. |
#deserialize | Converts a value from database input to the appropriate ruby type. |
#eql? | Alias for ActiveModel::Type::Value#==. |
#hash, | |
#serializable? | Returns true if this type can convert |
#serialize | Casts a value from the ruby type to a type that the database knows how to understand. |
#type | Returns the unique type name as a |
#cast_value | Convenience method for types which do not need separate type casting behavior for user and database inputs. |
#force_equality?, #map, | |
#type_cast_for_schema |
|
#value_constructed_by_mass_assignment? |
::ActiveModel::Type::SerializeCastValue
- Included
Constructor Details
This class inherits a constructor from ActiveModel::Type::Value
Instance Method Details
#build_point(x, y) (private)
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 57
def build_point(x, y) ActiveRecord::Point.new(Float(x), Float(y)) end
#cast(value)
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 16
def cast(value) case value when ::String return if value.blank? if value.start_with?("(") && value.end_with?(")") value = value[1...-1] end x, y = value.split(",") build_point(x, y) when ::Array build_point(*value) else value end end
#number_for_point(number) (private)
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 53
def number_for_point(number) number.to_s.delete_suffix(".0") end
#serialize(value)
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 33
def serialize(value) case value when ActiveRecord::Point "(#{number_for_point(value.x)},#{number_for_point(value.y)})" when ::Array serialize(build_point(*value)) else super end end
#type
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 12
def type :point end
#type_cast_for_schema(value)
[ GitHub ]# File 'activerecord/lib/active_record/connection_adapters/postgresql/oid/point.rb', line 44
def type_cast_for_schema(value) if ActiveRecord::Point === value [value.x, value.y] else super end end