|
@@ -4,9 +4,12 @@
|
|
|
|
|
|
#include "atom/browser/node_debugger.h"
|
|
|
|
|
|
+#include <memory>
|
|
|
#include <string>
|
|
|
+#include <vector>
|
|
|
|
|
|
#include "base/command_line.h"
|
|
|
+#include "base/logging.h"
|
|
|
#include "base/strings/utf_string_conversions.h"
|
|
|
#include "libplatform/libplatform.h"
|
|
|
#include "native_mate/dictionary.h"
|
|
@@ -24,29 +27,40 @@ void NodeDebugger::Start() {
|
|
|
if (inspector == nullptr)
|
|
|
return;
|
|
|
|
|
|
- node::DebugOptions options;
|
|
|
+ std::vector<std::string> args;
|
|
|
for (auto& arg : base::CommandLine::ForCurrentProcess()->argv()) {
|
|
|
#if defined(OS_WIN)
|
|
|
- const std::string nice_arg = base::UTF16ToUTF8(arg);
|
|
|
+ args.push_back(base::UTF16ToUTF8(arg));
|
|
|
#else
|
|
|
- const std::string& nice_arg = arg;
|
|
|
+ args.push_back(arg);
|
|
|
#endif
|
|
|
- // Stop handling arguments after a "--" to be consistent with Chromium
|
|
|
- if (nice_arg == "--")
|
|
|
- break;
|
|
|
+ }
|
|
|
+
|
|
|
+ auto options = std::make_shared<node::DebugOptions>();
|
|
|
+ std::vector<std::string> exec_args;
|
|
|
+ std::vector<std::string> v8_args;
|
|
|
+ std::string error;
|
|
|
+
|
|
|
+ node::options_parser::DebugOptionsParser::instance.Parse(
|
|
|
+ &args, &exec_args, &v8_args, options.get(),
|
|
|
+ node::options_parser::kDisallowedInEnvironment, &error);
|
|
|
|
|
|
- options.ParseOption("Electron", nice_arg);
|
|
|
+ if (!error.empty()) {
|
|
|
+ // TODO(jeremy): what's the appropriate behaviour here?
|
|
|
+ LOG(ERROR) << "Error parsing node options: " << error;
|
|
|
}
|
|
|
|
|
|
// Set process._debugWaitConnect if --inspect-brk was specified to stop
|
|
|
// the debugger on the first line
|
|
|
- if (options.wait_for_connect()) {
|
|
|
+ if (options->wait_for_connect()) {
|
|
|
mate::Dictionary process(env_->isolate(), env_->process_object());
|
|
|
process.Set("_breakFirstLine", true);
|
|
|
}
|
|
|
|
|
|
- inspector->Start(/* path */ nullptr, options);
|
|
|
- DCHECK(env_->inspector_agent()->IsStarted());
|
|
|
+ const char* path = "";
|
|
|
+ inspector->Start(path, options);
|
|
|
+ // FIXME
|
|
|
+ // DCHECK(env_->inspector_agent()->IsListening());
|
|
|
}
|
|
|
|
|
|
} // namespace atom
|