StackSerializer.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  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;
  16. using System.Collections;
  17. using System.Collections.Generic;
  18. using System.Linq;
  19. using MongoDB.Bson.Serialization.Conventions;
  20. using MongoDB.Bson.Serialization.Options;
  21. namespace MongoDB.Bson.Serialization.Serializers
  22. {
  23. /// <summary>
  24. /// Represents a serializer for Stacks.
  25. /// </summary>
  26. public class StackSerializer :
  27. EnumerableSerializerBase<Stack>,
  28. IChildSerializerConfigurable,
  29. IBsonArraySerializer
  30. {
  31. // constructors
  32. /// <summary>
  33. /// Initializes a new instance of the <see cref="StackSerializer"/> class.
  34. /// </summary>
  35. public StackSerializer()
  36. {
  37. }
  38. /// <summary>
  39. /// Initializes a new instance of the <see cref="StackSerializer"/> class.
  40. /// </summary>
  41. /// <param name="itemSerializer">The item serializer.</param>
  42. public StackSerializer(IBsonSerializer itemSerializer)
  43. : base(itemSerializer)
  44. {
  45. }
  46. /// <summary>
  47. /// Initializes a new instance of the <see cref="StackSerializer" /> class.
  48. /// </summary>
  49. /// <param name="serializerRegistry">The serializer registry.</param>
  50. public StackSerializer(IBsonSerializerRegistry serializerRegistry)
  51. : base(serializerRegistry)
  52. {
  53. }
  54. // public methods
  55. /// <summary>
  56. /// Returns a serializer that has been reconfigured with the specified item serializer.
  57. /// </summary>
  58. /// <param name="itemSerializer">The item serializer.</param>
  59. /// <returns>The reconfigured serializer.</returns>
  60. public StackSerializer WithItemSerializer(IBsonSerializer itemSerializer)
  61. {
  62. return new StackSerializer(itemSerializer);
  63. }
  64. // protected methods
  65. /// <summary>
  66. /// Adds the item.
  67. /// </summary>
  68. /// <param name="accumulator">The accumulator.</param>
  69. /// <param name="item">The item.</param>
  70. protected override void AddItem(object accumulator, object item)
  71. {
  72. ((Stack)accumulator).Push(item);
  73. }
  74. /// <summary>
  75. /// Creates the accumulator.
  76. /// </summary>
  77. /// <returns>The accumulator.</returns>
  78. protected override object CreateAccumulator()
  79. {
  80. return new Stack();
  81. }
  82. /// <summary>
  83. /// Enumerates the items in serialization order.
  84. /// </summary>
  85. /// <param name="value">The value.</param>
  86. /// <returns>The items.</returns>
  87. protected override IEnumerable EnumerateItemsInSerializationOrder(Stack value)
  88. {
  89. return value.Cast<object>().Reverse();
  90. }
  91. /// <summary>
  92. /// Finalizes the result.
  93. /// </summary>
  94. /// <param name="accumulator">The accumulator.</param>
  95. /// <returns>The result.</returns>
  96. protected override Stack FinalizeResult(object accumulator)
  97. {
  98. return (Stack)accumulator;
  99. }
  100. // explicit interface implementations
  101. IBsonSerializer IChildSerializerConfigurable.ChildSerializer
  102. {
  103. get { return ItemSerializer; }
  104. }
  105. IBsonSerializer IChildSerializerConfigurable.WithChildSerializer(IBsonSerializer childSerializer)
  106. {
  107. return WithItemSerializer(childSerializer);
  108. }
  109. }
  110. /// <summary>
  111. /// Represents a serializer for Stacks.
  112. /// </summary>
  113. /// <typeparam name="TItem">The type of the elements.</typeparam>
  114. public class StackSerializer<TItem> :
  115. EnumerableSerializerBase<Stack<TItem>, TItem>,
  116. IChildSerializerConfigurable,
  117. IBsonArraySerializer
  118. {
  119. // constructors
  120. /// <summary>
  121. /// Initializes a new instance of the <see cref="StackSerializer{TItem}"/> class.
  122. /// </summary>
  123. public StackSerializer()
  124. {
  125. }
  126. /// <summary>
  127. /// Initializes a new instance of the <see cref="StackSerializer{TItem}"/> class.
  128. /// </summary>
  129. /// <param name="itemSerializer">The item serializer.</param>
  130. public StackSerializer(IBsonSerializer<TItem> itemSerializer)
  131. : base(itemSerializer)
  132. {
  133. }
  134. /// <summary>
  135. /// Initializes a new instance of the <see cref="StackSerializer{TItem}" /> class.
  136. /// </summary>
  137. /// <param name="serializerRegistry">The serializer registry.</param>
  138. public StackSerializer(IBsonSerializerRegistry serializerRegistry)
  139. : base(serializerRegistry)
  140. {
  141. }
  142. // public methods
  143. /// <summary>
  144. /// Returns a serializer that has been reconfigured with the specified item serializer.
  145. /// </summary>
  146. /// <param name="itemSerializer">The item serializer.</param>
  147. /// <returns>The reconfigured serializer.</returns>
  148. public StackSerializer<TItem> WithItemSerializer(IBsonSerializer<TItem> itemSerializer)
  149. {
  150. return new StackSerializer<TItem>(itemSerializer);
  151. }
  152. // protected methods
  153. /// <summary>
  154. /// Adds the item.
  155. /// </summary>
  156. /// <param name="accumulator">The accumulator.</param>
  157. /// <param name="item">The item.</param>
  158. protected override void AddItem(object accumulator, TItem item)
  159. {
  160. ((Stack<TItem>)accumulator).Push(item);
  161. }
  162. /// <summary>
  163. /// Creates the accumulator.
  164. /// </summary>
  165. /// <returns>The accumulator.</returns>
  166. protected override object CreateAccumulator()
  167. {
  168. return new Stack<TItem>();
  169. }
  170. /// <summary>
  171. /// Enumerates the items in serialization order.
  172. /// </summary>
  173. /// <param name="value">The value.</param>
  174. /// <returns>The items.</returns>
  175. protected override IEnumerable<TItem> EnumerateItemsInSerializationOrder(Stack<TItem> value)
  176. {
  177. return value.Reverse();
  178. }
  179. /// <summary>
  180. /// Finalizes the result.
  181. /// </summary>
  182. /// <param name="accumulator">The accumulator.</param>
  183. /// <returns>The result.</returns>
  184. protected override Stack<TItem> FinalizeResult(object accumulator)
  185. {
  186. return (Stack<TItem>)accumulator;
  187. }
  188. // explicit interface implementations
  189. IBsonSerializer IChildSerializerConfigurable.ChildSerializer
  190. {
  191. get { return ItemSerializer; }
  192. }
  193. IBsonSerializer IChildSerializerConfigurable.WithChildSerializer(IBsonSerializer childSerializer)
  194. {
  195. return WithItemSerializer((IBsonSerializer<TItem>)childSerializer);
  196. }
  197. }
  198. }