module Mongoid::Traversable::ClassMethods
Public Instance Methods
hereditary?()
click to toggle source
Determines if the document is a subclass of another document.
@example Check if the document is a subclass.
Square.hereditary?
@return [ true, false ] True if hereditary, false if not.
# File lib/mongoid/traversable.rb, line 158 def hereditary? Mongoid::Document > superclass end
inherited(subclass)
click to toggle source
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.
@example Inherit from this class.
Person.inherited(Doctor)
@param [ Class ] subclass The inheriting class.
@since 2.0.0.rc.6
Calls superclass method
# File lib/mongoid/traversable.rb, line 172 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