microsoft/vscode-react-native
Publicmirrored fromhttps://github.com/microsoft/vscode-react-nativeAvailable
src/debugger/reactNativeDebugEntryPoint.ts
80lines · 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 | |
| 4 | import * as fs from "fs"; |
| 5 | import * as path from "path"; |
| 6 | |
| 7 | import {TelemetryHelper} from "../common/telemetryHelper"; |
| 8 | import {EntryPointHandler, ProcessType} from "../common/entryPointHandler"; |
| 9 | import {ErrorHelper} from "../common/error/errorHelper"; |
| 10 | import {InternalErrorCode} from "../common/error/internalErrorCode"; |
| 11 | import {NullTelemetryReporter, ReassignableTelemetryReporter} from "../common/telemetryReporters"; |
| 12 | import { makeAdapter, makeSession } from "./nodeDebugWrapper"; |
| 13 | |
| 14 | const version = JSON.parse(fs.readFileSync(path.join(__dirname, "..", "..", "package.json"), "utf-8")).version; |
| 15 | const telemetryReporter = new ReassignableTelemetryReporter(new NullTelemetryReporter()); |
| 16 | const extensionName = "react-native-debug-adapter"; |
| 17 | |
| 18 | function 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 | |
| 24 | // Enable telemetry |
| 25 | new EntryPointHandler(ProcessType.Debugger).runApp(extensionName, () => version, |
| 26 | ErrorHelper.getInternalError(InternalErrorCode.DebuggingFailed), telemetryReporter, () => { |
| 27 | |
| 28 | /** |
| 29 | * For debugging React Native we basically want to debug node plus some other stuff. |
| 30 | * There is no need to create a new adapter for node because ther already exists one. |
| 31 | * We look for node debug adapter on client's computer so we can jump of on top of that. |
| 32 | */ |
| 33 | let nodeDebugFolder: string; |
| 34 | let VSCodeDebugAdapter: typeof VSCodeDebugAdapterPackage; |
| 35 | let Node2DebugAdapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter; |
| 36 | let ChromeDebuggerPackage: typeof ChromeDebuggerCorePackage; |
| 37 | |
| 38 | // nodeDebugLocation.json is dynamically generated on extension activation. |
| 39 | // If it fails, we must not have been in a react native project |
| 40 | try { |
| 41 | /* tslint:disable:no-var-requires */ |
| 42 | // FIXME: uncomment this before submitting |
| 43 | // nodeDebugFolder = require("./nodeDebugLocation.json").nodeDebugPath; |
| 44 | nodeDebugFolder = "/Applications/Visual Studio Code.app/Contents/Resources/app/extensions/ms-vscode.node-debug2"; |
| 45 | VSCodeDebugAdapter = require(path.join(nodeDebugFolder, "node_modules/vscode-debugadapter")); |
| 46 | ChromeDebuggerPackage = require(path.join(nodeDebugFolder, "node_modules/vscode-chrome-debug-core")); |
| 47 | Node2DebugAdapter = require(path.join(nodeDebugFolder, "out/src/nodeDebugAdapter")).NodeDebugAdapter; |
| 48 | /* tslint:enable:no-var-requires */ |
| 49 | } catch (e) { |
| 50 | // Nothing we can do here: can't even communicate back because we don't know how to speak debug adapter |
| 51 | bailOut("cannotFindDebugAdapter"); |
| 52 | } |
| 53 | |
| 54 | /** |
| 55 | * We did find chrome debugger package and node2 debug adapter. Lets create debug |
| 56 | * session and adapter with our customizations. |
| 57 | */ |
| 58 | let session: typeof ChromeDebuggerCorePackage.ChromeDebugSession; |
| 59 | let adapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter; |
| 60 | |
| 61 | try { |
| 62 | let logFilePath = "/Users/kotikov.vladimir/vscode-react-native-debug.log"; |
| 63 | /* Create customised react-native debug adapter based on Node-debug2 adapter */ |
| 64 | adapter = makeAdapter(Node2DebugAdapter); |
| 65 | // Create a debug session class based on ChromeDebugSession |
| 66 | session = makeSession(ChromeDebuggerPackage.ChromeDebugSession, |
| 67 | { adapter, extensionName, logFilePath }, VSCodeDebugAdapter, telemetryReporter, extensionName, version); |
| 68 | } catch (e) { |
| 69 | // TODO: this is declared as abstract in vscode-chrome-debug-core. |
| 70 | // Need to check whether that possible to instantiate it here |
| 71 | const debugSession = new ChromeDebuggerPackage.ChromeDebugSession(); |
| 72 | debugSession.sendEvent(new VSCodeDebugAdapter.OutputEvent("Unable to start debug adapter: " + e.toString(), "stderr")); |
| 73 | debugSession.sendEvent(new VSCodeDebugAdapter.TerminatedEvent()); |
| 74 | bailOut(e.toString()); |
| 75 | } |
| 76 | |
| 77 | // Run the debug session for the node debug adapter with our modified requests |
| 78 | ChromeDebuggerPackage.ChromeDebugSession.run(session); |
| 79 | }); |