@react-native-windows/cli 0.0.0-canary.2 → 0.0.0-canary.200

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (183) hide show
  1. package/README.md +47 -0
  2. package/lib-commonjs/commands/autolinkWindows/autolinkWindows.d.ts +87 -0
  3. package/lib-commonjs/commands/autolinkWindows/autolinkWindows.js +661 -0
  4. package/lib-commonjs/commands/autolinkWindows/autolinkWindows.js.map +1 -0
  5. package/lib-commonjs/commands/autolinkWindows/autolinkWindowsOptions.d.ts +14 -0
  6. package/lib-commonjs/commands/autolinkWindows/autolinkWindowsOptions.js +33 -0
  7. package/lib-commonjs/commands/autolinkWindows/autolinkWindowsOptions.js.map +1 -0
  8. package/lib-commonjs/commands/codegenWindows/codegenWindows.d.ts +27 -0
  9. package/lib-commonjs/commands/codegenWindows/codegenWindows.js +206 -0
  10. package/lib-commonjs/commands/codegenWindows/codegenWindows.js.map +1 -0
  11. package/lib-commonjs/commands/codegenWindows/codegenWindowsOptions.d.ts +12 -0
  12. package/lib-commonjs/commands/codegenWindows/codegenWindowsOptions.js +23 -0
  13. package/lib-commonjs/commands/codegenWindows/codegenWindowsOptions.js.map +1 -0
  14. package/lib-commonjs/{config → commands/config}/configUtils.d.ts +34 -6
  15. package/lib-commonjs/commands/config/configUtils.js +381 -0
  16. package/lib-commonjs/commands/config/configUtils.js.map +1 -0
  17. package/lib-commonjs/{config → commands/config}/dependencyConfig.d.ts +3 -3
  18. package/lib-commonjs/commands/config/dependencyConfig.js +228 -0
  19. package/lib-commonjs/commands/config/dependencyConfig.js.map +1 -0
  20. package/lib-commonjs/{config → commands/config}/projectConfig.d.ts +6 -3
  21. package/lib-commonjs/{config → commands/config}/projectConfig.js +72 -12
  22. package/lib-commonjs/commands/config/projectConfig.js.map +1 -0
  23. package/lib-commonjs/commands/healthCheck/healthCheckList.d.ts +6 -0
  24. package/lib-commonjs/commands/healthCheck/healthCheckList.js +21 -0
  25. package/lib-commonjs/commands/healthCheck/healthCheckList.js.map +1 -0
  26. package/lib-commonjs/commands/healthCheck/healthChecks.d.ts +7 -0
  27. package/lib-commonjs/commands/healthCheck/healthChecks.js +124 -0
  28. package/lib-commonjs/commands/healthCheck/healthChecks.js.map +1 -0
  29. package/lib-commonjs/commands/initWindows/initWindows.d.ts +46 -0
  30. package/lib-commonjs/commands/initWindows/initWindows.js +244 -0
  31. package/lib-commonjs/commands/initWindows/initWindows.js.map +1 -0
  32. package/lib-commonjs/commands/initWindows/initWindowsOptions.d.ts +15 -0
  33. package/lib-commonjs/commands/initWindows/initWindowsOptions.js +38 -0
  34. package/lib-commonjs/commands/initWindows/initWindowsOptions.js.map +1 -0
  35. package/lib-commonjs/commands/runWindows/runWindows.js +322 -0
  36. package/lib-commonjs/commands/runWindows/runWindows.js.map +1 -0
  37. package/lib-commonjs/{runWindows → commands/runWindows}/runWindowsOptions.d.ts +17 -11
  38. package/lib-commonjs/{runWindows → commands/runWindows}/runWindowsOptions.js +16 -11
  39. package/lib-commonjs/commands/runWindows/runWindowsOptions.js.map +1 -0
  40. package/lib-commonjs/e2etest/autolink.test.d.ts +6 -0
  41. package/lib-commonjs/e2etest/autolink.test.js +367 -0
  42. package/lib-commonjs/e2etest/autolink.test.js.map +1 -0
  43. package/lib-commonjs/e2etest/dependencyConfig.test.d.ts +6 -0
  44. package/lib-commonjs/e2etest/dependencyConfig.test.js +130 -0
  45. package/lib-commonjs/e2etest/dependencyConfig.test.js.map +1 -0
  46. package/lib-commonjs/e2etest/healthChecks.test.d.ts +6 -0
  47. package/lib-commonjs/e2etest/healthChecks.test.js +31 -0
  48. package/lib-commonjs/e2etest/healthChecks.test.js.map +1 -0
  49. package/lib-commonjs/e2etest/initWindows.test.d.ts +6 -0
  50. package/lib-commonjs/e2etest/initWindows.test.js +43 -0
  51. package/lib-commonjs/e2etest/initWindows.test.js.map +1 -0
  52. package/lib-commonjs/e2etest/projectConfig.test.d.ts +6 -0
  53. package/lib-commonjs/e2etest/projectConfig.test.js +111 -0
  54. package/lib-commonjs/e2etest/projectConfig.test.js.map +1 -0
  55. package/lib-commonjs/e2etest/projectConfig.utils.d.ts +8 -0
  56. package/lib-commonjs/e2etest/projectConfig.utils.js +77 -0
  57. package/lib-commonjs/e2etest/projectConfig.utils.js.map +1 -0
  58. package/lib-commonjs/e2etest/runWindows.test.d.ts +6 -0
  59. package/lib-commonjs/e2etest/runWindows.test.js +61 -0
  60. package/lib-commonjs/e2etest/runWindows.test.js.map +1 -0
  61. package/lib-commonjs/generator-common/index.d.ts +17 -1
  62. package/lib-commonjs/generator-common/index.js +61 -40
  63. package/lib-commonjs/generator-common/index.js.map +1 -1
  64. package/lib-commonjs/generator-windows/index.d.ts +2 -2
  65. package/lib-commonjs/generator-windows/index.js +238 -187
  66. package/lib-commonjs/generator-windows/index.js.map +1 -1
  67. package/lib-commonjs/index.d.ts +7 -2
  68. package/lib-commonjs/index.js +51 -11
  69. package/lib-commonjs/index.js.map +1 -1
  70. package/lib-commonjs/{runWindows/utils → utils}/build.d.ts +2 -3
  71. package/lib-commonjs/{runWindows/utils → utils}/build.js +26 -33
  72. package/lib-commonjs/utils/build.js.map +1 -0
  73. package/lib-commonjs/{runWindows/utils → utils}/checkRequirements.js +11 -7
  74. package/lib-commonjs/utils/checkRequirements.js.map +1 -0
  75. package/lib-commonjs/{runWindows/utils → utils}/commandWithProgress.d.ts +11 -3
  76. package/lib-commonjs/utils/commandWithProgress.js +150 -0
  77. package/lib-commonjs/utils/commandWithProgress.js.map +1 -0
  78. package/lib-commonjs/{runWindows/utils → utils}/deploy.d.ts +2 -2
  79. package/lib-commonjs/utils/deploy.js +354 -0
  80. package/lib-commonjs/utils/deploy.js.map +1 -0
  81. package/lib-commonjs/{runWindows/utils → utils}/info.js +5 -2
  82. package/lib-commonjs/utils/info.js.map +1 -0
  83. package/lib-commonjs/utils/msbuildtools.d.ts +28 -0
  84. package/lib-commonjs/utils/msbuildtools.js +274 -0
  85. package/lib-commonjs/utils/msbuildtools.js.map +1 -0
  86. package/lib-commonjs/utils/pathHelpers.d.ts +9 -0
  87. package/lib-commonjs/utils/pathHelpers.js +37 -0
  88. package/lib-commonjs/utils/pathHelpers.js.map +1 -0
  89. package/lib-commonjs/utils/telemetryHelpers.d.ts +29 -0
  90. package/lib-commonjs/utils/telemetryHelpers.js +121 -0
  91. package/lib-commonjs/utils/telemetryHelpers.js.map +1 -0
  92. package/lib-commonjs/{runWindows/utils → utils}/version.d.ts +4 -4
  93. package/lib-commonjs/utils/version.js.map +1 -0
  94. package/lib-commonjs/{runWindows/utils → utils}/vsInstalls.d.ts +5 -2
  95. package/lib-commonjs/utils/vsInstalls.js +100 -0
  96. package/lib-commonjs/utils/vsInstalls.js.map +1 -0
  97. package/lib-commonjs/{runWindows/utils → utils}/vstools.d.ts +2 -1
  98. package/lib-commonjs/utils/vstools.js +190 -0
  99. package/lib-commonjs/utils/vstools.js.map +1 -0
  100. package/lib-commonjs/{runWindows/utils → utils}/winappdeploytool.d.ts +3 -3
  101. package/lib-commonjs/{runWindows/utils → utils}/winappdeploytool.js +17 -14
  102. package/lib-commonjs/utils/winappdeploytool.js.map +1 -0
  103. package/package.json +50 -28
  104. package/{powershell → src/powershell}/Add-AppDevPackage.ps1 +2 -2
  105. package/src/powershell/Eval-MsBuildProperties.ps1 +156 -0
  106. package/{powershell → src/powershell}/WindowsStoreAppUtils.ps1 +11 -1
  107. package/CHANGELOG.json +0 -35
  108. package/CHANGELOG.md +0 -21
  109. package/lib-commonjs/config/configUtils.js +0 -265
  110. package/lib-commonjs/config/configUtils.js.map +0 -1
  111. package/lib-commonjs/config/dependencyConfig.js +0 -148
  112. package/lib-commonjs/config/dependencyConfig.js.map +0 -1
  113. package/lib-commonjs/config/projectConfig.js.map +0 -1
  114. package/lib-commonjs/runWindows/runWindows.js +0 -139
  115. package/lib-commonjs/runWindows/runWindows.js.map +0 -1
  116. package/lib-commonjs/runWindows/runWindowsOptions.js.map +0 -1
  117. package/lib-commonjs/runWindows/utils/autolink.d.ts +0 -7
  118. package/lib-commonjs/runWindows/utils/autolink.js +0 -343
  119. package/lib-commonjs/runWindows/utils/autolink.js.map +0 -1
  120. package/lib-commonjs/runWindows/utils/build.js.map +0 -1
  121. package/lib-commonjs/runWindows/utils/checkRequirements.js.map +0 -1
  122. package/lib-commonjs/runWindows/utils/commandWithProgress.js +0 -114
  123. package/lib-commonjs/runWindows/utils/commandWithProgress.js.map +0 -1
  124. package/lib-commonjs/runWindows/utils/deploy.js +0 -247
  125. package/lib-commonjs/runWindows/utils/deploy.js.map +0 -1
  126. package/lib-commonjs/runWindows/utils/info.js.map +0 -1
  127. package/lib-commonjs/runWindows/utils/msbuildtools.d.ts +0 -22
  128. package/lib-commonjs/runWindows/utils/msbuildtools.js +0 -183
  129. package/lib-commonjs/runWindows/utils/msbuildtools.js.map +0 -1
  130. package/lib-commonjs/runWindows/utils/version.js.map +0 -1
  131. package/lib-commonjs/runWindows/utils/vsInstalls.js +0 -59
  132. package/lib-commonjs/runWindows/utils/vsInstalls.js.map +0 -1
  133. package/lib-commonjs/runWindows/utils/vstools.js +0 -144
  134. package/lib-commonjs/runWindows/utils/vstools.js.map +0 -1
  135. package/lib-commonjs/runWindows/utils/winappdeploytool.js.map +0 -1
  136. package/templates/_gitignore +0 -92
  137. package/templates/b_gitignore +0 -1
  138. package/templates/cpp/keys/MyApp_TemporaryKey.pfx +0 -0
  139. package/templates/cpp/proj/MyApp.sln +0 -194
  140. package/templates/cpp/proj/MyApp.vcxproj +0 -220
  141. package/templates/cpp/proj/MyApp.vcxproj.filters +0 -63
  142. package/templates/cpp/proj/packages.config +0 -6
  143. package/templates/cpp/src/App.cpp +0 -80
  144. package/templates/cpp/src/App.h +0 -25
  145. package/templates/cpp/src/App.idl +0 -3
  146. package/templates/cpp/src/AutolinkedNativeModules.g.cpp +0 -13
  147. package/templates/cpp/src/AutolinkedNativeModules.g.h +0 -10
  148. package/templates/cpp/src/AutolinkedNativeModules.g.targets +0 -6
  149. package/templates/cpp/src/MainPage.cpp +0 -24
  150. package/templates/cpp/src/MainPage.h +0 -21
  151. package/templates/cpp/src/MainPage.idl +0 -8
  152. package/templates/cpp/src/PropertySheet.props +0 -16
  153. package/templates/cpp/src/ReactPackageProvider.cpp +0 -18
  154. package/templates/cpp/src/ReactPackageProvider.h +0 -15
  155. package/templates/cpp/src/pch.cpp +0 -1
  156. package/templates/cpp/src/pch.h +0 -26
  157. package/templates/cs/keys/MyApp_TemporaryKey.pfx +0 -0
  158. package/templates/cs/proj/MyApp.csproj +0 -190
  159. package/templates/cs/proj/MyApp.sln +0 -227
  160. package/templates/cs/src/App.xaml.cs +0 -51
  161. package/templates/cs/src/AutolinkedNativeModules.g.cs +0 -13
  162. package/templates/cs/src/AutolinkedNativeModules.g.targets +0 -6
  163. package/templates/cs/src/MainPage.xaml.cs +0 -33
  164. package/templates/cs/src/Properties/AssemblyInfo.cs +0 -29
  165. package/templates/cs/src/Properties/Default.rd.xml +0 -32
  166. package/templates/cs/src/ReactPackageProvider.cs +0 -17
  167. package/templates/index.windows.bundle +0 -9
  168. package/templates/metro.config.js +0 -29
  169. package/templates/shared/assets/LockScreenLogo.scale-200.png +0 -0
  170. package/templates/shared/assets/SplashScreen.scale-200.png +0 -0
  171. package/templates/shared/assets/Square150x150Logo.scale-200.png +0 -0
  172. package/templates/shared/assets/Square44x44Logo.scale-200.png +0 -0
  173. package/templates/shared/assets/Square44x44Logo.targetsize-24_altform-unplated.png +0 -0
  174. package/templates/shared/assets/StoreLogo.png +0 -0
  175. package/templates/shared/assets/Wide310x150Logo.scale-200.png +0 -0
  176. package/templates/shared/proj/NuGet.Config +0 -13
  177. package/templates/shared/src/App.xaml +0 -10
  178. package/templates/shared/src/MainPage.xaml +0 -21
  179. package/templates/shared/src/Package.appxmanifest +0 -50
  180. /package/lib-commonjs/{runWindows → commands/runWindows}/runWindows.d.ts +0 -0
  181. /package/lib-commonjs/{runWindows/utils → utils}/checkRequirements.d.ts +0 -0
  182. /package/lib-commonjs/{runWindows/utils → utils}/info.d.ts +0 -0
  183. /package/lib-commonjs/{runWindows/utils → utils}/version.js +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dependencyConfig.js","sourceRoot":"","sources":["../../../src/commands/config/dependencyConfig.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) Microsoft Corporation.\n * Licensed under the MIT License.\n * @format\n */\n\n// Types in this file are inaccurate compared to usage in terms of falsiness.\n// We should try to rewrite some of this to do automated schema validation to\n// guarantee correct types\n/* eslint-disable @typescript-eslint/no-unnecessary-condition */\n\nimport {platform} from 'os';\nimport path from 'path';\n\nimport * as configUtils from './configUtils';\n\n/*\n\nreact-native config will generate the following JSON for each native module dependency\nunder node_modules that has a Windows implementation, in order to support auto-linking.\nThis is done heuristically, so if the result isn't quite correct, native module developers\ncan provide a manual override file: react-native.config.js.\n\nSchema for dependencies:\n\nTags:\nauto - Item is always calculated by config. An override file should NEVER provide it.\nreq - Item is required. If an override file exists, it MUST provide it. If no override file exists, config will try to calculate it.\nopt - Item is optional. If an override file exists, it MAY provide it. If no override file exists, config may try to calculate it.\n\n{\n folder: string, // (auto) Absolute path to the module root folder, determined by react-native config, ex: 'c:\\path\\to\\app-name\\node_modules\\my-module'\n sourceDir: string, // (opt, req if projects defined) Relative path to the Windows implementation under folder, ex: 'windows'\n solutionFile: string, // (opt) Relative path to the module's VS solution file under sourceDir, ex: 'MyModule.sln'\n projects: [ // (opt) Array of VS projects that must be added to the consuming app's solution file, so they are built\n {\n projectFile: string, // (req) Relative path to the VS project file under sourceDir, ex: 'MyModule\\MyModule.vcxproj' for 'c:\\path\\to\\app-name\\node_modules\\my-module\\windows\\MyModule\\MyModule.vcxproj'\n directDependency: bool, // (req) Whether to add the project file as a dependency to the consuming app's project file. true for projects that provide native modules\n projectName: string, // (auto) Name of the project, determined from projectFile, ex: 'MyModule'\n projectLang: string, // (auto) Language of the project, cpp or cs, determined from projectFile\n projectGuid: string, // (auto) Project identifier, determined from projectFile\n cppHeaders: [], // (opt) Array of cpp header include lines, ie: 'winrt/MyModule.h', to be transformed into '#include <winrt/MyModule.h>'\n cppPackageProviders: [], // (opt) Array of fully qualified cpp IReactPackageProviders, ie: 'MyModule::ReactPackageProvider'\n csNamespaces: [], // (opt) Array of cs namespaces, ie: 'MyModule', to be transformed into 'using MyModule;'\n csPackageProviders: [], // (opt) Array of fully qualified cs IReactPackageProviders, ie: 'MyModule.ReactPackageProvider'\n },\n ],\n nugetPackages: [ // (opt) Array of nuget packages including native modules that must be added as a dependency to the consuming app. It can be empty, but by its nature it can't be calculated\n {\n packageName: string, // (req) Name of the nuget package to install\n packageVersion: string, // (req) Version of the nuget package to install\n cppHeaders: [], // (req) Array of cpp header include lines, ie: 'winrt/NugetModule.h', to be transformed into '#include <winrt/NugetModule.h>'\n cppPackageProviders: [], // (req) Array of fully qualified cpp IReactPackageProviders, ie: 'NugetModule::ReactPackageProvider'\n csNamespaces: [], // (req) Array of cs namespaces, ie: 'NugetModule', to be transformed into 'using NugetModule;'\n csPackageProviders: [], // (req) Array of fully qualified cs IReactPackageProviders, ie: 'NugetModule.ReactPackageProvider'\n },\n ],\n}\n\nExample react-native.config.js for a 'MyModule':\n\nmodule.exports = {\n dependency: {\n platforms: {\n windows: {\n sourceDir: 'windows',\n solutionFile: 'MyModule.sln',\n projects: [\n {\n projectFile: 'MyModule\\\\MyModule.vcxproj',\n directDependency: true,\n }\n ],\n },\n },\n },\n};\n\n*/\n\nexport interface ProjectDependency {\n projectFile: string;\n directDependency: boolean;\n projectName: string;\n projectLang: 'cpp' | 'cs' | null;\n projectGuid: string | null;\n cppHeaders: string[];\n cppPackageProviders: string[];\n csNamespaces: string[];\n csPackageProviders: string[];\n}\n\nexport interface NuGetPackageDependency {\n packageName: string;\n packageVersion: string;\n cppHeaders: string[];\n cppPackageProviders: string[];\n csNamespaces: string[];\n csPackageProviders: string[];\n}\n\nexport interface WindowsDependencyConfig {\n folder: string;\n sourceDir?: string;\n solutionFile?: string | null;\n projects: ProjectDependency[];\n nugetPackages: NuGetPackageDependency[];\n}\n\n/**\n * Gets the config of any RNW native modules under the target folder.\n * @param userConfig A manually specified override config.\n * @return The config if any RNW native modules exist.\n */\n// Disabled due to existing high cyclomatic complexity\n// eslint-disable-next-line complexity\nexport function dependencyConfigWindows(\n folder: string,\n userConfig: Partial<WindowsDependencyConfig> | null = {},\n): WindowsDependencyConfig | null {\n if (platform() !== 'win32') {\n return null;\n }\n\n if (userConfig === null) {\n return null;\n }\n\n const usingManualProjectsOverride =\n 'projects' in userConfig && Array.isArray(userConfig.projects);\n\n const usingManualNugetPackagesOverride =\n 'nugetPackages' in userConfig && Array.isArray(userConfig.nugetPackages);\n\n const result: WindowsDependencyConfig = {\n folder,\n projects: usingManualProjectsOverride ? userConfig.projects! : [],\n solutionFile: null,\n nugetPackages: usingManualNugetPackagesOverride\n ? userConfig.nugetPackages!\n : [],\n };\n\n let sourceDir: string | null = null;\n if (usingManualProjectsOverride && result.projects.length > 0) {\n // Manually provided projects, so extract the sourceDir\n if (!('sourceDir' in userConfig)) {\n sourceDir =\n 'Error: Source dir is required if projects are specified, but it is not specified in react-native.config.';\n } else if (userConfig.sourceDir === null) {\n sourceDir =\n 'Error: Source dir is required if projects are specified, but it is null in react-native.config.';\n } else {\n sourceDir = path.join(folder, userConfig.sourceDir!);\n }\n } else if (!usingManualProjectsOverride) {\n // No manually provided projects, try to find sourceDir\n if ('sourceDir' in userConfig && userConfig.sourceDir !== null) {\n sourceDir = path.join(folder, userConfig.sourceDir!);\n } else {\n sourceDir = configUtils.findWindowsFolder(folder);\n }\n }\n\n if (sourceDir === null) {\n // Try to salvage the missing sourceDir\n if (result.projects.length === 0 && result.nugetPackages.length > 0) {\n // Only nuget packages, no sourceDir required\n return result;\n } else if (result.projects.length > 0) {\n // Projects overridden but no sourceDir, assume the sourceDir === folder\n sourceDir = folder;\n }\n } else if (sourceDir.startsWith('Error: ')) {\n // Source dir error, bail with error\n result.sourceDir = sourceDir;\n return result;\n }\n\n if (sourceDir === null) {\n // After everything above, if sourceDir is still null,\n // there's nothing more to look for here, bail\n return null;\n }\n\n result.sourceDir = path.relative(folder, sourceDir);\n\n const usingManualSolutionFile = 'solutionFile' in userConfig;\n\n let solutionFile = null;\n if (usingManualSolutionFile && userConfig.solutionFile !== null) {\n // Manually provided solutionFile, so extract it\n solutionFile = path.join(sourceDir, userConfig.solutionFile!);\n } else if (!usingManualSolutionFile) {\n // No manually provided solutionFile, try to find it\n const foundSolutions = configUtils.findSolutionFiles(sourceDir);\n if (foundSolutions.length === 1) {\n solutionFile = path.join(sourceDir, foundSolutions[0]);\n }\n }\n\n result.solutionFile =\n solutionFile !== null ? path.relative(sourceDir, solutionFile) : null;\n\n if (usingManualProjectsOverride) {\n // react-native.config used, fill out (auto) items for each provided project, verify (req) items are present\n\n const alwaysRequired: Array<keyof ProjectDependency> = [\n 'projectFile',\n 'directDependency',\n ];\n\n for (const project of result.projects) {\n // Verifying (req) items\n let errorFound = false;\n\n alwaysRequired.forEach(item => {\n if (!(item in project)) {\n (project[\n item\n ] as string) = `Error: ${item} is required for each project in react-native.config`;\n errorFound = true;\n }\n });\n\n if (errorFound) {\n break;\n }\n\n const projectFile = path.join(sourceDir, project.projectFile);\n\n const projectContents = configUtils.readProjectFile(projectFile);\n\n project.projectFile = path.relative(sourceDir, projectFile);\n\n // Calculating (auto) items\n project.projectName = configUtils.getProjectName(\n projectFile,\n projectContents,\n );\n project.projectLang = configUtils.getProjectLanguage(projectFile);\n project.projectGuid = configUtils.getProjectGuid(projectContents);\n\n if (project.directDependency) {\n // Calculating more (auto) items\n\n const projectNamespace =\n configUtils.getProjectNamespace(projectContents);\n\n if (projectNamespace !== null) {\n const cppNamespace = projectNamespace!.replace(/\\./g, '::');\n const csNamespace = projectNamespace!.replace(/::/g, '.');\n\n project.cppHeaders = project.cppHeaders || [`winrt/${csNamespace}.h`];\n project.cppPackageProviders = project.cppPackageProviders || [\n `${cppNamespace}::ReactPackageProvider`,\n ];\n project.csNamespaces = project.csNamespaces || [`${csNamespace}`];\n project.csPackageProviders = project.csPackageProviders || [\n `${csNamespace}.ReactPackageProvider`,\n ];\n }\n }\n }\n } else {\n // No react-native.config, try to heuristically find any projects\n\n const foundProjects = configUtils.findDependencyProjectFiles(sourceDir);\n\n for (const foundProject of foundProjects) {\n const projectFile = path.join(sourceDir, foundProject);\n\n const projectContents = configUtils.readProjectFile(projectFile);\n\n const projectType = configUtils.getProjectType(\n projectFile,\n projectContents,\n );\n\n if (\n projectType === 'dynamiclibrary' ||\n projectType === 'winmdobj' ||\n projectType === 'library'\n ) {\n const projectLang = configUtils.getProjectLanguage(projectFile);\n\n const projectName = configUtils.getProjectName(\n projectFile,\n projectContents,\n );\n\n const projectGuid = configUtils.getProjectGuid(projectContents);\n\n const projectNamespace =\n configUtils.getProjectNamespace(projectContents);\n\n const directDependency = true;\n\n const cppHeaders: string[] = [];\n const cppPackageProviders: string[] = [];\n const csNamespaces: string[] = [];\n const csPackageProviders: string[] = [];\n\n if (projectNamespace !== null) {\n const cppNamespace = projectNamespace.replace(/\\./g, '::');\n const csNamespace = projectNamespace.replace(/::/g, '.');\n\n cppHeaders.push(`winrt/${csNamespace}.h`);\n cppPackageProviders.push(`${cppNamespace}::ReactPackageProvider`);\n csNamespaces.push(`${csNamespace}`);\n csPackageProviders.push(`${csNamespace}.ReactPackageProvider`);\n }\n\n result.projects.push({\n projectFile: path.relative(sourceDir, projectFile),\n projectName,\n projectLang,\n projectGuid,\n directDependency,\n cppHeaders,\n cppPackageProviders,\n csNamespaces,\n csPackageProviders,\n });\n } else {\n const projectPath = path.relative(sourceDir, projectFile);\n result.projects.push({\n projectFile: `Error: ${projectPath} is type '${projectType}'`,\n directDependency: false,\n projectName: '',\n projectLang: null,\n projectGuid: null,\n cppHeaders: [],\n cppPackageProviders: [],\n csNamespaces: [],\n csPackageProviders: [],\n });\n }\n }\n }\n\n return result;\n}\n"]}
