Module: Mongoid::Document::ClassMethods

Defined in:
lib/mongoid/document.rb

Overview

:nodoc:

Instance Method Summary collapse

Instance Method Details

#===(other) ⇒ true, false

Performs class equality checking.

Examples:

Compare the classes.

document === other

Parameters:

Returns:

  • (true, false)

    True if the classes are equal, false if not.

Since:

  • 2.0.0.rc.4



227
228
229
# File 'lib/mongoid/document.rb', line 227

def ===(other)
  self == (other.is_a?(Class) ? other : other.class)
end

#_typesArray<Class>

Returns all types to query for when using this class as the base.

Examples:

Get the types.

document._types

Returns:

  • (Array<Class>)

    All subclasses of the current document.



256
257
258
# File 'lib/mongoid/document.rb', line 256

def _types
  @_type ||= [descendants + [self]].flatten.uniq.map { |t| t.to_s }
end

#i18n_scopeSymbol

Set the i18n scope to overwrite ActiveModel.

Returns:



263
264
265
# File 'lib/mongoid/document.rb', line 263

def i18n_scope
  :mongoid
end

#instantiate(attrs = nil) ⇒ Document

Instantiate a new object, only when loaded from the database or when the attributes have already been typecast.

Examples:

Create the document.

Person.instantiate(:title => "Sir", :age => 30)

Parameters:

  • attrs (Hash) (defaults to: nil)

    The hash of attributes to instantiate with.

Returns:



240
241
242
243
244
245
246
247
248
# File 'lib/mongoid/document.rb', line 240

def instantiate(attrs = nil)
  attributes = attrs || {}
  allocate.tap do |doc|
    doc.instance_variable_set(:@attributes, attributes)
    doc.send(:apply_defaults)
    IdentityMap.set(doc) unless _loading_revision?
    doc.run_callbacks(:initialize) { doc }
  end
end

#loggerLogger

Returns the logger

Examples:

Get the logger.

Person.logger

Returns:

  • (Logger)

    The configured logger or a default Logger instance.

Since:

  • 2.2.0



275
276
277
# File 'lib/mongoid/document.rb', line 275

def logger
  Mongoid.logger
end