@akylas/nativescript-cli 8.7.2
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.
- package/LICENSE +201 -0
- package/README.md +385 -0
- package/bin/nativescript +3 -0
- package/bin/nativescript.js +3 -0
- package/bin/ns +3 -0
- package/bin/nsc +3 -0
- package/bin/nsc.js +3 -0
- package/bin/tns +12 -0
- package/bin/tns.cmd +1 -0
- package/config/config.json +8 -0
- package/config/test-dependencies.json +58 -0
- package/config/test-deps-versions-generated.json +1 -0
- package/docs/build-jekyll-md.sh +7 -0
- package/docs/helpers/favicon.ico +0 -0
- package/docs/helpers/logo.png +0 -0
- package/docs/man_pages/cloud/cloud-setup.md +29 -0
- package/docs/man_pages/device/device-android.md +32 -0
- package/docs/man_pages/device/device-ios.md +40 -0
- package/docs/man_pages/device/device-list-applications.md +37 -0
- package/docs/man_pages/device/device-log.md +37 -0
- package/docs/man_pages/device/device-run.md +55 -0
- package/docs/man_pages/device/device.md +46 -0
- package/docs/man_pages/env-configuration/setup.md +22 -0
- package/docs/man_pages/general/autocomplete-disable.md +37 -0
- package/docs/man_pages/general/autocomplete-enable.md +37 -0
- package/docs/man_pages/general/autocomplete-status.md +35 -0
- package/docs/man_pages/general/autocomplete.md +46 -0
- package/docs/man_pages/general/clean.md +22 -0
- package/docs/man_pages/general/doctor.md +33 -0
- package/docs/man_pages/general/error-reporting.md +41 -0
- package/docs/man_pages/general/extension-install.md +45 -0
- package/docs/man_pages/general/extension-uninstall.md +41 -0
- package/docs/man_pages/general/extension.md +35 -0
- package/docs/man_pages/general/help.md +39 -0
- package/docs/man_pages/general/info.md +33 -0
- package/docs/man_pages/general/migrate.md +79 -0
- package/docs/man_pages/general/package-manager-get.md +26 -0
- package/docs/man_pages/general/package-manager-set.md +29 -0
- package/docs/man_pages/general/package-manager.md +25 -0
- package/docs/man_pages/general/proxy-clear.md +26 -0
- package/docs/man_pages/general/proxy-set.md +45 -0
- package/docs/man_pages/general/proxy.md +31 -0
- package/docs/man_pages/general/update.md +40 -0
- package/docs/man_pages/general/usage-reporting.md +41 -0
- package/docs/man_pages/index.html +3 -0
- package/docs/man_pages/lib-management/plugin-add.md +42 -0
- package/docs/man_pages/lib-management/plugin-build.md +32 -0
- package/docs/man_pages/lib-management/plugin-create.md +48 -0
- package/docs/man_pages/lib-management/plugin-install.md +42 -0
- package/docs/man_pages/lib-management/plugin-remove.md +31 -0
- package/docs/man_pages/lib-management/plugin-update.md +41 -0
- package/docs/man_pages/lib-management/plugin.md +39 -0
- package/docs/man_pages/project/configuration/generate.md +36 -0
- package/docs/man_pages/project/configuration/install.md +43 -0
- package/docs/man_pages/project/configuration/open-android.md +27 -0
- package/docs/man_pages/project/configuration/open-ios.md +31 -0
- package/docs/man_pages/project/configuration/open.md +36 -0
- package/docs/man_pages/project/configuration/platform-add.md +46 -0
- package/docs/man_pages/project/configuration/platform-clean.md +41 -0
- package/docs/man_pages/project/configuration/platform-remove.md +41 -0
- package/docs/man_pages/project/configuration/platform-update.md +45 -0
- package/docs/man_pages/project/configuration/platform.md +29 -0
- package/docs/man_pages/project/configuration/prepare.md +49 -0
- package/docs/man_pages/project/configuration/resources/resources-generate-icons.md +39 -0
- package/docs/man_pages/project/configuration/resources/resources-generate-splashes.md +39 -0
- package/docs/man_pages/project/configuration/resources/resources-update.md +35 -0
- package/docs/man_pages/project/configuration/resources/resources.md +14 -0
- package/docs/man_pages/project/creation/create.md +64 -0
- package/docs/man_pages/project/testing/build-android.md +62 -0
- package/docs/man_pages/project/testing/build-ios.md +65 -0
- package/docs/man_pages/project/testing/build.md +66 -0
- package/docs/man_pages/project/testing/debug-android.md +64 -0
- package/docs/man_pages/project/testing/debug-ios.md +65 -0
- package/docs/man_pages/project/testing/debug.md +67 -0
- package/docs/man_pages/project/testing/deploy.md +72 -0
- package/docs/man_pages/project/testing/dev-test-android.md +31 -0
- package/docs/man_pages/project/testing/dev-test-ios.md +36 -0
- package/docs/man_pages/project/testing/preview.md +35 -0
- package/docs/man_pages/project/testing/run-android.md +79 -0
- package/docs/man_pages/project/testing/run-ios.md +83 -0
- package/docs/man_pages/project/testing/run.md +92 -0
- package/docs/man_pages/project/testing/test-android.md +46 -0
- package/docs/man_pages/project/testing/test-init.md +34 -0
- package/docs/man_pages/project/testing/test-ios.md +48 -0
- package/docs/man_pages/project/testing/test.md +48 -0
- package/docs/man_pages/project/testing/typings.md +52 -0
- package/docs/man_pages/publishing/apple-login.md +35 -0
- package/docs/man_pages/publishing/appstore-upload.md +52 -0
- package/docs/man_pages/publishing/appstore.md +42 -0
- package/docs/man_pages/publishing/publish-ios.md +55 -0
- package/docs/man_pages/publishing/publish.md +38 -0
- package/docs/man_pages/start.md +81 -0
- package/lib/.d.ts +494 -0
- package/lib/android-tools-info.js +135 -0
- package/lib/base-package-manager.js +129 -0
- package/lib/bash-scripts/terminateProcess.sh +12 -0
- package/lib/bootstrap.js +203 -0
- package/lib/bun-package-manager.js +135 -0
- package/lib/color.js +10 -0
- package/lib/commands/add-platform.js +49 -0
- package/lib/commands/apple-login.js +52 -0
- package/lib/commands/appstore-list.js +75 -0
- package/lib/commands/appstore-upload.js +106 -0
- package/lib/commands/build.js +161 -0
- package/lib/commands/clean.js +253 -0
- package/lib/commands/command-base.js +46 -0
- package/lib/commands/config.js +135 -0
- package/lib/commands/create-project.js +431 -0
- package/lib/commands/debug.js +191 -0
- package/lib/commands/deploy.js +78 -0
- package/lib/commands/extensibility/install-extension.js +33 -0
- package/lib/commands/extensibility/list-extensions.js +40 -0
- package/lib/commands/extensibility/uninstall-extension.js +32 -0
- package/lib/commands/fonts.js +64 -0
- package/lib/commands/generate-assets.js +71 -0
- package/lib/commands/generate-help.js +26 -0
- package/lib/commands/generate.js +78 -0
- package/lib/commands/info.js +26 -0
- package/lib/commands/install.js +80 -0
- package/lib/commands/list-platforms.js +45 -0
- package/lib/commands/migrate.js +44 -0
- package/lib/commands/platform-clean.js +54 -0
- package/lib/commands/plugin/add-plugin.js +43 -0
- package/lib/commands/plugin/build-plugin.js +70 -0
- package/lib/commands/plugin/create-plugin.js +175 -0
- package/lib/commands/plugin/list-plugins.js +54 -0
- package/lib/commands/plugin/remove-plugin.js +52 -0
- package/lib/commands/plugin/update-plugin.js +52 -0
- package/lib/commands/post-install.js +57 -0
- package/lib/commands/prepare.js +63 -0
- package/lib/commands/preview.js +93 -0
- package/lib/commands/remove-platform.js +40 -0
- package/lib/commands/resources/resources-update.js +45 -0
- package/lib/commands/run.js +177 -0
- package/lib/commands/setup.js +15 -0
- package/lib/commands/start.js +33 -0
- package/lib/commands/test-init.js +167 -0
- package/lib/commands/test.js +146 -0
- package/lib/commands/typings.js +180 -0
- package/lib/commands/update-platform.js +57 -0
- package/lib/commands/update.js +70 -0
- package/lib/common/LICENSE +201 -0
- package/lib/common/README.md +1084 -0
- package/lib/common/bin/common-lib.js +5 -0
- package/lib/common/bootstrap.js +97 -0
- package/lib/common/child-process.js +217 -0
- package/lib/common/codeGeneration/code-entity.js +47 -0
- package/lib/common/codeGeneration/code-generation.d.ts +47 -0
- package/lib/common/codeGeneration/code-printer.js +48 -0
- package/lib/common/command-params.js +45 -0
- package/lib/common/commands/analytics.js +81 -0
- package/lib/common/commands/autocompletion.js +110 -0
- package/lib/common/commands/device/device-log-stream.js +44 -0
- package/lib/common/commands/device/get-file.js +54 -0
- package/lib/common/commands/device/list-applications.js +42 -0
- package/lib/common/commands/device/list-devices.js +150 -0
- package/lib/common/commands/device/list-files.js +55 -0
- package/lib/common/commands/device/put-file.js +55 -0
- package/lib/common/commands/device/run-application.js +46 -0
- package/lib/common/commands/device/stop-application.js +42 -0
- package/lib/common/commands/device/uninstall-application.js +33 -0
- package/lib/common/commands/doctor.js +54 -0
- package/lib/common/commands/generate-messages.js +45 -0
- package/lib/common/commands/help.js +51 -0
- package/lib/common/commands/package-manager-get.js +32 -0
- package/lib/common/commands/package-manager-set.js +37 -0
- package/lib/common/commands/post-install.js +27 -0
- package/lib/common/commands/preuninstall.js +61 -0
- package/lib/common/commands/proxy/proxy-base.js +34 -0
- package/lib/common/commands/proxy/proxy-clear.js +32 -0
- package/lib/common/commands/proxy/proxy-get.js +31 -0
- package/lib/common/commands/proxy/proxy-set.js +150 -0
- package/lib/common/common-lib.js +5 -0
- package/lib/common/constants.js +122 -0
- package/lib/common/declarations.d.ts +1713 -0
- package/lib/common/decorators.js +201 -0
- package/lib/common/definitions/cli-global.d.ts +22 -0
- package/lib/common/definitions/commands-service.d.ts +27 -0
- package/lib/common/definitions/commands.d.ts +51 -0
- package/lib/common/definitions/config.d.ts +33 -0
- package/lib/common/definitions/extensibility.d.ts +147 -0
- package/lib/common/definitions/google-analytics.d.ts +109 -0
- package/lib/common/definitions/json-file-settings-service.d.ts +24 -0
- package/lib/common/definitions/key-commands.d.ts +62 -0
- package/lib/common/definitions/logger.d.ts +41 -0
- package/lib/common/definitions/mobile.d.ts +1499 -0
- package/lib/common/definitions/validator.d.ts +8 -0
- package/lib/common/definitions/yok.d.ts +56 -0
- package/lib/common/dispatchers.js +151 -0
- package/lib/common/docs/helpers/basic-extensions-page.html +15 -0
- package/lib/common/docs/helpers/basic-page.html +14 -0
- package/lib/common/docs/helpers/styles.css +365 -0
- package/lib/common/doctor.d.ts +6 -0
- package/lib/common/errors.js +206 -0
- package/lib/common/file-system.js +441 -0
- package/lib/common/header.js +30 -0
- package/lib/common/helpers.js +658 -0
- package/lib/common/host-info.js +133 -0
- package/lib/common/http-client.js +173 -0
- package/lib/common/logger/appenders/cli-appender.js +24 -0
- package/lib/common/logger/appenders/emit-appender.js +30 -0
- package/lib/common/logger/layouts/cli-layout.js +33 -0
- package/lib/common/logger/logger.js +199 -0
- package/lib/common/messages/messages.interface.d.ts +10 -0
- package/lib/common/messages/messages.js +15 -0
- package/lib/common/mobile/android/android-application-manager.js +228 -0
- package/lib/common/mobile/android/android-debug-bridge-result-handler.js +332 -0
- package/lib/common/mobile/android/android-debug-bridge.js +167 -0
- package/lib/common/mobile/android/android-device-file-system.js +176 -0
- package/lib/common/mobile/android/android-device-hash-service.js +133 -0
- package/lib/common/mobile/android/android-device.js +164 -0
- package/lib/common/mobile/android/android-emulator-services.js +205 -0
- package/lib/common/mobile/android/android-ini-file-parser.js +77 -0
- package/lib/common/mobile/android/android-log-filter.js +42 -0
- package/lib/common/mobile/android/android-virtual-device-service.js +360 -0
- package/lib/common/mobile/android/device-android-debug-bridge.js +48 -0
- package/lib/common/mobile/android/genymotion/genymotion-service.js +211 -0
- package/lib/common/mobile/android/genymotion/virtualbox-service.js +121 -0
- package/lib/common/mobile/android/logcat-helper.js +165 -0
- package/lib/common/mobile/application-manager-base.js +136 -0
- package/lib/common/mobile/device-emitter.js +61 -0
- package/lib/common/mobile/device-log-emitter.js +40 -0
- package/lib/common/mobile/device-log-provider-base.js +76 -0
- package/lib/common/mobile/device-log-provider.js +126 -0
- package/lib/common/mobile/device-platforms-constants.js +22 -0
- package/lib/common/mobile/emulator-helper.js +84 -0
- package/lib/common/mobile/ios/device/ios-application-manager.js +159 -0
- package/lib/common/mobile/ios/device/ios-device-file-system.js +133 -0
- package/lib/common/mobile/ios/device/ios-device-operations.js +234 -0
- package/lib/common/mobile/ios/device/ios-device.js +153 -0
- package/lib/common/mobile/ios/ios-device-base.js +108 -0
- package/lib/common/mobile/ios/ios-device-product-name-mapper.js +65 -0
- package/lib/common/mobile/ios/ios-log-filter.js +24 -0
- package/lib/common/mobile/ios/simulator/ios-emulator-services.js +139 -0
- package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +23 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +147 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-device.js +106 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +81 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +69 -0
- package/lib/common/mobile/local-to-device-path-data-factory.js +37 -0
- package/lib/common/mobile/log-filter.js +51 -0
- package/lib/common/mobile/logging-levels.js +12 -0
- package/lib/common/mobile/mobile-core/android-device-discovery.js +91 -0
- package/lib/common/mobile/mobile-core/android-emulator-discovery.js +65 -0
- package/lib/common/mobile/mobile-core/android-process-service.js +259 -0
- package/lib/common/mobile/mobile-core/device-discovery.js +64 -0
- package/lib/common/mobile/mobile-core/devices-service.js +854 -0
- package/lib/common/mobile/mobile-core/ios-device-discovery.js +63 -0
- package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +109 -0
- package/lib/common/mobile/mobile-helper.js +102 -0
- package/lib/common/mobile/wp8/wp8-emulator-services.js +82 -0
- package/lib/common/old.npmignore +12 -0
- package/lib/common/opener.js +16 -0
- package/lib/common/os-info.js +21 -0
- package/lib/common/plist-parser.js +24 -0
- package/lib/common/project-helper.js +70 -0
- package/lib/common/prompter.js +191 -0
- package/lib/common/queue.js +37 -0
- package/lib/common/resource-loader.js +25 -0
- package/lib/common/resources/messages/errorMessages.json +7 -0
- package/lib/common/resources/platform-tools/android/darwin/NOTICE.txt +3407 -0
- package/lib/common/resources/platform-tools/android/darwin/adb +0 -0
- package/lib/common/resources/platform-tools/android/linux/NOTICE.txt +4451 -0
- package/lib/common/resources/platform-tools/android/linux/adb +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinUsbApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/NOTICE.txt +4451 -0
- package/lib/common/resources/platform-tools/android/win32/adb.exe +0 -0
- package/lib/common/resources/platform-tools/android/win32/fastboot.exe +0 -0
- package/lib/common/resources/platform-tools/unzip/win32/unzip.exe +0 -0
- package/lib/common/services/analytics/google-analytics-custom-dimensions.d.ts +16 -0
- package/lib/common/services/auto-completion-service.js +265 -0
- package/lib/common/services/cancellation.js +67 -0
- package/lib/common/services/commands-service.js +268 -0
- package/lib/common/services/help-service.js +252 -0
- package/lib/common/services/hooks-service.js +318 -0
- package/lib/common/services/ios-notification-service.js +49 -0
- package/lib/common/services/json-file-settings-service.js +133 -0
- package/lib/common/services/lock-service.js +129 -0
- package/lib/common/services/message-contract-generator.js +83 -0
- package/lib/common/services/messages-service.js +77 -0
- package/lib/common/services/micro-templating-service.js +49 -0
- package/lib/common/services/net-service.js +137 -0
- package/lib/common/services/project-files-manager.js +100 -0
- package/lib/common/services/project-files-provider-base.js +54 -0
- package/lib/common/services/proxy-service.js +64 -0
- package/lib/common/services/qr.js +39 -0
- package/lib/common/services/settings-service.js +42 -0
- package/lib/common/services/xcode-select-service.js +62 -0
- package/lib/common/utils.js +31 -0
- package/lib/common/validators/project-name-validator.js +88 -0
- package/lib/common/validators/validation-result.js +16 -0
- package/lib/common/vendor/License.txt +4 -0
- package/lib/common/vendor/jaro-winkler_distance.js +111 -0
- package/lib/common/verify-node-version.js +78 -0
- package/lib/common/yok.js +426 -0
- package/lib/config.js +137 -0
- package/lib/constants-provider.js +12 -0
- package/lib/constants.js +350 -0
- package/lib/controllers/build-controller.js +133 -0
- package/lib/controllers/debug-controller.js +235 -0
- package/lib/controllers/deploy-controller.js +38 -0
- package/lib/controllers/migrate-controller.js +1114 -0
- package/lib/controllers/platform-controller.js +127 -0
- package/lib/controllers/prepare-controller.js +353 -0
- package/lib/controllers/run-controller.js +525 -0
- package/lib/controllers/update-controller-base.js +84 -0
- package/lib/controllers/update-controller.js +188 -0
- package/lib/data/build-data.js +44 -0
- package/lib/data/controller-data-base.js +11 -0
- package/lib/data/debug-data.js +6 -0
- package/lib/data/platform-data.js +13 -0
- package/lib/data/prepare-data.js +46 -0
- package/lib/data/run-data.js +11 -0
- package/lib/declarations.d.ts +1256 -0
- package/lib/definitions/android-bundle-tool-service.d.ts +17 -0
- package/lib/definitions/android-plugin-migrator.d.ts +52 -0
- package/lib/definitions/build.d.ts +92 -0
- package/lib/definitions/cleanup-service.d.ts +79 -0
- package/lib/definitions/data.d.ts +7 -0
- package/lib/definitions/debug.d.ts +166 -0
- package/lib/definitions/deploy.d.ts +3 -0
- package/lib/definitions/file-log-service.d.ts +19 -0
- package/lib/definitions/files-hash-service.d.ts +35 -0
- package/lib/definitions/gradle.d.ts +33 -0
- package/lib/definitions/hmr-status-service.d.ts +5 -0
- package/lib/definitions/initialize-service.d.ts +11 -0
- package/lib/definitions/ios-debugger-port-service.d.ts +29 -0
- package/lib/definitions/ios.d.ts +97 -0
- package/lib/definitions/ip-service.d.ts +10 -0
- package/lib/definitions/livesync-global.d.ts +7 -0
- package/lib/definitions/livesync.d.ts +601 -0
- package/lib/definitions/lock-service.d.ts +43 -0
- package/lib/definitions/log-parser-service.d.ts +14 -0
- package/lib/definitions/marking-mode-service.d.ts +11 -0
- package/lib/definitions/metadata-filtering-service.d.ts +48 -0
- package/lib/definitions/migrate.d.ts +46 -0
- package/lib/definitions/nativescript-dev-xcode.d.ts +87 -0
- package/lib/definitions/pacote-service.d.ts +50 -0
- package/lib/definitions/platform.d.ts +146 -0
- package/lib/definitions/plugins.d.ts +75 -0
- package/lib/definitions/prepare.d.ts +51 -0
- package/lib/definitions/project-changes.d.ts +34 -0
- package/lib/definitions/project.d.ts +858 -0
- package/lib/definitions/prompter.d.ts +27 -0
- package/lib/definitions/qr-code.d.ts +3 -0
- package/lib/definitions/require.d.ts +11 -0
- package/lib/definitions/run.d.ts +45 -0
- package/lib/definitions/start-service.d.ts +15 -0
- package/lib/definitions/subscription-service.d.ts +11 -0
- package/lib/definitions/system-warnings.d.ts +4 -0
- package/lib/definitions/temp-service.d.ts +9 -0
- package/lib/definitions/terminal-spinner-service.d.ts +12 -0
- package/lib/definitions/update.d.ts +16 -0
- package/lib/definitions/xcode.d.ts +12 -0
- package/lib/detached-processes/cleanup-js-subprocess.js +62 -0
- package/lib/detached-processes/cleanup-process-definitions.d.ts +70 -0
- package/lib/detached-processes/cleanup-process.js +281 -0
- package/lib/detached-processes/detached-process-enums.d.ts +70 -0
- package/lib/detached-processes/file-log-service.js +20 -0
- package/lib/device-path-provider.js +60 -0
- package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +217 -0
- package/lib/device-sockets/ios/notification.js +30 -0
- package/lib/device-sockets/ios/socket-request-executor.js +56 -0
- package/lib/helpers/android-bundle-validator-helper.js +52 -0
- package/lib/helpers/deploy-command-helper.js +70 -0
- package/lib/helpers/key-command-helper.js +124 -0
- package/lib/helpers/livesync-command-helper.js +220 -0
- package/lib/helpers/network-connectivity-validator.js +47 -0
- package/lib/helpers/options-track-helper.js +88 -0
- package/lib/helpers/package-path-helper.js +6 -0
- package/lib/helpers/platform-command-helper.js +192 -0
- package/lib/helpers/version-validator-helper.js +25 -0
- package/lib/key-commands/bootstrap.js +21 -0
- package/lib/key-commands/index.js +456 -0
- package/lib/nativescript-cli-lib-bootstrap.js +8 -0
- package/lib/nativescript-cli-lib.js +5 -0
- package/lib/nativescript-cli.js +55 -0
- package/lib/node/pbxproj-dom-xcode.js +5 -0
- package/lib/node/xcode.js +7 -0
- package/lib/node-package-manager.js +156 -0
- package/lib/options.js +393 -0
- package/lib/package-installation-manager.js +221 -0
- package/lib/package-manager.js +184 -0
- package/lib/platform-command-param.js +29 -0
- package/lib/pnpm-package-manager.js +136 -0
- package/lib/project-data.js +237 -0
- package/lib/providers/project-files-provider.js +46 -0
- package/lib/resolvers/livesync-service-resolver.js +22 -0
- package/lib/services/analytics/analytics-broker-process.js +77 -0
- package/lib/services/analytics/analytics-broker.js +53 -0
- package/lib/services/analytics/analytics-service.js +366 -0
- package/lib/services/analytics/analytics.d.ts +55 -0
- package/lib/services/analytics/google-analytics-cross-client-custom-dimensions.d.ts +6 -0
- package/lib/services/analytics/google-analytics-provider.js +152 -0
- package/lib/services/analytics-settings-service.js +104 -0
- package/lib/services/android/android-bundle-tool-service.js +81 -0
- package/lib/services/android/gradle-build-args-service.js +87 -0
- package/lib/services/android/gradle-build-service.js +68 -0
- package/lib/services/android/gradle-command-service.js +49 -0
- package/lib/services/android-device-debug-service.js +173 -0
- package/lib/services/android-plugin-build-service.js +527 -0
- package/lib/services/android-project-service.js +600 -0
- package/lib/services/android-resources-migration-service.js +104 -0
- package/lib/services/apple-portal/apple-portal-application-service.js +82 -0
- package/lib/services/apple-portal/apple-portal-cookie-service.js +53 -0
- package/lib/services/apple-portal/apple-portal-session-service.js +277 -0
- package/lib/services/apple-portal/definitions.d.ts +87 -0
- package/lib/services/assets-generation/assets-generation-service.js +178 -0
- package/lib/services/build-artifacts-service.js +113 -0
- package/lib/services/build-data-service.js +20 -0
- package/lib/services/build-info-file-service.js +79 -0
- package/lib/services/cleanup-service.js +194 -0
- package/lib/services/cocoapods-platform-manager.js +137 -0
- package/lib/services/cocoapods-service.js +354 -0
- package/lib/services/debug-data-service.js +21 -0
- package/lib/services/debug-service-base.js +44 -0
- package/lib/services/device/device-install-app-service.js +118 -0
- package/lib/services/doctor-service.js +294 -0
- package/lib/services/extensibility-service.js +220 -0
- package/lib/services/files-hash-service.js +79 -0
- package/lib/services/hmr-status-service.js +128 -0
- package/lib/services/info-service.js +14 -0
- package/lib/services/initialize-service.js +70 -0
- package/lib/services/ios/export-options-plist-service.js +131 -0
- package/lib/services/ios/ios-signing-service.js +265 -0
- package/lib/services/ios/spm-service.js +78 -0
- package/lib/services/ios/xcodebuild-args-service.js +163 -0
- package/lib/services/ios/xcodebuild-command-service.js +40 -0
- package/lib/services/ios/xcodebuild-service.js +93 -0
- package/lib/services/ios-debugger-port-service.js +140 -0
- package/lib/services/ios-device-debug-service.js +167 -0
- package/lib/services/ios-entitlements-service.js +78 -0
- package/lib/services/ios-extensions-service.js +63 -0
- package/lib/services/ios-log-filter.js +70 -0
- package/lib/services/ios-native-target-service.js +108 -0
- package/lib/services/ios-project-service.js +851 -0
- package/lib/services/ios-provision-service.js +173 -0
- package/lib/services/ios-watch-app-service.js +76 -0
- package/lib/services/ip-service.js +78 -0
- package/lib/services/itmstransporter-service.js +216 -0
- package/lib/services/karma-execution.js +16 -0
- package/lib/services/livesync/android-device-livesync-service-base.js +68 -0
- package/lib/services/livesync/android-device-livesync-service.js +203 -0
- package/lib/services/livesync/android-device-livesync-sockets-service.js +198 -0
- package/lib/services/livesync/android-livesync-service.js +76 -0
- package/lib/services/livesync/android-livesync-tool.js +427 -0
- package/lib/services/livesync/android-livesync-tool.md +211 -0
- package/lib/services/livesync/device-livesync-service-base.js +69 -0
- package/lib/services/livesync/ios-device-livesync-service.js +218 -0
- package/lib/services/livesync/ios-livesync-service.js +95 -0
- package/lib/services/livesync/livesync-socket.js +14 -0
- package/lib/services/livesync/platform-livesync-service-base.js +180 -0
- package/lib/services/livesync-process-data-service.js +43 -0
- package/lib/services/log-parser-service.js +52 -0
- package/lib/services/log-source-map-service.js +235 -0
- package/lib/services/marking-mode-service.js +56 -0
- package/lib/services/metadata-filtering-service.js +105 -0
- package/lib/services/npm-config-service.js +39 -0
- package/lib/services/pacote-service.js +109 -0
- package/lib/services/performance-service.js +92 -0
- package/lib/services/platform/add-platform-service.js +119 -0
- package/lib/services/platform/platform-validation-service.js +85 -0
- package/lib/services/platform/prepare-native-platform-service.js +87 -0
- package/lib/services/platform-environment-requirements.js +87 -0
- package/lib/services/platform-project-service-base.js +32 -0
- package/lib/services/platforms-data-service.js +31 -0
- package/lib/services/plugins-service.js +477 -0
- package/lib/services/prepare-data-service.js +21 -0
- package/lib/services/project-backup-service.js +114 -0
- package/lib/services/project-changes-service.js +274 -0
- package/lib/services/project-cleanup-service.js +102 -0
- package/lib/services/project-config-service.js +335 -0
- package/lib/services/project-data-service.js +478 -0
- package/lib/services/project-name-service.js +67 -0
- package/lib/services/project-service.js +204 -0
- package/lib/services/project-templates-service.js +114 -0
- package/lib/services/qr-code-terminal-service.js +20 -0
- package/lib/services/require-service.js +11 -0
- package/lib/services/start-service.js +116 -0
- package/lib/services/temp-service.js +36 -0
- package/lib/services/terminal-spinner-service.js +38 -0
- package/lib/services/test-execution-service.js +154 -0
- package/lib/services/test-initialization-service.js +54 -0
- package/lib/services/timeline-profiler-service.js +108 -0
- package/lib/services/user-settings-service.js +34 -0
- package/lib/services/versions-service.js +196 -0
- package/lib/services/watch-ignore-list-service.js +20 -0
- package/lib/services/webpack/webpack-compiler-service.js +405 -0
- package/lib/services/webpack/webpack.d.ts +227 -0
- package/lib/services/xcconfig-service.js +76 -0
- package/lib/services/xcproj-service.js +11 -0
- package/lib/shared-event-bus.js +7 -0
- package/lib/sys-info.js +120 -0
- package/lib/tools/config-manipulation/config-transformer.js +201 -0
- package/lib/tools/node-modules/node-modules-builder.js +42 -0
- package/lib/tools/node-modules/node-modules-dependencies-builder.js +100 -0
- package/lib/yarn-package-manager.js +134 -0
- package/lib/yarn2-package-manager.js +143 -0
- package/package.json +192 -0
- package/postinstall.js +10 -0
- package/preuninstall.js +14 -0
- package/resources/assets/image-definitions.json +655 -0
- package/resources/test/example.jasmine.js +6 -0
- package/resources/test/example.jasmine.ts +6 -0
- package/resources/test/example.mocha.js +9 -0
- package/resources/test/example.mocha.ts +9 -0
- package/resources/test/example.qunit.js +7 -0
- package/resources/test/example.qunit.ts +7 -0
- package/resources/test/karma.conf.js +93 -0
- package/resources/test/test-main.js +9 -0
- package/resources/test/test-main.ts +11 -0
- package/resources/test/tsconfig.spec.json +9 -0
- package/setup/mac-startup-shell-script.sh +2 -0
- package/vendor/aab-tool/LICENSE +202 -0
- package/vendor/aab-tool/README.txt +1 -0
- package/vendor/aab-tool/bundletool.jar +0 -0
- package/vendor/gradle-app/app/build.gradle +1054 -0
- package/vendor/gradle-app/app/gradle-helpers/AnalyticsCollector.gradle +48 -0
- package/vendor/gradle-app/app/gradle-helpers/BuildToolTask.gradle +50 -0
- package/vendor/gradle-app/app/gradle-helpers/CustomExecutionLogger.gradle +52 -0
- package/vendor/gradle-app/build.gradle +170 -0
- package/vendor/gradle-app/settings.gradle +78 -0
- package/vendor/gradle-plugin/LICENSE +995 -0
- package/vendor/gradle-plugin/build.gradle +363 -0
- package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.properties +6 -0
- package/vendor/gradle-plugin/gradle.properties +6 -0
- package/vendor/gradle-plugin/gradlew +172 -0
- package/vendor/gradle-plugin/gradlew.bat +84 -0
- package/vendor/gradle-plugin/settings.gradle +45 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CocoaPodsPlatformManager = void 0;
|
|
4
|
+
const os_1 = require("os");
|
|
5
|
+
const path = require("path");
|
|
6
|
+
const semver = require("semver");
|
|
7
|
+
const _ = require("lodash");
|
|
8
|
+
const constants_1 = require("../constants");
|
|
9
|
+
const yok_1 = require("../common/yok");
|
|
10
|
+
class CocoaPodsPlatformManager {
|
|
11
|
+
constructor($logger) {
|
|
12
|
+
this.$logger = $logger;
|
|
13
|
+
}
|
|
14
|
+
addPlatformSection(projectData, podfilePlatformData, projectPodfileContent) {
|
|
15
|
+
const platformSectionData = this.getPlatformSectionData(projectPodfileContent);
|
|
16
|
+
if (platformSectionData && platformSectionData.podfilePlatformData) {
|
|
17
|
+
const shouldReplacePlatformSection = this.shouldReplacePlatformSection(projectData, platformSectionData.podfilePlatformData, podfilePlatformData);
|
|
18
|
+
if (shouldReplacePlatformSection) {
|
|
19
|
+
this.$logger.warn(`Multiple identical platforms with different versions have been detected during the processing of podfiles. The current platform's content "${platformSectionData.podfilePlatformData.content}" from ${platformSectionData.podfilePlatformData.path} will be replaced with "${podfilePlatformData.content}" from ${podfilePlatformData.path}`);
|
|
20
|
+
const newSection = this.buildPlatformSection(podfilePlatformData);
|
|
21
|
+
projectPodfileContent = projectPodfileContent.replace(platformSectionData.platformSectionContent, newSection.trim());
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
projectPodfileContent =
|
|
26
|
+
projectPodfileContent.trim() +
|
|
27
|
+
os_1.EOL +
|
|
28
|
+
os_1.EOL +
|
|
29
|
+
this.buildPlatformSection(podfilePlatformData);
|
|
30
|
+
}
|
|
31
|
+
return projectPodfileContent;
|
|
32
|
+
}
|
|
33
|
+
removePlatformSection(moduleName, projectPodfileContent, podfilePath) {
|
|
34
|
+
const platformSectionData = this.getPlatformSectionData(projectPodfileContent);
|
|
35
|
+
if (platformSectionData &&
|
|
36
|
+
platformSectionData.podfilePlatformData &&
|
|
37
|
+
platformSectionData.podfilePlatformData.path === podfilePath) {
|
|
38
|
+
const podfileContentRegExp = new RegExp(`# Begin Podfile - ([\\s\\S]*?)# End Podfile`, "mg");
|
|
39
|
+
const allPodfiles = projectPodfileContent.match(podfileContentRegExp) || [];
|
|
40
|
+
const selectedPlatformData = this.selectPlatformDataFromProjectPodfile(allPodfiles);
|
|
41
|
+
const newPlatformSection = selectedPlatformData
|
|
42
|
+
? this.buildPlatformSection(selectedPlatformData)
|
|
43
|
+
: "";
|
|
44
|
+
const regExp = new RegExp(`${platformSectionData.platformSectionContent}\\r?\\n`, "mg");
|
|
45
|
+
projectPodfileContent = projectPodfileContent.replace(regExp, newPlatformSection);
|
|
46
|
+
}
|
|
47
|
+
return projectPodfileContent;
|
|
48
|
+
}
|
|
49
|
+
replacePlatformRow(podfileContent, podfilePath) {
|
|
50
|
+
let podfilePlatformData = null;
|
|
51
|
+
const platformRowRegExp = new RegExp(`^\\s*?(platform\\b\\s*?\\:\\s*?ios\\b(?:,\\s*?['"](.+)['"])?)`, "gm");
|
|
52
|
+
const replacedContent = podfileContent.replace(platformRowRegExp, (substring, firstGroup, secondGroup) => {
|
|
53
|
+
podfilePlatformData = {
|
|
54
|
+
content: firstGroup,
|
|
55
|
+
version: secondGroup,
|
|
56
|
+
path: podfilePath,
|
|
57
|
+
};
|
|
58
|
+
return `# ${substring.trim()}`;
|
|
59
|
+
});
|
|
60
|
+
return { replacedContent, podfilePlatformData };
|
|
61
|
+
}
|
|
62
|
+
getPlatformSectionData(projectPodfileContent) {
|
|
63
|
+
const platformSectionRegExp = new RegExp(`${this.getPlatformSectionHeader()} ([\\s\\S]*?)with[\\s\\S]*?\\n([\\s\\S]*?(?:,\\s*?['"](.+)['"])?)\\n${this.getPlatformSectionFooter()}`, "m");
|
|
64
|
+
const match = platformSectionRegExp.exec(projectPodfileContent);
|
|
65
|
+
let result = null;
|
|
66
|
+
if (match && match[0]) {
|
|
67
|
+
result = {
|
|
68
|
+
platformSectionContent: match[0],
|
|
69
|
+
podfilePlatformData: {
|
|
70
|
+
path: match[1].trim(),
|
|
71
|
+
content: match[2],
|
|
72
|
+
version: match[3],
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
78
|
+
selectPlatformDataFromProjectPodfile(allPodfiles) {
|
|
79
|
+
const platformRowRegExp = new RegExp(`^\\s*?#\\s*?(platform\\b\\s*?\\:\\s*?ios\\b(?:,\\s*?['"](.+)['"])?)`, "m");
|
|
80
|
+
const podfilePathRegExp = new RegExp(`# Begin Podfile - ([\\s\\S]*?)${os_1.EOL}`);
|
|
81
|
+
let selectedPlatformData = null;
|
|
82
|
+
_.each(allPodfiles, (podfileContent) => {
|
|
83
|
+
const platformMatch = platformRowRegExp.exec(podfileContent);
|
|
84
|
+
const podfilePathMatch = podfilePathRegExp.exec(podfileContent) || [];
|
|
85
|
+
if (platformMatch && platformMatch[0] && !platformMatch[2]) {
|
|
86
|
+
selectedPlatformData = {
|
|
87
|
+
version: null,
|
|
88
|
+
content: platformMatch[1],
|
|
89
|
+
path: podfilePathMatch[1],
|
|
90
|
+
};
|
|
91
|
+
return false;
|
|
92
|
+
}
|
|
93
|
+
if (platformMatch && platformMatch[0] && platformMatch[2]) {
|
|
94
|
+
if (!selectedPlatformData ||
|
|
95
|
+
semver.gt(semver.coerce(platformMatch[2]), semver.coerce(selectedPlatformData.version))) {
|
|
96
|
+
selectedPlatformData = {
|
|
97
|
+
version: platformMatch[2],
|
|
98
|
+
content: platformMatch[1],
|
|
99
|
+
path: podfilePathMatch[1],
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
return selectedPlatformData;
|
|
105
|
+
}
|
|
106
|
+
shouldReplacePlatformSection(projectData, oldPodfilePlatformData, currentPodfilePlatformData) {
|
|
107
|
+
const appResourcesPodfilePath = path.join(projectData.getAppResourcesDirectoryPath(), "iOS", constants_1.PODFILE_NAME);
|
|
108
|
+
const isFromAppResources = oldPodfilePlatformData.path !== appResourcesPodfilePath &&
|
|
109
|
+
currentPodfilePlatformData.path === appResourcesPodfilePath;
|
|
110
|
+
const isFromAppResourcesWithGreaterPlatformVersion = oldPodfilePlatformData.path === appResourcesPodfilePath &&
|
|
111
|
+
currentPodfilePlatformData.path === appResourcesPodfilePath &&
|
|
112
|
+
semver.gt(semver.coerce(currentPodfilePlatformData.version), semver.coerce(oldPodfilePlatformData.version));
|
|
113
|
+
const isPodfileWithGreaterPlatformVersion = !currentPodfilePlatformData.version ||
|
|
114
|
+
(oldPodfilePlatformData.version &&
|
|
115
|
+
semver.gt(semver.coerce(currentPodfilePlatformData.version), semver.coerce(oldPodfilePlatformData.version)));
|
|
116
|
+
const result = isFromAppResources ||
|
|
117
|
+
isFromAppResourcesWithGreaterPlatformVersion ||
|
|
118
|
+
isPodfileWithGreaterPlatformVersion;
|
|
119
|
+
return result;
|
|
120
|
+
}
|
|
121
|
+
buildPlatformSection(podfilePlatformData) {
|
|
122
|
+
let result = `${this.getPlatformSectionHeader()} ${podfilePlatformData.path} with`;
|
|
123
|
+
if (podfilePlatformData.version) {
|
|
124
|
+
result += ` ${podfilePlatformData.version}`;
|
|
125
|
+
}
|
|
126
|
+
result += `${os_1.EOL}${podfilePlatformData.content}${os_1.EOL}${this.getPlatformSectionFooter()}${os_1.EOL}`;
|
|
127
|
+
return result;
|
|
128
|
+
}
|
|
129
|
+
getPlatformSectionHeader() {
|
|
130
|
+
return "# NativeScriptPlatformSection";
|
|
131
|
+
}
|
|
132
|
+
getPlatformSectionFooter() {
|
|
133
|
+
return "# End NativeScriptPlatformSection";
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
exports.CocoaPodsPlatformManager = CocoaPodsPlatformManager;
|
|
137
|
+
yok_1.injector.register("cocoaPodsPlatformManager", CocoaPodsPlatformManager);
|
|
@@ -0,0 +1,354 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.CocoaPodsService = void 0;
|
|
13
|
+
const os_1 = require("os");
|
|
14
|
+
const path = require("path");
|
|
15
|
+
const _ = require("lodash");
|
|
16
|
+
const constants_1 = require("../constants");
|
|
17
|
+
const helpers_1 = require("../common/helpers");
|
|
18
|
+
const yok_1 = require("../common/yok");
|
|
19
|
+
const constants = require("../constants");
|
|
20
|
+
class CocoaPodsService {
|
|
21
|
+
constructor($cocoaPodsPlatformManager, $fs, $childProcess, $errors, $logger, $config, $xcconfigService, $xcodeSelectService) {
|
|
22
|
+
this.$cocoaPodsPlatformManager = $cocoaPodsPlatformManager;
|
|
23
|
+
this.$fs = $fs;
|
|
24
|
+
this.$childProcess = $childProcess;
|
|
25
|
+
this.$errors = $errors;
|
|
26
|
+
this.$logger = $logger;
|
|
27
|
+
this.$config = $config;
|
|
28
|
+
this.$xcconfigService = $xcconfigService;
|
|
29
|
+
this.$xcodeSelectService = $xcodeSelectService;
|
|
30
|
+
this.getCocoaPodsFromPodfile = _.memoize(this._getCocoaPodsFromPodfile, helpers_1.getHash);
|
|
31
|
+
}
|
|
32
|
+
getPodfileHeader(targetName) {
|
|
33
|
+
return `use_frameworks!${os_1.EOL}${os_1.EOL}target "${targetName}" do${os_1.EOL}`;
|
|
34
|
+
}
|
|
35
|
+
getPodfileFooter() {
|
|
36
|
+
return `${os_1.EOL}end`;
|
|
37
|
+
}
|
|
38
|
+
getProjectPodfilePath(projectRoot) {
|
|
39
|
+
return path.join(projectRoot, constants_1.PODFILE_NAME);
|
|
40
|
+
}
|
|
41
|
+
executePodInstall(projectRoot, xcodeProjPath) {
|
|
42
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
43
|
+
this.$logger.info("Installing pods...");
|
|
44
|
+
let podTool = this.$config.USE_POD_SANDBOX ? "sandbox-pod" : "pod";
|
|
45
|
+
const args = ["install"];
|
|
46
|
+
if (process.platform === "darwin" && process.arch === "arm64") {
|
|
47
|
+
const res = yield this.$childProcess
|
|
48
|
+
.exec("arch -x86_64 pod --version", null, {
|
|
49
|
+
showStderr: true,
|
|
50
|
+
})
|
|
51
|
+
.then((res) => res.stdout + " " + res.stderr)
|
|
52
|
+
.catch((err) => err.message);
|
|
53
|
+
if (!res.includes("Bad CPU type in executable")) {
|
|
54
|
+
this.$logger.trace("Running on arm64 but pod is installed under rosetta2 - running pod through rosetta2");
|
|
55
|
+
args.unshift(podTool);
|
|
56
|
+
args.unshift("-x86_64");
|
|
57
|
+
podTool = "arch";
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
const podInstallResult = yield this.$childProcess.spawnFromEvent(podTool, args, "close", { cwd: projectRoot, stdio: ["pipe", process.stdout, process.stdout] }, { throwError: false });
|
|
61
|
+
if (podInstallResult.exitCode !== 0) {
|
|
62
|
+
const versionResolutionHint = podInstallResult.exitCode === 31
|
|
63
|
+
? `For more information on resolving CocoaPod issues in NativeScript read.`
|
|
64
|
+
: "";
|
|
65
|
+
this.$errors.fail(`'${podTool} install' command failed.${podInstallResult.stderr ? " Error is: " + podInstallResult.stderr : ""}
|
|
66
|
+
${versionResolutionHint}`);
|
|
67
|
+
}
|
|
68
|
+
return podInstallResult;
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
mergePodXcconfigFile(projectData, platformData) {
|
|
72
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
+
const podFilesRootDirName = path.join("Pods", "Target Support Files", `Pods-${projectData.projectName}`);
|
|
74
|
+
const podFolder = path.join(platformData.projectRoot, podFilesRootDirName);
|
|
75
|
+
if (this.$fs.exists(podFolder)) {
|
|
76
|
+
const pluginsXcconfigFilePaths = this.$xcconfigService.getPluginsXcconfigFilePaths(platformData.projectRoot);
|
|
77
|
+
for (const configuration in pluginsXcconfigFilePaths) {
|
|
78
|
+
const pluginsXcconfigFilePath = pluginsXcconfigFilePaths[configuration];
|
|
79
|
+
const podXcconfigFilePath = path.join(podFolder, `Pods-${projectData.projectName}.${configuration}.xcconfig`);
|
|
80
|
+
yield this.$xcconfigService.mergeFiles(podXcconfigFilePath, pluginsXcconfigFilePath);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
applyPodfileFromAppResources(projectData, platformData) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
const { projectRoot, normalizedPlatformName } = platformData;
|
|
88
|
+
const mainPodfilePath = path.join(projectData.appResourcesDirectoryPath, normalizedPlatformName, constants_1.PODFILE_NAME);
|
|
89
|
+
const projectPodfilePath = this.getProjectPodfilePath(projectRoot);
|
|
90
|
+
if (this.$fs.exists(projectPodfilePath) ||
|
|
91
|
+
this.$fs.exists(mainPodfilePath)) {
|
|
92
|
+
yield this.applyPodfileToProject(constants_1.NS_BASE_PODFILE, mainPodfilePath, projectData, platformData);
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
applyPodfileArchExclusions(projectData, platformData) {
|
|
97
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
+
const xcodeVersionData = yield this.$xcodeSelectService.getXcodeVersion();
|
|
99
|
+
if (+xcodeVersionData.major !== 12) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
const { projectRoot } = platformData;
|
|
103
|
+
const exclusionsPodfile = path.join(projectRoot, "Podfile-exclusions");
|
|
104
|
+
if (!this.$fs.exists(exclusionsPodfile)) {
|
|
105
|
+
const exclusions = `
|
|
106
|
+
post_install do |installer|
|
|
107
|
+
installer.pods_project.build_configurations.each do |config|
|
|
108
|
+
config.build_settings.delete "VALID_ARCHS"
|
|
109
|
+
config.build_settings["EXCLUDED_ARCHS_x86_64"] = "arm64 arm64e"
|
|
110
|
+
config.build_settings["EXCLUDED_ARCHS[sdk=iphonesimulator*]"] = "i386 armv6 armv7 armv7s armv8 $(EXCLUDED_ARCHS_$(NATIVE_ARCH_64_BIT))"
|
|
111
|
+
config.build_settings["EXCLUDED_ARCHS[sdk=iphoneos*]"] = "i386 armv6 armv7 armv7s armv8 x86_64"
|
|
112
|
+
end
|
|
113
|
+
end`.trim();
|
|
114
|
+
this.$fs.writeFile(exclusionsPodfile, exclusions);
|
|
115
|
+
}
|
|
116
|
+
yield this.applyPodfileToProject("NativeScript-CLI-Architecture-Exclusions", exclusionsPodfile, projectData, platformData);
|
|
117
|
+
this.$fs.deleteFile(exclusionsPodfile);
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
applyPodfileFromExtensions(projectData, platformData) {
|
|
121
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
122
|
+
const extensionFolderPath = path.join(projectData.getAppResourcesDirectoryPath(), constants.iOSAppResourcesFolderName, constants.NATIVE_EXTENSION_FOLDER);
|
|
123
|
+
const projectPodfilePath = this.getProjectPodfilePath(platformData.projectRoot);
|
|
124
|
+
if (!this.$fs.exists(extensionFolderPath) ||
|
|
125
|
+
!this.$fs.exists(projectPodfilePath)) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
let projectPodFileContent = this.$fs.readText(projectPodfilePath);
|
|
129
|
+
const extensionsPodfile = this.$fs
|
|
130
|
+
.readDirectory(extensionFolderPath)
|
|
131
|
+
.filter((name) => {
|
|
132
|
+
const extensionPath = path.join(extensionFolderPath, name);
|
|
133
|
+
const stats = this.$fs.getFsStats(extensionPath);
|
|
134
|
+
return stats.isDirectory() && !name.startsWith(".");
|
|
135
|
+
})
|
|
136
|
+
.map((name) => ({
|
|
137
|
+
targetName: name,
|
|
138
|
+
podfilePath: path.join(extensionFolderPath, name, constants.PODFILE_NAME),
|
|
139
|
+
}));
|
|
140
|
+
extensionsPodfile.forEach(({ targetName, podfilePath }) => {
|
|
141
|
+
const regExpToRemove = new RegExp(`${this.getExtensionPodfileHeader(podfilePath, targetName)}[\\s\\S]*?${this.getExtensionPodfileEnd()}`, "mg");
|
|
142
|
+
projectPodFileContent = projectPodFileContent.replace(regExpToRemove, "");
|
|
143
|
+
if (this.$fs.exists(podfilePath)) {
|
|
144
|
+
const podfileContentWithoutTarget = this.$fs.readText(podfilePath);
|
|
145
|
+
const podFileContent = this.getExtensionPodfileHeader(podfilePath, targetName) +
|
|
146
|
+
os_1.EOL +
|
|
147
|
+
podfileContentWithoutTarget +
|
|
148
|
+
os_1.EOL +
|
|
149
|
+
this.getExtensionPodfileEnd();
|
|
150
|
+
projectPodFileContent += os_1.EOL + podFileContent;
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
this.$fs.writeFile(projectPodfilePath, projectPodFileContent);
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
applyPodfileToProject(moduleName, podfilePath, projectData, platformData) {
|
|
157
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
158
|
+
const nativeProjectPath = platformData.projectRoot;
|
|
159
|
+
if (!this.$fs.exists(podfilePath)) {
|
|
160
|
+
this.removePodfileFromProject(moduleName, podfilePath, projectData, nativeProjectPath);
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
const { podfileContent, replacedFunctions, podfilePlatformData } = this.buildPodfileContent(podfilePath, moduleName, projectData, platformData);
|
|
164
|
+
const pathToProjectPodfile = this.getProjectPodfilePath(nativeProjectPath);
|
|
165
|
+
const projectPodfileContent = this.$fs.exists(pathToProjectPodfile)
|
|
166
|
+
? this.$fs.readText(pathToProjectPodfile).trim()
|
|
167
|
+
: "";
|
|
168
|
+
if (projectPodfileContent.indexOf(podfileContent) === -1) {
|
|
169
|
+
this.removePodfileFromProject(moduleName, podfilePath, projectData, nativeProjectPath);
|
|
170
|
+
let finalPodfileContent = this.$fs.exists(pathToProjectPodfile)
|
|
171
|
+
? this.getPodfileContentWithoutTarget(projectData, this.$fs.readText(pathToProjectPodfile))
|
|
172
|
+
: "";
|
|
173
|
+
if (podfileContent.indexOf(CocoaPodsService.PODFILE_POST_INSTALL_SECTION_NAME) !== -1) {
|
|
174
|
+
finalPodfileContent = this.addPostInstallHook(replacedFunctions, finalPodfileContent, podfileContent);
|
|
175
|
+
}
|
|
176
|
+
if (podfilePlatformData) {
|
|
177
|
+
finalPodfileContent = this.$cocoaPodsPlatformManager.addPlatformSection(projectData, podfilePlatformData, finalPodfileContent);
|
|
178
|
+
}
|
|
179
|
+
finalPodfileContent = `${finalPodfileContent.trim()}${os_1.EOL}${os_1.EOL}${podfileContent.trim()}${os_1.EOL}`;
|
|
180
|
+
this.saveProjectPodfile(projectData, finalPodfileContent, nativeProjectPath);
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
removePodfileFromProject(moduleName, podfilePath, projectData, projectRoot) {
|
|
185
|
+
if (this.$fs.exists(this.getProjectPodfilePath(projectRoot))) {
|
|
186
|
+
let projectPodFileContent = this.$fs.readText(this.getProjectPodfilePath(projectRoot));
|
|
187
|
+
const regExpToRemove = new RegExp(`${this.getPluginPodfileHeader(podfilePath).replace(/\+/g, "\\+")}[\\s\\S]*?${this.getPluginPodfileEnd()}`, "mg");
|
|
188
|
+
projectPodFileContent = projectPodFileContent.replace(regExpToRemove, "");
|
|
189
|
+
projectPodFileContent = this.removePostInstallHook(moduleName, projectPodFileContent);
|
|
190
|
+
projectPodFileContent =
|
|
191
|
+
this.$cocoaPodsPlatformManager.removePlatformSection(moduleName, projectPodFileContent, podfilePath);
|
|
192
|
+
const defaultPodfileBeginning = this.getPodfileHeader(projectData.projectName);
|
|
193
|
+
const defaultContentWithPostInstallHook = `${defaultPodfileBeginning}${this.getPostInstallHookHeader()}end${os_1.EOL}end`;
|
|
194
|
+
const defaultContentWithoutPostInstallHook = `${defaultPodfileBeginning}${os_1.EOL}end`;
|
|
195
|
+
const trimmedProjectPodFileContent = projectPodFileContent.trim();
|
|
196
|
+
if (!trimmedProjectPodFileContent ||
|
|
197
|
+
trimmedProjectPodFileContent === defaultContentWithPostInstallHook ||
|
|
198
|
+
trimmedProjectPodFileContent === defaultContentWithoutPostInstallHook) {
|
|
199
|
+
this.$fs.deleteFile(this.getProjectPodfilePath(projectRoot));
|
|
200
|
+
}
|
|
201
|
+
else {
|
|
202
|
+
this.$fs.writeFile(this.getProjectPodfilePath(projectRoot), projectPodFileContent);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
getPluginPodfilePath(pluginData) {
|
|
207
|
+
const pluginPlatformsFolderPath = pluginData.pluginPlatformsFolderPath("ios");
|
|
208
|
+
const pluginPodFilePath = path.join(pluginPlatformsFolderPath, constants_1.PODFILE_NAME);
|
|
209
|
+
return pluginPodFilePath;
|
|
210
|
+
}
|
|
211
|
+
addPostInstallHook(replacedFunctions, finalPodfileContent, pluginPodfileContent) {
|
|
212
|
+
const postInstallHookStart = this.getPostInstallHookHeader();
|
|
213
|
+
let postInstallHookContent = "";
|
|
214
|
+
_.each(replacedFunctions, (rubyFunction) => {
|
|
215
|
+
let functionExecution = rubyFunction.functionName;
|
|
216
|
+
if (rubyFunction.functionParameters &&
|
|
217
|
+
rubyFunction.functionParameters.length) {
|
|
218
|
+
functionExecution = `${functionExecution} ${CocoaPodsService.INSTALLER_BLOCK_PARAMETER_NAME}`;
|
|
219
|
+
}
|
|
220
|
+
postInstallHookContent += ` ${functionExecution}${os_1.EOL}`;
|
|
221
|
+
});
|
|
222
|
+
if (postInstallHookContent) {
|
|
223
|
+
const index = finalPodfileContent.indexOf(postInstallHookStart);
|
|
224
|
+
if (index !== -1) {
|
|
225
|
+
const regExp = new RegExp(`(${(0, helpers_1.regExpEscape)(postInstallHookStart)}[\\s\\S]*?)(\\bend\\b)`, "m");
|
|
226
|
+
finalPodfileContent = finalPodfileContent.replace(regExp, `$1${postInstallHookContent.trimRight()}${os_1.EOL}$2`);
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
if (finalPodfileContent.length > 0) {
|
|
230
|
+
finalPodfileContent += `${os_1.EOL}${os_1.EOL}`;
|
|
231
|
+
}
|
|
232
|
+
const postInstallHook = `${postInstallHookStart}${postInstallHookContent}end`;
|
|
233
|
+
finalPodfileContent = `${finalPodfileContent}${postInstallHook}`;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
return finalPodfileContent;
|
|
237
|
+
}
|
|
238
|
+
getPodfileContentWithoutTarget(projectData, projectPodfileContent) {
|
|
239
|
+
const podFileHeader = this.getPodfileHeader(projectData.projectName);
|
|
240
|
+
if (_.startsWith(projectPodfileContent, podFileHeader)) {
|
|
241
|
+
projectPodfileContent = projectPodfileContent.substr(podFileHeader.length);
|
|
242
|
+
const podFileFooter = this.getPodfileFooter();
|
|
243
|
+
if (_.endsWith(projectPodfileContent, podFileFooter)) {
|
|
244
|
+
projectPodfileContent = projectPodfileContent.substr(0, projectPodfileContent.length - podFileFooter.length);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
return projectPodfileContent.trim();
|
|
248
|
+
}
|
|
249
|
+
saveProjectPodfile(projectData, projectPodfileContent, projectRoot) {
|
|
250
|
+
projectPodfileContent = this.getPodfileContentWithoutTarget(projectData, projectPodfileContent);
|
|
251
|
+
const podFileHeader = this.getPodfileHeader(projectData.projectName);
|
|
252
|
+
const podFileFooter = this.getPodfileFooter();
|
|
253
|
+
const contentToWrite = `${podFileHeader}${projectPodfileContent}${podFileFooter}`;
|
|
254
|
+
const projectPodfilePath = this.getProjectPodfilePath(projectRoot);
|
|
255
|
+
this.$fs.writeFile(projectPodfilePath, contentToWrite);
|
|
256
|
+
}
|
|
257
|
+
removePostInstallHook(moduleName, projectPodFileContent) {
|
|
258
|
+
const regExp = new RegExp(`^.*?${this.getHookBasicFuncNameForPlugin(CocoaPodsService.PODFILE_POST_INSTALL_SECTION_NAME, moduleName)}.*?$\\r?\\n`, "gm");
|
|
259
|
+
projectPodFileContent = projectPodFileContent.replace(regExp, "");
|
|
260
|
+
return projectPodFileContent;
|
|
261
|
+
}
|
|
262
|
+
getHookBasicFuncNameForPlugin(hookName, pluginName) {
|
|
263
|
+
const replacedPluginName = pluginName
|
|
264
|
+
.replace(/_/g, "___")
|
|
265
|
+
.replace(/[^A-Za-z0-9_]/g, "_");
|
|
266
|
+
return `${hookName}${replacedPluginName}`;
|
|
267
|
+
}
|
|
268
|
+
replaceHookContent(hookName, podfileContent, pluginName) {
|
|
269
|
+
const hookStart = `${hookName} do`;
|
|
270
|
+
const hookDefinitionRegExp = new RegExp(`${hookStart} *(\\|(\\w+)\\|)?`, "g");
|
|
271
|
+
const newFunctions = [];
|
|
272
|
+
const replacedContent = podfileContent.replace(hookDefinitionRegExp, (substring, firstGroup, secondGroup, index) => {
|
|
273
|
+
const newFunctionName = `${this.getHookBasicFuncNameForPlugin(hookName, pluginName)}_${newFunctions.length}`;
|
|
274
|
+
let newDefinition = `def ${newFunctionName}`;
|
|
275
|
+
const rubyFunction = { functionName: newFunctionName };
|
|
276
|
+
if (firstGroup && secondGroup) {
|
|
277
|
+
newDefinition = `${newDefinition} (${secondGroup})`;
|
|
278
|
+
rubyFunction.functionParameters = secondGroup;
|
|
279
|
+
}
|
|
280
|
+
newFunctions.push(rubyFunction);
|
|
281
|
+
return newDefinition;
|
|
282
|
+
});
|
|
283
|
+
return { replacedContent, newFunctions };
|
|
284
|
+
}
|
|
285
|
+
getPluginPodfileHeader(pluginPodFilePath) {
|
|
286
|
+
pluginPodFilePath = pluginPodFilePath.replace(/\+/g, "\\+");
|
|
287
|
+
return `# Begin Podfile - ${pluginPodFilePath}`;
|
|
288
|
+
}
|
|
289
|
+
getPluginPodfileEnd() {
|
|
290
|
+
return `# End Podfile${os_1.EOL}`;
|
|
291
|
+
}
|
|
292
|
+
getExtensionPodfileHeader(extensionPodFilePath, targetName) {
|
|
293
|
+
const targetHeader = `target "${targetName.trim()}" do`;
|
|
294
|
+
return `${this.getPluginPodfileHeader(extensionPodFilePath)}${os_1.EOL}${targetHeader}`;
|
|
295
|
+
}
|
|
296
|
+
getExtensionPodfileEnd() {
|
|
297
|
+
return `end${os_1.EOL}${this.getPluginPodfileEnd()}`;
|
|
298
|
+
}
|
|
299
|
+
getPostInstallHookHeader() {
|
|
300
|
+
return `${CocoaPodsService.PODFILE_POST_INSTALL_SECTION_NAME} do |${CocoaPodsService.INSTALLER_BLOCK_PARAMETER_NAME}|${os_1.EOL}`;
|
|
301
|
+
}
|
|
302
|
+
buildPodfileContent(pluginPodFilePath, pluginName, projectData, platformData) {
|
|
303
|
+
const pluginPodfileContent = this.$fs.readText(pluginPodFilePath);
|
|
304
|
+
const data = this.replaceHookContent(CocoaPodsService.PODFILE_POST_INSTALL_SECTION_NAME, pluginPodfileContent, pluginName);
|
|
305
|
+
const cocoapodsData = this.$cocoaPodsPlatformManager.replacePlatformRow(data.replacedContent, pluginPodFilePath);
|
|
306
|
+
const podfilePlatformData = cocoapodsData.podfilePlatformData;
|
|
307
|
+
let replacedContent = cocoapodsData.replacedContent;
|
|
308
|
+
if (projectData.nsConfig &&
|
|
309
|
+
projectData.nsConfig.overridePods &&
|
|
310
|
+
!this.isMainPodFile(pluginPodFilePath, projectData, platformData)) {
|
|
311
|
+
replacedContent = this.overridePodsFromFile(replacedContent, projectData, platformData);
|
|
312
|
+
}
|
|
313
|
+
return {
|
|
314
|
+
podfileContent: `${this.getPluginPodfileHeader(pluginPodFilePath)}${os_1.EOL}${replacedContent}${os_1.EOL}${this.getPluginPodfileEnd()}`,
|
|
315
|
+
replacedFunctions: data.newFunctions,
|
|
316
|
+
podfilePlatformData,
|
|
317
|
+
};
|
|
318
|
+
}
|
|
319
|
+
getMainPodFilePath(projectData, platformData) {
|
|
320
|
+
return path.join(projectData.appResourcesDirectoryPath, platformData.normalizedPlatformName, constants_1.PODFILE_NAME);
|
|
321
|
+
}
|
|
322
|
+
isMainPodFile(podFilePath, projectData, platformData) {
|
|
323
|
+
const mainPodfilePath = this.getMainPodFilePath(projectData, platformData);
|
|
324
|
+
return podFilePath === mainPodfilePath;
|
|
325
|
+
}
|
|
326
|
+
overridePodsFromFile(podfileContent, projectData, platformData) {
|
|
327
|
+
const mainPodfilePath = this.getMainPodFilePath(projectData, platformData);
|
|
328
|
+
if (this.$fs.exists(mainPodfilePath)) {
|
|
329
|
+
const mainPodfileContent = this.$fs.readText(mainPodfilePath);
|
|
330
|
+
const pods = this.getCocoaPodsFromPodfile(mainPodfileContent);
|
|
331
|
+
_.forEach(pods, (pod) => {
|
|
332
|
+
podfileContent = podfileContent.replace(new RegExp(`^[ ]*pod\\s*["']${pod}['"].*$`, "gm"), "#$&");
|
|
333
|
+
});
|
|
334
|
+
}
|
|
335
|
+
return podfileContent;
|
|
336
|
+
}
|
|
337
|
+
_getCocoaPodsFromPodfile(podfileContent) {
|
|
338
|
+
const pods = [];
|
|
339
|
+
const podsRegex = /^\s*pod\s*["'](.*?)['"].*$/gm;
|
|
340
|
+
let match = podsRegex.exec(podfileContent);
|
|
341
|
+
while (match != null) {
|
|
342
|
+
const podName = match[1];
|
|
343
|
+
if (podName) {
|
|
344
|
+
pods.push(podName);
|
|
345
|
+
}
|
|
346
|
+
match = podsRegex.exec(podfileContent);
|
|
347
|
+
}
|
|
348
|
+
return pods;
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
CocoaPodsService.PODFILE_POST_INSTALL_SECTION_NAME = "post_install";
|
|
352
|
+
CocoaPodsService.INSTALLER_BLOCK_PARAMETER_NAME = "installer";
|
|
353
|
+
exports.CocoaPodsService = CocoaPodsService;
|
|
354
|
+
yok_1.injector.register("cocoapodsService", CocoaPodsService);
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DebugDataService = void 0;
|
|
4
|
+
const yok_1 = require("../common/yok");
|
|
5
|
+
class DebugDataService {
|
|
6
|
+
constructor($devicesService) {
|
|
7
|
+
this.$devicesService = $devicesService;
|
|
8
|
+
}
|
|
9
|
+
getDebugData(deviceIdentifier, projectData, debugOptions) {
|
|
10
|
+
const device = this.$devicesService.getDeviceByIdentifier(deviceIdentifier);
|
|
11
|
+
return {
|
|
12
|
+
applicationIdentifier: projectData.projectIdentifiers[device.deviceInfo.platform.toLowerCase()],
|
|
13
|
+
projectDir: projectData.projectDir,
|
|
14
|
+
deviceIdentifier,
|
|
15
|
+
projectName: projectData.projectName,
|
|
16
|
+
debugOptions,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.DebugDataService = DebugDataService;
|
|
21
|
+
yok_1.injector.register("debugDataService", DebugDataService);
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DebugServiceBase = void 0;
|
|
4
|
+
const events_1 = require("events");
|
|
5
|
+
class DebugServiceBase extends events_1.EventEmitter {
|
|
6
|
+
constructor(device, $devicesService) {
|
|
7
|
+
super();
|
|
8
|
+
this.device = device;
|
|
9
|
+
this.$devicesService = $devicesService;
|
|
10
|
+
}
|
|
11
|
+
getCanExecuteAction(deviceIdentifier) {
|
|
12
|
+
return (device) => {
|
|
13
|
+
if (deviceIdentifier) {
|
|
14
|
+
let isSearchedDevice = device.deviceInfo.identifier === deviceIdentifier;
|
|
15
|
+
if (!isSearchedDevice) {
|
|
16
|
+
const deviceByDeviceOption = this.$devicesService.getDeviceByDeviceOption();
|
|
17
|
+
isSearchedDevice =
|
|
18
|
+
deviceByDeviceOption &&
|
|
19
|
+
device.deviceInfo.identifier ===
|
|
20
|
+
deviceByDeviceOption.deviceInfo.identifier;
|
|
21
|
+
}
|
|
22
|
+
return isSearchedDevice;
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
getChromeDebugUrl(debugOptions, port) {
|
|
30
|
+
const commitSHA = debugOptions.devToolsCommit || "02e6bde1bbe34e43b309d4ef774b1168d25fd024";
|
|
31
|
+
const devToolsProtocol = `devtools`;
|
|
32
|
+
let chromeDevToolsPrefix = `${devToolsProtocol}://devtools/remote/serve_file/@${commitSHA}`;
|
|
33
|
+
if (debugOptions.useBundledDevTools === undefined ||
|
|
34
|
+
debugOptions.useBundledDevTools) {
|
|
35
|
+
chromeDevToolsPrefix = `${devToolsProtocol}://devtools/bundled`;
|
|
36
|
+
}
|
|
37
|
+
if (debugOptions.useHttpUrl) {
|
|
38
|
+
chromeDevToolsPrefix = `https://chrome-devtools-frontend.appspot.com/serve_file/@${commitSHA}`;
|
|
39
|
+
}
|
|
40
|
+
const chromeUrl = `${chromeDevToolsPrefix}/inspector.html?ws=localhost:${port}`;
|
|
41
|
+
return chromeUrl;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.DebugServiceBase = DebugServiceBase;
|