Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "sky/viewer/content_handler_impl.h" | 5 #include "sky/viewer/content_handler_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | |
| 8 #include "mojo/services/public/interfaces/network/network_service.mojom.h" | |
| 7 #include "sky/viewer/document_view.h" | 9 #include "sky/viewer/document_view.h" |
| 8 | 10 |
| 9 namespace sky { | 11 namespace sky { |
| 10 | 12 |
| 13 namespace { | |
| 14 | |
| 15 class EmptyServiceProvider : public mojo::InterfaceImpl<mojo::ServiceProvider> { | |
|
Aaron Boodman
2014/11/18 23:46:15
unused?
qsr
2014/11/19 13:42:38
Seems so.
| |
| 16 private: | |
| 17 void ConnectToService(const mojo::String& service_name, | |
| 18 mojo::ScopedMessagePipeHandle client_handle) override {} | |
| 19 }; | |
| 20 | |
| 21 } // namespace | |
| 22 | |
| 23 class SkyApplication : public mojo::Application { | |
| 24 public: | |
| 25 SkyApplication(scoped_refptr<base::MessageLoopProxy> compositor_thread, | |
| 26 mojo::ShellPtr shell, | |
| 27 mojo::URLResponsePtr response) | |
| 28 : compositor_thread_(compositor_thread), | |
| 29 url_(response->url), | |
| 30 shell_(shell.Pass()), | |
| 31 initial_response_(response.Pass()), | |
| 32 nb_views_(0) { | |
|
Aaron Boodman
2014/11/18 23:46:15
view_count_ ? or num_views_
qsr
2014/11/19 13:42:38
Done.
| |
| 33 shell_.set_client(this); | |
| 34 shell_->ConnectToApplication("mojo:network_service", | |
| 35 mojo::GetProxy(&network_service_app_)); | |
|
Aaron Boodman
2014/11/18 23:46:15
Just make network_service_app a local. You don't n
qsr
2014/11/19 13:42:38
I was not sure of what will happen when I close th
| |
| 36 mojo::MessagePipe pipe; | |
| 37 network_service_app_->ConnectToService(mojo::NetworkService::Name_, | |
|
Aaron Boodman
2014/11/18 23:46:15
Use mojo/public/cpp/application/connect.h
qsr
2014/11/19 13:42:38
Done.
| |
| 38 pipe.handle0.Pass()); | |
| 39 network_service_.Bind(pipe.handle1.Pass()); | |
| 40 } | |
| 41 | |
| 42 void Initialize(mojo::Array<mojo::String> args) override {} | |
| 43 | |
| 44 void AcceptConnection(const mojo::String& requestor_url, | |
| 45 mojo::ServiceProviderPtr provider) override { | |
| 46 ++nb_views_; | |
| 47 if (initial_response_) { | |
| 48 OnResponseReceived(nullptr, provider.Pass(), initial_response_.Pass()); | |
| 49 } else { | |
| 50 mojo::URLLoaderPtr* loader = new mojo::URLLoaderPtr; | |
|
Aaron Boodman
2014/11/18 23:46:15
What happens if this is a normal URLLoaderPtr, and
qsr
2014/11/19 13:42:38
The issue is we then do:
loader->Start(..., loade
Aaron Boodman
2014/11/19 15:58:15
I pinged jyasskin, my go-to C++ expert. He says yo
qsr
2014/11/19 16:37:22
Done.
| |
| 51 network_service_->CreateURLLoader(mojo::GetProxy(loader)); | |
| 52 mojo::URLRequestPtr request(mojo::URLRequest::New()); | |
| 53 request->url = url_; | |
| 54 request->auto_follow_redirects = true; | |
| 55 (*loader)->Start(request.Pass(), | |
| 56 base::Bind(&SkyApplication::OnResponseReceived, | |
| 57 base::Unretained(this), base::Owned(loader), | |
| 58 base::Passed(&provider))); | |
| 59 } | |
| 60 } | |
| 61 | |
| 62 private: | |
| 63 void OnViewDestroyed() { | |
| 64 --nb_views_; | |
| 65 if (nb_views_ == 0) { | |
| 66 delete this; | |
| 67 } | |
| 68 } | |
| 69 | |
| 70 void OnResponseReceived(mojo::URLLoaderPtr* loader, | |
|
Aaron Boodman
2014/11/18 23:46:15
Doesn't loader leak?
You may have to keep the loa
qsr
2014/11/19 13:42:38
Unless I'm misunderstanding base::Owned, I don't t
Aaron Boodman
2014/11/19 15:58:15
OK, just scary-looking. See above comment.
qsr
2014/11/19 16:37:22
Yes, that's for sure. The response owns the body.
| |
| 71 mojo::ServiceProviderPtr provider, | |
| 72 mojo::URLResponsePtr response) { | |
| 73 new DocumentView( | |
| 74 base::Bind(&SkyApplication::OnViewDestroyed, base::Unretained(this)), | |
| 75 provider.Pass(), response.Pass(), shell_.get(), compositor_thread_); | |
| 76 } | |
| 77 | |
| 78 scoped_refptr<base::MessageLoopProxy> compositor_thread_; | |
| 79 mojo::String url_; | |
| 80 mojo::ShellPtr shell_; | |
| 81 mojo::ServiceProviderPtr network_service_app_; | |
|
Aaron Boodman
2014/11/18 23:46:15
You don't need to keep this alive. Just make it a
qsr
2014/11/19 13:42:38
Done.
| |
| 82 mojo::NetworkServicePtr network_service_; | |
| 83 mojo::URLResponsePtr initial_response_; | |
| 84 uint32_t nb_views_; | |
| 85 }; | |
| 86 | |
| 11 ContentHandlerImpl::ContentHandlerImpl( | 87 ContentHandlerImpl::ContentHandlerImpl( |
| 12 scoped_refptr<base::MessageLoopProxy> compositor_thread) | 88 scoped_refptr<base::MessageLoopProxy> compositor_thread) |
| 13 : compositor_thread_(compositor_thread) { | 89 : compositor_thread_(compositor_thread) { |
| 14 } | 90 } |
| 15 | 91 |
| 16 ContentHandlerImpl::~ContentHandlerImpl() { | 92 ContentHandlerImpl::~ContentHandlerImpl() { |
| 17 } | 93 } |
| 18 | 94 |
| 19 void ContentHandlerImpl::StartApplication(mojo::ShellPtr shell, | 95 void ContentHandlerImpl::StartApplication(mojo::ShellPtr shell, |
| 20 mojo::URLResponsePtr response) { | 96 mojo::URLResponsePtr response) { |
| 21 new DocumentView(response.Pass(), shell.Pass(), compositor_thread_); | 97 new SkyApplication(compositor_thread_, shell.Pass(), response.Pass()); |
| 22 } | 98 } |
| 23 | 99 |
| 24 } // namespace sky | 100 } // namespace sky |
| OLD | NEW |