Module: ActiveRecord::Type

Defined in:
activerecord/lib/active_record/type/adapter_specific_registry.rb,
activerecord/lib/active_record/type.rb,
activerecord/lib/active_record/type/date.rb,
activerecord/lib/active_record/type/time.rb,
activerecord/lib/active_record/type/type_map.rb,
activerecord/lib/active_record/type/date_time.rb,
activerecord/lib/active_record/type/serialized.rb,
activerecord/lib/active_record/type/internal/timezone.rb,
activerecord/lib/active_record/type/hash_lookup_type_map.rb,
activerecord/lib/active_record/type/internal/abstract_json.rb

Overview

:stopdoc:

Defined Under Namespace

Modules: Internal Classes: AdapterSpecificRegistry, Date, DateTime, DecorationRegistration, HashLookupTypeMap, Registration, Serialized, Time, TypeMap

Constant Summary collapse

Helpers =
ActiveModel::Type::Helpers
BigInteger =
ActiveModel::Type::BigInteger
Binary =
ActiveModel::Type::Binary
Boolean =
ActiveModel::Type::Boolean
Decimal =
ActiveModel::Type::Decimal
DecimalWithoutScale =
ActiveModel::Type::DecimalWithoutScale
Float =
ActiveModel::Type::Float
Integer =
ActiveModel::Type::Integer
String =
ActiveModel::Type::String
Text =
ActiveModel::Type::Text
UnsignedInteger =
ActiveModel::Type::UnsignedInteger
Value =
ActiveModel::Type::Value

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.registryObject

:nodoc:


21
22
23
# File 'activerecord/lib/active_record/type.rb', line 21

def registry
  @registry
end

Class Method Details

.lookup(*args, adapter: current_adapter_name, **kwargs) ⇒ Object

:nodoc:


36
37
38
# File 'activerecord/lib/active_record/type.rb', line 36

def lookup(*args, adapter: current_adapter_name, **kwargs) # :nodoc:
  registry.lookup(*args, adapter: adapter, **kwargs)
end

.register(type_name, klass = nil, **options, &block) ⇒ Object

Add a new type to the registry, allowing it to be referenced as a symbol by ActiveRecord::Base.attribute. If your type is only meant to be used with a specific database adapter, you can do so by passing adapter: :postgresql. If your type has the same name as a native type for the current adapter, an exception will be raised unless you specify an :override option. override: true will cause your type to be used instead of the native type. override: false will cause the native type to be used over yours if one exists.


32
33
34
# File 'activerecord/lib/active_record/type.rb', line 32

def register(type_name, klass = nil, **options, &block)
  registry.register(type_name, klass, **options, &block)
end