QueueSerializer.cs 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /* Copyright 2010-present MongoDB Inc.
  2. *
  3. * Licensed under the Apache License, Version 2.0 (the "License");
  4. * you may not use this file except in compliance with the License.
  5. * You may obtain a copy of the License at
  6. *
  7. * http://www.apache.org/licenses/LICENSE-2.0
  8. *
  9. * Unless required by applicable law or agreed to in writing, software
  10. * distributed under the License is distributed on an "AS IS" BASIS,
  11. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. * See the License for the specific language governing permissions and
  13. * limitations under the License.
  14. */
  15. using System.Collections;
  16. using System.Collections.Generic;
  17. namespace MongoDB.Bson.Serialization.Serializers
  18. {
  19. /// <summary>
  20. /// Represents a serializer for Queues.
  21. /// </summary>
  22. public class QueueSerializer :
  23. EnumerableSerializerBase<Queue>,
  24. IChildSerializerConfigurable,
  25. IBsonArraySerializer
  26. {
  27. // constructors
  28. /// <summary>
  29. /// Initializes a new instance of the <see cref="QueueSerializer"/> class.
  30. /// </summary>
  31. public QueueSerializer()
  32. {
  33. }
  34. /// <summary>
  35. /// Initializes a new instance of the <see cref="QueueSerializer"/> class.
  36. /// </summary>
  37. /// <param name="itemSerializer">The item serializer.</param>
  38. public QueueSerializer(IBsonSerializer itemSerializer)
  39. : base(itemSerializer)
  40. {
  41. }
  42. /// <summary>
  43. /// Initializes a new instance of the <see cref="QueueSerializer" /> class.
  44. /// </summary>
  45. /// <param name="serializerRegistry"></param>
  46. public QueueSerializer(IBsonSerializerRegistry serializerRegistry)
  47. : base(serializerRegistry)
  48. {
  49. }
  50. // public methods
  51. /// <summary>
  52. /// Returns a serializer that has been reconfigured with the specified item serializer.
  53. /// </summary>
  54. /// <param name="itemSerializer">The item serializer.</param>
  55. /// <returns>The reconfigured serializer.</returns>
  56. public QueueSerializer WithItemSerializer(IBsonSerializer itemSerializer)
  57. {
  58. return new QueueSerializer(itemSerializer);
  59. }
  60. // protected methods
  61. /// <summary>
  62. /// Adds the item.
  63. /// </summary>
  64. /// <param name="accumulator">The accumulator.</param>
  65. /// <param name="item">The item.</param>
  66. protected override void AddItem(object accumulator, object item)
  67. {
  68. ((Queue)accumulator).Enqueue(item);
  69. }
  70. /// <summary>
  71. /// Creates the accumulator.
  72. /// </summary>
  73. /// <returns>The accumulator.</returns>
  74. protected override object CreateAccumulator()
  75. {
  76. return new Queue();
  77. }
  78. /// <summary>
  79. /// Enumerates the items.
  80. /// </summary>
  81. /// <param name="value">The value.</param>
  82. /// <returns>The items.</returns>
  83. protected override IEnumerable EnumerateItemsInSerializationOrder(Queue value)
  84. {
  85. return value;
  86. }
  87. /// <summary>
  88. /// Finalizes the result.
  89. /// </summary>
  90. /// <param name="accumulator">The instance.</param>
  91. /// <returns>The result.</returns>
  92. protected override Queue FinalizeResult(object accumulator)
  93. {
  94. return (Queue)accumulator;
  95. }
  96. // explicit interface implementations
  97. IBsonSerializer IChildSerializerConfigurable.ChildSerializer
  98. {
  99. get { return ItemSerializer; }
  100. }
  101. IBsonSerializer IChildSerializerConfigurable.WithChildSerializer(IBsonSerializer childSerializer)
  102. {
  103. return WithItemSerializer(childSerializer);
  104. }
  105. }
  106. /// <summary>
  107. /// Represents a serializer for Queues.
  108. /// </summary>
  109. /// <typeparam name="TItem">The type of the elements.</typeparam>
  110. public class QueueSerializer<TItem> :
  111. EnumerableSerializerBase<Queue<TItem>, TItem>,
  112. IChildSerializerConfigurable,
  113. IBsonArraySerializer
  114. {
  115. // constructors
  116. /// <summary>
  117. /// Initializes a new instance of the <see cref="QueueSerializer{TItem}"/> class.
  118. /// </summary>
  119. public QueueSerializer()
  120. {
  121. }
  122. /// <summary>
  123. /// Initializes a new instance of the <see cref="QueueSerializer{TItem}"/> class.
  124. /// </summary>
  125. /// <param name="itemSerializer">The item serializer.</param>
  126. public QueueSerializer(IBsonSerializer<TItem> itemSerializer)
  127. : base(itemSerializer)
  128. {
  129. }
  130. /// <summary>
  131. /// Initializes a new instance of the <see cref="QueueSerializer{TItem}" /> class.
  132. /// </summary>
  133. /// <param name="serializerRegistry">The serializer registry.</param>
  134. public QueueSerializer(IBsonSerializerRegistry serializerRegistry)
  135. : base(serializerRegistry)
  136. {
  137. }
  138. // public methods
  139. /// <summary>
  140. /// Returns a serializer that has been reconfigured with the specified item serializer.
  141. /// </summary>
  142. /// <param name="itemSerializer">The item serializer.</param>
  143. /// <returns>The reconfigured serializer.</returns>
  144. public QueueSerializer<TItem> WithItemSerializer(IBsonSerializer<TItem> itemSerializer)
  145. {
  146. return new QueueSerializer<TItem>(itemSerializer);
  147. }
  148. // protected methods
  149. /// <summary>
  150. /// Adds the item.
  151. /// </summary>
  152. /// <param name="accumulator">The accumulator.</param>
  153. /// <param name="item">The item.</param>
  154. protected override void AddItem(object accumulator, TItem item)
  155. {
  156. ((Queue<TItem>)accumulator).Enqueue(item);
  157. }
  158. /// <summary>
  159. /// Creates the accumulator.
  160. /// </summary>
  161. /// <returns>The accumulator.</returns>
  162. protected override object CreateAccumulator()
  163. {
  164. return new Queue<TItem>();
  165. }
  166. /// <summary>
  167. /// Enumerates the items in serialization order.
  168. /// </summary>
  169. /// <param name="value">The value.</param>
  170. /// <returns>The items.</returns>
  171. protected override IEnumerable<TItem> EnumerateItemsInSerializationOrder(Queue<TItem> value)
  172. {
  173. return value;
  174. }
  175. /// <summary>
  176. /// Finalizes the result.
  177. /// </summary>
  178. /// <param name="accumulator">The accumulator.</param>
  179. /// <returns>The result.</returns>
  180. protected override Queue<TItem> FinalizeResult(object accumulator)
  181. {
  182. return (Queue<TItem>)accumulator;
  183. }
  184. // explicit interface implementations
  185. IBsonSerializer IChildSerializerConfigurable.ChildSerializer
  186. {
  187. get { return ItemSerializer; }
  188. }
  189. IBsonSerializer IChildSerializerConfigurable.WithChildSerializer(IBsonSerializer childSerializer)
  190. {
  191. return WithItemSerializer((IBsonSerializer<TItem>)childSerializer);
  192. }
  193. }
  194. }