electron/atom/app/node_main.cc

100 lines
3 KiB
C++
Raw Normal View History

// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/app/node_main.h"
2015-09-03 02:28:50 +00:00
#include "atom/app/uv_task_runner.h"
#include "atom/browser/javascript_environment.h"
#include "atom/browser/node_debugger.h"
#include "base/command_line.h"
#include "base/feature_list.h"
2016-07-04 06:08:55 +00:00
#include "base/threading/thread_task_runner_handle.h"
#include "gin/array_buffer.h"
#include "gin/public/isolate_holder.h"
#include "gin/v8_initializer.h"
2016-10-12 20:01:17 +00:00
#include "atom/common/api/atom_bindings.h"
2016-10-12 20:01:17 +00:00
#include "atom/common/native_mate_converters/string16_converter.h"
#include "native_mate/dictionary.h"
2016-07-21 06:51:57 +00:00
#include "atom/common/node_includes.h"
namespace atom {
int NodeMain(int argc, char *argv[]) {
base::CommandLine::Init(argc, argv);
int exit_code = 1;
{
2015-09-03 02:28:50 +00:00
// Feed gin::PerIsolateData with a task runner.
argv = uv_setup_args(argc, argv);
2015-09-03 02:28:50 +00:00
uv_loop_t* loop = uv_default_loop();
scoped_refptr<UvTaskRunner> uv_task_runner(new UvTaskRunner(loop));
base::ThreadTaskRunnerHandle handle(uv_task_runner);
// Initialize feature list.
std::unique_ptr<base::FeatureList> feature_list(new base::FeatureList);
feature_list->InitializeFromCommandLine("", "");
base::FeatureList::SetInstance(std::move(feature_list));
gin::V8Initializer::LoadV8Snapshot();
2015-09-03 02:28:50 +00:00
gin::V8Initializer::LoadV8Natives();
JavascriptEnvironment gin_env;
int exec_argc;
const char** exec_argv;
node::Init(&argc, const_cast<const char**>(argv), &exec_argc, &exec_argv);
2017-01-18 17:56:41 +00:00
node::IsolateData isolate_data(gin_env.isolate(), loop);
node::Environment* env = node::CreateEnvironment(
2017-01-18 17:56:41 +00:00
&isolate_data, gin_env.context(), argc, argv,
2015-04-20 06:10:15 +00:00
exec_argc, exec_argv);
// Start our custom debugger implementation.
NodeDebugger node_debugger(gin_env.isolate());
if (node_debugger.IsRunning())
2016-11-30 07:30:03 +00:00
env->AssignToContext(v8::Debug::GetDebugContext(gin_env.isolate()));
2016-10-12 16:33:28 +00:00
mate::Dictionary process(gin_env.isolate(), env->process_object());
#if defined(OS_WIN)
2016-10-12 16:33:28 +00:00
process.SetMethod("log", &AtomBindings::Log);
2016-10-12 20:01:17 +00:00
#endif
process.SetMethod("crash", &AtomBindings::Crash);
2015-04-20 06:10:15 +00:00
2016-12-09 09:44:12 +00:00
v8::Local<v8::Object> crashReporterObj = v8::Object::New(env->isolate());
mate::Dictionary crashReporterDict(gin_env.isolate(), crashReporterObj);
crashReporterDict.SetMethod("start", &AtomBindings::StartCrashReporter);
process.Set("crashReporter", crashReporterObj);
2016-10-12 16:33:28 +00:00
node::LoadEnvironment(env);
bool more;
do {
more = uv_run(env->event_loop(), UV_RUN_ONCE);
if (more == false) {
node::EmitBeforeExit(env);
// Emit `beforeExit` if the loop became alive either after emitting
// event, or after running some callbacks.
more = uv_loop_alive(env->event_loop());
if (uv_run(env->event_loop(), UV_RUN_NOWAIT) != 0)
more = true;
}
} while (more == true);
exit_code = node::EmitExit(env);
node::RunAtExit(env);
2016-07-21 07:43:21 +00:00
node::FreeEnvironment(env);
}
v8::V8::Dispose();
return exit_code;
}
} // namespace atom