mongoid 8.0.1 → 8.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (144) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/lib/config/locales/en.yml +1 -0
  4. data/lib/mongoid/association/accessors.rb +6 -6
  5. data/lib/mongoid/association/bindable.rb +2 -2
  6. data/lib/mongoid/association/constrainable.rb +0 -1
  7. data/lib/mongoid/association/embedded/batchable.rb +5 -5
  8. data/lib/mongoid/association/embedded/cyclic.rb +1 -1
  9. data/lib/mongoid/association/embedded/embedded_in/proxy.rb +2 -2
  10. data/lib/mongoid/association/embedded/embedded_in.rb +1 -1
  11. data/lib/mongoid/association/embedded/embeds_many/proxy.rb +10 -10
  12. data/lib/mongoid/association/embedded/embeds_many.rb +2 -2
  13. data/lib/mongoid/association/embedded/embeds_one/proxy.rb +2 -2
  14. data/lib/mongoid/association/embedded/embeds_one.rb +3 -3
  15. data/lib/mongoid/association/many.rb +6 -7
  16. data/lib/mongoid/association/nested/many.rb +3 -3
  17. data/lib/mongoid/association/nested/nested_buildable.rb +4 -4
  18. data/lib/mongoid/association/nested/one.rb +5 -5
  19. data/lib/mongoid/association/one.rb +2 -2
  20. data/lib/mongoid/association/options.rb +9 -9
  21. data/lib/mongoid/association/proxy.rb +2 -3
  22. data/lib/mongoid/association/referenced/auto_save.rb +1 -1
  23. data/lib/mongoid/association/referenced/belongs_to/proxy.rb +5 -6
  24. data/lib/mongoid/association/referenced/belongs_to.rb +1 -1
  25. data/lib/mongoid/association/referenced/counter_cache.rb +2 -2
  26. data/lib/mongoid/association/referenced/eager.rb +2 -2
  27. data/lib/mongoid/association/referenced/has_and_belongs_to_many/proxy.rb +2 -2
  28. data/lib/mongoid/association/referenced/has_and_belongs_to_many.rb +2 -2
  29. data/lib/mongoid/association/referenced/has_many/enumerable.rb +10 -10
  30. data/lib/mongoid/association/referenced/has_many/proxy.rb +12 -9
  31. data/lib/mongoid/association/referenced/has_many.rb +3 -3
  32. data/lib/mongoid/association/referenced/has_one/nested_builder.rb +5 -5
  33. data/lib/mongoid/association/referenced/has_one/proxy.rb +1 -1
  34. data/lib/mongoid/association/referenced/has_one.rb +3 -3
  35. data/lib/mongoid/association/referenced/syncable.rb +2 -2
  36. data/lib/mongoid/association/reflections.rb +2 -2
  37. data/lib/mongoid/association/relatable.rb +6 -6
  38. data/lib/mongoid/association.rb +5 -5
  39. data/lib/mongoid/atomic/modifiers.rb +2 -2
  40. data/lib/mongoid/attributes/dynamic.rb +3 -3
  41. data/lib/mongoid/attributes/nested.rb +5 -5
  42. data/lib/mongoid/attributes/processing.rb +1 -1
  43. data/lib/mongoid/attributes/projector.rb +1 -1
  44. data/lib/mongoid/attributes/readonly.rb +2 -2
  45. data/lib/mongoid/attributes.rb +13 -13
  46. data/lib/mongoid/changeable.rb +5 -5
  47. data/lib/mongoid/clients/options.rb +1 -1
  48. data/lib/mongoid/clients/validators/storage.rb +3 -3
  49. data/lib/mongoid/config/validators/client.rb +6 -6
  50. data/lib/mongoid/config.rb +7 -7
  51. data/lib/mongoid/contextual/aggregable/memory.rb +1 -1
  52. data/lib/mongoid/contextual/aggregable/mongo.rb +4 -4
  53. data/lib/mongoid/contextual/aggregable/none.rb +1 -1
  54. data/lib/mongoid/contextual/atomic.rb +1 -1
  55. data/lib/mongoid/contextual/geo_near.rb +7 -7
  56. data/lib/mongoid/contextual/memory.rb +5 -5
  57. data/lib/mongoid/contextual/mongo.rb +14 -14
  58. data/lib/mongoid/contextual/none.rb +2 -2
  59. data/lib/mongoid/contextual/queryable.rb +1 -1
  60. data/lib/mongoid/contextual.rb +2 -2
  61. data/lib/mongoid/criteria/findable.rb +7 -4
  62. data/lib/mongoid/criteria/includable.rb +1 -1
  63. data/lib/mongoid/criteria/permission.rb +1 -1
  64. data/lib/mongoid/criteria/queryable/aggregable.rb +2 -2
  65. data/lib/mongoid/criteria/queryable/extensions/boolean.rb +1 -1
  66. data/lib/mongoid/criteria/queryable/extensions/regexp.rb +2 -2
  67. data/lib/mongoid/criteria/queryable/extensions/set.rb +1 -1
  68. data/lib/mongoid/criteria/queryable/extensions/string.rb +3 -3
  69. data/lib/mongoid/criteria/queryable/extensions/symbol.rb +1 -1
  70. data/lib/mongoid/criteria/queryable/key.rb +3 -3
  71. data/lib/mongoid/criteria/queryable/optional.rb +2 -2
  72. data/lib/mongoid/criteria/queryable/options.rb +1 -1
  73. data/lib/mongoid/criteria/queryable/pipeline.rb +1 -1
  74. data/lib/mongoid/criteria/queryable/selectable.rb +3 -3
  75. data/lib/mongoid/criteria/queryable/selector.rb +3 -3
  76. data/lib/mongoid/criteria/queryable/smash.rb +1 -1
  77. data/lib/mongoid/criteria/queryable.rb +1 -1
  78. data/lib/mongoid/criteria/scopable.rb +2 -2
  79. data/lib/mongoid/criteria.rb +14 -9
  80. data/lib/mongoid/deprecable.rb +1 -1
  81. data/lib/mongoid/document.rb +2 -2
  82. data/lib/mongoid/equality.rb +12 -12
  83. data/lib/mongoid/errors/document_not_found.rb +5 -5
  84. data/lib/mongoid/errors/invalid_config_option.rb +1 -1
  85. data/lib/mongoid/errors/invalid_dependent_strategy.rb +1 -1
  86. data/lib/mongoid/errors/invalid_field.rb +1 -1
  87. data/lib/mongoid/errors/invalid_relation.rb +1 -1
  88. data/lib/mongoid/errors/invalid_relation_option.rb +1 -1
  89. data/lib/mongoid/errors/invalid_session_use.rb +1 -1
  90. data/lib/mongoid/errors/invalid_storage_options.rb +1 -1
  91. data/lib/mongoid/errors/mongoid_error.rb +3 -3
  92. data/lib/mongoid/errors/nested_attributes_metadata_not_found.rb +1 -1
  93. data/lib/mongoid/errors/no_client_database.rb +1 -1
  94. data/lib/mongoid/errors/no_client_hosts.rb +1 -1
  95. data/lib/mongoid/errors/readonly_attribute.rb +1 -1
  96. data/lib/mongoid/errors/unknown_attribute.rb +1 -1
  97. data/lib/mongoid/extensions/array.rb +1 -1
  98. data/lib/mongoid/extensions/false_class.rb +1 -1
  99. data/lib/mongoid/extensions/hash.rb +1 -1
  100. data/lib/mongoid/extensions/module.rb +1 -1
  101. data/lib/mongoid/extensions/object.rb +6 -6
  102. data/lib/mongoid/extensions/string.rb +9 -9
  103. data/lib/mongoid/extensions/symbol.rb +1 -1
  104. data/lib/mongoid/extensions/true_class.rb +1 -1
  105. data/lib/mongoid/fields/foreign_key.rb +4 -4
  106. data/lib/mongoid/fields/localized.rb +2 -2
  107. data/lib/mongoid/fields/standard.rb +7 -7
  108. data/lib/mongoid/fields.rb +9 -9
  109. data/lib/mongoid/findable.rb +7 -6
  110. data/lib/mongoid/indexable/specification.rb +1 -1
  111. data/lib/mongoid/indexable/validators/options.rb +2 -1
  112. data/lib/mongoid/interceptable.rb +4 -4
  113. data/lib/mongoid/matchable.rb +1 -1
  114. data/lib/mongoid/matcher.rb +12 -7
  115. data/lib/mongoid/persistable/creatable.rb +4 -4
  116. data/lib/mongoid/persistable/deletable.rb +1 -1
  117. data/lib/mongoid/persistable/destroyable.rb +1 -1
  118. data/lib/mongoid/persistable/savable.rb +2 -2
  119. data/lib/mongoid/persistable/unsettable.rb +1 -1
  120. data/lib/mongoid/persistable/updatable.rb +7 -7
  121. data/lib/mongoid/persistable/upsertable.rb +1 -1
  122. data/lib/mongoid/persistable.rb +3 -3
  123. data/lib/mongoid/persistence_context.rb +3 -3
  124. data/lib/mongoid/query_cache.rb +2 -2
  125. data/lib/mongoid/scopable.rb +17 -15
  126. data/lib/mongoid/serializable.rb +10 -6
  127. data/lib/mongoid/stateful.rb +10 -10
  128. data/lib/mongoid/tasks/database.rb +0 -2
  129. data/lib/mongoid/threaded/lifecycle.rb +5 -5
  130. data/lib/mongoid/threaded.rb +9 -9
  131. data/lib/mongoid/timestamps/updated.rb +1 -1
  132. data/lib/mongoid/traversable.rb +3 -3
  133. data/lib/mongoid/validatable/localizable.rb +1 -1
  134. data/lib/mongoid/validatable/macros.rb +0 -2
  135. data/lib/mongoid/validatable/presence.rb +2 -2
  136. data/lib/mongoid/validatable/uniqueness.rb +7 -7
  137. data/lib/mongoid/validatable.rb +6 -6
  138. data/lib/mongoid/version.rb +1 -1
  139. data/spec/mongoid/equality_spec.rb +12 -12
  140. data/spec/mongoid/indexable_spec.rb +23 -1
  141. data/spec/mongoid/scopable_spec.rb +34 -16
  142. data.tar.gz.sig +0 -0
  143. metadata +2 -2
  144. metadata.gz.sig +0 -0
