microsoft/vscode-react-native

Public

mirrored from https://github.com/microsoft/vscode-react-nativeAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
a593f339aaef614caa22033ca067884a7c0aa038

Branches

Tags

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

Clone

HTTPS

Download ZIP

src/debugger/reactNativeDebugEntryPoint.ts

80lines · modeblame

40e4b177Patricio Beltran10 years ago1// 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";
e45838cbVladimir Kotikov9 years ago12import { makeAdapter, makeSession } from "./nodeDebugWrapper";
40e4b177Patricio Beltran10 years ago13
14const version = JSON.parse(fs.readFileSync(path.join(__dirname, "..", "..", "package.json"), "utf-8")).version;
15const telemetryReporter = new ReassignableTelemetryReporter(new NullTelemetryReporter());
e45838cbVladimir Kotikov9 years ago16const extensionName = "react-native-debug-adapter";
40e4b177Patricio Beltran10 years ago17
18function bailOut(reason: string): void {
19// Things have gone wrong in initialization: Report the error to telemetry and exit
20TelemetryHelper.sendSimpleEvent(reason);
21process.exit(1);
22}
23
24// Enable telemetry
e45838cbVladimir Kotikov9 years ago25new EntryPointHandler(ProcessType.Debugger).runApp(extensionName, () => version,
40e4b177Patricio Beltran10 years ago26ErrorHelper.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*/
33let nodeDebugFolder: string;
e45838cbVladimir Kotikov9 years ago34let VSCodeDebugAdapter: typeof VSCodeDebugAdapterPackage;
35let Node2DebugAdapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter;
36let ChromeDebuggerPackage: typeof ChromeDebuggerCorePackage;
40e4b177Patricio Beltran10 years ago37
38// nodeDebugLocation.json is dynamically generated on extension activation.
39// If it fails, we must not have been in a react native project
40try {
41/* tslint:disable:no-var-requires */
e45838cbVladimir Kotikov9 years ago42// FIXME: uncomment this before submitting
43// nodeDebugFolder = require("./nodeDebugLocation.json").nodeDebugPath;
44nodeDebugFolder = "/Applications/Visual Studio Code.app/Contents/Resources/app/extensions/ms-vscode.node-debug2";
45VSCodeDebugAdapter = require(path.join(nodeDebugFolder, "node_modules/vscode-debugadapter"));
46ChromeDebuggerPackage = require(path.join(nodeDebugFolder, "node_modules/vscode-chrome-debug-core"));
47Node2DebugAdapter = require(path.join(nodeDebugFolder, "out/src/nodeDebugAdapter")).NodeDebugAdapter;
40e4b177Patricio Beltran10 years ago48/* 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
51bailOut("cannotFindDebugAdapter");
52}
53
54/**
e45838cbVladimir Kotikov9 years ago55* We did find chrome debugger package and node2 debug adapter. Lets create debug
56* session and adapter with our customizations.
40e4b177Patricio Beltran10 years ago57*/
e45838cbVladimir Kotikov9 years ago58let session: typeof ChromeDebuggerCorePackage.ChromeDebugSession;
59let adapter: typeof Node2DebugAdapterPackage.Node2DebugAdapter;
40e4b177Patricio Beltran10 years ago60
61try {
e38efae1Vladimir Kotikov9 years ago62let logFilePath = "/Users/kotikov.vladimir/vscode-react-native-debug.log";
e45838cbVladimir Kotikov9 years ago63/* Create customised react-native debug adapter based on Node-debug2 adapter */
64adapter = makeAdapter(Node2DebugAdapter);
65// Create a debug session class based on ChromeDebugSession
66session = makeSession(ChromeDebuggerPackage.ChromeDebugSession,
e38efae1Vladimir Kotikov9 years ago67{ adapter, extensionName, logFilePath }, VSCodeDebugAdapter, telemetryReporter, extensionName, version);
40e4b177Patricio Beltran10 years ago68} catch (e) {
e45838cbVladimir Kotikov9 years ago69// TODO: this is declared as abstract in vscode-chrome-debug-core.
70// Need to check whether that possible to instantiate it here
71const debugSession = new ChromeDebuggerPackage.ChromeDebugSession();
72debugSession.sendEvent(new VSCodeDebugAdapter.OutputEvent("Unable to start debug adapter: " + e.toString(), "stderr"));
73debugSession.sendEvent(new VSCodeDebugAdapter.TerminatedEvent());
40e4b177Patricio Beltran10 years ago74bailOut(e.toString());
75}
76
77// Run the debug session for the node debug adapter with our modified requests
e45838cbVladimir Kotikov9 years ago78ChromeDebuggerPackage.ChromeDebugSession.run(session);
774cffd7Vladimir Kotikov9 years ago79});
e45838cbVladimir Kotikov9 years ago80