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; |