@@ -13,7 +13,7 @@ module Mongoid
13
13
  # @example Reset the given counter cache
14
14
  # post.reset_counters(:comments)
15
15
  #
16
- # @param [ Symbol, Array ] counters One or more counter caches to reset
16
+ # @param [ Symbol | Array ] counters One or more counter caches to reset
17
17
  def reset_counters(*counters)
18
18
  self.class.with(persistence_context) do |_class|
19
19
  _class.reset_counters(self, *counters)
@@ -30,7 +30,7 @@ module Mongoid
30
30
  # Post.reset_counters('50e0edd97c71c17ea9000001', :comments)
31
31
  #
32
32
  # @param [ String ] id The id of the object that will be reset.
33
- # @param [ Symbol, Array ] counters One or more counter caches to reset
33
+ # @param [ Symbol | Array ] counters One or more counter caches to reset
34
34
  def reset_counters(id, *counters)
35
35
  document = id.is_a?(Document) ? id : find(id)
36
36
  counters.each do |name|
@@ -85,7 +85,7 @@ module Mongoid
85
85
  # loader.set_on_parent("foo", docs)
86
86
  #
87
87
  # @param [ ObjectId ] id parent`s id
88
- # @param [ Document, Array ] element to push into the parent
88
+ # @param [ Document | Array ] element to push into the parent
89
89
  def set_on_parent(id, element)
