| Index: mojo/services/network/main.cc
|
| diff --git a/mojo/services/network/main.cc b/mojo/services/network/main.cc
|
| index bdfbda2412b26282a3fb39aec210ebdf2b35ff6b..8fd503c7704b40082d3b693293b7d06dc28cffee 100644
|
| --- a/mojo/services/network/main.cc
|
| +++ b/mojo/services/network/main.cc
|
| @@ -11,6 +11,7 @@
|
| #include "mojo/public/cpp/application/application_connection.h"
|
| #include "mojo/public/cpp/application/application_delegate.h"
|
| #include "mojo/public/cpp/application/application_impl.h"
|
| +#include "mojo/public/cpp/application/application_runner_chromium.h"
|
| #include "mojo/public/cpp/application/interface_factory.h"
|
| #include "mojo/public/cpp/bindings/interface_ptr.h"
|
| #include "mojo/services/network/network_context.h"
|
| @@ -50,27 +51,8 @@ class Delegate : public mojo::ApplicationDelegate,
|
|
|
| extern "C" APPLICATION_EXPORT MojoResult CDECL MojoMain(
|
| MojoHandle shell_handle) {
|
| - base::CommandLine::Init(0, NULL);
|
| -#if !defined(COMPONENT_BUILD)
|
| - base::AtExitManager at_exit;
|
| -#endif
|
| -
|
| - // The Delegate owns the NetworkContext, which needs to outlive
|
| - // MessageLoopForIO. Destruction of the message loop will serve to
|
| - // invalidate connections made to network services (URLLoader) and cause
|
| - // the service instances to be cleaned up as a result of observing pipe
|
| - // errors. This is important as ~URLRequestContext asserts that no out-
|
| - // standing URLRequests exist.
|
| - Delegate delegate;
|
| - {
|
| - // The IO message loop allows us to use net::URLRequest on this thread.
|
| - base::MessageLoopForIO loop;
|
| -
|
| - mojo::ApplicationImpl app(
|
| - &delegate,
|
| - mojo::MakeScopedHandle(mojo::MessagePipeHandle(shell_handle)));
|
| -
|
| - loop.Run();
|
| - }
|
| - return MOJO_RESULT_OK;
|
| + mojo::ApplicationRunnerChromium app;
|
| + app.take_delegate(make_scoped_delegate(new Delegate));
|
| + app.set_loop_type(base::MessageLoop::TYPE_IO);
|
| + return app.Run(shell_handle);
|
| }
|
|
|