OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 #include "components/html_viewer/document_resource_waiter.h" | 5 #include "components/html_viewer/document_resource_waiter.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "components/html_viewer/global_state.h" | 9 #include "components/html_viewer/global_state.h" |
10 #include "components/html_viewer/html_document.h" | 10 #include "components/html_viewer/html_document.h" |
11 #include "components/html_viewer/html_frame_tree_manager.h" | 11 #include "components/html_viewer/html_frame_tree_manager.h" |
12 #include "components/mus/public/cpp/window.h" | 12 #include "components/mus/public/cpp/window.h" |
13 | 13 |
14 using web_view::mojom::WindowConnectType; | 14 using web_view::mojom::WindowConnectType; |
15 | 15 |
16 namespace html_viewer { | 16 namespace html_viewer { |
17 | 17 |
18 DocumentResourceWaiter::DocumentResourceWaiter(GlobalState* global_state, | 18 DocumentResourceWaiter::DocumentResourceWaiter(GlobalState* global_state, |
19 mojo::URLResponsePtr response, | 19 mojo::URLResponsePtr response, |
20 HTMLDocument* document) | 20 HTMLDocument* document) |
21 : global_state_(global_state), | 21 : global_state_(global_state), |
22 document_(document), | 22 document_(document), |
23 response_(std::move(response)), | 23 response_(std::move(response)), |
24 root_(nullptr), | 24 root_(nullptr), |
25 change_id_(0u), | 25 change_id_(0u), |
26 window_id_(0u), | 26 window_id_(0u), |
27 window_connect_type_(web_view::mojom::WINDOW_CONNECT_TYPE_USE_NEW), | 27 window_connect_type_(web_view::mojom::WindowConnectType::USE_NEW), |
28 frame_client_binding_(this), | 28 frame_client_binding_(this), |
29 is_ready_(false), | 29 is_ready_(false), |
30 waiting_for_change_id_(false), | 30 waiting_for_change_id_(false), |
31 target_frame_tree_(nullptr) {} | 31 target_frame_tree_(nullptr) {} |
32 | 32 |
33 DocumentResourceWaiter::~DocumentResourceWaiter() { | 33 DocumentResourceWaiter::~DocumentResourceWaiter() { |
34 if (root_) | 34 if (root_) |
35 root_->RemoveObserver(this); | 35 root_->RemoveObserver(this); |
36 if (target_frame_tree_) | 36 if (target_frame_tree_) |
37 target_frame_tree_->RemoveObserver(this); | 37 target_frame_tree_->RemoveObserver(this); |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
93 // (|frame_data_| is valid) and we have a window with valid metrics. The | 93 // (|frame_data_| is valid) and we have a window with valid metrics. The |
94 // window is not necessary is WindowConnectType is USE_EXISTING, which means | 94 // window is not necessary is WindowConnectType is USE_EXISTING, which means |
95 // the | 95 // the |
96 // application is not asked for a ViewTreeClient. The metrics are necessary | 96 // application is not asked for a ViewTreeClient. The metrics are necessary |
97 // to initialize ResourceBundle. If USE_EXISTING is true, it means a Window | 97 // to initialize ResourceBundle. If USE_EXISTING is true, it means a Window |
98 // has already been provided to another HTMLDocument and there is no need to | 98 // has already been provided to another HTMLDocument and there is no need to |
99 // wait for metrics. | 99 // wait for metrics. |
100 bool is_ready = | 100 bool is_ready = |
101 (!frame_data_.is_null() && | 101 (!frame_data_.is_null() && |
102 ((window_connect_type_ == | 102 ((window_connect_type_ == |
103 web_view::mojom::WINDOW_CONNECT_TYPE_USE_EXISTING) || | 103 web_view::mojom::WindowConnectType::USE_EXISTING) || |
104 (root_ && root_->viewport_metrics().device_pixel_ratio != 0.0f))); | 104 (root_ && root_->viewport_metrics().device_pixel_ratio != 0.0f))); |
105 if (is_ready) { | 105 if (is_ready) { |
106 HTMLFrameTreeManager* frame_tree = | 106 HTMLFrameTreeManager* frame_tree = |
107 HTMLFrameTreeManager::FindFrameTreeWithRoot(frame_data_[0]->frame_id); | 107 HTMLFrameTreeManager::FindFrameTreeWithRoot(frame_data_[0]->frame_id); |
108 // Once we've received OnConnect() and the window (if necessary), we | 108 // Once we've received OnConnect() and the window (if necessary), we |
109 // determine which HTMLFrameTreeManager the new frame ends up in. If there | 109 // determine which HTMLFrameTreeManager the new frame ends up in. If there |
110 // is an existing HTMLFrameTreeManager then we must wait for the change_id | 110 // is an existing HTMLFrameTreeManager then we must wait for the change_id |
111 // supplied to OnConnect() to be <= that of the HTMLFrameTreeManager's | 111 // supplied to OnConnect() to be <= that of the HTMLFrameTreeManager's |
112 // change_id. If we did not wait for the change id to be <= then the | 112 // change_id. If we did not wait for the change id to be <= then the |
113 // structure of the tree is not in the expected state and it's possible the | 113 // structure of the tree is not in the expected state and it's possible the |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
234 | 234 |
235 void DocumentResourceWaiter::OnHTMLFrameTreeManagerChangeIdAdvanced() { | 235 void DocumentResourceWaiter::OnHTMLFrameTreeManagerChangeIdAdvanced() { |
236 UpdateIsReady(); | 236 UpdateIsReady(); |
237 } | 237 } |
238 | 238 |
239 void DocumentResourceWaiter::OnHTMLFrameTreeManagerDestroyed() { | 239 void DocumentResourceWaiter::OnHTMLFrameTreeManagerDestroyed() { |
240 document_->Destroy(); // This destroys us. | 240 document_->Destroy(); // This destroys us. |
241 } | 241 } |
242 | 242 |
243 } // namespace html_viewer | 243 } // namespace html_viewer |
OLD | NEW |