90
90
  grouped_docs[id].each do |d|
91
91
  set_relation(d, element)
@@ -140,7 +140,7 @@ module Mongoid
140
140
  # loader.set_relation(doc, docs)
141
141
  #
142
142
  # @param [ Document ] doc The object to set the association on
143
- # @param [ Document, Array ] element to set into the parent
143
+ # @param [ Document | Array ] element to set into the parent
144
144
  def set_relation(doc, element)
145
145
  doc.set_relation(@association.name, element) unless doc.blank?
146
146
  end
@@ -21,7 +21,7 @@ module Mongoid
21
21
  # @example Concat with other documents.
22
22
  # person.posts.concat([ post_one, post_two ])
23
23
  #
24
- # @param [ Document, Array<Document> ] args Any number of documents.
24
+ # @param [ Document | Array<Document> ] args Any number of documents.
25
25
  #
26
26
  # @return [ Array<Document> ] The loaded docs.
27
27
  def <<(*args)
@@ -282,7 +282,7 @@ module Mongoid
282
282
  #
283
283
  # @param [ Document ] doc The document.
284
284
  #
285
- # @return [ true, false ] If the document can be persisted.
285
+ # @return [ true | false ] If the document can be persisted.
286
286
  def child_persistable?(doc)
287
287
  (persistable? || _creating?) &&
288
288
  !(doc.persisted? && _association.forced_nil_inverse?)
@@ -78,7 +78,7 @@ module Mongoid
78
78
 
79
79
  # Are ids only saved on this side of the association?
80
80
  #
81
- # @return [ true, false ] Whether this association has a forced nil inverse.
81
+ # @return [ true | false ] Whether this association has a forced nil inverse.
82
82
  def forced_nil_inverse?
83
83
  @forced_nil_inverse ||= @options.key?(:inverse_of) && !@options[:inverse_of]
84
84
  end
@@ -131,7 +131,7 @@ module Mongoid
131
131
  #
132
132
  # @param [ Document ] doc The document to be bound.
133
133
  #
