IJsonSerializer.cs 3.5 KB

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