Class: Mongoid::Association::Embedded::EmbeddedIn::Proxy
- Defined in:
- lib/mongoid/association/embedded/embedded_in/proxy.rb
Overview
Instance Attribute Summary
Attributes inherited from Proxy
#_association, #_base, #_target
Class Method Summary collapse
-
.embedded? ⇒ true
Returns true if the association is an embedded one.
-
.path(document) ⇒ Root
Get the path calculator for the supplied document.
Instance Method Summary collapse
-
#initialize(base, target, association) ⇒ In
constructor
Instantiate a new embedded_in association.
-
#substitute(replacement) ⇒ Document?
Substitutes the supplied target documents for the existing document in the association.
Methods inherited from One
#__evolve_object_id__, #clear, #in_memory, #respond_to?
Methods inherited from Proxy
apply_ordering, #extend_proxies, #init, #klass, #reset_unloaded, #substitutable
Methods included from Marshalable
Constructor Details
#initialize(base, target, association) ⇒ In
Instantiate a new embedded_in association.
21 22 23 24 25 26 |
# File 'lib/mongoid/association/embedded/embedded_in/proxy.rb', line 21 def initialize(base, target, association) init(base, target, association) do characterize_one(_target) bind_one end end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Mongoid::Association::Proxy
Class Method Details
.embedded? ⇒ true
Returns true if the association is an embedded one. In this case always true.
102 103 104 |
# File 'lib/mongoid/association/embedded/embedded_in/proxy.rb', line 102 def true end |
Instance Method Details
#substitute(replacement) ⇒ Document?
Substitutes the supplied target documents for the existing document in the association.
39 40 41 42 43 44 45 46 47 48 49 |
# File 'lib/mongoid/association/embedded/embedded_in/proxy.rb', line 39 def substitute(replacement) unbind_one unless replacement _base.delete if persistable? return nil end _base.new_record = true self._target = replacement bind_one self end |