@@ -6,14 +6,17 @@
6
6
  export interface Project {
7
7
  projectFile: string;
8
8
  projectName: string;
9
- projectLang: 'cpp' | 'cs';
10
- projectGuid: string;
9
+ projectLang: 'cpp' | 'cs' | null;
10
+ projectGuid: string | null;
11
+ projectTypeGuid?: string;
11
12
  }
12
13
  export interface WindowsProjectConfig {
13
14
  folder: string;
14
15
  sourceDir: string;
15
16
  solutionFile: string;
16
17
  project: Project;
18
+ useWinUI3?: boolean;
19
+ experimentalFeatures?: Record<string, string>;
17
20
  }
18
21
  /**
19
22
  * Gets the config of any RNW apps under the target folder.
@@ -21,4 +24,4 @@ export interface WindowsProjectConfig {
21
24
  * @param userConfig A manually specified override config.
22
25
  * @return The config if any RNW apps exist.
23
26
  */
24
- export declare function projectConfigWindows(folder: string, userConfig?: Partial<WindowsProjectConfig>): WindowsProjectConfig | null;
27
+ export declare function projectConfigWindows(folder: string, userConfig?: Partial<WindowsProjectConfig> | null): WindowsProjectConfig | null;
@@ -4,33 +4,71 @@
4
4
  * Licensed under the MIT License.
