microsoft/vscode-react-native

Public

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

CodeCommitsIssuesPull requestsActionsInsightsSecurity
0.11.2

Branches

Tags

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

Clone

HTTPS

Download ZIP

src/extension/windows/windowsPlatform.ts

82lines · 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 Q from "q";
5import * as semver from "semver";
6
7import {GeneralMobilePlatform, MobilePlatformDeps} from "../generalMobilePlatform";
8import {IWindowsRunOptions} from "../launchArgs";
9import {OutputVerifier, PatternToFailure} from "../../common/outputVerifier";
10import {TelemetryHelper} from "../../common/telemetryHelper";
11import {CommandExecutor} from "../../common/commandExecutor";
12import {ReactNativeProjectHelper} from "../../common/reactNativeProjectHelper";
13import { InternalErrorCode } from "../../common/error/internalErrorCode";
14
15/**
16 * Windows specific platform implementation for debugging RN applications.
17 */
18export class WindowsPlatform extends GeneralMobilePlatform {
19 protected static NO_PACKAGER_VERSION = "0.53.0";
20
21 private static SUCCESS_PATTERNS = [
22 "Installing new version of the app",
23 "Starting the app",
24 ];
25 private static FAILURE_PATTERNS: PatternToFailure[] = [
26 {
27 pattern: "Unrecognized command 'run-windows'",
28 errorCode: InternalErrorCode.WinRNMPPluginIsNotInstalled,
29 },
30 ];
31
32 constructor(protected runOptions: IWindowsRunOptions, platformDeps: MobilePlatformDeps = {}) {
33 super(runOptions, platformDeps);
34 }
35
36 public runApp(enableDebug: boolean = true): Q.Promise<void> {
37 const extProps = {
38 platform: {
39 value: "windows",
40 isPii: false,
41 },
42 };
43
44 return TelemetryHelper.generate("WindowsPlatform.runApp", extProps, () => {
45 const env = this.getEnvArgument();
46
47 if (enableDebug) {
48 this.runArguments.push("--proxy");
49 }
50
51 return ReactNativeProjectHelper.getReactNativeVersion(this.runOptions.projectRoot)
52 .then(version => {
53 if (!semver.valid(version) /*Custom RN implementations should support this flag*/ || semver.gte(version, WindowsPlatform.NO_PACKAGER_VERSION)) {
54 this.runArguments.push("--no-packager");
55 }
56
57 const runWindowsSpawn = new CommandExecutor(this.projectPath, this.logger).spawnReactCommand(`run-${this.platformName}`, this.runArguments, {env});
58 return new OutputVerifier(() => Q(WindowsPlatform.SUCCESS_PATTERNS), () => Q(WindowsPlatform.FAILURE_PATTERNS), this.platformName)
59 .process(runWindowsSpawn);
60 });
61 });
62 }
63
64 public prewarmBundleCache(): Q.Promise<void> {
65 return this.packager.prewarmBundleCache("windows");
66 }
67
68 public getRunArguments(): string[] {
69 let runArguments: string[] = [];
70
71 if (this.runOptions.runArguments && this.runOptions.runArguments.length > 0) {
72 runArguments.push(...this.runOptions.runArguments);
73 } else {
74 let target = this.runOptions.target === WindowsPlatform.simulatorString ? "" : this.runOptions.target;
75 if (target) {
76 runArguments.push(`--${target}`);
77 }
78 }
79
80 return runArguments;
81 }
82}
83