Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(245)

Side by Side Diff: mojo/apps/js/content_handler_impl.cc

Issue 665743003: Mojo JS Bindings: Simplify sharing services for content-provided JS applications (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "mojo/apps/js/content_handler_impl.h" 5 #include "mojo/apps/js/content_handler_impl.h"
6 6
7 #include "mojo/apps/js/application_delegate_impl.h" 7 #include "mojo/apps/js/application_delegate_impl.h"
8 #include "mojo/apps/js/js_app.h" 8 #include "mojo/apps/js/js_app.h"
9 #include "mojo/common/data_pipe_utils.h" 9 #include "mojo/common/data_pipe_utils.h"
10 10
11 namespace mojo { 11 namespace mojo {
12 namespace apps { 12 namespace apps {
13 13
14 class ContentHandlerJSApp : public JSApp { 14 class ContentHandlerJSApp : public JSApp {
15 public: 15 public:
16 ContentHandlerJSApp(ApplicationDelegateImpl* app_delegate_impl, 16 ContentHandlerJSApp(ApplicationDelegateImpl* app_delegate_impl,
17 URLResponsePtr content) 17 URLResponsePtr content,
18 ScopedMessagePipeHandle sp)
Aaron Boodman 2014/10/29 17:12:51 Same thing here -- I would prefer to see the stron
hansmuller 2014/10/29 22:43:40 I tried to do this but was thwarted by base::Bind(
18 : JSApp(app_delegate_impl), 19 : JSApp(app_delegate_impl),
19 content_(content.Pass()) { 20 content_(content.Pass()),
21 requestor_message_pipe_handle_(sp.Pass()) {
20 } 22 }
21 23
22 bool Load(std::string* source, std::string* file_name) override { 24 bool Load(std::string* source, std::string* file_name) override {
23 *file_name = content_->url; 25 *file_name = content_->url;
24 if (content_.is_null()) 26 if (content_.is_null())
25 return false; 27 return false;
26 return common::BlockingCopyToString(content_->body.Pass(), source); 28 return common::BlockingCopyToString(content_->body.Pass(), source);
27 } 29 }
28 30
31 virtual Handle RequestorMessagePipeHandle() override {
32 return requestor_message_pipe_handle_.release();
33 }
34
29 private: 35 private:
30 URLResponsePtr content_; 36 URLResponsePtr content_;
37 ScopedMessagePipeHandle requestor_message_pipe_handle_;
31 }; 38 };
32 39
33 40
34 ContentHandlerImpl::ContentHandlerImpl(ApplicationDelegateImpl* app) 41 ContentHandlerImpl::ContentHandlerImpl(ApplicationDelegateImpl* app)
35 : app_delegate_impl_(app) { 42 : app_delegate_impl_(app) {
36 } 43 }
37 44
38 ContentHandlerImpl::~ContentHandlerImpl() { 45 ContentHandlerImpl::~ContentHandlerImpl() {
39 } 46 }
40 47
41 void ContentHandlerImpl::OnConnect( 48 void ContentHandlerImpl::OnConnect(
42 const mojo::String& requestor_url, 49 const mojo::String& requestor_url,
43 URLResponsePtr content, 50 URLResponsePtr content,
44 InterfaceRequest<ServiceProvider> service_provider) { 51 InterfaceRequest<ServiceProvider> service_provider) {
52 ScopedMessagePipeHandle sp(service_provider.PassMessagePipe());
45 scoped_ptr<JSApp> js_app( 53 scoped_ptr<JSApp> js_app(
46 new ContentHandlerJSApp(app_delegate_impl_, content.Pass())); 54 new ContentHandlerJSApp(app_delegate_impl_, content.Pass(), sp.Pass()));
47 app_delegate_impl_->StartJSApp(js_app.Pass()); 55 app_delegate_impl_->StartJSApp(js_app.Pass());
48 } 56 }
49 57
50 } // namespace apps 58 } // namespace apps
51 } // namespace mojo 59 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698