5
5
  * @format
6
6
  */
7
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
8
+ if (k2 === undefined) k2 = k;
9
+ var desc = Object.getOwnPropertyDescriptor(m, k);
10
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
11
+ desc = { enumerable: true, get: function() { return m[k]; } };
12
+ }
13
+ Object.defineProperty(o, k2, desc);
14
+ }) : (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ o[k2] = m[k];
17
+ }));
18
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
19
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
20
+ }) : function(o, v) {
21
+ o["default"] = v;
22
+ });
23
+ var __importStar = (this && this.__importStar) || function (mod) {
24
+ if (mod && mod.__esModule) return mod;
25
+ var result = {};
26
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
27
+ __setModuleDefault(result, mod);
28
+ return result;
29
+ };
30
+ var __importDefault = (this && this.__importDefault) || function (mod) {
31
+ return (mod && mod.__esModule) ? mod : { "default": mod };
32
+ };
7
33
  Object.defineProperty(exports, "__esModule", { value: true });
8
34
  exports.projectConfigWindows = void 0;
9
- const path = require("path");
10
- const configUtils = require("./configUtils.js");
35
+ // Types in this file are inaccurate compared to usage in terms of falsiness.
36
+ // We should try to rewrite some of this to do automated schema validation to
37
+ // guarantee correct types
38
+ /* eslint-disable @typescript-eslint/no-unnecessary-condition */
39
+ const os_1 = require("os");
40
+ const path_1 = __importDefault(require("path"));
41
+ const configUtils = __importStar(require("./configUtils"));
11
42
  /**
12
43
  * Gets the config of any RNW apps under the target folder.
13
44
  * @param folder The absolute path to the target folder.
14
45
  * @param userConfig A manually specified override config.
15
46
  * @return The config if any RNW apps exist.
16
47
  */
