ActiveRecord::Type::Value (original) (raw)

Active Model Value Type

The base class for all attribute types. This class also serves as the default type for attributes that do not specify a type.

Methods

A

C

D

E

H

N

S

T

Included Modules

Attributes

[R] limit
[R] precision
[R] scale

Class Public methods

Initializes a type with three basic configuration settings: precision, limit, and scale. The Value base class does not define behavior for these settings. It uses them for equality comparison and hash key generation only.

Source: show | on GitHub

def initialize(precision: nil, limit: nil, scale: nil) super() @precision = precision @scale = scale @limit = limit end

Instance Public methods

Also aliased as: eql?

Source: show | on GitHub

def ==(other) self.class == other.class && precision == other.precision && scale == other.scale && limit == other.limit end

Type casts a value from user input (e.g. from a setter). This value may be a string from the form builder, or a ruby object passed to a setter. There is currently no way to differentiate between which source it came from.

The return value of this method will be returned from ActiveRecord::AttributeMethods::Read#read_attribute. See also: Value#cast_value.

value The raw input, as provided to the attribute setter.

Source: show | on GitHub

def cast(value) cast_value(value) unless value.nil? end

Determines whether a value has changed for dirty checking. old_value and new_value will always be type-cast. Types should not need to override this method.

Source: show | on GitHub

def changed?(old_value, new_value, _new_value_before_type_cast) old_value != new_value end

Determines whether the mutable value has been modified since it was read. Returns false by default. If your type returns an object which could be mutated, you should override this method. You will need to either:

or

raw_old_value The original value, before being passed to deserialize.

new_value The current value, after type casting.

Source: show | on GitHub

def changed_in_place?(raw_old_value, new_value) false end

Alias for: ==

Source: show | on GitHub

def hash [self.class, precision, scale, limit].hash end

Returns true if this type can convert value to a type that is usable by the database. For example a boolean type can return true if the value parameter is a Ruby boolean, but may return false if the value parameter is some other object.

Casts a value from the ruby type to a type that the database knows how to understand. The returned value from this method should be a String, Numeric, Date, Time, Symbol, true, false, or nil.

Returns the unique type name as a Symbol. Subclasses should override this method.

Instance Private methods

Convenience method for types which do not need separate type casting behavior for user and database inputs. Called by Value#cast for values except nil.