134
- # @return [ true, false ] Whether the document can be bound.
134
+ # @return [ true | false ] Whether the document can be bound.
135
135
  def bindable?(doc)
136
136
  forced_nil_inverse? || (!!inverse && doc.fields.keys.include?(foreign_key))
137
137
  end
@@ -28,7 +28,7 @@ module Mongoid
28
28
  #
29
29
  # @param [ Enumerable ] other The other enumerable.
30
30
  #
31
- # @return [ true, false ] If the objects are equal.
31
+ # @return [ true | false ] If the objects are equal.
32
32
  def ==(other)
33
33
  return false unless other.respond_to?(:entries)
34
34
  entries == other.entries
@@ -42,7 +42,7 @@ module Mongoid
42
42
  #
43
43
  # @param [ Object ] other The object to check.
44
44
  #
45
- # @return [ true, false ] If the objects are equal in a case.
45
+ # @return [ true | false ] If the objects are equal in a case.
46
46
  def ===(other)
47
47
  return false unless other.respond_to?(:entries)
48
48
  if Mongoid.legacy_triple_equals
@@ -192,7 +192,7 @@ module Mongoid
192
192
  # @example Is the enumerable empty?
193
193
  # enumerable.empty?
194
194
  #
195
- # @return [ true, false ] If the enumerable is empty.
195
+ # @return [ true | false ] If the enumerable is empty.
196
196
  def empty?
197
197
  if _loaded?
198
198
  in_memory.empty?
@@ -224,7 +224,7 @@ module Mongoid
224
224
  # @param [ Object ] condition The condition that documents
225
225
  # must satisfy. See Enumerable documentation for details.
226
226
  #
227
- # @return [ true, false ] If the association has any documents.
227
+ # @return [ true | false ] If the association has any documents.
228
228
  def any?(*args)
229
229
  return super if args.any? || block_given?
230
230
 
@@ -261,7 +261,7 @@ module Mongoid
261
261
  # @example Initialize the enumerable with an array.
262
262
  # Enumerable.new([ post ])
263
263
  #
264
- # @param [ Criteria, Array<Document> ] target The wrapped object.
264
+ # @param [ Criteria | Array<Document> ] target The wrapped object.
265
265
  def initialize(target, base = nil, association = nil)
266
266
  @_base = base
267
267
  @_association = association
@@ -283,7 +283,7 @@ module Mongoid
283
283
  #
284
284
  # @param [ Document ] doc The document to check.
285
285
  #
286
- # @return [ true, false ] If the document is in the target.
286
+ # @return [ true | false ] If the document is in the target.
287
287
  def include?(doc)
288
288
  return super unless _unloaded
289
289
  _unloaded.where(_id: doc._id).exists? || _added.has_key?(doc._id)
@@ -352,7 +352,7 @@ module Mongoid
352
352
  # @example Is the enumerable _loaded?
353
353
  # enumerable._loaded?
354
354
  #
355
- # @return [ true, false ] If the enumerable has been _loaded.
355
+ # @return [ true | false ] If the enumerable has been _loaded.
356
356
  def _loaded?
357
357
  !!@executed
358
358
  end
@@ -405,11 +405,11 @@ module Mongoid
405
405
  # @example Does the enumerable respond to the method?
406
406
  # enumerable.respond_to?(:sum)
407
407
  #
408
- # @param [ String, Symbol ] name The name of the method.
409
- # @param [ true, false ] include_private Whether to include private
408
+ # @param [ String | Symbol ] name The name of the method.
409
+ # @param [ true | false ] include_private Whether to include private
410
410
  # methods.
411
411
  #
412
- # @return [ true, false ] Whether the enumerable responds.
412
+ # @return [ true | false ] Whether the enumerable responds.
413
413
  def respond_to?(name, include_private = false)
414
414
  [].respond_to?(name, include_private) || super
415
415
  end
@@ -25,7 +25,7 @@ module Mongoid
25
25
  # @example Concat with other documents.
26
26
  # person.posts.concat([ post_one, post_two ])
27
27
  #
28
- # @param [ Document, Array<Document> ] args Any number of documents.
28
+ # @param [ Document | Array<Document> ] args Any number of documents.
29
29
  #
30
30
  # @return [ Array<Document> ] The loaded docs.
31
31
  def <<(*args)
@@ -168,7 +168,7 @@ module Mongoid
168
168
  # @example Are there persisted documents?
169
169
  # person.posts.exists?
170
170
  #
171
- # @return [ true, false ] True is persisted documents exist, false if not.
171
+ # @return [ true | false ] True is persisted documents exist, false if not.
172
172
  def exists?
173
173
  criteria.exists?
174
174
  end
