// Copyright (c) 2014 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #include "atom/browser/node_debugger.h" #include #include #include #include "atom/common/node_includes.h" #include "base/command_line.h" #include "base/logging.h" #include "base/strings/string_util.h" #include "base/strings/utf_string_conversions.h" #include "libplatform/libplatform.h" #include "native_mate/dictionary.h" namespace atom { NodeDebugger::NodeDebugger(node::Environment* env) : env_(env) {} NodeDebugger::~NodeDebugger() {} void NodeDebugger::Start() { auto* inspector = env_->inspector_agent(); if (inspector == nullptr) return; std::vector args; for (auto& arg : base::CommandLine::ForCurrentProcess()->argv()) { #if defined(OS_WIN) args.push_back(base::UTF16ToUTF8(arg)); #else args.push_back(arg); #endif } node::DebugOptions options; std::vector exec_args; std::vector v8_args; std::vector errors; node::options_parser::DebugOptionsParser::instance.Parse( &args, &exec_args, &v8_args, &options, node::options_parser::kDisallowedInEnvironment, &errors); if (!errors.empty()) { // TODO(jeremy): what's the appropriate behaviour here? LOG(ERROR) << "Error parsing node options: " << base::JoinString(errors, " "); } // Set process._debugWaitConnect if --inspect-brk was specified to stop // the debugger on the first line if (options.wait_for_connect()) { mate::Dictionary process(env_->isolate(), env_->process_object()); process.Set("_breakFirstLine", true); } const char* path = ""; if (inspector->Start(path, options, env_->inspector_host_port(), true /* is_main */)) DCHECK(env_->inspector_agent()->IsListening()); } } // namespace atom