| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ | 5 #ifndef CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ |
| 6 #define CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ | 6 #define CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ |
| 7 | 7 |
| 8 #include <stddef.h> | 8 #include <stddef.h> |
| 9 #include <stdint.h> | 9 #include <stdint.h> |
| 10 | 10 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 | 24 |
| 25 class ResourceDispatcher; | 25 class ResourceDispatcher; |
| 26 struct ResourceRequestCompletionStatus; | 26 struct ResourceRequestCompletionStatus; |
| 27 | 27 |
| 28 // This class pulls data from a data pipe and dispatches it to the | 28 // This class pulls data from a data pipe and dispatches it to the |
| 29 // ResourceDispatcher. This class is used only for mojo-enabled requests. | 29 // ResourceDispatcher. This class is used only for mojo-enabled requests. |
| 30 class CONTENT_EXPORT URLResponseBodyConsumer final | 30 class CONTENT_EXPORT URLResponseBodyConsumer final |
| 31 : public base::RefCounted<URLResponseBodyConsumer>, | 31 : public base::RefCounted<URLResponseBodyConsumer>, |
| 32 public base::SupportsWeakPtr<URLResponseBodyConsumer> { | 32 public base::SupportsWeakPtr<URLResponseBodyConsumer> { |
| 33 public: | 33 public: |
| 34 URLResponseBodyConsumer(int request_id, | 34 URLResponseBodyConsumer( |
| 35 ResourceDispatcher* resource_dispatcher, | 35 int request_id, |
| 36 mojo::ScopedDataPipeConsumerHandle handle, | 36 ResourceDispatcher* resource_dispatcher, |
| 37 base::SingleThreadTaskRunner* task_runner); | 37 mojo::ScopedDataPipeConsumerHandle handle, |
| 38 scoped_refptr<base::SingleThreadTaskRunner> task_runner); |
| 38 | 39 |
| 39 // Sets the completion status. The completion status is dispatched to the | 40 // Sets the completion status. The completion status is dispatched to the |
| 40 // ResourceDispatcher when the both following conditions hold: | 41 // ResourceDispatcher when the both following conditions hold: |
| 41 // 1) This function has been called and the completion status is set, and | 42 // 1) This function has been called and the completion status is set, and |
| 42 // 2) All data is read from the handle. | 43 // 2) All data is read from the handle. |
| 43 void OnComplete(const ResourceRequestCompletionStatus& status); | 44 void OnComplete(const ResourceRequestCompletionStatus& status); |
| 44 | 45 |
| 45 // Cancels watching the handle and dispatches an error to the | 46 // Cancels watching the handle and dispatches an error to the |
| 46 // ResourceDispatcher. This function does nothing if the reading is already | 47 // ResourceDispatcher. This function does nothing if the reading is already |
| 47 // cancelled or done. | 48 // cancelled or done. |
| (...skipping 18 matching lines...) Expand all Loading... |
| 66 bool has_received_completion_ = false; | 67 bool has_received_completion_ = false; |
| 67 bool has_been_cancelled_ = false; | 68 bool has_been_cancelled_ = false; |
| 68 bool has_seen_end_of_data_; | 69 bool has_seen_end_of_data_; |
| 69 | 70 |
| 70 DISALLOW_COPY_AND_ASSIGN(URLResponseBodyConsumer); | 71 DISALLOW_COPY_AND_ASSIGN(URLResponseBodyConsumer); |
| 71 }; | 72 }; |
| 72 | 73 |
| 73 } // namespace content | 74 } // namespace content |
| 74 | 75 |
| 75 #endif // CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ | 76 #endif // CONTENT_CHILD_URL_RESPONSE_BODY_CONSUMER_H_ |
| OLD | NEW |