nativescript 8.9.0-dev.2 → 8.9.0-dev.3
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/config/test-deps-versions-generated.json +1 -1
- package/lib/android-tools-info.js +9 -32
- package/lib/base-package-manager.js +47 -71
- package/lib/bootstrap.js +1 -5
- package/lib/bun-package-manager.js +65 -104
- package/lib/color.js +2 -5
- package/lib/commands/add-platform.js +14 -31
- package/lib/commands/apple-login.js +18 -30
- package/lib/commands/appstore-list.js +34 -46
- package/lib/commands/appstore-upload.js +52 -68
- package/lib/commands/build.js +57 -90
- package/lib/commands/clean.js +161 -197
- package/lib/commands/command-base.js +14 -28
- package/lib/commands/config.js +48 -71
- package/lib/commands/create-project.js +210 -235
- package/lib/commands/debug.js +66 -93
- package/lib/commands/deploy.js +30 -47
- package/lib/commands/embedding/embed.js +33 -59
- package/lib/commands/extensibility/install-extension.js +5 -17
- package/lib/commands/extensibility/list-extensions.js +13 -25
- package/lib/commands/extensibility/uninstall-extension.js +4 -16
- package/lib/commands/fonts.js +30 -42
- package/lib/commands/generate-assets.js +13 -29
- package/lib/commands/generate-help.js +2 -14
- package/lib/commands/generate.js +12 -70
- package/lib/commands/info.js +2 -14
- package/lib/commands/install.js +34 -50
- package/lib/commands/list-platforms.js +14 -26
- package/lib/commands/migrate.js +15 -27
- package/lib/commands/native-add.js +23 -51
- package/lib/commands/platform-clean.js +19 -33
- package/lib/commands/plugin/add-plugin.js +12 -26
- package/lib/commands/plugin/build-plugin.js +31 -45
- package/lib/commands/plugin/create-plugin.js +110 -138
- package/lib/commands/plugin/list-plugins.js +22 -34
- package/lib/commands/plugin/remove-plugin.js +20 -35
- package/lib/commands/plugin/update-plugin.js +20 -34
- package/lib/commands/post-install.js +20 -39
- package/lib/commands/prepare.js +22 -39
- package/lib/commands/preview.js +49 -64
- package/lib/commands/remove-platform.js +7 -19
- package/lib/commands/resources/resources-update.js +13 -28
- package/lib/commands/run.js +55 -77
- package/lib/commands/setup.js +0 -1
- package/lib/commands/start.js +6 -20
- package/lib/commands/test-init.js +123 -138
- package/lib/commands/test.js +67 -97
- package/lib/commands/typings.js +126 -143
- package/lib/commands/update-platform.js +22 -40
- package/lib/commands/update.js +30 -45
- package/lib/commands/widget.js +390 -352
- package/lib/common/bootstrap.js +0 -1
- package/lib/common/child-process.js +53 -75
- package/lib/common/codeGeneration/code-entity.js +1 -2
- package/lib/common/codeGeneration/code-printer.js +1 -2
- package/lib/common/command-params.js +7 -19
- package/lib/common/commands/analytics.js +27 -43
- package/lib/common/commands/autocompletion.js +39 -59
- package/lib/common/commands/device/device-log-stream.js +12 -24
- package/lib/common/commands/device/get-file.js +22 -35
- package/lib/common/commands/device/list-applications.js +12 -24
- package/lib/common/commands/device/list-devices.js +72 -90
- package/lib/common/commands/device/list-files.js +23 -36
- package/lib/common/commands/device/put-file.js +22 -35
- package/lib/common/commands/device/run-application.js +12 -26
- package/lib/common/commands/device/stop-application.js +11 -23
- package/lib/common/commands/device/uninstall-application.js +6 -18
- package/lib/common/commands/doctor.js +2 -3
- package/lib/common/commands/generate-messages.js +17 -29
- package/lib/common/commands/help.js +20 -34
- package/lib/common/commands/package-manager-get.js +6 -18
- package/lib/common/commands/package-manager-set.js +9 -21
- package/lib/common/commands/post-install.js +2 -14
- package/lib/common/commands/preuninstall.js +24 -48
- package/lib/common/commands/proxy/proxy-base.js +8 -23
- package/lib/common/commands/proxy/proxy-clear.js +4 -16
- package/lib/common/commands/proxy/proxy-get.js +3 -15
- package/lib/common/commands/proxy/proxy-set.js +87 -101
- package/lib/common/common-lib.js +0 -1
- package/lib/common/constants.js +11 -22
- package/lib/common/decorators.js +10 -70
- package/lib/common/dispatchers.js +80 -106
- package/lib/common/errors.js +91 -116
- package/lib/common/file-system.js +108 -141
- package/lib/common/header.js +1 -5
- package/lib/common/helpers.js +152 -267
- package/lib/common/host-info.js +37 -54
- package/lib/common/http-client.js +93 -128
- package/lib/common/logger/appenders/cli-appender.js +1 -6
- package/lib/common/logger/appenders/emit-appender.js +1 -6
- package/lib/common/logger/layouts/cli-layout.js +1 -3
- package/lib/common/logger/logger.js +4 -9
- package/lib/common/messages/messages.js +0 -6
- package/lib/common/mobile/android/android-application-manager.js +122 -162
- package/lib/common/mobile/android/android-debug-bridge-result-handler.js +1 -2
- package/lib/common/mobile/android/android-debug-bridge.js +87 -118
- package/lib/common/mobile/android/android-device-file-system.js +98 -135
- package/lib/common/mobile/android/android-device-hash-service.js +50 -78
- package/lib/common/mobile/android/android-device.js +68 -93
- package/lib/common/mobile/android/android-emulator-services.js +105 -131
- package/lib/common/mobile/android/android-ini-file-parser.js +0 -9
- package/lib/common/mobile/android/android-log-filter.js +1 -5
- package/lib/common/mobile/android/android-virtual-device-service.js +76 -123
- package/lib/common/mobile/android/device-android-debug-bridge.js +13 -30
- package/lib/common/mobile/android/genymotion/genymotion-service.js +91 -123
- package/lib/common/mobile/android/genymotion/virtualbox-service.js +64 -92
- package/lib/common/mobile/android/logcat-helper.js +108 -140
- package/lib/common/mobile/application-manager-base.js +84 -113
- package/lib/common/mobile/device-emitter.js +0 -4
- package/lib/common/mobile/device-log-emitter.js +0 -1
- package/lib/common/mobile/device-log-provider-base.js +7 -19
- package/lib/common/mobile/device-log-provider.js +0 -23
- package/lib/common/mobile/device-platforms-constants.js +0 -1
- package/lib/common/mobile/emulator-helper.js +0 -3
- package/lib/common/mobile/ios/device/ios-application-manager.js +79 -111
- package/lib/common/mobile/ios/device/ios-device-file-system.js +78 -106
- package/lib/common/mobile/ios/device/ios-device-operations.js +105 -146
- package/lib/common/mobile/ios/device/ios-device.js +20 -40
- package/lib/common/mobile/ios/ios-device-base.js +58 -82
- package/lib/common/mobile/ios/ios-device-product-name-mapper.js +0 -2
- package/lib/common/mobile/ios/ios-log-filter.js +0 -1
- package/lib/common/mobile/ios/simulator/ios-emulator-services.js +63 -96
- package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +1 -2
- package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +60 -95
- package/lib/common/mobile/ios/simulator/ios-simulator-device.js +27 -48
- package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +37 -63
- package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +24 -36
- package/lib/common/mobile/local-to-device-path-data-factory.js +0 -1
- package/lib/common/mobile/log-filter.js +0 -2
- package/lib/common/mobile/logging-levels.js +0 -1
- package/lib/common/mobile/mobile-core/android-device-discovery.js +43 -64
- package/lib/common/mobile/mobile-core/android-emulator-discovery.js +21 -35
- package/lib/common/mobile/mobile-core/android-process-service.js +143 -214
- package/lib/common/mobile/mobile-core/device-discovery.js +2 -14
- package/lib/common/mobile/mobile-core/devices-service.js +386 -505
- package/lib/common/mobile/mobile-core/ios-device-discovery.js +24 -37
- package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +47 -65
- package/lib/common/mobile/mobile-helper.js +15 -27
- package/lib/common/mobile/wp8/wp8-emulator-services.js +25 -53
- package/lib/common/opener.js +2 -3
- package/lib/common/os-info.js +0 -1
- package/lib/common/plist-parser.js +0 -1
- package/lib/common/project-helper.js +0 -1
- package/lib/common/prompter.js +91 -114
- package/lib/common/queue.js +9 -21
- package/lib/common/resource-loader.js +0 -1
- package/lib/common/services/auto-completion-service.js +40 -65
- package/lib/common/services/cancellation.js +17 -29
- package/lib/common/services/commands-service.js +146 -180
- package/lib/common/services/help-service.js +133 -166
- package/lib/common/services/hooks-service.js +93 -121
- package/lib/common/services/ios-notification-service.js +21 -35
- package/lib/common/services/json-file-settings-service.js +52 -77
- package/lib/common/services/lock-service.js +35 -58
- package/lib/common/services/message-contract-generator.js +35 -47
- package/lib/common/services/messages-service.js +0 -1
- package/lib/common/services/micro-templating-service.js +4 -21
- package/lib/common/services/net-service.js +90 -110
- package/lib/common/services/project-files-manager.js +10 -28
- package/lib/common/services/project-files-provider-base.js +0 -1
- package/lib/common/services/proxy-service.js +13 -25
- package/lib/common/services/qr.js +13 -25
- package/lib/common/services/settings-service.js +1 -2
- package/lib/common/services/xcode-select-service.js +20 -36
- package/lib/common/utils.js +2 -3
- package/lib/common/validators/project-name-validator.js +1 -2
- package/lib/common/validators/validation-result.js +1 -2
- package/lib/common/verify-node-version.js +3 -11
- package/lib/common/yok.js +35 -69
- package/lib/config.js +36 -72
- package/lib/constants-provider.js +0 -1
- package/lib/constants.js +24 -77
- package/lib/controllers/build-controller.js +82 -100
- package/lib/controllers/debug-controller.js +107 -133
- package/lib/controllers/deploy-controller.js +15 -24
- package/lib/controllers/migrate-controller.js +723 -884
- package/lib/controllers/platform-controller.js +71 -94
- package/lib/controllers/prepare-controller.js +232 -274
- package/lib/controllers/run-controller.js +397 -427
- package/lib/controllers/update-controller-base.js +16 -30
- package/lib/controllers/update-controller.js +94 -130
- package/lib/data/build-data.js +0 -1
- package/lib/data/controller-data-base.js +0 -1
- package/lib/data/debug-data.js +0 -1
- package/lib/data/platform-data.js +0 -1
- package/lib/data/prepare-data.js +4 -2
- package/lib/data/run-data.js +0 -1
- package/lib/definitions/project.d.ts +24 -24
- package/lib/detached-processes/cleanup-js-subprocess.js +5 -20
- package/lib/detached-processes/cleanup-process.js +30 -43
- package/lib/detached-processes/file-log-service.js +1 -2
- package/lib/device-path-provider.js +23 -35
- package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +149 -171
- package/lib/device-sockets/ios/notification.js +1 -4
- package/lib/device-sockets/ios/socket-request-executor.js +24 -42
- package/lib/helpers/android-bundle-validator-helper.js +2 -3
- package/lib/helpers/deploy-command-helper.js +44 -50
- package/lib/helpers/key-command-helper.js +6 -17
- package/lib/helpers/livesync-command-helper.js +137 -155
- package/lib/helpers/network-connectivity-validator.js +6 -18
- package/lib/helpers/options-track-helper.js +7 -19
- package/lib/helpers/package-path-helper.js +0 -1
- package/lib/helpers/platform-command-helper.js +101 -127
- package/lib/helpers/version-validator-helper.js +0 -1
- package/lib/key-commands/bootstrap.js +2 -3
- package/lib/key-commands/index.js +154 -205
- package/lib/nativescript-cli-lib-bootstrap.js +0 -4
- package/lib/nativescript-cli-lib.js +0 -1
- package/lib/nativescript-cli.js +6 -24
- package/lib/node/pbxproj-dom-xcode.js +0 -1
- package/lib/node/xcode.js +0 -1
- package/lib/node-package-manager.js +81 -114
- package/lib/options.js +122 -156
- package/lib/package-installation-manager.js +130 -172
- package/lib/package-manager.js +63 -88
- package/lib/platform-command-param.js +4 -16
- package/lib/pnpm-package-manager.js +59 -81
- package/lib/project-data.js +1 -13
- package/lib/providers/project-files-provider.js +1 -2
- package/lib/resolvers/livesync-service-resolver.js +0 -1
- package/lib/services/analytics/analytics-broker-process.js +19 -32
- package/lib/services/analytics/analytics-broker.js +17 -31
- package/lib/services/analytics/analytics-service.js +170 -210
- package/lib/services/analytics/google-analytics-provider.js +43 -59
- package/lib/services/analytics-settings-service.js +15 -37
- package/lib/services/android/android-bundle-tool-service.js +43 -61
- package/lib/services/android/gradle-build-args-service.js +9 -23
- package/lib/services/android/gradle-build-service.js +22 -36
- package/lib/services/android/gradle-command-service.js +22 -36
- package/lib/services/android-device-debug-service.js +90 -123
- package/lib/services/android-plugin-build-service.js +205 -260
- package/lib/services/android-project-service.js +129 -241
- package/lib/services/android-resources-migration-service.js +51 -71
- package/lib/services/apple-portal/apple-portal-application-service.js +46 -64
- package/lib/services/apple-portal/apple-portal-cookie-service.js +0 -1
- package/lib/services/apple-portal/apple-portal-session-service.js +197 -218
- package/lib/services/apple-portal/srp/srp-wrapper.js +43 -61
- package/lib/services/assets-generation/assets-generation-service.js +103 -128
- package/lib/services/build-artifacts-service.js +10 -22
- package/lib/services/build-data-service.js +0 -1
- package/lib/services/build-info-file-service.js +20 -36
- package/lib/services/cleanup-service.js +48 -81
- package/lib/services/cocoapods-platform-manager.js +0 -9
- package/lib/services/cocoapods-service.js +112 -153
- package/lib/services/debug-data-service.js +0 -1
- package/lib/services/debug-service-base.js +0 -7
- package/lib/services/device/device-install-app-service.js +54 -72
- package/lib/services/doctor-service.js +101 -135
- package/lib/services/extensibility-service.js +81 -108
- package/lib/services/files-hash-service.js +26 -44
- package/lib/services/hmr-status-service.js +1 -3
- package/lib/services/info-service.js +0 -1
- package/lib/services/initialize-service.js +37 -54
- package/lib/services/ios/export-options-plist-service.js +38 -55
- package/lib/services/ios/ios-signing-service.js +168 -191
- package/lib/services/ios/spm-service.js +46 -70
- package/lib/services/ios/xcodebuild-args-service.js +77 -103
- package/lib/services/ios/xcodebuild-command-service.js +14 -26
- package/lib/services/ios/xcodebuild-service.js +52 -72
- package/lib/services/ios-debugger-port-service.js +24 -38
- package/lib/services/ios-device-debug-service.js +75 -103
- package/lib/services/ios-entitlements-service.js +31 -43
- package/lib/services/ios-extensions-service.js +18 -30
- package/lib/services/ios-log-filter.js +0 -20
- package/lib/services/ios-native-target-service.js +4 -6
- package/lib/services/ios-project-service.js +452 -603
- package/lib/services/ios-provision-service.js +108 -132
- package/lib/services/ios-watch-app-service.js +21 -33
- package/lib/services/ip-service.js +38 -55
- package/lib/services/itmstransporter-service.js +129 -153
- package/lib/services/karma-execution.js +0 -2
- package/lib/services/livesync/android-device-livesync-service-base.js +31 -49
- package/lib/services/livesync/android-device-livesync-service.js +120 -151
- package/lib/services/livesync/android-device-livesync-sockets-service.js +121 -155
- package/lib/services/livesync/android-livesync-service.js +14 -36
- package/lib/services/livesync/android-livesync-tool.js +90 -117
- package/lib/services/livesync/device-livesync-service-base.js +15 -30
- package/lib/services/livesync/ios-device-livesync-service.js +114 -150
- package/lib/services/livesync/ios-livesync-service.js +42 -60
- package/lib/services/livesync/livesync-socket.js +0 -1
- package/lib/services/livesync/platform-livesync-service-base.js +94 -124
- package/lib/services/livesync-process-data-service.js +0 -1
- package/lib/services/log-parser-service.js +1 -2
- package/lib/services/log-source-map-service.js +30 -56
- package/lib/services/marking-mode-service.js +17 -33
- package/lib/services/metadata-filtering-service.js +0 -1
- package/lib/services/npm-config-service.js +1 -5
- package/lib/services/pacote-service.js +49 -71
- package/lib/services/performance-service.js +2 -4
- package/lib/services/platform/add-platform-service.js +51 -119
- package/lib/services/platform/platform-validation-service.js +22 -34
- package/lib/services/platform/prepare-native-platform-service.js +49 -65
- package/lib/services/platform-environment-requirements.js +27 -43
- package/lib/services/platform-project-service-base.js +0 -1
- package/lib/services/platforms-data-service.js +0 -1
- package/lib/services/plugins-service.js +125 -168
- package/lib/services/prepare-data-service.js +0 -1
- package/lib/services/project-backup-service.js +1 -5
- package/lib/services/project-changes-service.js +124 -152
- package/lib/services/project-cleanup-service.js +64 -79
- package/lib/services/project-config-service.js +73 -102
- package/lib/services/project-data-service.js +108 -154
- package/lib/services/project-name-service.js +28 -44
- package/lib/services/project-service.js +84 -113
- package/lib/services/project-templates-service.js +52 -68
- package/lib/services/qr-code-terminal-service.js +0 -1
- package/lib/services/require-service.js +0 -1
- package/lib/services/start-service.js +41 -60
- package/lib/services/temp-service.js +8 -22
- package/lib/services/terminal-spinner-service.js +15 -28
- package/lib/services/test-execution-service.js +59 -79
- package/lib/services/test-initialization-service.js +2 -6
- package/lib/services/timeline-profiler-service.js +1 -2
- package/lib/services/user-settings-service.js +0 -1
- package/lib/services/versions-service.js +119 -140
- package/lib/services/watch-ignore-list-service.js +0 -1
- package/lib/services/webpack/webpack-compiler-service.js +215 -279
- package/lib/services/xcconfig-service.js +8 -21
- package/lib/services/xcproj-service.js +0 -1
- package/lib/shared-event-bus.js +0 -6
- package/lib/sys-info.js +45 -63
- package/lib/tools/config-manipulation/config-transformer.js +0 -12
- package/lib/tools/node-modules/node-modules-builder.js +16 -28
- package/lib/tools/node-modules/node-modules-dependencies-builder.js +0 -6
- package/lib/yarn-package-manager.js +59 -79
- package/lib/yarn2-package-manager.js +60 -82
- package/package.json +65 -80
- package/node_modules/@npmcli/move-file/LICENSE.md +0 -22
- package/node_modules/@npmcli/move-file/README.md +0 -69
- package/node_modules/@npmcli/move-file/lib/index.js +0 -185
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/LICENSE +0 -21
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/bin/cmd.js +0 -68
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/index.js +0 -31
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/find-made.js +0 -29
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/mkdirp-manual.js +0 -64
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/mkdirp-native.js +0 -39
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/opts-arg.js +0 -23
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/path-arg.js +0 -29
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/lib/use-native.js +0 -10
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/package.json +0 -44
- package/node_modules/@npmcli/move-file/node_modules/mkdirp/readme.markdown +0 -266
- package/node_modules/@npmcli/move-file/package.json +0 -47
- package/node_modules/balanced-match/.github/FUNDING.yml +0 -2
- package/node_modules/balanced-match/LICENSE.md +0 -21
- package/node_modules/balanced-match/README.md +0 -97
- package/node_modules/balanced-match/index.js +0 -62
- package/node_modules/balanced-match/package.json +0 -48
- package/node_modules/concat-map/.travis.yml +0 -4
- package/node_modules/concat-map/LICENSE +0 -18
- package/node_modules/concat-map/README.markdown +0 -62
- package/node_modules/concat-map/example/map.js +0 -6
- package/node_modules/concat-map/index.js +0 -13
- package/node_modules/concat-map/package.json +0 -43
- package/node_modules/concat-map/test/map.js +0 -39
- package/node_modules/fs.realpath/LICENSE +0 -43
- package/node_modules/fs.realpath/README.md +0 -33
- package/node_modules/fs.realpath/index.js +0 -66
- package/node_modules/fs.realpath/old.js +0 -303
- package/node_modules/fs.realpath/package.json +0 -26
- package/node_modules/inflight/LICENSE +0 -15
- package/node_modules/inflight/README.md +0 -37
- package/node_modules/inflight/inflight.js +0 -54
- package/node_modules/inflight/package.json +0 -29
- package/node_modules/inherits/LICENSE +0 -16
- package/node_modules/inherits/README.md +0 -42
- package/node_modules/inherits/inherits.js +0 -9
- package/node_modules/inherits/inherits_browser.js +0 -27
- package/node_modules/inherits/package.json +0 -29
- package/node_modules/once/LICENSE +0 -15
- package/node_modules/once/README.md +0 -79
- package/node_modules/once/once.js +0 -42
- package/node_modules/once/package.json +0 -33
- package/node_modules/path-is-absolute/index.js +0 -20
- package/node_modules/path-is-absolute/license +0 -21
- package/node_modules/path-is-absolute/package.json +0 -43
- package/node_modules/path-is-absolute/readme.md +0 -59
- package/node_modules/rimraf/LICENSE +0 -15
- package/node_modules/rimraf/README.md +0 -101
- package/node_modules/rimraf/bin.js +0 -68
- package/node_modules/rimraf/node_modules/brace-expansion/LICENSE +0 -21
- package/node_modules/rimraf/node_modules/brace-expansion/README.md +0 -129
- package/node_modules/rimraf/node_modules/brace-expansion/index.js +0 -201
- package/node_modules/rimraf/node_modules/brace-expansion/package.json +0 -47
- package/node_modules/rimraf/node_modules/glob/LICENSE +0 -21
- package/node_modules/rimraf/node_modules/glob/README.md +0 -378
- package/node_modules/rimraf/node_modules/glob/common.js +0 -238
- package/node_modules/rimraf/node_modules/glob/glob.js +0 -790
- package/node_modules/rimraf/node_modules/glob/package.json +0 -55
- package/node_modules/rimraf/node_modules/glob/sync.js +0 -486
- package/node_modules/rimraf/node_modules/minimatch/LICENSE +0 -15
- package/node_modules/rimraf/node_modules/minimatch/README.md +0 -230
- package/node_modules/rimraf/node_modules/minimatch/minimatch.js +0 -947
- package/node_modules/rimraf/node_modules/minimatch/package.json +0 -33
- package/node_modules/rimraf/package.json +0 -32
- package/node_modules/rimraf/rimraf.js +0 -360
- package/node_modules/stringify-package/LICENSE +0 -13
- package/node_modules/stringify-package/README.md +0 -55
- package/node_modules/stringify-package/index.js +0 -18
- package/node_modules/stringify-package/package.json +0 -38
- package/node_modules/wrappy/LICENSE +0 -15
- package/node_modules/wrappy/README.md +0 -36
- package/node_modules/wrappy/package.json +0 -29
- package/node_modules/wrappy/wrappy.js +0 -33
package/lib/commands/clean.js
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
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
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.CleanCommand = void 0;
|
|
13
4
|
const color_1 = require("../color");
|
|
@@ -26,18 +17,6 @@ function bytesToHumanReadable(bytes) {
|
|
|
26
17
|
}
|
|
27
18
|
return `${bytes.toFixed(2)} ${units[unit]}`;
|
|
28
19
|
}
|
|
29
|
-
/**
|
|
30
|
-
* A helper function to map an array of values to promises with a concurrency limit.
|
|
31
|
-
* The mapper function should return a promise. It will be called for each value in the values array.
|
|
32
|
-
* The concurrency limit is the number of promises that can be running at the same time.
|
|
33
|
-
*
|
|
34
|
-
* This function will return a promise that resolves when all values have been mapped.
|
|
35
|
-
*
|
|
36
|
-
* @param values A static array of values to map to promises
|
|
37
|
-
* @param mapper A function that maps a value to a promise
|
|
38
|
-
* @param concurrency The number of promises that can be running at the same time
|
|
39
|
-
* @returns Promise<void>
|
|
40
|
-
*/
|
|
41
20
|
function promiseMap(values, mapper, concurrency = 10) {
|
|
42
21
|
let index = 0;
|
|
43
22
|
let pending = 0;
|
|
@@ -75,199 +54,184 @@ class CleanCommand {
|
|
|
75
54
|
this.$staticConfig = $staticConfig;
|
|
76
55
|
this.allowedParameters = [];
|
|
77
56
|
}
|
|
78
|
-
execute(args) {
|
|
57
|
+
async execute(args) {
|
|
79
58
|
var _a, _b;
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
if (Array.isArray(overridePathsToClean)) {
|
|
101
|
-
pathsToClean = overridePathsToClean;
|
|
102
|
-
}
|
|
103
|
-
if (Array.isArray(additionalPaths)) {
|
|
104
|
-
pathsToClean.push(...additionalPaths);
|
|
105
|
-
}
|
|
59
|
+
const isDryRun = (_a = this.$options.dryRun) !== null && _a !== void 0 ? _a : false;
|
|
60
|
+
const isJSON = (_b = this.$options.json) !== null && _b !== void 0 ? _b : false;
|
|
61
|
+
const spinner = this.$terminalSpinnerService.createSpinner({
|
|
62
|
+
isSilent: isJSON,
|
|
63
|
+
});
|
|
64
|
+
if (!this.$projectService.isValidNativeScriptProject()) {
|
|
65
|
+
return this.cleanMultipleProjects(spinner);
|
|
66
|
+
}
|
|
67
|
+
spinner.start("Cleaning project...\n");
|
|
68
|
+
let pathsToClean = [
|
|
69
|
+
constants.HOOKS_DIR_NAME,
|
|
70
|
+
constants.PLATFORMS_DIR_NAME,
|
|
71
|
+
constants.NODE_MODULES_FOLDER_NAME,
|
|
72
|
+
constants.PACKAGE_LOCK_JSON_FILE_NAME,
|
|
73
|
+
];
|
|
74
|
+
try {
|
|
75
|
+
const overridePathsToClean = this.$projectConfigService.getValue("cli.pathsToClean");
|
|
76
|
+
const additionalPaths = this.$projectConfigService.getValue("cli.additionalPathsToClean");
|
|
77
|
+
if (Array.isArray(overridePathsToClean)) {
|
|
78
|
+
pathsToClean = overridePathsToClean;
|
|
106
79
|
}
|
|
107
|
-
|
|
108
|
-
|
|
80
|
+
if (Array.isArray(additionalPaths)) {
|
|
81
|
+
pathsToClean.push(...additionalPaths);
|
|
109
82
|
}
|
|
110
|
-
|
|
83
|
+
}
|
|
84
|
+
catch (err) {
|
|
85
|
+
}
|
|
86
|
+
const res = await this.$projectCleanupService.clean(pathsToClean, {
|
|
87
|
+
dryRun: isDryRun,
|
|
88
|
+
silent: isJSON,
|
|
89
|
+
stats: isJSON,
|
|
90
|
+
});
|
|
91
|
+
if (res.stats && isJSON) {
|
|
92
|
+
console.log(JSON.stringify({
|
|
93
|
+
ok: res.ok,
|
|
111
94
|
dryRun: isDryRun,
|
|
112
|
-
|
|
113
|
-
|
|
95
|
+
stats: Object.fromEntries(res.stats.entries()),
|
|
96
|
+
}, null, 2));
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
if (res.ok) {
|
|
100
|
+
spinner.succeed("Project successfully cleaned.");
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
spinner.fail(color_1.color.red("Project unsuccessfully cleaned."));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
async cleanMultipleProjects(spinner) {
|
|
107
|
+
if (!(0, helpers_1.isInteractive)() || this.$options.json) {
|
|
108
|
+
this.$logger.warn("No project found in the current directory.");
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const shouldScan = await this.$prompter.confirm("No project found in the current directory. Would you like to scan for all projects in sub-directories instead?");
|
|
112
|
+
if (!shouldScan) {
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
spinner.start("Scanning for projects... Please wait.");
|
|
116
|
+
const paths = await this.getNSProjectPathsInDirectory();
|
|
117
|
+
spinner.succeed(`Found ${paths.length} projects.`);
|
|
118
|
+
let computed = 0;
|
|
119
|
+
const updateProgress = () => {
|
|
120
|
+
const current = color_1.color.grey(`${computed}/${paths.length}`);
|
|
121
|
+
spinner.start(`Gathering cleanable sizes. This may take a while... ${current}`);
|
|
122
|
+
};
|
|
123
|
+
updateProgress();
|
|
124
|
+
const projects = new Map();
|
|
125
|
+
await promiseMap(paths, (p) => {
|
|
126
|
+
return this.$childProcess
|
|
127
|
+
.exec(`node ${this.$staticConfig.cliBinPath} clean --dry-run --json --disable-analytics`, {
|
|
128
|
+
cwd: p,
|
|
129
|
+
})
|
|
130
|
+
.then((res) => {
|
|
131
|
+
const paths = JSON.parse(res).stats;
|
|
132
|
+
return Object.values(paths).reduce((a, b) => a + b, 0);
|
|
133
|
+
})
|
|
134
|
+
.catch((err) => {
|
|
135
|
+
this.$logger.trace("Failed to get project size for %s, Error is:", p, err);
|
|
136
|
+
return -1;
|
|
137
|
+
})
|
|
138
|
+
.then((size) => {
|
|
139
|
+
if (size > 0 || size === -1) {
|
|
140
|
+
projects.set(p, size);
|
|
141
|
+
}
|
|
142
|
+
computed++;
|
|
143
|
+
updateProgress();
|
|
114
144
|
});
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
145
|
+
}, os.cpus().length);
|
|
146
|
+
spinner.clear();
|
|
147
|
+
spinner.stop();
|
|
148
|
+
this.$logger.clearScreen();
|
|
149
|
+
const totalSize = Array.from(projects.values())
|
|
150
|
+
.filter((s) => s > 0)
|
|
151
|
+
.reduce((a, b) => a + b, 0);
|
|
152
|
+
const pathsToClean = await this.$prompter.promptForChoice(`Found ${projects.size} cleanable project(s) with a total size of: ${color_1.color.green(bytesToHumanReadable(totalSize))}. Select projects to clean`, Array.from(projects.keys()).map((p) => {
|
|
153
|
+
const size = projects.get(p);
|
|
154
|
+
let description;
|
|
155
|
+
if (size === -1) {
|
|
156
|
+
description = " - could not get size";
|
|
125
157
|
}
|
|
126
158
|
else {
|
|
127
|
-
|
|
159
|
+
description = ` - ${bytesToHumanReadable(size)}`;
|
|
128
160
|
}
|
|
161
|
+
return {
|
|
162
|
+
title: `${p}${color_1.color.grey(description)}`,
|
|
163
|
+
value: p,
|
|
164
|
+
};
|
|
165
|
+
}), true, {
|
|
166
|
+
optionsPerPage: process.stdout.rows - 6,
|
|
129
167
|
});
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
168
|
+
this.$logger.clearScreen();
|
|
169
|
+
spinner.warn(`This will run "${color_1.color.yellow(`ns clean`)}" in all the selected projects and ${color_1.color.red.bold("delete files from your system")}!`);
|
|
170
|
+
spinner.warn(`This action cannot be undone!`);
|
|
171
|
+
let confirmed = await this.$prompter.confirm("Are you sure you want to clean the selected projects?");
|
|
172
|
+
if (!confirmed) {
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
spinner.info("Cleaning... This might take a while...");
|
|
176
|
+
let totalSizeCleaned = 0;
|
|
177
|
+
for (let i = 0; i < pathsToClean.length; i++) {
|
|
178
|
+
const currentPath = pathsToClean[i];
|
|
179
|
+
spinner.start(`Cleaning ${color_1.color.cyan(currentPath)}... ${i + 1}/${pathsToClean.length}`);
|
|
180
|
+
const ok = await this.$childProcess
|
|
181
|
+
.exec(`node ${this.$staticConfig.cliBinPath} clean ${this.$options.dryRun ? "--dry-run" : ""} --json --disable-analytics`, {
|
|
182
|
+
cwd: currentPath,
|
|
183
|
+
})
|
|
184
|
+
.then((res) => {
|
|
185
|
+
const cleanupRes = JSON.parse(res);
|
|
186
|
+
return cleanupRes.ok;
|
|
187
|
+
})
|
|
188
|
+
.catch((err) => {
|
|
189
|
+
this.$logger.trace('Failed to clean project "%s"', currentPath, err);
|
|
190
|
+
return false;
|
|
191
|
+
});
|
|
192
|
+
if (ok) {
|
|
193
|
+
const cleanedSize = projects.get(currentPath);
|
|
194
|
+
const cleanedSizeStr = color_1.color.grey(`- ${bytesToHumanReadable(cleanedSize)}`);
|
|
195
|
+
spinner.succeed(`Cleaned ${color_1.color.cyan(currentPath)} ${cleanedSizeStr}`);
|
|
196
|
+
totalSizeCleaned += cleanedSize;
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
spinner.fail(`Failed to clean ${color_1.color.cyan(currentPath)} - skipped`);
|
|
137
200
|
}
|
|
138
|
-
|
|
139
|
-
|
|
201
|
+
}
|
|
202
|
+
spinner.clear();
|
|
203
|
+
spinner.stop();
|
|
204
|
+
spinner.succeed(`Done! We've just freed up ${color_1.color.green(bytesToHumanReadable(totalSizeCleaned))}! Woohoo! 🎉`);
|
|
205
|
+
if (this.$options.dryRun) {
|
|
206
|
+
spinner.info('Note: the "--dry-run" flag was used, so no files were actually deleted.');
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
async getNSProjectPathsInDirectory(dir = process.cwd()) {
|
|
210
|
+
let nsDirs = [];
|
|
211
|
+
const getFiles = async (dir) => {
|
|
212
|
+
if (dir.includes("node_modules")) {
|
|
140
213
|
return;
|
|
141
214
|
}
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
let computed = 0;
|
|
146
|
-
const updateProgress = () => {
|
|
147
|
-
const current = color_1.color.grey(`${computed}/${paths.length}`);
|
|
148
|
-
spinner.start(`Gathering cleanable sizes. This may take a while... ${current}`);
|
|
149
|
-
};
|
|
150
|
-
// update the progress initially
|
|
151
|
-
updateProgress();
|
|
152
|
-
const projects = new Map();
|
|
153
|
-
yield promiseMap(paths, (p) => {
|
|
154
|
-
return this.$childProcess
|
|
155
|
-
.exec(`node ${this.$staticConfig.cliBinPath} clean --dry-run --json --disable-analytics`, {
|
|
156
|
-
cwd: p,
|
|
157
|
-
})
|
|
158
|
-
.then((res) => {
|
|
159
|
-
const paths = JSON.parse(res).stats;
|
|
160
|
-
return Object.values(paths).reduce((a, b) => a + b, 0);
|
|
161
|
-
})
|
|
162
|
-
.catch((err) => {
|
|
163
|
-
this.$logger.trace("Failed to get project size for %s, Error is:", p, err);
|
|
164
|
-
return -1;
|
|
165
|
-
})
|
|
166
|
-
.then((size) => {
|
|
167
|
-
if (size > 0 || size === -1) {
|
|
168
|
-
// only store size if it's larger than 0 or -1 (error while getting size)
|
|
169
|
-
projects.set(p, size);
|
|
170
|
-
}
|
|
171
|
-
// update the progress after each processed project
|
|
172
|
-
computed++;
|
|
173
|
-
updateProgress();
|
|
174
|
-
});
|
|
175
|
-
}, os.cpus().length);
|
|
176
|
-
spinner.clear();
|
|
177
|
-
spinner.stop();
|
|
178
|
-
this.$logger.clearScreen();
|
|
179
|
-
const totalSize = Array.from(projects.values())
|
|
180
|
-
.filter((s) => s > 0)
|
|
181
|
-
.reduce((a, b) => a + b, 0);
|
|
182
|
-
const pathsToClean = yield this.$prompter.promptForChoice(`Found ${projects.size} cleanable project(s) with a total size of: ${color_1.color.green(bytesToHumanReadable(totalSize))}. Select projects to clean`, Array.from(projects.keys()).map((p) => {
|
|
183
|
-
const size = projects.get(p);
|
|
184
|
-
let description;
|
|
185
|
-
if (size === -1) {
|
|
186
|
-
description = " - could not get size";
|
|
187
|
-
}
|
|
188
|
-
else {
|
|
189
|
-
description = ` - ${bytesToHumanReadable(size)}`;
|
|
190
|
-
}
|
|
191
|
-
return {
|
|
192
|
-
title: `${p}${color_1.color.grey(description)}`,
|
|
193
|
-
value: p,
|
|
194
|
-
};
|
|
195
|
-
}), true, {
|
|
196
|
-
optionsPerPage: process.stdout.rows - 6, // 6 lines are taken up by the instructions
|
|
215
|
+
const dirents = await (0, promises_1.readdir)(dir, { withFileTypes: true }).catch((err) => {
|
|
216
|
+
this.$logger.trace('Failed to read directory "%s". Error is:', dir, err);
|
|
217
|
+
return [];
|
|
197
218
|
});
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
if (!confirmed) {
|
|
219
|
+
const hasNSConfig = dirents.some((ent) => ent.name.includes("nativescript.config.ts") ||
|
|
220
|
+
ent.name.includes("nativescript.config.js"));
|
|
221
|
+
if (hasNSConfig) {
|
|
222
|
+
nsDirs.push(dir);
|
|
203
223
|
return;
|
|
204
224
|
}
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
spinner.start(`Cleaning ${color_1.color.cyan(currentPath)}... ${i + 1}/${pathsToClean.length}`);
|
|
210
|
-
const ok = yield this.$childProcess
|
|
211
|
-
.exec(`node ${this.$staticConfig.cliBinPath} clean ${this.$options.dryRun ? "--dry-run" : ""} --json --disable-analytics`, {
|
|
212
|
-
cwd: currentPath,
|
|
213
|
-
})
|
|
214
|
-
.then((res) => {
|
|
215
|
-
const cleanupRes = JSON.parse(res);
|
|
216
|
-
return cleanupRes.ok;
|
|
217
|
-
})
|
|
218
|
-
.catch((err) => {
|
|
219
|
-
this.$logger.trace('Failed to clean project "%s"', currentPath, err);
|
|
220
|
-
return false;
|
|
221
|
-
});
|
|
222
|
-
if (ok) {
|
|
223
|
-
const cleanedSize = projects.get(currentPath);
|
|
224
|
-
const cleanedSizeStr = color_1.color.grey(`- ${bytesToHumanReadable(cleanedSize)}`);
|
|
225
|
-
spinner.succeed(`Cleaned ${color_1.color.cyan(currentPath)} ${cleanedSizeStr}`);
|
|
226
|
-
totalSizeCleaned += cleanedSize;
|
|
227
|
-
}
|
|
228
|
-
else {
|
|
229
|
-
spinner.fail(`Failed to clean ${color_1.color.cyan(currentPath)} - skipped`);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
spinner.clear();
|
|
233
|
-
spinner.stop();
|
|
234
|
-
spinner.succeed(`Done! We've just freed up ${color_1.color.green(bytesToHumanReadable(totalSizeCleaned))}! Woohoo! 🎉`);
|
|
235
|
-
if (this.$options.dryRun) {
|
|
236
|
-
spinner.info('Note: the "--dry-run" flag was used, so no files were actually deleted.');
|
|
237
|
-
}
|
|
238
|
-
});
|
|
239
|
-
}
|
|
240
|
-
getNSProjectPathsInDirectory(dir = process.cwd()) {
|
|
241
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
242
|
-
let nsDirs = [];
|
|
243
|
-
const getFiles = (dir) => __awaiter(this, void 0, void 0, function* () {
|
|
244
|
-
if (dir.includes("node_modules")) {
|
|
245
|
-
// skip traversing node_modules
|
|
246
|
-
return;
|
|
225
|
+
await Promise.all(dirents.map((dirent) => {
|
|
226
|
+
const res = (0, path_1.resolve)(dir, dirent.name);
|
|
227
|
+
if (dirent.isDirectory()) {
|
|
228
|
+
return getFiles(res);
|
|
247
229
|
}
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
const hasNSConfig = dirents.some((ent) => ent.name.includes("nativescript.config.ts") ||
|
|
253
|
-
ent.name.includes("nativescript.config.js"));
|
|
254
|
-
if (hasNSConfig) {
|
|
255
|
-
nsDirs.push(dir);
|
|
256
|
-
// found a NativeScript project, stop traversing
|
|
257
|
-
return;
|
|
258
|
-
}
|
|
259
|
-
yield Promise.all(dirents.map((dirent) => {
|
|
260
|
-
const res = (0, path_1.resolve)(dir, dirent.name);
|
|
261
|
-
if (dirent.isDirectory()) {
|
|
262
|
-
return getFiles(res);
|
|
263
|
-
}
|
|
264
|
-
}));
|
|
265
|
-
});
|
|
266
|
-
yield getFiles(dir);
|
|
267
|
-
return nsDirs;
|
|
268
|
-
});
|
|
230
|
+
}));
|
|
231
|
+
};
|
|
232
|
+
await getFiles(dir);
|
|
233
|
+
return nsDirs;
|
|
269
234
|
}
|
|
270
235
|
}
|
|
271
236
|
exports.CleanCommand = CleanCommand;
|
|
272
237
|
yok_1.injector.registerCommand("clean", CleanCommand);
|
|
273
|
-
//# sourceMappingURL=clean.js.map
|
|
@@ -1,13 +1,4 @@
|
|
|
1
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
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.ValidatePlatformCommandBase = void 0;
|
|
13
4
|
class ValidatePlatformCommandBase {
|
|
@@ -17,25 +8,21 @@ class ValidatePlatformCommandBase {
|
|
|
17
8
|
this.$platformValidationService = $platformValidationService;
|
|
18
9
|
this.$projectData = $projectData;
|
|
19
10
|
}
|
|
20
|
-
canExecuteCommandBase(platform, options) {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
return result;
|
|
30
|
-
});
|
|
11
|
+
async canExecuteCommandBase(platform, options) {
|
|
12
|
+
options = options || {};
|
|
13
|
+
const validatePlatformOutput = await this.validatePlatformBase(platform, options.notConfiguredEnvOptions);
|
|
14
|
+
const canExecute = this.canExecuteCommand(validatePlatformOutput);
|
|
15
|
+
let result = canExecute;
|
|
16
|
+
if (canExecute && options.validateOptions) {
|
|
17
|
+
result = await this.$platformValidationService.validateOptions(this.$options.provision, this.$options.teamId, this.$projectData, platform);
|
|
18
|
+
}
|
|
19
|
+
return result;
|
|
31
20
|
}
|
|
32
|
-
validatePlatformBase(platform, notConfiguredEnvOptions) {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
return result;
|
|
38
|
-
});
|
|
21
|
+
async validatePlatformBase(platform, notConfiguredEnvOptions) {
|
|
22
|
+
const platformData = this.$platformsDataService.getPlatformData(platform, this.$projectData);
|
|
23
|
+
const platformProjectService = platformData.platformProjectService;
|
|
24
|
+
const result = await platformProjectService.validate(this.$projectData, this.$options, notConfiguredEnvOptions);
|
|
25
|
+
return result;
|
|
39
26
|
}
|
|
40
27
|
canExecuteCommand(validatePlatformOutput) {
|
|
41
28
|
return (validatePlatformOutput &&
|
|
@@ -44,4 +31,3 @@ class ValidatePlatformCommandBase {
|
|
|
44
31
|
}
|
|
45
32
|
}
|
|
46
33
|
exports.ValidatePlatformCommandBase = ValidatePlatformCommandBase;
|
|
47
|
-
//# sourceMappingURL=command-base.js.map
|
package/lib/commands/config.js
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
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
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.ConfigSetCommand = exports.ConfigGetCommand = exports.ConfigListCommand = void 0;
|
|
13
4
|
const yok_1 = require("../common/yok");
|
|
@@ -18,16 +9,14 @@ class ConfigListCommand {
|
|
|
18
9
|
this.$logger = $logger;
|
|
19
10
|
this.allowedParameters = [];
|
|
20
11
|
}
|
|
21
|
-
execute(args) {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}
|
|
30
|
-
});
|
|
12
|
+
async execute(args) {
|
|
13
|
+
try {
|
|
14
|
+
const config = this.$projectConfigService.readConfig();
|
|
15
|
+
this.$logger.info(this.getValueString(config));
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
this.$logger.info("Failed to read config. Error is: ", error);
|
|
19
|
+
}
|
|
31
20
|
}
|
|
32
21
|
getValueString(value, depth = 0) {
|
|
33
22
|
const indent = () => " ".repeat(depth);
|
|
@@ -36,7 +25,6 @@ class ConfigListCommand {
|
|
|
36
25
|
Object.keys(value)
|
|
37
26
|
.map((key) => {
|
|
38
27
|
return (color_1.color.green(`${indent()}${key}: `) +
|
|
39
|
-
// @ts-ignore
|
|
40
28
|
this.getValueString(value[key], depth + 1));
|
|
41
29
|
})
|
|
42
30
|
.join("\n"));
|
|
@@ -54,25 +42,20 @@ class ConfigGetCommand {
|
|
|
54
42
|
this.$errors = $errors;
|
|
55
43
|
this.allowedParameters = [];
|
|
56
44
|
}
|
|
57
|
-
execute(args) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
// ignore
|
|
66
|
-
}
|
|
67
|
-
});
|
|
45
|
+
async execute(args) {
|
|
46
|
+
try {
|
|
47
|
+
const [key] = args;
|
|
48
|
+
const current = this.$projectConfigService.getValue(key);
|
|
49
|
+
this.$logger.info(current);
|
|
50
|
+
}
|
|
51
|
+
catch (err) {
|
|
52
|
+
}
|
|
68
53
|
}
|
|
69
|
-
canExecute(args) {
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
return true;
|
|
75
|
-
});
|
|
54
|
+
async canExecute(args) {
|
|
55
|
+
if (!args[0]) {
|
|
56
|
+
this.$errors.failWithHelp("You must specify a key. Eg: ios.id");
|
|
57
|
+
}
|
|
58
|
+
return true;
|
|
76
59
|
}
|
|
77
60
|
}
|
|
78
61
|
exports.ConfigGetCommand = ConfigGetCommand;
|
|
@@ -83,45 +66,40 @@ class ConfigSetCommand {
|
|
|
83
66
|
this.$errors = $errors;
|
|
84
67
|
this.allowedParameters = [];
|
|
85
68
|
}
|
|
86
|
-
execute(args) {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
}
|
|
106
|
-
});
|
|
69
|
+
async execute(args) {
|
|
70
|
+
const [key, value] = args;
|
|
71
|
+
const current = this.$projectConfigService.getValue(key);
|
|
72
|
+
if (current && typeof current === "object") {
|
|
73
|
+
this.$errors.fail(`Unable to change object values. Please update individual values instead.\nEg: ns config set android.codeCache true`);
|
|
74
|
+
}
|
|
75
|
+
const convertedValue = this.getConvertedValue(value);
|
|
76
|
+
const existingKey = current !== undefined;
|
|
77
|
+
const keyDisplay = color_1.color.green(key);
|
|
78
|
+
const currentDisplay = color_1.color.yellow(current);
|
|
79
|
+
const updatedDisplay = color_1.color.cyan(convertedValue);
|
|
80
|
+
this.$logger.info(`${existingKey ? "Updating" : "Setting"} ${keyDisplay}${existingKey ? ` from ${currentDisplay} ` : " "}to ${updatedDisplay}`);
|
|
81
|
+
try {
|
|
82
|
+
await this.$projectConfigService.setValue(key, convertedValue);
|
|
83
|
+
this.$logger.info("Done");
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
this.$logger.info("Could not update conifg. Error is: ", error);
|
|
87
|
+
}
|
|
107
88
|
}
|
|
108
|
-
canExecute(args) {
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
return true;
|
|
117
|
-
});
|
|
89
|
+
async canExecute(args) {
|
|
90
|
+
if (!args[0]) {
|
|
91
|
+
this.$errors.failWithHelp("You must specify a key. Eg: ios.id");
|
|
92
|
+
}
|
|
93
|
+
if (!args[1]) {
|
|
94
|
+
this.$errors.failWithHelp("You must specify a value.");
|
|
95
|
+
}
|
|
96
|
+
return true;
|
|
118
97
|
}
|
|
119
98
|
getConvertedValue(v) {
|
|
120
99
|
try {
|
|
121
100
|
return JSON.parse(v);
|
|
122
101
|
}
|
|
123
102
|
catch (e) {
|
|
124
|
-
// just treat it as a string
|
|
125
103
|
return `${v}`;
|
|
126
104
|
}
|
|
127
105
|
}
|
|
@@ -130,4 +108,3 @@ exports.ConfigSetCommand = ConfigSetCommand;
|
|
|
130
108
|
yok_1.injector.registerCommand("config|*list", ConfigListCommand);
|
|
131
109
|
yok_1.injector.registerCommand("config|get", ConfigGetCommand);
|
|
132
110
|
yok_1.injector.registerCommand("config|set", ConfigSetCommand);
|
|
133
|
-
//# sourceMappingURL=config.js.map
|