Module: Mongoid::Criteria::Queryable::Extensions::Object

Defined in:
lib/mongoid/criteria/queryable/extensions/object.rb

Overview

This module contains additional object behaviour.

Defined Under Namespace

Modules: ClassMethods

Instance Method Summary collapse

Instance Method Details

#__add__(object) ⇒ Object

Combine the two objects using the add strategy.

Examples:

Add the object to the array.

[ 1, 2, 3 ].__add__(4)

Parameters:

  • object (Object)

    The object to add.

Returns:

  • (Object)

    The result of the add.

Since:

  • 1.0.0



20
21
22
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 20

def __add__(object)
  (object == self) ? self : [ self, object ].flatten.uniq
end

#__add_from_array__(array) ⇒ Array

Merge this object into the provided array.

Examples:

Merge the object into the array.

4.__add_from_array__([ 1, 2 ])

Parameters:

  • value (Array)

    The array to add to.

Returns:

  • (Array)

    The merged object.

Since:

  • 1.0.0



34
35
36
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 34

def __add_from_array__(array)
  array.concat(Array(self)).uniq
end

#__array__Array

Get the object as an array.

Examples:

Get the object as an array.

4.__array__

Returns:

  • (Array)

    The wrapped object.

Since:

  • 1.0.0



127
128
129
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 127

def __array__
  [ self ]
end

#__deep_copy__Object

Deep copy the object. This is for API compatibility, but needs to be overridden.

Examples:

Deep copy the object.

1.__deep_copy__

Returns:

Since:

  • 1.0.0



117
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 117

def __deep_copy__; self; end

#__expand_complex__Object

Get the object as expanded.

Examples:

Get the object expanded.

obj.__expand_complex__

Returns:

Since:

  • 1.0.5



139
140
141
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 139

def __expand_complex__
  self
end

#__intersect__(object) ⇒ Array

Combine the two objects using the intersect strategy.

Examples:

Add the object to the array.

[ 1, 2, 3 ].__intersect__(4)

Parameters:

  • object (Object)

    The object to intersect.

Returns:

  • (Array)

    The result of the intersect.

Since:

  • 1.0.0



48
49
50
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 48

def __intersect__(object)
  object.__intersect_from_object__(self)
end

#__intersect_from_array__(array) ⇒ Array

Merge this object into the provided array.

Examples:

Merge the object into the array.

4.__intersect_from_array__([ 1, 2 ])

Parameters:

  • value (Array)

    The array to intersect to.

Returns:

  • (Array)

    The merged object.

Since:

  • 1.0.0



62
63
64
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 62

def __intersect_from_array__(array)
  array & Array(self)
end

#__intersect_from_object__(object) ⇒ Array

Merge this object into the provided array.

Examples:

Merge the object into the array.

4.__intersect_from_object__([ 1, 2 ])

Parameters:

  • value (Object)

    The value to intersect to.

Returns:

  • (Array)

    The merged object.

Since:

  • 1.0.0



76
77
78
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 76

def __intersect_from_object__(object)
  Array(object) & Array(self)
end

#__union__(object) ⇒ Array

Combine the two objects using the union strategy.

Examples:

Add the object to the array.

[ 1, 2, 3 ].__union__(4)

Parameters:

  • object (Object)

    The object to union.

Returns:

  • (Array)

    The result of the union.

Since:

  • 1.0.0



90
91
92
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 90

def __union__(object)
  object.__union_from_object__(self)
end

#__union_from_object__(object) ⇒ Array

Merge this object into the provided array.

Examples:

Merge the object into the array.

4.__union_from_object__([ 1, 2 ])

Parameters:

  • value (Object)

    The value to union to.

Returns:

  • (Array)

    The merged object.

Since:

  • 1.0.0



104
105
106
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 104

def __union_from_object__(object)
  (Array(object) + Array(self)).uniq
end

#regexp?false

Is the object a regex.

Examples:

Is the object a regex?

obj.regexp?

Returns:

  • (false)

    Always false.

Since:

  • 1.0.4



151
152
153
# File 'lib/mongoid/criteria/queryable/extensions/object.rb', line 151

def regexp?
  false
end