@@ -184,6 +184,9 @@ module Mongoid
184
184
  # of those found by the current Criteria object for which the block
185
185
  # returns a truthy value.
186
186
  #
187
+ # @note Each argument can be an individual id, an array of ids or
188
+ # a nested array. Each array will be flattened.
189
+ #
187
190
  # @example Find by an id.
188
191
  # person.posts.find(BSON::ObjectId.new)
189
192
  #
@@ -196,7 +199,7 @@ module Mongoid
196
199
  # @note This will keep matching documents in memory for iteration
197
200
  # later.
198
201
  #
199
- # @param [ BSON::ObjectId, Array<BSON::ObjectId> ] args The ids.
202
+ # @param [ Object | Array<Object> ] *args The ids.
200
203
  # @param [ Proc ] block Optional block to pass.
201
204
  #
202
205
  # @return [ Document | Array<Document> | nil ] A document or matching documents.
@@ -328,7 +331,7 @@ module Mongoid
328
331
  # relation.with_add_callbacks(document, false)
329
332
  #
330
333
  # @param [ Document ] document The document to append to the target.
331
- # @param [ true, false ] already_related Whether the document is already related
334
+ # @param [ true | false ] already_related Whether the document is already related
332
335
  # to the target.
333
336
  def with_add_callbacks(document, already_related)
334
337
  execute_callback :before_add, document unless already_related
@@ -343,7 +346,7 @@ module Mongoid
343
346
  #
344
347
  # @param [ Document ] document The document to possibly append to the target.
345
348
  #
346
- # @return [ true, false ] Whether the document is already related to the base and the
349
+ # @return [ true | false ] Whether the document is already related to the base and the
347
350
  # association is persisted.
348
351
  def already_related?(document)
349
352
  document.persisted? &&
@@ -391,7 +394,7 @@ module Mongoid
391
394
  #
392
395
  # @param [ Document ] document The document to cascade on.
393
396
  #
394
- # @return [ true, false ] If the association is destructive.
397
+ # @return [ true | false ] If the association is destructive.
395
398
  def cascade!(document)
396
399
  if persistable?
397
400
  case _association.dependent
@@ -410,11 +413,11 @@ module Mongoid
410
413
  #
411
414
  # If the method exists on the array, use the default proxy behavior.
412
415
  #
413
- # @param [ Symbol, String ] name The name of the method.
416
+ # @param [ Symbol | String ] name The name of the method.
414
417
  # @param [ Array ] args The method args
415
418
  # @param [ Proc ] block Optional block to pass.
416
419
  #
417
- # @return [ Criteria, Object ] A Criteria or return value from the target.
420
+ # @return [ Criteria | Object ] A Criteria or return value from the target.
418
421
  ruby2_keywords def method_missing(name, *args, &block)
419
422
  if _target.respond_to?(name)
420
423
  _target.send(name, *args, &block)
@@ -450,7 +453,7 @@ module Mongoid
450
453
  # @example Can we persist the association?
451
454
  # relation.persistable?
452
455
  #
453
- # @return [ true, false ] If the association is persistable.
456
+ # @return [ true | false ] If the association is persistable.
454
457
  def persistable?
455
458
  !_binding? && (_creating? || _base.persisted? && !_building?)
456
459
  end
@@ -118,7 +118,7 @@ module Mongoid
118
118
  #
119
119
  # @note Only relevant for polymorphic associations.
120
120
  #
121
- # @return [ String, nil ] The type field.
121
+ # @return [ String | nil ] The type field.
122
122
  def type
123
123
  @type ||= "#{as}_type" if polymorphic?
124
124
  end
@@ -140,7 +140,7 @@ module Mongoid
140
140
 
141
141
  # Is this association polymorphic?
142
142
  #
143
- # @return [ true, false ] Whether this association is polymorphic.
143
+ # @return [ true | false ] Whether this association is polymorphic.
144
144
  def polymorphic?
145
145
  @polymorphic ||= !!as
146
146
  end
@@ -150,7 +150,7 @@ module Mongoid
150
150
  #
151
151
  # @param [ Document ] doc The document to be bound.
152
152
  #
153
- # @return [ true, false ] Whether the document can be bound.
153
+ # @return [ true | false ] Whether the document can be bound.
154
154
  def bindable?(doc)
155
155
  forced_nil_inverse? || (!!inverse && doc.fields.keys.include?(foreign_key))
156
156
  end
@@ -60,7 +60,7 @@ module Mongoid
60
60
  # @example Is the id acceptable?
61
61
  # one.acceptable_id?
62
62
  #
63
- # @return [ true, false ] If the id part of the logic will allow an update.
63
+ # @return [ true | false ] If the id part of the logic will allow an update.
64
64
  def acceptable_id?
