| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ |
| 6 #define CONTENT_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 | 24 |
| 25 // Used to buffer a request until enough data has been received. | 25 // Used to buffer a request until enough data has been received. |
| 26 class BufferedResourceHandler : public LayeredResourceHandler { | 26 class BufferedResourceHandler : public LayeredResourceHandler { |
| 27 public: | 27 public: |
| 28 BufferedResourceHandler(ResourceHandler* handler, | 28 BufferedResourceHandler(ResourceHandler* handler, |
| 29 ResourceDispatcherHostImpl* host, | 29 ResourceDispatcherHostImpl* host, |
| 30 net::URLRequest* request); | 30 net::URLRequest* request); |
| 31 | 31 |
| 32 // ResourceHandler implementation: | 32 // ResourceHandler implementation: |
| 33 virtual bool OnResponseStarted(int request_id, | 33 virtual bool OnResponseStarted(int request_id, |
| 34 ResourceResponse* response) OVERRIDE; | 34 ResourceResponse* response, |
| 35 bool* defer) OVERRIDE; |
| 35 virtual bool OnWillRead(int request_id, | 36 virtual bool OnWillRead(int request_id, |
| 36 net::IOBuffer** buf, | 37 net::IOBuffer** buf, |
| 37 int* buf_size, | 38 int* buf_size, |
| 38 int min_size) OVERRIDE; | 39 int min_size) OVERRIDE; |
| 39 virtual bool OnReadCompleted(int request_id, int* bytes_read) OVERRIDE; | 40 virtual bool OnReadCompleted(int request_id, int* bytes_read, |
| 41 bool* defer) OVERRIDE; |
| 40 virtual void OnRequestClosed() OVERRIDE; | 42 virtual void OnRequestClosed() OVERRIDE; |
| 41 | 43 |
| 42 private: | 44 private: |
| 43 virtual ~BufferedResourceHandler(); | 45 virtual ~BufferedResourceHandler(); |
| 44 | 46 |
| 45 // Returns true if we should delay OnResponseStarted forwarding. | 47 // Returns true if we should delay OnResponseStarted forwarding. |
| 46 bool DelayResponse(); | 48 bool DelayResponse(); |
| 47 | 49 |
| 48 // Returns true if there is enough information to process the DocType. | 50 // Returns true if there is enough information to process the DocType. |
| 49 bool DidBufferEnough(int bytes_read); | 51 bool DidBufferEnough(int bytes_read); |
| 50 | 52 |
| 51 // Returns true if we have to keep buffering data. | 53 // Returns true if we have to keep buffering data. |
| 52 bool KeepBuffering(int bytes_read); | 54 bool KeepBuffering(int bytes_read); |
| 53 | 55 |
| 54 // Sends a pending OnResponseStarted notification. | 56 // Sends a pending OnResponseStarted notification. |
| 55 bool CompleteResponseStarted(int request_id); | 57 bool CompleteResponseStarted(int request_id, bool* defer); |
| 56 | 58 |
| 57 // Returns true if we have to wait until the plugin list is generated. | 59 // Returns true if we have to wait until the plugin list is generated. |
| 58 bool ShouldWaitForPlugins(); | 60 bool ShouldWaitForPlugins(); |
| 59 | 61 |
| 60 // A test to determining whether the request should be forwarded to the | 62 // A test to determining whether the request should be forwarded to the |
| 61 // download thread. If need_plugin_list was passed in and was set to true, | 63 // download thread. If need_plugin_list was passed in and was set to true, |
| 62 // that means that the check couldn't be fully done because the plugins aren't | 64 // that means that the check couldn't be fully done because the plugins aren't |
| 63 // loaded. The function should be called again after the plugin list is | 65 // loaded. The function should be called again after the plugin list is |
| 64 // loaded. | 66 // loaded. |
| 65 bool ShouldDownload(bool* need_plugin_list); | 67 bool ShouldDownload(bool* need_plugin_list); |
| 66 | 68 |
| 67 // Informs the original ResourceHandler |next_handler_| that the response | 69 // Informs the original ResourceHandler |next_handler_| that the response |
| 68 // will be handled entirely by the new ResourceHandler |handler|. A | 70 // will be handled entirely by the new ResourceHandler |handler|. A |
| 69 // reference to |handler| is acquired. Returns false to indicate an error, | 71 // reference to |handler| is acquired. Returns false to indicate an error, |
| 70 // which will result in the request being cancelled. | 72 // which will result in the request being cancelled. |
| 71 bool UseAlternateResourceHandler(int request_id, ResourceHandler* handler); | 73 bool UseAlternateResourceHandler(int request_id, ResourceHandler* handler, |
| 74 bool* defer); |
| 72 | 75 |
| 73 // Forwards any queued events to |next_handler_|. Returns false to indicate | 76 // Forwards any queued events to |next_handler_|. Returns false to indicate |
| 74 // an error, which will result in the request being cancelled. | 77 // an error, which will result in the request being cancelled. |
| 75 bool ForwardPendingEventsToNextHandler(int request_id); | 78 bool ForwardPendingEventsToNextHandler(int request_id, bool* defer); |
| 76 | 79 |
| 77 // Copies data from |read_buffer_| to |next_handler_|. | 80 // Copies data from |read_buffer_| to |next_handler_|. |
| 78 void CopyReadBufferToNextHandler(int request_id); | 81 void CopyReadBufferToNextHandler(int request_id); |
| 79 | 82 |
| 80 // Called on the IO thread once the list of plugins has been loaded. | 83 // Called on the IO thread once the list of plugins has been loaded. |
| 81 void OnPluginsLoaded(const std::vector<webkit::WebPluginInfo>& plugins); | 84 void OnPluginsLoaded(const std::vector<webkit::WebPluginInfo>& plugins); |
| 82 | 85 |
| 83 scoped_refptr<ResourceResponse> response_; | 86 scoped_refptr<ResourceResponse> response_; |
| 84 ResourceDispatcherHostImpl* host_; | 87 ResourceDispatcherHostImpl* host_; |
| 85 net::URLRequest* request_; | 88 net::URLRequest* request_; |
| 86 scoped_refptr<net::IOBuffer> read_buffer_; | 89 scoped_refptr<net::IOBuffer> read_buffer_; |
| 87 scoped_refptr<net::IOBuffer> my_buffer_; | 90 scoped_refptr<net::IOBuffer> my_buffer_; |
| 88 int read_buffer_size_; | 91 int read_buffer_size_; |
| 89 int bytes_read_; | 92 int bytes_read_; |
| 90 bool sniff_content_; | 93 bool sniff_content_; |
| 91 bool wait_for_plugins_; | 94 bool wait_for_plugins_; |
| 95 bool deferred_waiting_for_plugins_; |
| 92 bool buffering_; | 96 bool buffering_; |
| 93 bool next_handler_needs_response_started_; | 97 bool next_handler_needs_response_started_; |
| 94 bool next_handler_needs_will_read_; | 98 bool next_handler_needs_will_read_; |
| 95 bool finished_; | 99 bool finished_; |
| 96 | 100 |
| 97 DISALLOW_COPY_AND_ASSIGN(BufferedResourceHandler); | 101 DISALLOW_COPY_AND_ASSIGN(BufferedResourceHandler); |
| 98 }; | 102 }; |
| 99 | 103 |
| 100 } // namespace content | 104 } // namespace content |
| 101 | 105 |
| 102 #endif // CONTENT_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ | 106 #endif // CONTENT_BROWSER_RENDERER_HOST_BUFFERED_RESOURCE_HANDLER_H_ |
| OLD | NEW |