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

Side by Side Diff: examples/native_run_app/native_run_app.cc

Issue 2015643002: Add (optional) options to Run[Main]Application(). (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: doh Created 4 years, 7 months 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 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 // This is a terminal client (i.e., a "raw" |mojo.terminal.Terminal| -- e.g., 5 // This is a terminal client (i.e., a "raw" |mojo.terminal.Terminal| -- e.g.,
6 // moterm -- can be asked to talk to this) that prompts the user for a native 6 // moterm -- can be asked to talk to this) that prompts the user for a native
7 // (Linux) binary to run and then does so (via mojo:native_support). 7 // (Linux) binary to run and then does so (via mojo:native_support).
8 // 8 //
9 // E.g., first run mojo:moterm_example_app (embedded by a window manager). Then, 9 // E.g., first run mojo:moterm_example_app (embedded by a window manager). Then,
10 // at the prompt, enter "mojo:native_run_app". At the next prompt, enter "bash" 10 // at the prompt, enter "mojo:native_run_app". At the next prompt, enter "bash"
11 // (or "echo hello mojo"). 11 // (or "echo hello mojo").
12 // 12 //
13 // TODO(vtl): Maybe it should optionally be able to extract the binary path (and 13 // TODO(vtl): Maybe it should optionally be able to extract the binary path (and
14 // args) from the connection URL? 14 // args) from the connection URL?
15 15
16 #include <string.h> 16 #include <string.h>
17 17
18 #include <string> 18 #include <string>
19 #include <utility> 19 #include <utility>
20 #include <vector> 20 #include <vector>
21 21
22 #include "base/logging.h" 22 #include "base/logging.h"
23 #include "base/macros.h" 23 #include "base/macros.h"
24 #include "base/strings/string_split.h" 24 #include "base/strings/string_split.h"
25 #include "mojo/application/application_runner_chromium.h"
26 #include "mojo/public/c/system/main.h" 25 #include "mojo/public/c/system/main.h"
27 #include "mojo/public/cpp/application/application_delegate.h" 26 #include "mojo/public/cpp/application/application_delegate.h"
28 #include "mojo/public/cpp/application/application_impl.h" 27 #include "mojo/public/cpp/application/application_impl_base.h"
29 #include "mojo/public/cpp/application/connect.h" 28 #include "mojo/public/cpp/application/connect.h"
29 #include "mojo/public/cpp/application/run_application.h"
30 #include "mojo/public/cpp/application/service_provider_impl.h" 30 #include "mojo/public/cpp/application/service_provider_impl.h"
31 #include "mojo/public/cpp/bindings/interface_request.h" 31 #include "mojo/public/cpp/bindings/interface_request.h"
32 #include "mojo/public/cpp/bindings/strong_binding.h" 32 #include "mojo/public/cpp/bindings/strong_binding.h"
33 #include "mojo/services/files/interfaces/files.mojom.h" 33 #include "mojo/services/files/interfaces/files.mojom.h"
34 #include "mojo/services/files/interfaces/ioctl.mojom.h" 34 #include "mojo/services/files/interfaces/ioctl.mojom.h"
35 #include "mojo/services/files/interfaces/ioctl_terminal.mojom.h" 35 #include "mojo/services/files/interfaces/ioctl_terminal.mojom.h"
36 #include "mojo/services/files/interfaces/types.mojom.h" 36 #include "mojo/services/files/interfaces/types.mojom.h"
37 #include "mojo/services/native_support/interfaces/process.mojom.h" 37 #include "mojo/services/native_support/interfaces/process.mojom.h"
38 #include "mojo/services/terminal/interfaces/terminal_client.mojom.h" 38 #include "mojo/services/terminal/interfaces/terminal_client.mojom.h"
39 39
(...skipping 173 matching lines...) Expand 10 before | Expand all | Expand 10 after
213 } 213 }
214 } 214 }
215 215
216 private: 216 private:
217 mojo::StrongBinding<TerminalClient> binding_; 217 mojo::StrongBinding<TerminalClient> binding_;
218 native_support::Process* native_support_process_; 218 native_support::Process* native_support_process_;
219 219
220 DISALLOW_COPY_AND_ASSIGN(TerminalClientImpl); 220 DISALLOW_COPY_AND_ASSIGN(TerminalClientImpl);
221 }; 221 };
222 222
223 class NativeRunApp : public mojo::ApplicationDelegate { 223 class NativeRunApp : public mojo::ApplicationImplBase {
224 public: 224 public:
225 NativeRunApp() : application_impl_(nullptr) {} 225 NativeRunApp() {}
226 ~NativeRunApp() override {} 226 ~NativeRunApp() override {}
227 227
228 private: 228 private:
229 // |mojo::ApplicationDelegate|: 229 // |mojo::ApplicationImplBase| overrides:
230 void Initialize(mojo::ApplicationImpl* application_impl) override { 230 void OnInitialize() override {
231 DCHECK(!application_impl_); 231 mojo::ConnectToService(shell(), "mojo:native_support",
232 application_impl_ = application_impl;
233 mojo::ConnectToService(application_impl_->shell(), "mojo:native_support",
234 GetProxy(&native_support_process_)); 232 GetProxy(&native_support_process_));
235 } 233 }
236 234
237 bool ConfigureIncomingConnection( 235 bool OnAcceptConnection(
238 mojo::ServiceProviderImpl* service_provider_impl) override { 236 mojo::ServiceProviderImpl* service_provider_impl) override {
239 service_provider_impl->AddService<TerminalClient>( 237 service_provider_impl->AddService<TerminalClient>(
240 [this](const mojo::ConnectionContext& connection_context, 238 [this](const mojo::ConnectionContext& connection_context,
241 mojo::InterfaceRequest<TerminalClient> terminal_client_request) { 239 mojo::InterfaceRequest<TerminalClient> terminal_client_request) {
242 new TerminalClientImpl(terminal_client_request.Pass(), 240 new TerminalClientImpl(terminal_client_request.Pass(),
243 native_support_process_.get()); 241 native_support_process_.get());
244 }); 242 });
245 return true; 243 return true;
246 } 244 }
247 245
248 mojo::ApplicationImpl* application_impl_;
249 native_support::ProcessPtr native_support_process_; 246 native_support::ProcessPtr native_support_process_;
250 247
251 DISALLOW_COPY_AND_ASSIGN(NativeRunApp); 248 DISALLOW_COPY_AND_ASSIGN(NativeRunApp);
252 }; 249 };
253 250
254 MojoResult MojoMain(MojoHandle application_request) { 251 MojoResult MojoMain(MojoHandle application_request) {
255 mojo::ApplicationRunnerChromium runner(new NativeRunApp()); 252 NativeRunApp native_run_app;
256 return runner.Run(application_request); 253 return mojo::RunMainApplication(application_request, &native_run_app);
257 } 254 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698