microsoft/vscode-react-native

Public

mirrored fromhttps://github.com/microsoft/vscode-react-nativeAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
3c172a056576b34ff7bb5d777cbd9b47ff97cd7f

Branches

Tags

  • No tags available.
0Branches0Tags
Go to file
Add file
Code

Clone

HTTPS

Download ZIP

src/debugger/reactNativeDebugEntryPoint.ts

86lines · modecode

1// Copyright (c) Microsoft Corporation. All rights reserved.
2// Licensed under the MIT license. See LICENSE file in the project root for details.
3
4import * as fs from "fs";
5import * as path from "path";
6
7import { TelemetryHelper } from "../common/telemetryHelper";
8import { EntryPointHandler, ProcessType } from "../common/entryPointHandler";
9import { ErrorHelper } from "../common/error/errorHelper";
10import { InternalErrorCode } from "../common/error/internalErrorCode";
11import { NullTelemetryReporter, ReassignableTelemetryReporter } from "../common/telemetryReporters";
12import { makeAdapter, makeSession } from "./nodeDebugWrapper";
13
14const version = JSON.parse(fs.readFileSync(path.join(__dirname, "..", "..", "package.json"), "utf-8")).version;
15const telemetryReporter = new ReassignableTelemetryReporter(new NullTelemetryReporter());
16const extensionName = "react-native-debug-adapter";
17
18function bailOut(reason: string): void {
19 // Things have gone wrong in initialization: Report the error to telemetry and exit
20 TelemetryHelper.sendSimpleEvent(reason);
21 process.exit(1);
22}
23
24function codeToRun() {
25
26 /**
27 * For debugging React Native we basically want to debug node plus some other stuff.
28 * There is no need to create a new adapter for node because ther already exists one.
29 * We look for node debug adapter on client's computer so we can jump of on top of that.
30 */
31 let nodeDebugFolder: string;
32 let VSCodeDebugAdapter: typeof VSCodeDebugAdapterPackage;
33 let Node2DebugAdapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter;
34 let ChromeDebuggerPackage: typeof ChromeDebuggerCorePackage;
35
36 // nodeDebugLocation.json is dynamically generated on extension activation.
37 // If it fails, we must not have been in a react native project
38 try {
39 /* tslint:disable:no-var-requires */
40 nodeDebugFolder = require("./nodeDebugLocation.json").nodeDebugPath;
41 VSCodeDebugAdapter = require(path.join(nodeDebugFolder, "node_modules/vscode-debugadapter"));
42 ChromeDebuggerPackage = require(path.join(nodeDebugFolder, "node_modules/vscode-chrome-debug-core"));
43 Node2DebugAdapter = require(path.join(nodeDebugFolder, "out/src/nodeDebugAdapter")).NodeDebugAdapter;
44 /* tslint:enable:no-var-requires */
45
46 /**
47 * We did find chrome debugger package and node2 debug adapter. Lets create debug
48 * session and adapter with our customizations.
49 */
50 let session: typeof ChromeDebuggerCorePackage.ChromeDebugSession;
51 let adapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter;
52
53 try {
54 /* Create customised react-native debug adapter based on Node-debug2 adapter */
55 adapter = makeAdapter(Node2DebugAdapter);
56 // Create a debug session class based on ChromeDebugSession
57 session = makeSession(ChromeDebuggerPackage.ChromeDebugSession,
58 { adapter, extensionName }, VSCodeDebugAdapter, telemetryReporter, extensionName, version);
59
60 // Run the debug session for the node debug adapter with our modified requests
61 ChromeDebuggerPackage.ChromeDebugSession.run(session);
62 } catch (e) {
63 const debugSession = new VSCodeDebugAdapter.DebugSession();
64 // Start session before sending any events otherwise the client wouldn't receive them
65 debugSession.start(process.stdin, process.stdout);
66 debugSession.sendEvent(new VSCodeDebugAdapter.OutputEvent("Unable to start debug adapter: " + e.toString(), "stderr"));
67 debugSession.sendEvent(new VSCodeDebugAdapter.TerminatedEvent());
68 bailOut(e.toString());
69 }
70 } catch (e) {
71 // Nothing we can do here: can't even communicate back because we don't know how to speak debug adapter
72 bailOut("cannotFindDebugAdapter");
73 }
74
75}
76
77// Enable telemetry
78const entryPointHandler = new EntryPointHandler(ProcessType.Debugger);
79entryPointHandler.runApp(
80 extensionName,
81 () => version,
82 ErrorHelper.getInternalError(InternalErrorCode.DebuggingFailed),
83 telemetryReporter,
84 codeToRun
85);
86
87