KTVHCDataLoader.m 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. //
  2. // KTVHCDataLoader.m
  3. // KTVHTTPCache
  4. //
  5. // Created by Single on 2018/6/7.
  6. // Copyright © 2018 Single. All rights reserved.
  7. //
  8. #import "KTVHCDataLoader.h"
  9. #import "KTVHCDataReader.h"
  10. #import "KTVHCDataResponse.h"
  11. #import "KTVHCLog.h"
  12. @interface KTVHCDataLoader () <KTVHCDataReaderDelegate>
  13. @property (nonatomic, strong) KTVHCDataReader * reader;
  14. @end
  15. @implementation KTVHCDataLoader
  16. + (instancetype)loaderWithRequest:(KTVHCDataRequest *)request
  17. {
  18. return [[self alloc] initWithRequest:request];
  19. }
  20. - (instancetype)initWithRequest:(KTVHCDataRequest *)request
  21. {
  22. if (self = [super init])
  23. {
  24. KTVHCLogAlloc(self);
  25. self.reader = [KTVHCDataReader readerWithRequest:request];
  26. self.reader.delegate = self;
  27. KTVHCLogDataLoader(@"%p, Create loader\norignalRequest : %@\nreader : %@", self, request, self.reader);
  28. }
  29. return self;
  30. }
  31. - (void)dealloc
  32. {
  33. KTVHCLogDealloc(self);
  34. [self close];
  35. KTVHCLogDataLoader(@"%p, Destory reader\nError : %@\nprogress : %f", self, self.error, self.progress);
  36. }
  37. - (void)prepare
  38. {
  39. KTVHCLogDataLoader(@"%p, Call prepare", self);
  40. [self.reader prepare];
  41. }
  42. - (void)close
  43. {
  44. KTVHCLogDataLoader(@"%p, Call close", self);
  45. [self.reader close];
  46. }
  47. - (KTVHCDataRequest *)request
  48. {
  49. return self.reader.request;
  50. }
  51. - (KTVHCDataResponse *)response
  52. {
  53. return self.reader.response;
  54. }
  55. - (NSError *)error
  56. {
  57. return self.reader.error;
  58. }
  59. - (BOOL)didClosed
  60. {
  61. return self.reader.didClosed;
  62. }
  63. - (BOOL)didFinished
  64. {
  65. return self.reader.didFinished;
  66. }
  67. #pragma mark - KTVHCDataReaderDelegate
  68. - (void)readerDidPrepared:(KTVHCDataReader *)reader
  69. {
  70. [self readData];
  71. }
  72. - (void)readerHasAvailableData:(KTVHCDataReader *)reader
  73. {
  74. [self readData];
  75. }
  76. - (void)reader:(KTVHCDataReader *)reader didFailed:(NSError *)error
  77. {
  78. KTVHCLogDataLoader(@"%p, Callback for failed", self);
  79. if ([self.delegate respondsToSelector:@selector(loader:didFailed:)])
  80. {
  81. [self.delegate loader:self didFailed:error];
  82. }
  83. }
  84. - (void)readData
  85. {
  86. while (YES)
  87. {
  88. @autoreleasepool
  89. {
  90. NSData * data = [self.reader readDataOfLength:1024 * 1024 * 1];
  91. if (self.reader.didFinished)
  92. {
  93. _progress = 1.0f;
  94. if ([self.delegate respondsToSelector:@selector(loader:didChangeProgress:)])
  95. {
  96. [self.delegate loader:self didChangeProgress:_progress];
  97. }
  98. KTVHCLogDataLoader(@"%p, Callback finished", self);
  99. if ([self.delegate respondsToSelector:@selector(loaderDidFinished:)])
  100. {
  101. [self.delegate loaderDidFinished:self];
  102. }
  103. }
  104. else if (data)
  105. {
  106. _progress = (double)self.reader.readOffset / (double)self.response.currentLength;
  107. if ([self.delegate respondsToSelector:@selector(loader:didChangeProgress:)])
  108. {
  109. [self.delegate loader:self didChangeProgress:_progress];
  110. }
  111. KTVHCLogDataLoader(@"%p, read data progress %f", self, _progress);
  112. continue;
  113. }
  114. KTVHCLogDataLoader(@"%p, read data break", self);
  115. break;
  116. }
  117. }
  118. }
  119. @end