65
65
  id = convert_id(existing.class, attributes[:_id])
66
66
  existing._id == id || id.nil? || (existing._id != id && update_only?)
@@ -71,7 +71,7 @@ module Mongoid
71
71
  # @example Can the existing object be deleted?
72
72
  # one.delete?
73
73
  #
74
- # @return [ true, false ] If the association should be deleted.
74
+ # @return [ true | false ] If the association should be deleted.
75
75
  def delete?
76
76
  destroyable? && !attributes[:_id].nil?
77
77
  end
@@ -81,7 +81,7 @@ module Mongoid
81
81
  # @example Is the object destroyable?
82
82
  # one.destroyable?({ :_destroy => "1" })
83
83
  #
84
- # @return [ true, false ] If the association can potentially be
84
+ # @return [ true | false ] If the association can potentially be
85
85
  # destroyed.
86
86
  def destroyable?
87
87
  [ 1, "1", true, "true" ].include?(destroy) && allow_destroy?
@@ -92,7 +92,7 @@ module Mongoid
92
92
  # @example Is the document to be replaced?
93
93
  # one.replace?
94
94
  #
95
- # @return [ true, false ] If the document should be replaced.
95
+ # @return [ true | false ] If the document should be replaced.
96
96
  def replace?
97
97
  !existing && !destroyable? && !attributes.blank?
98
98
  end
@@ -102,7 +102,7 @@ module Mongoid
102
102
  # @example Should the document be updated?
103
103
  # one.update?
104
104
  #
105
- # @return [ true, false ] If the object should have its attributes updated.
105
+ # @return [ true | false ] If the object should have its attributes updated.
106
106
  def update?
107
107
  existing && !destroyable? && acceptable_id?
108
108
  end
@@ -79,7 +79,7 @@ module Mongoid
79
79
  # @example Can we persist the association?
80
80
  # relation.persistable?
81
81
  #
82
- # @return [ true, false ] If the association is persistable.
82
+ # @return [ true | false ] If the association is persistable.
83
83
  def persistable?
84
84
  _base.persisted? && !_binding? && !_building?
85
85
  end
@@ -92,7 +92,7 @@ module Mongoid
92
92
 
93
93
  # Is this association polymorphic?
94
94
  #
95
- # @return [ true, false ] Whether this association is polymorphic.
95
+ # @return [ true | false ] Whether this association is polymorphic.
96
96
  def polymorphic?
97
97
  @polymorphic ||= !!as
98
98
  end
@@ -101,7 +101,7 @@ module Mongoid
101
101
  #
102
102
  # @note Only relevant for polymorphic associations.
103
103
  #
104
- # @return [ String, nil ] The type field.
104
+ # @return [ String | nil ] The type field.
105
105
  def type
106
106
  @type ||= "#{as}_type" if polymorphic?
107
107
  end
@@ -111,7 +111,7 @@ module Mongoid
111
111
  #
112
112
  # @param [ Document ] doc The document to be bound.
113
113
  #
114
- # @return [ true, false ] Whether the document can be bound.
114
+ # @return [ true | false ] Whether the document can be bound.
115
115
  def bindable?(doc)
116
116
  forced_nil_inverse? || (!!inverse && doc.fields.keys.include?(foreign_key))
117
117
  end
@@ -16,7 +16,7 @@ module Mongoid
16
16
  #
17
17
  # @param [ Association ] association The association metadata.
18
18
  #
19
- # @return [ true, false ] If we can sync.
19
+ # @return [ true | false ] If we can sync.
20
20
  def _syncable?(association)
21
21
  !_synced?(association.foreign_key) && send(association.foreign_key_check)
22
22
  end
@@ -38,7 +38,7 @@ module Mongoid
38
38
  #
39
39
  # @param [ String ] foreign_key The foreign key.
40
40
  #
41
- # @return [ true, false ] If we can sync.
41
+ # @return [ true | false ] If we can sync.
42
42
  def _synced?(foreign_key)
43
43
  !!_synced[foreign_key]
44
44
  end
@@ -13,7 +13,7 @@ module Mongoid
13
13
  # @example Find association metadata by name.
14
14
  # person.reflect_on_association(:addresses)
15
15
  #
16
- # @param [ String, Symbol ] name The name of the association to find.
16
+ # @param [ String | Symbol ] name The name of the association to find.
17
17
  #
18
18
  # @return [ Association ] The matching association metadata.
19
19
  def reflect_on_association(name)
@@ -39,7 +39,7 @@ module Mongoid
39
39
  # @example Find association metadata by name.
