Module: Mongoid::Traversable::ClassMethods

Defined in:
lib/mongoid/traversable.rb

Overview

Since:

  • 4.0.0

Instance Method Summary collapse

Instance Method Details

#hereditary?true, false

Determines if the document is a subclass of another document.

Examples:

Check if the document is a subclass.

Square.hereditary?

Returns:

  • (true, false)

    True if hereditary, false if not.

Since:

  • 4.0.0



178
179
180
# File 'lib/mongoid/traversable.rb', line 178

def hereditary?
  !!(Mongoid::Document > superclass)
end

#inherited(subclass) ⇒ Object

When inheriting, we want to copy the fields from the parent class and set the on the child to start, mimicking the behaviour of the old class_inheritable_accessor that was deprecated in Rails edge.

Examples:

Inherit from this class.

Person.inherited(Doctor)

Parameters:

  • subclass (Class)

    The inheriting class.

Since:

  • 2.0.0.rc.6



192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
# File 'lib/mongoid/traversable.rb', line 192

def inherited(subclass)
  super
  @_type = nil
  subclass.aliased_fields = aliased_fields.dup
  subclass.localized_fields = localized_fields.dup
  subclass.fields = fields.dup
  subclass.pre_processed_defaults = pre_processed_defaults.dup
  subclass.post_processed_defaults = post_processed_defaults.dup
  subclass._declared_scopes = Hash.new { |hash,key| self._declared_scopes[key] }

  # We only need the _type field if inheritance is in play, but need to
  # add to the root class as well for backwards compatibility.
  unless fields.has_key?("_type")
    field(:_type, default: self.name, type: String)
  end
  subclass_default = subclass.name || ->{ self.class.name }
  subclass.field(:_type, default: subclass_default, type: String, overwrite: true)
end