IJsonSerializer.cs 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  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 file.
  17. /// </summary>
  18. /// <param name="obj">The obj.</param>
  19. /// <param name="file">The file.</param>
  20. /// <exception cref="ArgumentNullException">obj</exception>
  21. void SerializeToFile(object obj, string file);
  22. /// <summary>
  23. /// Deserializes from file.
  24. /// </summary>
  25. /// <param name="type">The type.</param>
  26. /// <param name="file">The file.</param>
  27. /// <returns>System.Object.</returns>
  28. /// <exception cref="ArgumentNullException">type</exception>
  29. object DeserializeFromFile(Type type, string file);
  30. /// <summary>
  31. /// Deserializes from file.
  32. /// </summary>
  33. /// <typeparam name="T"></typeparam>
  34. /// <param name="file">The file.</param>
  35. /// <returns>``0.</returns>
  36. /// <exception cref="ArgumentNullException">file</exception>
  37. T DeserializeFromFile<T>(string file)
  38. where T : class;
  39. /// <summary>
  40. /// Deserializes from stream.
  41. /// </summary>
  42. /// <typeparam name="T"></typeparam>
  43. /// <param name="stream">The stream.</param>
  44. /// <returns>``0.</returns>
  45. /// <exception cref="ArgumentNullException">stream</exception>
  46. T DeserializeFromStream<T>(Stream stream);
  47. /// <summary>
  48. /// Deserializes from string.
  49. /// </summary>
  50. /// <typeparam name="T"></typeparam>
  51. /// <param name="text">The text.</param>
  52. /// <returns>``0.</returns>
  53. /// <exception cref="ArgumentNullException">text</exception>
  54. T DeserializeFromString<T>(string text);
  55. /// <summary>
  56. /// Deserializes from stream.
  57. /// </summary>
  58. /// <param name="stream">The stream.</param>
  59. /// <param name="type">The type.</param>
  60. /// <returns>System.Object.</returns>
  61. /// <exception cref="ArgumentNullException">stream</exception>
  62. object DeserializeFromStream(Stream stream, Type type);
  63. /// <summary>
  64. /// Deserializes from string.
  65. /// </summary>
  66. /// <param name="json">The json.</param>
  67. /// <param name="type">The type.</param>
  68. /// <returns>System.Object.</returns>
  69. /// <exception cref="ArgumentNullException">json</exception>
  70. object DeserializeFromString(string json, Type type);
  71. /// <summary>
  72. /// Serializes to string.
  73. /// </summary>
  74. /// <param name="obj">The obj.</param>
  75. /// <returns>System.String.</returns>
  76. /// <exception cref="ArgumentNullException">obj</exception>
  77. string SerializeToString(object obj);
  78. Task<object> DeserializeFromStreamAsync(Stream stream, Type type);
  79. Task<T> DeserializeFromStreamAsync<T>(Stream stream);
  80. }
  81. }