microsoft/vscode-react-native

Public

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

CodeCommitsIssuesPull requestsActionsInsightsSecurity
e6f8520eb54d0bbc6e3410ff39332bc322621490

Branches

Tags

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

Clone

HTTPS

Download ZIP

src/debugger/reactNativeDebugEntryPoint.ts

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