// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for details.
import * as fs from "fs";
import * as path from "path";
import { TelemetryHelper } from "../common/telemetryHelper";
import { EntryPointHandler, ProcessType } from "../common/entryPointHandler";
import { ErrorHelper } from "../common/error/errorHelper";
import { InternalErrorCode } from "../common/error/internalErrorCode";
import { NullTelemetryReporter, ReassignableTelemetryReporter } from "../common/telemetryReporters";
import { makeAdapter, makeSession } from "./nodeDebugWrapper";
import { ChromeDebugSession, ChromeDebugAdapter } from "vscode-chrome-debug-core";
import { DebugSession, OutputEvent, TerminatedEvent } from "vscode-debugadapter";
const version = JSON.parse(fs.readFileSync(path.join(__dirname, "..", "..", "package.json"), "utf-8")).version;
const telemetryReporter = new ReassignableTelemetryReporter(new NullTelemetryReporter());
const extensionName = "react-native-tools";
function bailOut(reason: string): void {
// Things have gone wrong in initialization: Report the error to telemetry and exit
TelemetryHelper.sendSimpleEvent(reason);
process.exit(1);
}
function codeToRun() {
/**
* For debugging React Native we basically want to debug node plus some other stuff.
* There is no need to create a new adapter for node because ther already exists one.
* We look for node debug adapter on client's computer so we can jump of on top of that.
*/
let nodeDebugFolder: string;
let Node2DebugAdapter: typeof ChromeDebugAdapter;
// nodeDebugLocation.json is dynamically generated on extension activation.
// If it fails, we must not have been in a react native project
try {
/* tslint:disable:no-var-requires */
nodeDebugFolder = require("./nodeDebugLocation.json").nodeDebugPath;
Node2DebugAdapter = require(path.join(nodeDebugFolder, "out/src/nodeDebugAdapter")).NodeDebugAdapter;
/* tslint:enable:no-var-requires */
/**
* We did find chrome debugger package and node2 debug adapter. Lets create debug
* session and adapter with our customizations.
*/
let session: typeof ChromeDebugSession;
let adapter: typeof ChromeDebugAdapter;
try {
/* Create customised react-native debug adapter based on Node-debug2 adapter */
adapter = makeAdapter(Node2DebugAdapter);
// Create a debug session class based on ChromeDebugSession
session = makeSession(ChromeDebugSession,
{ adapter, extensionName }, telemetryReporter, extensionName, version);
// Run the debug session for the node debug adapter with our modified requests
ChromeDebugSession.run(session);
} catch (e) {
const debugSession = new DebugSession();
// Start session before sending any events otherwise the client wouldn't receive them
debugSession.start(process.stdin, process.stdout);
debugSession.sendEvent(new OutputEvent("Unable to start debug adapter: " + e.toString(), "stderr"));
debugSession.sendEvent(new TerminatedEvent());
bailOut(e.toString());
}
} catch (e) {
// Nothing we can do here: can't even communicate back because we don't know how to speak debug adapter
bailOut("cannotFindDebugAdapter");
}
}
// Enable telemetry
const entryPointHandler = new EntryPointHandler(ProcessType.Debugger);
entryPointHandler.runApp(
extensionName,
version,
ErrorHelper.getInternalError(InternalErrorCode.DebuggingFailed),
telemetryReporter,
codeToRun
);microsoft/vscode-react-native
Publicmirrored fromhttps://github.com/microsoft/vscode-react-nativeAvailable
src/debugger/reactNativeDebugEntryPoint.ts
85lines · modepreview