40
40
  # Person.reflect_on_association(:addresses)
41
41
  #
42
- # @param [ String, Symbol ] name The name of the association to find.
42
+ # @param [ String | Symbol ] name The name of the association to find.
43
43
  #
44
44
  # @return [ Association ] The matching association metadata.
45
45
  def reflect_on_association(name)
@@ -69,7 +69,7 @@ module Mongoid
69
69
  #
70
70
  # @param [ Symbol ] callback_type The type of callback type.
71
71
  #
72
- # @return [ Array<Proc, Symbol> ] A list of the callbacks, either method
72
+ # @return [ Array<Proc | Symbol> ] A list of the callbacks, either method
73
73
  # names or Procs.
74
74
  def get_callbacks(callback_type)
75
75
  Array(options[callback_type])
@@ -88,7 +88,7 @@ module Mongoid
88
88
  #
89
89
  # @param [ Document ] doc The document to be bound.
90
90
  #
91
- # @return [ true, false ] Whether the document can be bound.
91
+ # @return [ true | false ] Whether the document can be bound.
92
92
  def bindable?(doc); false; end
93
93
 
94
94
  # Get the inverse names.
@@ -189,7 +189,7 @@ module Mongoid
189
189
  # The foreign key field if this association stores a foreign key.
190
190
  # Otherwise, the primary key.
191
191
  #
192
- # @return [ Symbol, String ] The primary key.
192
+ # @return [ Symbol | String ] The primary key.
193
193
  def key
194
194
  stores_foreign_key? ? foreign_key : primary_key
195
195
  end
@@ -248,7 +248,7 @@ module Mongoid
248
248
  # Create an association proxy object using the owner and target.
249
249
  #
250
250
  # @param [ Document ] owner The document this association hangs off of.
251
- # @param [ Document, Array<Document> ] target The target (parent) of the
251
+ # @param [ Document | Array<Document> ] target The target (parent) of the
252
252
  # association.
253
253
  #
254
254
  # @return [ Proxy ]
@@ -258,7 +258,7 @@ module Mongoid
258
258
 
259
259
  # Whether the dependent method is destructive.
260
260
  #
261
- # @return [ true, false ] If the dependent method is destructive.
261
+ # @return [ true | false ] If the dependent method is destructive.
262
262
  def destructive?
263
263
  @destructive ||= !!(dependent && (dependent == :delete_all || dependent == :destroy))
264
264
  end
@@ -289,7 +289,7 @@ module Mongoid
289
289
 
290
290
  # Whether the associated object(s) should be validated.
291
291
  #
292
- # @return [ true, false ] If the associated object(s)
292
+ # @return [ true | false ] If the associated object(s)
293
293
  # should be validated.
294
294
  def validate?
295
295
  @validate ||= if @options[:validate].nil?
@@ -56,7 +56,7 @@ module Mongoid
56
56
  # @example Is the document embedded?
57
57
  # address.embedded?
58
58
  #
59
- # @return [ true, false ] True if the document has a parent document.
59
+ # @return [ true | false ] True if the document has a parent document.
60
60
  def embedded?
61
61
  @embedded ||= (cyclic ? _parent.present? : self.class.embedded?)
62
62
  end
@@ -66,7 +66,7 @@ module Mongoid
66
66
  # @example Is the document in an embeds many?
67
67
  # address.embedded_many?
68
68
  #
69
- # @return [ true, false ] True if in an embeds many.
69
+ # @return [ true | false ] True if in an embeds many.
70
70
  def embedded_many?
71
71
  _association && _association.is_a?(Association::Embedded::EmbedsMany)
72
72
  end
@@ -76,7 +76,7 @@ module Mongoid
76
76
  # @example Is the document in an embeds one?
77
77
  # address.embedded_one?
78
78
  #
79
- # @return [ true, false ] True if in an embeds one.
79
+ # @return [ true | false ] True if in an embeds one.
80
80
  def embedded_one?
81
81
  _association && _association.is_a?(Association::Embedded::EmbedsOne)
82
82
  end
@@ -100,7 +100,7 @@ module Mongoid
100
100
  # @example Is the document in a references many?
101
101
  # post.referenced_many?
102
102
  #
103
- # @return [ true, false ] True if in a references many.
103
+ # @return [ true | false ] True if in a references many.
104
104
  def referenced_many?
105
105
  _association && _association.is_a?(Association::Referenced::HasMany)
106
106
  end
@@ -110,7 +110,7 @@ module Mongoid
110
110
  # @example Is the document in a references one?
111
111
  # address.referenced_one?
112
112
  #
113
- # @return [ true, false ] True if in a references one.
113
+ # @return [ true | false ] True if in a references one.
114
114
  def referenced_one?
