| 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 <algorithm> | 5 #include <algorithm> |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/debug/profiler.h" | 8 #include "base/debug/profiler.h" |
| 9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
| 10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 class Debugger : public mojo::ApplicationDelegate, | 32 class Debugger : public mojo::ApplicationDelegate, |
| 33 public http_server::HttpHandler { | 33 public http_server::HttpHandler { |
| 34 public: | 34 public: |
| 35 Debugger() : is_tracing_(false), app_(nullptr), handler_binding_(this) {} | 35 Debugger() : is_tracing_(false), app_(nullptr), handler_binding_(this) {} |
| 36 ~Debugger() override {} | 36 ~Debugger() override {} |
| 37 | 37 |
| 38 private: | 38 private: |
| 39 // mojo::ApplicationDelegate: | 39 // mojo::ApplicationDelegate: |
| 40 void Initialize(mojo::ApplicationImpl* app) override { | 40 void Initialize(mojo::ApplicationImpl* app) override { |
| 41 app_ = app; | 41 app_ = app; |
| 42 app->ConnectToService("mojo:window_manager", &window_manager_); | |
| 43 | 42 |
| 44 // Format: --args-for="app_url command_port" | 43 // Format: --args-for="app_url command_port" |
| 45 if (app->args().size() < 2) { | 44 if (app->args().size() < 2) { |
| 46 LOG(ERROR) << "--args-for required to specify command_port"; | 45 LOG(ERROR) << "--args-for required to specify command_port"; |
| 47 mojo::ApplicationImpl::Terminate(); | 46 mojo::ApplicationImpl::Terminate(); |
| 48 return; | 47 return; |
| 49 } | 48 } |
| 49 if (app->args().size() == 3 && app->args()[2] == "--wm") { |
| 50 // Connect to window manager only if requested, as the user might want to |
| 51 // run the debugger without spawning one. |
| 52 app_->ConnectToService("mojo:window_manager", &window_manager_); |
| 53 } |
| 50 base::StringToUint(app->args()[1], &command_port_); | 54 base::StringToUint(app->args()[1], &command_port_); |
| 51 http_server::HttpServerFactoryPtr http_server_factory; | 55 http_server::HttpServerFactoryPtr http_server_factory; |
| 52 app->ConnectToService("mojo:http_server", &http_server_factory); | 56 app->ConnectToService("mojo:http_server", &http_server_factory); |
| 53 | 57 |
| 54 mojo::NetAddressPtr local_address(mojo::NetAddress::New()); | 58 mojo::NetAddressPtr local_address(mojo::NetAddress::New()); |
| 55 local_address->family = mojo::NET_ADDRESS_FAMILY_IPV4; | 59 local_address->family = mojo::NET_ADDRESS_FAMILY_IPV4; |
| 56 local_address->ipv4 = mojo::NetAddressIPv4::New(); | 60 local_address->ipv4 = mojo::NetAddressIPv4::New(); |
| 57 local_address->ipv4->addr.resize(4); | 61 local_address->ipv4->addr.resize(4); |
| 58 local_address->ipv4->addr[0] = 127; | 62 local_address->ipv4->addr[0] = 127; |
| 59 local_address->ipv4->addr[1] = 0; | 63 local_address->ipv4->addr[1] = 0; |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 122 } | 126 } |
| 123 | 127 |
| 124 void Load(const HandleRequestCallback& callback, std::string url) { | 128 void Load(const HandleRequestCallback& callback, std::string url) { |
| 125 url_ = url; | 129 url_ = url; |
| 126 Reload(); | 130 Reload(); |
| 127 std::string response = std::string("Loaded ") + url + "\n"; | 131 std::string response = std::string("Loaded ") + url + "\n"; |
| 128 Respond(callback, response); | 132 Respond(callback, response); |
| 129 } | 133 } |
| 130 | 134 |
| 131 void Reload() { | 135 void Reload() { |
| 136 if (!window_manager_) |
| 137 return; |
| 138 |
| 132 // SimpleWindowManager will wire up necessary services on our behalf. | 139 // SimpleWindowManager will wire up necessary services on our behalf. |
| 133 window_manager_->Embed(url_, nullptr, nullptr); | 140 window_manager_->Embed(url_, nullptr, nullptr); |
| 134 } | 141 } |
| 135 | 142 |
| 136 void Exit() { | 143 void Exit() { |
| 137 // TODO(eseidel): We should orderly shutdown once mojo can. | 144 // TODO(eseidel): We should orderly shutdown once mojo can. |
| 138 exit(0); | 145 exit(0); |
| 139 } | 146 } |
| 140 | 147 |
| 141 void StartTracing(const HandleRequestCallback& callback) { | 148 void StartTracing(const HandleRequestCallback& callback) { |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 205 DISALLOW_COPY_AND_ASSIGN(Debugger); | 212 DISALLOW_COPY_AND_ASSIGN(Debugger); |
| 206 }; | 213 }; |
| 207 | 214 |
| 208 } // namespace debugger | 215 } // namespace debugger |
| 209 | 216 |
| 210 MojoResult MojoMain(MojoHandle application_request) { | 217 MojoResult MojoMain(MojoHandle application_request) { |
| 211 mojo::ApplicationRunnerChromium runner(new debugger::Debugger); | 218 mojo::ApplicationRunnerChromium runner(new debugger::Debugger); |
| 212 runner.set_message_loop_type(base::MessageLoop::TYPE_IO); | 219 runner.set_message_loop_type(base::MessageLoop::TYPE_IO); |
| 213 return runner.Run(application_request); | 220 return runner.Run(application_request); |
| 214 } | 221 } |
| OLD | NEW |