IJsonSerializer.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. using System;
  2. using System.IO;
  3. using System.Threading.Tasks;
  4. namespace MediaBrowser.Model.Serialization
  5. {
  6. public interface IJsonSerializer
  7. {
  8. /// <summary>
  9. /// Serializes to stream.
  10. /// </summary>
  11. /// <param name="obj">The obj.</param>
  12. /// <param name="stream">The stream.</param>
  13. /// <exception cref="ArgumentNullException">obj</exception>
  14. void SerializeToStream(object obj, Stream stream);
  15. /// <summary>
  16. /// Serializes to stream.
  17. /// </summary>
  18. /// <param name="obj">The obj.</param>
  19. /// <param name="stream">The stream.</param>
  20. /// <exception cref="ArgumentNullException">obj</exception>
  21. void SerializeToStream<T>(T obj, Stream stream);
  22. /// <summary>
  23. /// Serializes to file.
  24. /// </summary>
  25. /// <param name="obj">The obj.</param>
  26. /// <param name="file">The file.</param>
  27. /// <exception cref="ArgumentNullException">obj</exception>
  28. void SerializeToFile(object obj, string file);
  29. /// <summary>
  30. /// Deserializes from file.
  31. /// </summary>
  32. /// <param name="type">The type.</param>
  33. /// <param name="file">The file.</param>
  34. /// <returns>System.Object.</returns>
  35. /// <exception cref="ArgumentNullException">type</exception>
  36. object DeserializeFromFile(Type type, string file);
  37. /// <summary>
  38. /// Deserializes from file.
  39. /// </summary>
  40. /// <typeparam name="T"></typeparam>
  41. /// <param name="file">The file.</param>
  42. /// <returns>``0.</returns>
  43. /// <exception cref="ArgumentNullException">file</exception>
  44. T DeserializeFromFile<T>(string file)
  45. where T : class;
  46. /// <summary>
  47. /// Deserializes from stream.
  48. /// </summary>
  49. /// <typeparam name="T"></typeparam>
  50. /// <param name="stream">The stream.</param>
  51. /// <returns>``0.</returns>
  52. /// <exception cref="ArgumentNullException">stream</exception>
  53. T DeserializeFromStream<T>(Stream stream);
  54. /// <summary>
  55. /// Deserializes from string.
  56. /// </summary>
  57. /// <typeparam name="T"></typeparam>
  58. /// <param name="text">The text.</param>
  59. /// <returns>``0.</returns>
  60. /// <exception cref="ArgumentNullException">text</exception>
  61. T DeserializeFromString<T>(string text);
  62. /// <summary>
  63. /// Deserializes from stream.
  64. /// </summary>
  65. /// <param name="stream">The stream.</param>
  66. /// <param name="type">The type.</param>
  67. /// <returns>System.Object.</returns>
  68. /// <exception cref="ArgumentNullException">stream</exception>
  69. object DeserializeFromStream(Stream stream, Type type);
  70. /// <summary>
  71. /// Deserializes from string.
  72. /// </summary>
  73. /// <param name="json">The json.</param>
  74. /// <param name="type">The type.</param>
  75. /// <returns>System.Object.</returns>
  76. /// <exception cref="ArgumentNullException">json</exception>
  77. object DeserializeFromString(string json, Type type);
  78. /// <summary>
  79. /// Serializes to string.
  80. /// </summary>
  81. /// <param name="obj">The obj.</param>
  82. /// <returns>System.String.</returns>
  83. /// <exception cref="ArgumentNullException">obj</exception>
  84. string SerializeToString(object obj);
  85. Task<object> DeserializeFromStreamAsync(Stream stream, Type type);
  86. Task<T> DeserializeFromStreamAsync<T>(Stream stream);
  87. }
  88. }