Utf8NameDecoder.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /* Copyright 2010-2015 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.IO;
  17. using System.Text;
  18. namespace MongoDB.Bson.IO
  19. {
  20. /// <summary>
  21. /// Represents a UTF8 name decoder.
  22. /// </summary>
  23. public class Utf8NameDecoder : INameDecoder
  24. {
  25. // private static fields
  26. private static readonly Utf8NameDecoder __instance = new Utf8NameDecoder();
  27. // public static properties
  28. /// <summary>
  29. /// Gets the instance.
  30. /// </summary>
  31. /// <value>
  32. /// The instance.
  33. /// </value>
  34. public static Utf8NameDecoder Instance
  35. {
  36. get { return __instance; }
  37. }
  38. // public methods
  39. /// <summary>
  40. /// Decodes the name.
  41. /// </summary>
  42. /// <param name="stream">The stream.</param>
  43. /// <param name="encoding">The encoding.</param>
  44. /// <returns>
  45. /// The name.
  46. /// </returns>
  47. public string Decode(BsonStream stream, UTF8Encoding encoding)
  48. {
  49. var utf8 = stream.ReadCStringBytes();
  50. return Utf8Helper.DecodeUtf8String(utf8.Array, utf8.Offset, utf8.Count, encoding);
  51. }
  52. /// <summary>
  53. /// Informs the decoder of an already decoded name (so the decoder can change state if necessary).
  54. /// </summary>
  55. /// <param name="name">The name.</param>
  56. public void Inform(string name)
  57. {
  58. }
  59. }
  60. }