48
+ // Disabled due to existing high cyclomatic complexity
49
+ // eslint-disable-next-line complexity
17
50
  function projectConfigWindows(folder, userConfig = {}) {
51
+ var _a;
52
+ if ((0, os_1.platform)() !== 'win32') {
53
+ return null;
54
+ }
18
55
  if (userConfig === null) {
19
56
  return null;
20
57
  }
21
58
  const usingManualOverride = 'sourceDir' in userConfig;
22
59
  const sourceDir = usingManualOverride
23
- ? path.join(folder, userConfig.sourceDir)
60
+ ? path_1.default.join(folder, userConfig.sourceDir)
24
61
  : configUtils.findWindowsFolder(folder);
25
62
  if (sourceDir === null) {
26
63
  // Nothing to look for here, bail
27
64
  return null;
28
65
  }
29
- var result = {
66
+ const result = {
30
67
  folder: folder,
31
- sourceDir: sourceDir.substr(folder.length + 1),
68
+ sourceDir: path_1.default.relative(folder, sourceDir),
32
69
  };
33
- var validProject = false;
70
+ let validSolution = false;
71
+ let validProject = false;
34
72
  if (usingManualOverride) {
35
73
  // Manual override, try to use it for solutionFile
36
74
  if (!('solutionFile' in userConfig)) {
@@ -42,7 +80,8 @@ function projectConfigWindows(folder, userConfig = {}) {
42
80
  'Error: Solution file is null in react-native.config.';
43
81
  }
44
82
  else {
45
- result.solutionFile = userConfig.solutionFile;
83
+ result.solutionFile = path_1.default.normalize(userConfig.solutionFile);
84
+ validSolution = true;
46
85
  }
47
86
  // Manual override, try to use it for project
48
87
  if (!('project' in userConfig)) {
@@ -68,11 +107,14 @@ function projectConfigWindows(folder, userConfig = {}) {
68
107
  }
69
108
  else {
70
109
  result.project = {
71
- projectFile: userConfig.project.projectFile,
110
+ projectFile: path_1.default.normalize(userConfig.project.projectFile),
72
111
  };
73
112
  validProject = true;
74
113
  }
75
114
  }
115
+ if ('useWinUI3' in userConfig) {
116
+ result.useWinUI3 = userConfig.useWinUI3;
117
+ }
76
118
  }
77
119
  else {
78
120
  // No manually provided solutionFile, try to find it
@@ -86,7 +128,8 @@ function projectConfigWindows(folder, userConfig = {}) {
86
128
  'Error: Too many app solution files found, please specify in react-native.config.';
87
129
  }
88
130
  else {
89
- result.solutionFile = foundSolutions[0];
131
+ result.solutionFile = path_1.default.normalize(foundSolutions[0]);
132
+ validSolution = true;
90
133
  }
91
134
  // No manually provided project, try to find it
92
135
  const foundProjects = configUtils.findAppProjectFiles(sourceDir);
@@ -102,18 +145,35 @@ function projectConfigWindows(folder, userConfig = {}) {
102
145
  }
103
146
  else {
104
147
  result.project = {
105
- projectFile: foundProjects[0],
148
+ projectFile: path_1.default.normalize(foundProjects[0]),
106
149
  };
107
150
  validProject = true;
108
151
  }
109
152
  }
153
+ if (validSolution) {
154
+ result.solutionFile = path_1.default.relative(sourceDir, path_1.default.join(sourceDir, result.solutionFile));
155
+ // Populating experimental features from ExperimentalFeatures.props
156
+ const experimentalFeatures = configUtils.getExperimentalFeatures(path_1.default.dirname(path_1.default.join(sourceDir, result.solutionFile)));
157
+ if (experimentalFeatures) {
158
+ result.experimentalFeatures = experimentalFeatures;
159
+ }
160
+ }
110
161
  if (validProject) {
111
- const projectFile = path.join(sourceDir, result.project.projectFile);
162
+ const projectFile = path_1.default.join(sourceDir, result.project.projectFile);
112
163
  const projectContents = configUtils.readProjectFile(projectFile);
164
+ result.project.projectFile = path_1.default.relative(sourceDir, projectFile);
113
165
  // Add missing (auto) items
114
166
  result.project.projectName = configUtils.getProjectName(projectFile, projectContents);
115
167
  result.project.projectLang = configUtils.getProjectLanguage(projectFile);
116
- result.project.projectGuid = configUtils.getProjectGuid(projectFile, projectContents);
168
+ result.project.projectGuid = configUtils.getProjectGuid(projectContents);
169
+ // Since we moved the UseExperimentalNuget property from the project to the
170
+ // ExperimentalFeatures.props file, we should should double-check the project file
171
+ // in case it was made with an older template
172
+ const useExperimentalNuget = configUtils.tryFindPropertyValue(projectContents, 'UseExperimentalNuget');
173
+ if (useExperimentalNuget) {
174
+ result.experimentalFeatures = (_a = result.experimentalFeatures) !== null && _a !== void 0 ? _a : {};
175
+ result.experimentalFeatures.UseExperimentalNuget = useExperimentalNuget;
176
+ }
117
177
  }
118
178
  return result;
119
179
  }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projectConfig.js","sourceRoot":"","sources":["../../../src/commands/config/projectConfig.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) Microsoft Corporation.\n * Licensed under the MIT License.\n * @format\n */\n\n// Types in this file are inaccurate compared to usage in terms of falsiness.\n// We should try to rewrite some of this to do automated schema validation to\n// guarantee correct types\n/* eslint-disable @typescript-eslint/no-unnecessary-condition */\n\nimport {platform} from 'os';\nimport path from 'path';\n\nimport * as configUtils from './configUtils';\n\n/*\n\nreact-native config will generate the following JSON for app projects that have a\nwindows implementation, as a target for auto-linking. This is done heuristically,\nso if the result isn't quite correct, app developers can provide a manual override\nfile: react-native.config.js.\n\nSchema for app projects:\n\nTags:\nauto - Item is always calculated by config. An override file should NEVER provide it.\nreq - Item is required. If an override file exists, it MUST provide it. If no override file exists, config will try to calculate it.\nopt - Item is optional. If an override file exists, it MAY provide it. If no override file exists, config may try to calculate it.\n\n{\n folder: string, // (auto) Absolute path to the app root folder, determined by react-native config, ex: 'c:\\path\\to\\my-app'\n sourceDir: string, // (req) Relative path to the Windows implementation under folder, ex: 'windows'\n solutionFile: string, // (req) Relative path to the app's VS solution file under sourceDir, ex: 'MyApp.sln'\n useWinUI3: boolean // (opt) If true, use WinUI 3. If false, use Windows XAML and WinUI 2.x. If missing, the value from rnwRoot\\PropertySheets\\ExperimentalFeatures.props will be used.\n project: { // (req)\n projectFile: string, // (req) Relative path to the VS project file under sourceDir, ex: 'MyApp\\MyApp.vcxproj' for 'c:\\path\\to\\my-app\\windows\\MyApp\\MyApp.vcxproj'\n projectName: string, // (auto) Name of the project, determined from projectFile, ex: 'MyApp'\n projectLang: string, // (auto) Language of the project, cpp or cs, determined from projectFile\n projectGuid: string, // (auto) Project identifier, determined from projectFile\n },\n experimentalFeatures: Record<String, string> // (auto) Properties extracted from ExperimentalFeatures.props\n}\n\nExample react-native.config.js for a 'MyApp':\n\nmodule.exports = {\n project: {\n windows: {\n sourceDir: 'windows',\n solutionFile: 'MyApp.sln',\n project: {\n projectFile: 'MyApp\\\\MyApp.vcxproj',\n },\n },\n },\n};\n\n*/\n\nexport interface Project {\n projectFile: string;\n projectName: string;\n projectLang: 'cpp' | 'cs' | null;\n projectGuid: string | null;\n projectTypeGuid?: string;\n}\n\nexport interface WindowsProjectConfig {\n folder: string;\n sourceDir: string;\n solutionFile: string;\n project: Project;\n useWinUI3?: boolean;\n experimentalFeatures?: Record<string, string>;\n}\n\ntype DeepPartial<T> = {[P in keyof T]?: DeepPartial<T[P]>};\n\n/**\n * Gets the config of any RNW apps under the target folder.\n * @param folder The absolute path to the target folder.\n * @param userConfig A manually specified override config.\n * @return The config if any RNW apps exist.\n */\n// Disabled due to existing high cyclomatic complexity\n// eslint-disable-next-line complexity\nexport function projectConfigWindows(\n folder: string,\n userConfig: Partial<WindowsProjectConfig> | null = {},\n): WindowsProjectConfig | null {\n if (platform() !== 'win32') {\n return null;\n }\n\n if (userConfig === null) {\n return null;\n }\n\n const usingManualOverride = 'sourceDir' in userConfig;\n\n const sourceDir = usingManualOverride\n ? path.join(folder, userConfig.sourceDir!)\n : configUtils.findWindowsFolder(folder);\n\n if (sourceDir === null) {\n // Nothing to look for here, bail\n return null;\n }\n\n const result: DeepPartial<WindowsProjectConfig> = {\n folder: folder,\n sourceDir: path.relative(folder, sourceDir),\n };\n\n let validSolution = false;\n let validProject = false;\n\n if (usingManualOverride) {\n // Manual override, try to use it for solutionFile\n if (!('solutionFile' in userConfig)) {\n result.solutionFile =\n 'Error: Solution file is required but not specified in react-native.config.';\n } else if (userConfig.solutionFile === null) {\n result.solutionFile =\n 'Error: Solution file is null in react-native.config.';\n } else {\n result.solutionFile = path.normalize(userConfig.solutionFile!);\n validSolution = true;\n }\n\n // Manual override, try to use it for project\n if (!('project' in userConfig)) {\n result.project = {\n projectFile:\n 'Error: Project is required but not specified in react-native.config.',\n };\n } else if (!userConfig.project) {\n result.project = {\n projectFile: 'Error: Project is null in react-native.config.',\n };\n } else {\n if (!('projectFile' in userConfig.project)) {\n result.project = {\n projectFile:\n 'Error: Project file is required for project in react-native.config.',\n };\n } else if (userConfig.project.projectFile === null) {\n result.project = {\n projectFile: 'Error: Project file is null in react-native.config.',\n };\n } else {\n result.project = {\n projectFile: path.normalize(userConfig.project.projectFile),\n };\n validProject = true;\n }\n }\n\n if ('useWinUI3' in userConfig) {\n result.useWinUI3 = userConfig.useWinUI3;\n }\n } else {\n // No manually provided solutionFile, try to find it\n const foundSolutions = configUtils.findSolutionFiles(sourceDir);\n if (foundSolutions.length === 0) {\n result.solutionFile =\n 'Error: No app solution file found, please specify in react-native.config.';\n } else if (foundSolutions.length > 1) {\n result.solutionFile =\n 'Error: Too many app solution files found, please specify in react-native.config.';\n } else {\n result.solutionFile = path.normalize(foundSolutions[0]);\n validSolution = true;\n }\n\n // No manually provided project, try to find it\n const foundProjects = configUtils.findAppProjectFiles(sourceDir);\n if (foundProjects.length === 0) {\n result.project = {\n projectFile:\n 'Error: No app project file found, please specify in react-native.config.',\n };\n } else if (foundProjects.length > 1) {\n result.project = {\n projectFile:\n 'Error: Too many app project files found, please specify in react-native.config.',\n };\n } else {\n result.project = {\n projectFile: path.normalize(foundProjects[0]),\n };\n validProject = true;\n }\n }\n\n if (validSolution) {\n result.solutionFile = path.relative(\n sourceDir,\n path.join(sourceDir, result.solutionFile),\n );\n\n // Populating experimental features from ExperimentalFeatures.props\n const experimentalFeatures = configUtils.getExperimentalFeatures(\n path.dirname(path.join(sourceDir, result.solutionFile)),\n );\n if (experimentalFeatures) {\n result.experimentalFeatures = experimentalFeatures;\n }\n }\n\n if (validProject) {\n const projectFile = path.join(sourceDir, result.project.projectFile!);\n const projectContents = configUtils.readProjectFile(projectFile);\n\n result.project.projectFile = path.relative(sourceDir, projectFile);\n\n // Add missing (auto) items\n result.project.projectName = configUtils.getProjectName(\n projectFile,\n projectContents,\n );\n result.project.projectLang = configUtils.getProjectLanguage(projectFile);\n result.project.projectGuid = configUtils.getProjectGuid(projectContents);\n\n // Since we moved the UseExperimentalNuget property from the project to the\n // ExperimentalFeatures.props file, we should should double-check the project file\n // in case it was made with an older template\n const useExperimentalNuget = configUtils.tryFindPropertyValue(\n projectContents,\n 'UseExperimentalNuget',\n );\n if (useExperimentalNuget) {\n result.experimentalFeatures = result.experimentalFeatures ?? {};\n result.experimentalFeatures.UseExperimentalNuget = useExperimentalNuget;\n }\n }\n\n return result as WindowsProjectConfig;\n}\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Copyright (c) Microsoft Corporation.
3
+ * Licensed under the MIT License.
4
+ * @format
5
+ */
6
+ export declare const HealthCheckList: (string | boolean)[][];
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Microsoft Corporation.
4
+ * Licensed under the MIT License.
5
+ * @format
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.HealthCheckList = void 0;
9
+ // Store list of health checks here to avoid having to launch PowerShell on every react-native config call
10
+ exports.HealthCheckList = [
11
+ [false, 'FreeSpace', 'Free space on current drive > 15 GB'],
12
+ [false, 'InstalledMemory', 'Installed memory >= 16 GB'],
13
+ [true, 'WindowsVersion', 'Windows version >= 10.0.17763.0'],
14
+ [true, 'DeveloperMode', 'Developer mode is on'],
15
+ [true, 'LongPath', 'Long path support is enabled'],
16
+ [true, 'VSUWP', 'Visual Studio 2022 (>= 17.9) & req. components'],
17
+ [true, 'Node', 'Node.js (LTS, >= 18.0)'],
18
+ [true, 'Yarn', 'Yarn'],
19
+ [true, 'DotNetCore', '.NET SDK (LTS, = 6.0)'],
20
+ ];
21
+ //# sourceMappingURL=healthCheckList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"healthCheckList.js","sourceRoot":"","sources":["../../../src/commands/healthCheck/healthCheckList.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAEH,0GAA0G;AAC7F,QAAA,eAAe,GAAG;IAC7B,CAAC,KAAK,EAAE,WAAW,EAAE,qCAAqC,CAAC;IAC3D,CAAC,KAAK,EAAE,iBAAiB,EAAE,2BAA2B,CAAC;IACvD,CAAC,IAAI,EAAE,gBAAgB,EAAE,iCAAiC,CAAC;IAC3D,CAAC,IAAI,EAAE,eAAe,EAAE,sBAAsB,CAAC;IAC/C,CAAC,IAAI,EAAE,UAAU,EAAE,8BAA8B,CAAC;IAClD,CAAC,IAAI,EAAE,OAAO,EAAE,gDAAgD,CAAC;IACjE,CAAC,IAAI,EAAE,MAAM,EAAE,wBAAwB,CAAC;IACxC,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC;IACtB,CAAC,IAAI,EAAE,YAAY,EAAE,uBAAuB,CAAC;CAC9C,CAAC","sourcesContent":["/**\n * Copyright (c) Microsoft Corporation.\n * Licensed under the MIT License.\n * @format\n */\n\n// Store list of health checks here to avoid having to launch PowerShell on every react-native config call\nexport const HealthCheckList = [\n [false, 'FreeSpace', 'Free space on current drive > 15 GB'],\n [false, 'InstalledMemory', 'Installed memory >= 16 GB'],\n [true, 'WindowsVersion', 'Windows version >= 10.0.17763.0'],\n [true, 'DeveloperMode', 'Developer mode is on'],\n [true, 'LongPath', 'Long path support is enabled'],\n [true, 'VSUWP', 'Visual Studio 2022 (>= 17.9) & req. components'],\n [true, 'Node', 'Node.js (LTS, >= 18.0)'],\n [true, 'Yarn', 'Yarn'],\n [true, 'DotNetCore', '.NET SDK (LTS, = 6.0)'],\n];\n"]}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Copyright (c) Microsoft Corporation.
3
+ * Licensed under the MIT License.
4
+ * @format
5
+ */
6
+ import type { HealthCheckCategory } from '@react-native-community/cli-doctor/build/types';
7
+ export declare function getHealthChecks(): HealthCheckCategory[] | undefined;
@@ -0,0 +1,124 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Microsoft Corporation.
4
+ * Licensed under the MIT License.
5
+ * @format
6
+ */
7
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
8
+ if (k2 === undefined) k2 = k;
9
+ var desc = Object.getOwnPropertyDescriptor(m, k);
10
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
11
+ desc = { enumerable: true, get: function() { return m[k]; } };
12
+ }
13
+ Object.defineProperty(o, k2, desc);
14
+ }) : (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ o[k2] = m[k];
17
+ }));
18
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
19
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
20
+ }) : function(o, v) {
21
+ o["default"] = v;
22
+ });
23
+ var __importStar = (this && this.__importStar) || function (mod) {
24
+ if (mod && mod.__esModule) return mod;
25
+ var result = {};
26
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
27
+ __setModuleDefault(result, mod);
28
+ return result;
29
+ };
30
+ var __importDefault = (this && this.__importDefault) || function (mod) {
31
+ return (mod && mod.__esModule) ? mod : { "default": mod };
32
+ };
33
+ Object.defineProperty(exports, "__esModule", { value: true });
34
+ exports.getHealthChecks = void 0;
35
+ const path_1 = __importDefault(require("path"));
36
+ const pathHelpers = __importStar(require("../../utils/pathHelpers"));
37
+ const rnDir = pathHelpers.resolveRnRoot(process.cwd());
38
+ const cliDir = pathHelpers.resolveRnCliRoot(rnDir);
39
+ const execaPath = require.resolve('execa', { paths: [cliDir] });
40
+ const execa = require(execaPath);
41
+ const commandWithProgress_1 = require("../../utils/commandWithProgress");
42
+ const healthCheckList_1 = require("./healthCheckList");
43
+ function getHealthChecks() {
44
+ // #8471: There are known cases where the dependencies script will error out.
45
+ // Fail gracefully if that happens in the meantime.
46
+ try {
47
+ return getHealthChecksUnsafe();
48
+ }
49
+ catch (_a) {
50
+ return [
51
+ {
52
+ label: 'Windows',
53
+ healthchecks: [
54
+ {
55
+ label: 'Failed to enumerate health checks',
56
+ description: 'Failed to enumerate health checks',
57
+ getDiagnostics: async () => ({ needsToBeFixed: true }),
58
+ runAutomaticFix: async ({ loader }) => {
59
+ loader.fail();
60
+ },
61
+ },
62
+ ],
63
+ },
64
+ ];
65
+ }
66
+ }
67
+ exports.getHealthChecks = getHealthChecks;
68
+ function getHealthChecksUnsafe() {
69
+ // All our health checks are windows only...
70
+ if (process.platform !== 'win32') {
71
+ return undefined;
72
+ }
73
+ const rnwDepScriptPath = path_1.default.join(pathHelpers.resolveRnwRoot(process.cwd()), 'Scripts/rnw-dependencies.ps1');
74
+ return [
75
+ {
76
+ label: 'Windows',
77
+ healthchecks: healthCheckList_1.HealthCheckList.map((dep) => {
78
+ const [optional, id, name] = dep;
79
+ return {
80
+ label: name,
81
+ description: name,
82
+ // The schema check of react-native doctor requires this to be a string, although it should be a boolean
83
+ // Enable this once we pick up a new version of the CLI that includes https://github.com/react-native-community/cli/pull/1367
84
+ isRequired: optional,
85
+ getDiagnostics: async () => {
86
+ let needsToBeFixed = true;
87
+ try {
88
+ await execa(`"${commandWithProgress_1.powershell}" -ExecutionPolicy Unrestricted -NoProfile "${rnwDepScriptPath}" -NoPrompt -Check ${id}`);
89
+ needsToBeFixed = false;
90
+ }
91
+ catch (_a) { }
92
+ return {
93
+ needsToBeFixed,
94
+ };
95
+ },
96
+ runAutomaticFix: async ({ loader, logManualInstallation }) => {
97
+ const command = `${commandWithProgress_1.powershell} -ExecutionPolicy Unrestricted -NoProfile "${rnwDepScriptPath}" -Check ${id}`;
98
+ try {
99
+ const { exitCode } = await execa(command, { stdio: 'inherit' });
100
+ if (exitCode) {
101
+ logManualInstallation({
102
+ command,
103
+ healthcheck: `react-native-windows dependency "${id}"`,
104
+ });
105
+ loader.fail();
106
+ }
107
+ else {
108
+ loader.succeed();
109
+ }
110
+ }
111
+ catch (_a) {
112
+ logManualInstallation({
113
+ command,
114
+ healthcheck: `react-native-windows dependency "${id}"`,
115
+ });
116
+ loader.fail();
117
+ }
118
+ },
119
+ };
120
+ }),
121
+ },
122
+ ];
123
+ }
124
+ //# sourceMappingURL=healthChecks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"healthChecks.js","sourceRoot":"","sources":["../../../src/commands/healthCheck/healthChecks.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) Microsoft Corporation.\n * Licensed under the MIT License.\n * @format\n */\n\nimport path from 'path';\n\nimport * as pathHelpers from '../../utils/pathHelpers';\n\nconst rnDir = pathHelpers.resolveRnRoot(process.cwd());\nconst cliDir = pathHelpers.resolveRnCliRoot(rnDir);\n\nconst execaPath = require.resolve('execa', {paths: [cliDir]});\nconst execa = require(execaPath);\n\nimport type {\n HealthCheckCategory,\n HealthCheckInterface,\n} from '@react-native-community/cli-doctor/build/types';\nimport {powershell} from '../../utils/commandWithProgress';\nimport {HealthCheckList} from './healthCheckList';\n\nexport function getHealthChecks(): HealthCheckCategory[] | undefined {\n // #8471: There are known cases where the dependencies script will error out.\n // Fail gracefully if that happens in the meantime.\n try {\n return getHealthChecksUnsafe();\n } catch {\n return [\n {\n label: 'Windows',\n healthchecks: [\n {\n label: 'Failed to enumerate health checks',\n description: 'Failed to enumerate health checks',\n getDiagnostics: async () => ({needsToBeFixed: true}),\n runAutomaticFix: async ({loader}) => {\n loader.fail();\n },\n },\n ],\n },\n ];\n }\n}\n\nfunction getHealthChecksUnsafe(): HealthCheckCategory[] | undefined {\n // All our health checks are windows only...\n if (process.platform !== 'win32') {\n return undefined;\n }\n\n const rnwDepScriptPath = path.join(\n pathHelpers.resolveRnwRoot(process.cwd()),\n 'Scripts/rnw-dependencies.ps1',\n );\n\n return [\n {\n label: 'Windows',\n healthchecks: HealthCheckList.map((dep: [boolean, string, string]) => {\n const [optional, id, name] = dep;\n return {\n label: name,\n description: name,\n // The schema check of react-native doctor requires this to be a string, although it should be a boolean\n // Enable this once we pick up a new version of the CLI that includes https://github.com/react-native-community/cli/pull/1367\n isRequired: optional,\n getDiagnostics: async () => {\n let needsToBeFixed = true;\n try {\n await execa(\n `\"${powershell}\" -ExecutionPolicy Unrestricted -NoProfile \"${rnwDepScriptPath}\" -NoPrompt -Check ${id}`,\n );\n needsToBeFixed = false;\n } catch {}\n return {\n needsToBeFixed,\n };\n },\n runAutomaticFix: async ({loader, logManualInstallation}) => {\n const command = `${powershell} -ExecutionPolicy Unrestricted -NoProfile \"${rnwDepScriptPath}\" -Check ${id}`;\n try {\n const {exitCode} = await execa(command, {stdio: 'inherit'});\n if (exitCode) {\n logManualInstallation({\n command,\n healthcheck: `react-native-windows dependency \"${id}\"`,\n });\n loader.fail();\n } else {\n loader.succeed();\n }\n } catch {\n logManualInstallation({\n command,\n healthcheck: `react-native-windows dependency \"${id}\"`,\n });\n loader.fail();\n }\n },\n } as HealthCheckInterface;\n }),\n },\n ];\n}\n"]}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Copyright (c) Microsoft Corporation.
3
+ * Licensed under the MIT License.
4
+ * @format
5
+ */
6
+ import { Ora } from 'ora';
7
+ import { Command, Config } from '@react-native-community/cli-types';
8
+ import { InitOptions } from './initWindowsOptions';
9
+ export interface TemplateFileMapping {
10
+ from: string;
11
+ to: string;
12
+ replacements?: Record<string, any>;
13
+ }
14
+ export interface InitWindowsTemplateConfig {
15
+ name: string;
16
+ description: string;
17
+ isDefault?: boolean;
18
+ preInstall?: (config: Config, options: InitOptions) => Promise<void>;
19
+ getFileMappings?: (config: Config, options: InitOptions) => Promise<TemplateFileMapping[]>;
20
+ postInstall?: (config: Config, options: InitOptions) => Promise<void>;
21
+ }
22
+ export declare class InitWindows {
23
+ readonly config: Config;
24
+ readonly options: InitOptions;
25
+ protected readonly rnwPath: string;
26
+ protected readonly templates: Map<string, InitWindowsTemplateConfig>;
27
+ constructor(config: Config, options: InitOptions);
28
+ protected verboseMessage(message: any): void;
29
+ protected loadTemplates(): Promise<void>;
30
+ protected getDefaultTemplateName(): string;
31
+ protected pascalCase(str: string): string;
32
+ protected isValidProjectName(name: string): boolean;
33
+ protected getReactNativeProjectName(projectDir: string): string;
34
+ run(spinner: Ora): Promise<void>;
35
+ }
36
+ /**
37
+ * Initializes a new RNW project from a given template.
38
+ * @param args Unprocessed args passed from react-native CLI.
39
+ * @param config Config passed from react-native CLI.
40
+ * @param options Options passed from react-native CLI.
41
+ */
42
+ export declare function initWindowsInternal(args: string[], config: Config, options: InitOptions): Promise<void>;
43
+ /**
44
+ * Initializes a new RNW project from a given template.
45
+ */
46
+ export declare const initCommand: Command;