115
115
  _association && _association.is_a?(Association::Referenced::HasOne)
116
116
  end
@@ -153,7 +153,7 @@ module Mongoid
153
153
  #
154
154
  # @param [ String ] field The field.
155
155
  #
156
- # @return [ true, false ] If this field is a conflict.
156
+ # @return [ true | false ] If this field is a conflict.
157
157
  def set_conflict?(field)
158
158
  name = field.split(".", 2)[0]
159
159
  pull_fields.has_key?(name) || push_fields.has_key?(name)
@@ -166,7 +166,7 @@ module Mongoid
166
166
  #
167
167
  # @param [ String ] field The field.
168
168
  #
169
- # @return [ true, false ] If this field is a conflict.
169
+ # @return [ true | false ] If this field is a conflict.
170
170
  def push_conflict?(field)
171
171
  name = field.split(".", 2)[0]
172
172
  set_fields.has_key?(name) || pull_fields.has_key?(name) ||
@@ -13,9 +13,9 @@ module Mongoid
13
13
  # person.respond_to?(:title)
14
14
  #
15
15
  # @param [ Array ] name The name of the method.
16
- # @param [ true, false ] include_private
16
+ # @param [ true | false ] include_private
17
17
  #
18
- # @return [ true, false ] True if it does, false if not.
18
+ # @return [ true | false ] True if it does, false if not.
19
19
  def respond_to?(name, include_private = false)
20
20
  super || (
21
21
  attributes &&
@@ -114,7 +114,7 @@ module Mongoid
114
114
  # @example Call through method_missing.
115
115
  # document.method_missing(:test)
116
116
  #
117
- # @param [ String, Symbol ] name The name of the method.
117
+ # @param [ String | Symbol ] name The name of the method.
118
118
  # @param [ Array ] args The arguments to the method.
119
119
  #
120
120
  # @return [ Object ] The result of the method call.
@@ -33,15 +33,15 @@ module Mongoid
33
33
  # accepts_nested_attributes_for :addresses, :game, :posts
34
34
  # end
35
35
  #
36
- # @param [ Array<Symbol>, Hash ] args A list of association names, followed
36
+ # @param [ Array<Symbol> | Hash ] args A list of association names, followed
37
37
  # by a hash of options.
38
38
  #
39
- # @option *args [ true, false ] :allow_destroy Can deletion occur?
40
- # @option *args [ Proc, Symbol ] :reject_if Block or symbol pointing
39
+ # @option *args [ true | false ] :allow_destroy Can deletion occur?
40
+ # @option *args [ Proc | Symbol ] :reject_if Block or symbol pointing
41
41
  # to a class method to reject documents with.
42
42
  # @option *args [ Integer ] :limit The max number to create.
43
- # @option *args [ true, false ] :update_only Only update existing docs.
44
- # @options *args [ true, false ] :autosave Whether autosave should be enabled on the
43
+ # @option *args [ true | false ] :update_only Only update existing docs.
44
+ # @option *args [ true | false ] :autosave Whether autosave should be enabled on the
45
45
  # association. Note that since the default is true, setting autosave to nil will still
46
46
  # enable it.
47
47
  def accepts_nested_attributes_for(*args)
@@ -40,7 +40,7 @@ module Mongoid
40
40
  # @param [ Symbol ] key The name of the attribute.
41
41
  # @param [ Object ] value The value of the attribute.
42
42
  #
43
- # @return [ true, false ] True if pending, false if not.
43
+ # @return [ true | false ] True if pending, false if not.
44
44
  def pending_attribute?(key, value)
45
45
  name = key.to_s
46
46
 
@@ -41,7 +41,7 @@ module Mongoid
41
41
  #
42
42
  # @param [ String ] name The name of the attribute or a dot notation path.
43
43
  #
44
- # @return [ true, false ] Whether the attribute is allowed by projection.
44
+ # @return [ true | false ] Whether the attribute is allowed by projection.
45
45
  #
46
46
  # @api private
47
47
  def attribute_or_path_allowed?(name)
@@ -17,9 +17,9 @@ module Mongoid
17
17
  # @example Can we write the attribute?
18
18
  # model.attribute_writable?(:title)
19
19
  #
20
- # @param [ String, Symbol ] name The name of the field.
20
+ # @param [ String | Symbol ] name The name of the field.
21
21
  #
22
- # @return [ true, false ] If the document is new, or if the field is not
22
+ # @return [ true | false ] If the document is new, or if the field is not
23
23
  # readonly.
24
24
  def attribute_writable?(name)
25
25
  new_record? || (!readonly_attributes.include?(name) && _loaded?(name))