SurrogateEncoder.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. //
  2. // System.Text.SurrogateEncoder.cs
  3. //
  4. // Author:
  5. // Kornél Pál <http://www.kornelpal.hu/>
  6. //
  7. // Copyright (C) 2006 Kornél Pál
  8. //
  9. //
  10. // Permission is hereby granted, free of charge, to any person obtaining
  11. // a copy of this software and associated documentation files (the
  12. // "Software"), to deal in the Software without restriction, including
  13. // without limitation the rights to use, copy, modify, merge, publish,
  14. // distribute, sublicense, and/or sell copies of the Software, and to
  15. // permit persons to whom the Software is furnished to do so, subject to
  16. // the following conditions:
  17. //
  18. // The above copyright notice and this permission notice shall be
  19. // included in all copies or substantial portions of the Software.
  20. //
  21. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  22. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  23. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  24. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  25. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  26. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  27. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  28. //
  29. //
  30. // These proxy classes implement IObjectReference.GetRealObject() that returns
  31. // an instance of the appropriate Encoding, Encoder or Decoder class.
  32. // As a result serialized objects of these types will transparently be
  33. // deserialized to instances of the above described classes.
  34. //
  35. // Use SerializationInfo.SetType() in ISerializable.GetObjectData() method of
  36. // serializable classes to serialize their instances using a proxy class.
  37. //
  38. // All of these proxy classes are non-public thus they only have to be
  39. // serialization compatible with .NET Framework.
  40. //
  41. //
  42. // .NET Framework 1.x uses this class for GB18030 encoder and
  43. // .NET Framework 2.0 can deserialize it using a proxy.
  44. // This class supports serialization compatibility.
  45. //
  46. using System;
  47. using System.Runtime.Serialization;
  48. namespace System.Text
  49. {
  50. [Serializable]
  51. internal sealed class SurrogateEncoder : ISerializable, IObjectReference
  52. {
  53. private Encoding encoding;
  54. private Encoder realObject;
  55. private SurrogateEncoder (SerializationInfo info, StreamingContext context)
  56. {
  57. if (info == null)
  58. throw new ArgumentNullException ("info");
  59. this.encoding = (Encoding) info.GetValue ("m_encoding", typeof (Encoding));
  60. }
  61. public void GetObjectData (SerializationInfo info, StreamingContext context)
  62. {
  63. throw new ArgumentException ("This class cannot be serialized.");
  64. }
  65. public object GetRealObject (StreamingContext context)
  66. {
  67. if (this.realObject == null)
  68. this.realObject = this.encoding.GetEncoder ();
  69. return this.realObject;
  70. }
  71. }
  72. }