This source file includes following definitions.
- Start
#include "mojo/shell/in_process_dynamic_service_runner.h"
#include "base/bind.h"
#include "base/callback_helpers.h"
#include "base/file_util.h"
#include "base/location.h"
#include "base/logging.h"
#include "base/message_loop/message_loop_proxy.h"
#include "base/scoped_native_library.h"
namespace mojo {
namespace shell {
InProcessDynamicServiceRunner::InProcessDynamicServiceRunner(
Context* )
: thread_(this, "app_thread") {
}
InProcessDynamicServiceRunner::~InProcessDynamicServiceRunner() {
if (thread_.HasBeenStarted()) {
DCHECK(!thread_.HasBeenJoined());
thread_.Join();
}
}
void InProcessDynamicServiceRunner::Start(
const base::FilePath& app_path,
ScopedShellHandle service_handle,
const base::Closure& app_completed_callback) {
app_path_ = app_path;
DCHECK(!service_handle_.is_valid());
service_handle_ = service_handle.Pass();
DCHECK(app_completed_callback_runner_.is_null());
app_completed_callback_runner_ = base::Bind(&base::TaskRunner::PostTask,
base::MessageLoopProxy::current(),
FROM_HERE,
app_completed_callback);
DCHECK(!thread_.HasBeenStarted());
thread_.Start();
}
void InProcessDynamicServiceRunner::Run() {
DVLOG(2) << "Loading/running Mojo app from " << app_path_.value()
<< " in process";
base::ScopedClosureRunner app_deleter(
base::Bind(base::IgnoreResult(&base::DeleteFile), app_path_, false));
do {
base::NativeLibraryLoadError error;
base::ScopedNativeLibrary app_library(
base::LoadNativeLibrary(app_path_, &error));
if (!app_library.is_valid()) {
LOG(ERROR) << "Failed to load library (error: " << error.ToString()
<< ")";
break;
}
typedef MojoResult (*MojoMainFunction)(MojoHandle);
MojoMainFunction main_function = reinterpret_cast<MojoMainFunction>(
app_library.GetFunctionPointer("MojoMain"));
if (!main_function) {
LOG(ERROR) << "Entrypoint MojoMain not found";
break;
}
MojoResult result = main_function(service_handle_.release().value());
if (result < MOJO_RESULT_OK)
LOG(ERROR) << "MojoMain returned an error: " << result;
} while (false);
bool success = app_completed_callback_runner_.Run();
app_completed_callback_runner_.Reset();
LOG_IF(ERROR, !success) << "Failed post run app_completed_callback";
}
}
}