| 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 "mojo/public/cpp/application/application_delegate.h" | 5 #include "mojo/public/cpp/application/application_delegate.h" |
| 6 #include "mojo/public/cpp/application/application_impl.h" | 6 #include "mojo/public/cpp/application/application_impl.h" |
| 7 #include "mojo/public/cpp/environment/environment.h" | 7 #include "mojo/public/cpp/environment/environment.h" |
| 8 #include "mojo/public/cpp/utility/run_loop.h" | 8 #include "mojo/public/cpp/utility/run_loop.h" |
| 9 | 9 |
| 10 extern "C" APPLICATION_EXPORT MojoResult CDECL MojoMain( | 10 extern "C" APPLICATION_EXPORT MojoResult CDECL MojoMain( |
| 11 MojoHandle shell_handle) { | 11 MojoHandle shell_handle) { |
| 12 mojo::Environment env; | 12 mojo::Environment env; |
| 13 mojo::RunLoop loop; | 13 mojo::ApplicationDelegate* delegate = NULL; |
| 14 mojo::ApplicationDelegate* delegate = mojo::ApplicationDelegate::Create(); | |
| 15 { | 14 { |
| 16 mojo::ApplicationImpl app(delegate); | 15 // We have to shut down the RunLoop before destroying the |
| 17 app.BindShell(shell_handle); | 16 // ApplicationDelegate. |
| 18 loop.Run(); | 17 mojo::RunLoop loop; |
| 18 delegate = mojo::ApplicationDelegate::Create(); |
| 19 { |
| 20 mojo::ApplicationImpl app(delegate); |
| 21 app.BindShell(shell_handle); |
| 22 loop.Run(); |
| 23 } |
| 19 } | 24 } |
| 20 delete delegate; | 25 delete delegate; |
| 21 | 26 |
| 22 return MOJO_RESULT_OK; | 27 return MOJO_RESULT_OK; |
| 23 } | 28 } |
| OLD | NEW |