Chromium Code Reviews| Index: mojo/public/cpp/application/lib/application_runner_chromium.cc |
| diff --git a/mojo/public/cpp/application/lib/application_runner_chromium.cc b/mojo/public/cpp/application/lib/application_runner_chromium.cc |
| index 6f5764b8f3a6e1be0dea2a874e6863efd7091fd1..7176d045a225f06363069a921b994ab2a0d49878 100644 |
| --- a/mojo/public/cpp/application/lib/application_runner_chromium.cc |
| +++ b/mojo/public/cpp/application/lib/application_runner_chromium.cc |
| @@ -6,7 +6,9 @@ |
| #include "base/at_exit.h" |
| #include "base/command_line.h" |
| +#include "base/memory/scoped_ptr.h" |
| #include "base/message_loop/message_loop.h" |
| +#include "mojo/common/message_pump_mojo.h" |
| #include "mojo/public/cpp/application/application_delegate.h" |
| #include "mojo/public/cpp/application/application_impl.h" |
| @@ -21,13 +23,13 @@ void ApplicationImpl::Terminate() { |
| ApplicationRunnerChromium::ApplicationRunnerChromium( |
| ApplicationDelegate* delegate) |
| : delegate_(scoped_ptr<ApplicationDelegate>(delegate)), |
| - message_loop_type_(base::MessageLoop::TYPE_DEFAULT) {} |
| + message_loop_type_(base::MessageLoop::TYPE_CUSTOM) {} |
| ApplicationRunnerChromium::~ApplicationRunnerChromium() {} |
| void ApplicationRunnerChromium::set_message_loop_type( |
| base::MessageLoop::Type type) { |
| - DCHECK_EQ(base::MessageLoop::TYPE_DEFAULT, message_loop_type_); |
| + DCHECK_EQ(base::MessageLoop::TYPE_CUSTOM, message_loop_type_); |
|
darin (slow to review)
2014/08/27 21:20:43
I don't understand this assertion. Why is it inval
yzshen1
2014/08/27 22:31:48
I honestly didn't think about it. :)
|
| message_loop_type_ = type; |
| } |
| @@ -38,10 +40,16 @@ MojoResult ApplicationRunnerChromium::Run(MojoHandle shell_handle) { |
| #endif |
| { |
| - base::MessageLoop loop(message_loop_type_); |
| + scoped_ptr<base::MessageLoop> loop; |
| + if (message_loop_type_ == base::MessageLoop::TYPE_CUSTOM) { |
| + loop.reset(new base::MessageLoop(common::MessagePumpMojo::Create())); |
| + } else { |
| + loop.reset(new base::MessageLoop(message_loop_type_)); |
| + } |
| + |
| ApplicationImpl impl(delegate_.get(), |
| MakeScopedHandle(MessagePipeHandle(shell_handle))); |
| - loop.Run(); |
| + loop->Run(); |
| } |
| delegate_.reset(); |
| return MOJO_RESULT_OK; |