microsoft/vscode-react-native

Public

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

CodeCommitsIssuesPull requestsActionsInsightsSecurity
bdad2966e136bda7c0f98643513f5e2cc9130bb6

Branches

Tags

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

Clone

HTTPS

Download ZIP

src/debugger/ios/iOSPlatform.ts

116lines · modeblame

488f1908Jimmy Thomson10 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 Q from "q";
5
190e393cMeena Kunnathur Balakrishnan10 years ago6import {Log} from "../../common/log/log";
dbe130e4Jimmy Thomson10 years ago7import {ChildProcess} from "../../common/node/childProcess";
b0061ac6Meena Kunnathur Balakrishnan10 years ago8import {CommandExecutor} from "../../common/commandExecutor";
f8d32439dlebu10 years ago9import {IAppPlatform} from "../platformResolver";
488f1908Jimmy Thomson10 years ago10import {Compiler} from "./compiler";
11import {DeviceDeployer} from "./deviceDeployer";
12import {DeviceRunner} from "./deviceRunner";
acf08bc2dlebu10 years ago13import {IRunOptions} from "../../common/launchArgs";
a9d96b7cdigeff10 years ago14import {PlistBuddy} from "../../common/ios/plistBuddy";
1ed272e1digeff10 years ago15import {IOSDebugModeManager} from "../../common/ios/iOSDebugModeManager";
f8b7022ddigeff10 years ago16import {OutputVerifier, PatternToFailure} from "../../common/outputVerifier";
488f1908Jimmy Thomson10 years ago17
f8d32439dlebu10 years ago18export class IOSPlatform implements IAppPlatform {
bc7a32ceJimmy Thomson10 years ago19private static deviceString = "device";
20private static simulatorString = "simulator";
21
a9d96b7cdigeff10 years ago22private plistBuddy = new PlistBuddy();
23
110558c0Jimmy Thomson10 years ago24private projectPath: string;
25private simulatorTarget: string;
26private isSimulator: boolean;
27
7cc67271digeff10 years ago28// We should add the common iOS build/run erros we find to this list
29private static RUN_IOS_FAILURE_PATTERNS: PatternToFailure = {
30"No devices are booted": "Unable to launch iOS simulator. Try specifying a different target.",
31"FBSOpenApplicationErrorDomain": "Unable to launch iOS simulator. Try specifying a different target." };
32
33private static RUN_IOS_SUCCESS_PATTERNS = ["BUILD SUCCEEDED"];
34
488f1908Jimmy Thomson10 years ago35public runApp(launchArgs: IRunOptions): Q.Promise<void> {
36// Compile, deploy, and launch the app on either a simulator or a device
110558c0Jimmy Thomson10 years ago37this.consumeArguments(launchArgs);
488f1908Jimmy Thomson10 years ago38
110558c0Jimmy Thomson10 years ago39if (this.isSimulator) {
488f1908Jimmy Thomson10 years ago40// React native supports running on the iOS simulator from the command line
f8d32439dlebu10 years ago41let runArguments: string[] = [];
110558c0Jimmy Thomson10 years ago42if (this.simulatorTarget.toLowerCase() !== IOSPlatform.simulatorString) {
488f1908Jimmy Thomson10 years ago43runArguments.push("--simulator");
110558c0Jimmy Thomson10 years ago44runArguments.push(this.simulatorTarget);
488f1908Jimmy Thomson10 years ago45}
46
10873e11digeff10 years ago47const runIosSpawn = new CommandExecutor(this.projectPath).spawnChildReactCommandProcess("run-ios", runArguments);
f8b7022ddigeff10 years ago48return new OutputVerifier(
7cc67271digeff10 years ago49() =>
50this.generateSuccessPatterns(launchArgs),
51() =>
52Q(IOSPlatform.RUN_IOS_FAILURE_PATTERNS)).process(runIosSpawn);
488f1908Jimmy Thomson10 years ago53}
54
bc96b26bJimmy Thomson10 years ago55return new Compiler(this.projectPath).compile().then(() => {
110558c0Jimmy Thomson10 years ago56return new DeviceDeployer(this.projectPath).deploy();
488f1908Jimmy Thomson10 years ago57}).then(() => {
110558c0Jimmy Thomson10 years ago58return new DeviceRunner(this.projectPath).run();
488f1908Jimmy Thomson10 years ago59});
60}
61
62public enableJSDebuggingMode(launchArgs: IRunOptions): Q.Promise<void> {
63// Configure the app for debugging
110558c0Jimmy Thomson10 years ago64this.consumeArguments(launchArgs);
488f1908Jimmy Thomson10 years ago65
110558c0Jimmy Thomson10 years ago66if (this.simulatorTarget.toLowerCase() === IOSPlatform.deviceString) {
488f1908Jimmy Thomson10 years ago67// Note that currently we cannot automatically switch the device into debug mode.
b044f0b9Jimmy Thomson10 years ago68Log.logMessage("Application is running on a device, please shake device and select 'Debug in Chrome' to enable debugging.");
488f1908Jimmy Thomson10 years ago69return Q.resolve<void>(void 0);
70}
71
dbe130e4Jimmy Thomson10 years ago72const iosDebugModeManager = new IOSDebugModeManager(this.projectPath);
73
74// Wait until the configuration file exists, and check to see if debugging is enabled
75return Q.all([
76iosDebugModeManager.getSimulatorJSDebuggingModeSetting(),
77this.plistBuddy.getBundleId(launchArgs.projectRoot)
78]).spread((debugModeSetting: string, bundleId: string) => {
79if (debugModeSetting !== IOSDebugModeManager.WEBSOCKET_EXECUTOR_NAME) {
80// Debugging must still be enabled
771dc596Jimmy Thomson10 years ago81// We enable debugging by writing to a plist file that backs a NSUserDefaults object,
82// but that file is written to by the app on occasion. To avoid races, we shut the app
83// down before writing to the file.
dbe130e4Jimmy Thomson10 years ago84const childProcess = new ChildProcess();
b3db6f6bJimmy Thomson10 years ago85
8bff2a55Jimmy Thomson10 years ago86return childProcess.execToString("xcrun simctl spawn booted launchctl list").then((output: string) => {
b3db6f6bJimmy Thomson10 years ago87// Try to find an entry that looks like UIKitApplication:com.example.myApp[0x4f37]
88const regex = new RegExp(`(\\S+${bundleId}\\S+)`);
8bff2a55Jimmy Thomson10 years ago89const match = regex.exec(output);
b3db6f6bJimmy Thomson10 years ago90
91// If we don't find a match, the app must not be running and so we do not need to close it
92if (match) {
93return childProcess.exec(`xcrun simctl spawn booted launchctl stop ${match[1]}`);
94}
dbe130e4Jimmy Thomson10 years ago95}).then(() => {
96// Write to the settings file while the app is not running to avoid races
97return iosDebugModeManager.setSimulatorJSDebuggingModeSetting(/*enable=*/ true);
98}).then(() => {
99// Relaunch the app
100return this.runApp(launchArgs);
101});
102}
103});
488f1908Jimmy Thomson10 years ago104}
110558c0Jimmy Thomson10 years ago105
106private consumeArguments(launchArgs: IRunOptions): void {
107this.projectPath = launchArgs.projectRoot;
108this.simulatorTarget = launchArgs.target || IOSPlatform.simulatorString;
109this.isSimulator = this.simulatorTarget.toLowerCase() !== IOSPlatform.deviceString;
110}
7cc67271digeff10 years ago111
112private generateSuccessPatterns(launchArgs: IRunOptions): Q.Promise<string[]> {
113return this.plistBuddy.getBundleId(launchArgs.projectRoot).then(bundleId =>
114IOSPlatform.RUN_IOS_SUCCESS_PATTERNS.concat([`Launching ${bundleId}\n${bundleId}: `]));
115}
a9d96b7cdigeff10 years ago116}