@tramvai/cli 2.64.0 → 2.66.0
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/README.md +46 -38
- package/lib/api/analyze/providers/shared.js +1 -1
- package/lib/api/analyze/providers/shared.js.map +1 -1
- package/lib/api/benchmark/index.d.ts +1 -1
- package/lib/api/build/child-app.js +3 -2
- package/lib/api/build/child-app.js.map +1 -1
- package/lib/api/build/module.js +1 -2
- package/lib/api/build/module.js.map +1 -1
- package/lib/api/build/providers/shared.js +1 -1
- package/lib/api/build/providers/shared.js.map +1 -1
- package/lib/api/index.d.ts +6 -2
- package/lib/api/index.js +3 -3
- package/lib/api/index.js.map +1 -1
- package/lib/api/shared/types/withConfig.d.ts +3 -2
- package/lib/api/start/providers/application/server.js +11 -18
- package/lib/api/start/providers/application/server.js.map +1 -1
- package/lib/api/start/providers/application/shared.js +17 -25
- package/lib/api/start/providers/application/shared.js.map +1 -1
- package/lib/api/start/providers/child-app/shared.js +19 -25
- package/lib/api/start/providers/child-app/shared.js.map +1 -1
- package/lib/api/start/providers/module/shared.js +18 -24
- package/lib/api/start/providers/module/shared.js.map +1 -1
- package/lib/api/start/utils/banner.js +3 -2
- package/lib/api/start/utils/banner.js.map +1 -1
- package/lib/api/start/utils/listenServer.js +3 -2
- package/lib/api/start/utils/listenServer.js.map +1 -1
- package/lib/api/start/utils/tips/tips.js +10 -8
- package/lib/api/start/utils/tips/tips.js.map +1 -1
- package/lib/api/start-prod/providers/application.js +6 -5
- package/lib/api/start-prod/providers/application.js.map +1 -1
- package/lib/api/start-prod/providers/child-app.js +3 -2
- package/lib/api/start-prod/providers/child-app.js.map +1 -1
- package/lib/api/start-prod/providers/shared.js +5 -13
- package/lib/api/start-prod/providers/shared.js.map +1 -1
- package/lib/builder/webpack/devServer/client.js +18 -15
- package/lib/builder/webpack/devServer/client.js.map +1 -1
- package/lib/builder/webpack/devServer/notifier.d.ts +2 -2
- package/lib/builder/webpack/devServer/notifier.js +3 -3
- package/lib/builder/webpack/devServer/notifier.js.map +1 -1
- package/lib/builder/webpack/devServer/pool/process/pool.js +3 -2
- package/lib/builder/webpack/devServer/pool/process/pool.js.map +1 -1
- package/lib/builder/webpack/devServer/pool/thread/pool.js +7 -0
- package/lib/builder/webpack/devServer/pool/thread/pool.js.map +1 -1
- package/lib/builder/webpack/devServer/server.js +7 -2
- package/lib/builder/webpack/devServer/server.js.map +1 -1
- package/lib/builder/webpack/providers/analyze/shared.js +3 -3
- package/lib/builder/webpack/providers/analyze/shared.js.map +1 -1
- package/lib/builder/webpack/providers/build/application/server.js.map +1 -1
- package/lib/builder/webpack/providers/build/client.js +3 -3
- package/lib/builder/webpack/providers/build/client.js.map +1 -1
- package/lib/builder/webpack/providers/build/server.js +1 -1
- package/lib/builder/webpack/providers/build/server.js.map +1 -1
- package/lib/builder/webpack/tokens.d.ts +313 -3
- package/lib/builder/webpack/tokens.js.map +1 -1
- package/lib/builder/webpack/utils/copyBuildFile.d.ts +2 -1
- package/lib/builder/webpack/utils/copyBuildFile.js +2 -3
- package/lib/builder/webpack/utils/copyBuildFile.js.map +1 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.d.ts +2 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.js +1 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.js.map +1 -1
- package/lib/cli/CLI.d.ts +2 -2
- package/lib/cli/CLI.js +2 -2
- package/lib/cli/CLI.js.map +1 -1
- package/lib/cli/index.js.map +1 -1
- package/lib/commands/analyze/command.d.ts +1 -1
- package/lib/commands/analyze/command.js.map +1 -1
- package/lib/commands/benchmark/command.d.ts +1 -1
- package/lib/commands/benchmark/command.js.map +1 -1
- package/lib/commands/build/command.d.ts +1 -1
- package/lib/commands/build/command.js.map +1 -1
- package/lib/commands/new/new.js +0 -1
- package/lib/commands/new/new.js.map +1 -1
- package/lib/commands/new/questions/packageManager.d.ts +1 -1
- package/lib/commands/new/questions/packageManager.js.map +1 -1
- package/lib/commands/new/questions/template.d.ts +1 -1
- package/lib/commands/new/questions/template.js.map +1 -1
- package/lib/commands/new/questions/testingFramework.d.ts +1 -1
- package/lib/commands/new/questions/testingFramework.js.map +1 -1
- package/lib/commands/new/questions/type.d.ts +1 -1
- package/lib/commands/new/questions/type.js.map +1 -1
- package/lib/commands/new/steps/initializationGit.d.ts +1 -1
- package/lib/commands/new/steps/initializationGit.js.map +1 -1
- package/lib/commands/start/command.d.ts +1 -1
- package/lib/commands/start/command.js.map +1 -1
- package/lib/commands/start-prod/command.d.ts +1 -1
- package/lib/commands/start-prod/command.js.map +1 -1
- package/lib/commands/static/application.js +4 -4
- package/lib/commands/static/application.js.map +1 -1
- package/lib/commands/static/command.d.ts +1 -1
- package/lib/commands/static/command.js.map +1 -1
- package/lib/commands/static/generate.js +2 -2
- package/lib/commands/static/generate.js.map +1 -1
- package/lib/commands/static/server.d.ts +2 -1
- package/lib/commands/static/server.js +1 -1
- package/lib/commands/static/server.js.map +1 -1
- package/lib/commands/static/staticServer.d.ts +2 -1
- package/lib/commands/static/staticServer.js +1 -1
- package/lib/commands/static/staticServer.js.map +1 -1
- package/lib/commands/update/updatePackageJson.js +3 -0
- package/lib/commands/update/updatePackageJson.js.map +1 -1
- package/lib/config/configManager.d.ts +15 -73
- package/lib/config/configManager.js +64 -92
- package/lib/config/configManager.js.map +1 -1
- package/lib/config/showConfig.d.ts +1 -1
- package/lib/config/showConfig.js +1 -1
- package/lib/config/showConfig.js.map +1 -1
- package/lib/config/validate.d.ts +5 -4
- package/lib/config/validate.js +2 -9
- package/lib/config/validate.js.map +1 -1
- package/lib/di/tokens/config.d.ts +106 -1
- package/lib/di/tokens/config.js.map +1 -1
- package/lib/external/config.d.ts +2 -2
- package/lib/library/babel/index.js +1 -0
- package/lib/library/babel/index.js.map +1 -1
- package/lib/library/swc/index.js +1 -1
- package/lib/library/swc/index.js.map +1 -1
- package/lib/library/webpack/application/client/common.js +6 -4
- package/lib/library/webpack/application/client/common.js.map +1 -1
- package/lib/library/webpack/application/client/dev.js +9 -8
- package/lib/library/webpack/application/client/dev.js.map +1 -1
- package/lib/library/webpack/application/client/prod/optimization/splitChunks.js +40 -39
- package/lib/library/webpack/application/client/prod/optimization/splitChunks.js.map +1 -1
- package/lib/library/webpack/application/client/prod.js +3 -4
- package/lib/library/webpack/application/client/prod.js.map +1 -1
- package/lib/library/webpack/application/server/common.js +5 -5
- package/lib/library/webpack/application/server/common.js.map +1 -1
- package/lib/library/webpack/application/server/dev.js +3 -6
- package/lib/library/webpack/application/server/dev.js.map +1 -1
- package/lib/library/webpack/application/server/prod.js +3 -4
- package/lib/library/webpack/application/server/prod.js.map +1 -1
- package/lib/library/webpack/blocks/apiResolve.js +1 -1
- package/lib/library/webpack/blocks/apiResolve.js.map +1 -1
- package/lib/library/webpack/blocks/configResolve.js +2 -2
- package/lib/library/webpack/blocks/configResolve.js.map +1 -1
- package/lib/library/webpack/blocks/configToEnv.js +5 -2
- package/lib/library/webpack/blocks/configToEnv.js.map +1 -1
- package/lib/library/webpack/blocks/css.d.ts +3 -1
- package/lib/library/webpack/blocks/css.js +17 -6
- package/lib/library/webpack/blocks/css.js.map +1 -1
- package/lib/library/webpack/blocks/extractCssPlugin.d.ts +4 -3
- package/lib/library/webpack/blocks/extractCssPlugin.js +4 -6
- package/lib/library/webpack/blocks/extractCssPlugin.js.map +1 -1
- package/lib/library/webpack/blocks/filesClient.d.ts +3 -2
- package/lib/library/webpack/blocks/filesClient.js +7 -7
- package/lib/library/webpack/blocks/filesClient.js.map +1 -1
- package/lib/library/webpack/blocks/filesServer.d.ts +2 -1
- package/lib/library/webpack/blocks/filesServer.js +3 -3
- package/lib/library/webpack/blocks/filesServer.js.map +1 -1
- package/lib/library/webpack/blocks/js.d.ts +2 -1
- package/lib/library/webpack/blocks/js.js +1 -1
- package/lib/library/webpack/blocks/js.js.map +1 -1
- package/lib/library/webpack/blocks/nodeClient.d.ts +2 -1
- package/lib/library/webpack/blocks/nodeClient.js +2 -2
- package/lib/library/webpack/blocks/nodeClient.js.map +1 -1
- package/lib/library/webpack/blocks/optimize.d.ts +2 -1
- package/lib/library/webpack/blocks/optimize.js +3 -3
- package/lib/library/webpack/blocks/optimize.js.map +1 -1
- package/lib/library/webpack/blocks/pagesResolve.js +1 -1
- package/lib/library/webpack/blocks/pagesResolve.js.map +1 -1
- package/lib/library/webpack/blocks/postcssAssets.d.ts +2 -1
- package/lib/library/webpack/blocks/postcssAssets.js +2 -2
- package/lib/library/webpack/blocks/postcssAssets.js.map +1 -1
- package/lib/library/webpack/blocks/serverInline.d.ts +2 -1
- package/lib/library/webpack/blocks/serverInline.js.map +1 -1
- package/lib/library/webpack/blocks/ts.d.ts +2 -1
- package/lib/library/webpack/blocks/ts.js.map +1 -1
- package/lib/library/webpack/child-app/client/common.d.ts +2 -2
- package/lib/library/webpack/child-app/client/common.js +1 -1
- package/lib/library/webpack/child-app/client/common.js.map +1 -1
- package/lib/library/webpack/child-app/client/dev.d.ts +2 -2
- package/lib/library/webpack/child-app/client/dev.js +6 -5
- package/lib/library/webpack/child-app/client/dev.js.map +1 -1
- package/lib/library/webpack/child-app/client/prod.d.ts +2 -2
- package/lib/library/webpack/child-app/client/prod.js.map +1 -1
- package/lib/library/webpack/child-app/common.d.ts +2 -2
- package/lib/library/webpack/child-app/common.js.map +1 -1
- package/lib/library/webpack/child-app/server/common.d.ts +2 -2
- package/lib/library/webpack/child-app/server/common.js +1 -1
- package/lib/library/webpack/child-app/server/common.js.map +1 -1
- package/lib/library/webpack/child-app/server/dev.d.ts +2 -2
- package/lib/library/webpack/child-app/server/dev.js.map +1 -1
- package/lib/library/webpack/child-app/server/prod.d.ts +2 -2
- package/lib/library/webpack/child-app/server/prod.js.map +1 -1
- package/lib/library/webpack/common/client/prod.d.ts +2 -1
- package/lib/library/webpack/common/client/prod.js +4 -5
- package/lib/library/webpack/common/client/prod.js.map +1 -1
- package/lib/library/webpack/common/main.d.ts +2 -1
- package/lib/library/webpack/common/main.js +3 -3
- package/lib/library/webpack/common/main.js.map +1 -1
- package/lib/library/webpack/common/server/prod.d.ts +2 -1
- package/lib/library/webpack/common/server/prod.js +4 -5
- package/lib/library/webpack/common/server/prod.js.map +1 -1
- package/lib/library/webpack/index.js +1 -2
- package/lib/library/webpack/index.js.map +1 -1
- package/lib/library/webpack/loaders/image-loader/index.d.ts +2 -1
- package/lib/library/webpack/loaders/image-loader/index.js.map +1 -1
- package/lib/library/webpack/loaders/pagesResolve.d.ts +10 -1
- package/lib/library/webpack/loaders/pagesResolve.js +4 -3
- package/lib/library/webpack/loaders/pagesResolve.js.map +1 -1
- package/lib/library/webpack/loaders/replaceContent.d.ts +6 -1
- package/lib/library/webpack/loaders/replaceContent.js +4 -3
- package/lib/library/webpack/loaders/replaceContent.js.map +1 -1
- package/lib/library/webpack/module/client/common.js +1 -1
- package/lib/library/webpack/module/client/common.js.map +1 -1
- package/lib/library/webpack/module/externals.d.ts +1 -1
- package/lib/library/webpack/module/externals.js.map +1 -1
- package/lib/library/webpack/module/resolveExternal.d.ts +1 -1
- package/lib/library/webpack/module/resolveExternal.js.map +1 -1
- package/lib/library/webpack/module/server/common.js +1 -1
- package/lib/library/webpack/module/server/common.js.map +1 -1
- package/lib/library/webpack/plugins/LazyModuleInitialization.d.ts +2 -2
- package/lib/library/webpack/plugins/LazyModuleInitialization.js +1 -0
- package/lib/library/webpack/plugins/LazyModuleInitialization.js.map +1 -1
- package/lib/library/webpack/plugins/WebpackBar/utils/index.d.ts +7 -7
- package/lib/library/webpack/plugins/WebpackBar/utils/index.js.map +1 -1
- package/lib/library/webpack/plugins/WebpackBar/utils/webpack.d.ts +2 -2
- package/lib/library/webpack/plugins/WebpackBar/utils/webpack.js.map +1 -1
- package/lib/library/webpack/types/webpack.d.ts +2 -2
- package/lib/library/webpack/utils/files.d.ts +4 -3
- package/lib/library/webpack/utils/files.js +2 -2
- package/lib/library/webpack/utils/files.js.map +1 -1
- package/lib/library/webpack/utils/transpiler.d.ts +3 -2
- package/lib/library/webpack/utils/transpiler.js +2 -2
- package/lib/library/webpack/utils/transpiler.js.map +1 -1
- package/lib/library/webpack/utils/workersPool.d.ts +3 -6
- package/lib/library/webpack/utils/workersPool.js +1 -1
- package/lib/library/webpack/utils/workersPool.js.map +1 -1
- package/lib/models/config.d.ts +2 -3
- package/lib/models/config.js +32 -3
- package/lib/models/config.js.map +1 -1
- package/lib/schema/ConfigSchema.d.ts +13 -4
- package/lib/schema/autogeneratedSchema.json +1808 -2074
- package/lib/typings/configEntry/application.d.ts +81 -86
- package/lib/typings/configEntry/child-app.d.ts +10 -29
- package/lib/typings/configEntry/cli.d.ts +254 -0
- package/lib/typings/configEntry/{CheckAsyncTsConfig.js → cli.js} +1 -1
- package/lib/typings/configEntry/cli.js.map +1 -0
- package/lib/typings/configEntry/common.d.ts +16 -276
- package/lib/typings/configEntry/common.js +15 -0
- package/lib/typings/configEntry/common.js.map +1 -1
- package/lib/typings/configEntry/module.d.ts +10 -29
- package/lib/typings/configEntry/package.d.ts +2 -1
- package/lib/ui/commander.js +1 -1
- package/lib/ui/commander.js.map +1 -1
- package/lib/utils/applyTemplate.js.map +1 -1
- package/lib/utils/detectPortSync.d.ts +1 -0
- package/lib/utils/detectPortSync.js +10 -0
- package/lib/utils/detectPortSync.js.map +1 -0
- package/lib/utils/safeRequire.js +5 -1
- package/lib/utils/safeRequire.js.map +1 -1
- package/lib/utils/webpackBuild.d.ts +2 -1
- package/lib/utils/webpackBuild.js +3 -3
- package/lib/utils/webpackBuild.js.map +1 -1
- package/package.json +14 -9
- package/schema.json +1802 -2068
- package/src/api/analyze/providers/shared.ts +3 -2
- package/src/api/benchmark/__integration__/__fixtures__/tramvai.json +1 -8
- package/src/api/benchmark/index.ts +1 -1
- package/src/api/build/__integration__/__fixtures__/app/App.tsx +0 -1
- package/src/api/build/__integration__/__fixtures__/app/index.tsx +14 -8
- package/src/api/build/__integration__/__fixtures__/app/server.tsx +0 -1
- package/src/api/build/__integration__/__fixtures__/tramvai.json +1 -10
- package/src/api/build/__integration__/build.test.ts +4 -13
- package/src/api/build/child-app.ts +4 -4
- package/src/api/build/module.ts +2 -4
- package/src/api/build/providers/shared.ts +2 -2
- package/src/api/index.ts +6 -2
- package/src/api/shared/types/withConfig.ts +5 -6
- package/src/api/start/__integration__/__fixtures__/app/index.tsx +11 -7
- package/src/api/start/__integration__/__fixtures__/tramvai.json +6 -17
- package/src/api/start/__integration__/start.test.ts +38 -13
- package/src/api/start/providers/application/server.ts +14 -23
- package/src/api/start/providers/application/shared.ts +26 -52
- package/src/api/start/providers/child-app/shared.ts +23 -46
- package/src/api/start/providers/module/shared.ts +24 -47
- package/src/api/start/utils/banner.ts +3 -2
- package/src/api/start/utils/listenServer.ts +2 -1
- package/src/api/start/utils/tips/tips.ts +11 -8
- package/src/api/start-prod/providers/application.ts +19 -19
- package/src/api/start-prod/providers/child-app.ts +7 -8
- package/src/api/start-prod/providers/shared.ts +6 -20
- package/src/builder/webpack/devServer/client.ts +22 -15
- package/src/builder/webpack/devServer/notifier.ts +6 -6
- package/src/builder/webpack/devServer/pool/process/pool.ts +3 -3
- package/src/builder/webpack/devServer/pool/thread/pool.ts +7 -0
- package/src/builder/webpack/devServer/server.ts +13 -6
- package/src/builder/webpack/providers/analyze/shared.ts +3 -2
- package/src/builder/webpack/providers/build/application/server.ts +5 -1
- package/src/builder/webpack/providers/build/client.ts +2 -2
- package/src/builder/webpack/providers/build/server.ts +1 -1
- package/src/builder/webpack/tokens.ts +4 -3
- package/src/builder/webpack/utils/copyBuildFile.ts +4 -5
- package/src/builder/webpack/utils/copyStatsJsonFile.ts +5 -2
- package/src/cli/CLI.ts +6 -6
- package/src/cli/index.ts +1 -1
- package/src/commands/analyze/command.ts +1 -1
- package/src/commands/benchmark/command.ts +1 -1
- package/src/commands/build/command.ts +2 -2
- package/src/commands/new/new.ts +0 -1
- package/src/commands/new/questions/packageManager.ts +1 -1
- package/src/commands/new/questions/template.ts +1 -1
- package/src/commands/new/questions/testingFramework.ts +1 -1
- package/src/commands/new/questions/type.ts +1 -1
- package/src/commands/new/steps/initializationGit.ts +1 -1
- package/src/commands/new/templates/app/monorepo/tramvai.json.hbs +6 -32
- package/src/commands/new/templates/app/multirepo/tramvai.json.hbs +6 -23
- package/src/commands/new/templates/child-app/monorepo/tramvai.json.hbs +3 -18
- package/src/commands/new/templates/child-app/multirepo/tramvai.json.hbs +3 -9
- package/src/commands/start/command.ts +2 -2
- package/src/commands/start-prod/command.ts +2 -2
- package/src/commands/static/application.ts +5 -14
- package/src/commands/static/command.ts +1 -1
- package/src/commands/static/generate.ts +2 -2
- package/src/commands/static/server.ts +5 -2
- package/src/commands/static/staticServer.ts +6 -3
- package/src/commands/update/updatePackageJson.ts +6 -2
- package/src/config/configManager.spec.ts +49 -0
- package/src/config/configManager.ts +129 -197
- package/src/config/showConfig.ts +2 -2
- package/src/config/validate.ts +14 -25
- package/src/di/tokens/config.ts +2 -1
- package/src/library/babel/index.ts +1 -0
- package/src/library/swc/__integration__/swc.build.test.ts +3 -21
- package/src/library/swc/__integration__/swc.start.test.ts +3 -21
- package/src/library/swc/index.ts +1 -1
- package/src/library/webpack/application/client/common.ts +7 -7
- package/src/library/webpack/application/client/dev.ts +9 -9
- package/src/library/webpack/application/client/prod/optimization/splitChunks.ts +43 -44
- package/src/library/webpack/application/client/prod.ts +3 -5
- package/src/library/webpack/application/server/common.ts +5 -8
- package/src/library/webpack/application/server/dev.ts +5 -6
- package/src/library/webpack/application/server/prod.ts +3 -9
- package/src/library/webpack/blocks/apiResolve.ts +1 -1
- package/src/library/webpack/blocks/configResolve.ts +2 -2
- package/src/library/webpack/blocks/configToEnv.ts +5 -2
- package/src/library/webpack/blocks/css.ts +26 -17
- package/src/library/webpack/blocks/extractCssPlugin.ts +11 -10
- package/src/library/webpack/blocks/filesClient.ts +52 -50
- package/src/library/webpack/blocks/filesServer.ts +4 -3
- package/src/library/webpack/blocks/js.ts +3 -2
- package/src/library/webpack/blocks/nodeClient.ts +4 -3
- package/src/library/webpack/blocks/optimize.ts +5 -6
- package/src/library/webpack/blocks/pagesResolve.ts +1 -1
- package/src/library/webpack/blocks/postcssAssets.ts +6 -7
- package/src/library/webpack/blocks/serverInline.ts +2 -1
- package/src/library/webpack/blocks/ts.ts +2 -1
- package/src/library/webpack/child-app/client/common.ts +3 -3
- package/src/library/webpack/child-app/client/dev.ts +8 -8
- package/src/library/webpack/child-app/client/prod.ts +2 -2
- package/src/library/webpack/child-app/common.ts +2 -2
- package/src/library/webpack/child-app/server/common.ts +3 -3
- package/src/library/webpack/child-app/server/dev.ts +2 -2
- package/src/library/webpack/child-app/server/prod.ts +2 -2
- package/src/library/webpack/common/client/prod.ts +10 -6
- package/src/library/webpack/common/main.ts +9 -4
- package/src/library/webpack/common/server/prod.ts +10 -6
- package/src/library/webpack/index.ts +2 -3
- package/src/library/webpack/loaders/image-loader/index.ts +2 -1
- package/src/library/webpack/loaders/pagesResolve.ts +17 -5
- package/src/library/webpack/loaders/replaceContent.ts +11 -2
- package/src/library/webpack/module/client/common.ts +1 -1
- package/src/library/webpack/module/externals.ts +1 -1
- package/src/library/webpack/module/resolveExternal.ts +1 -1
- package/src/library/webpack/module/server/common.ts +1 -1
- package/src/library/webpack/plugins/LazyModuleInitialization.ts +6 -1
- package/src/library/webpack/plugins/WebpackBar/utils/index.ts +8 -8
- package/src/library/webpack/plugins/WebpackBar/utils/webpack.ts +1 -1
- package/src/library/webpack/types/webpack.ts +2 -2
- package/src/library/webpack/utils/files.ts +4 -3
- package/src/library/webpack/utils/transpiler.ts +6 -11
- package/src/library/webpack/utils/workersPool.ts +6 -9
- package/src/models/config.spec.ts +352 -0
- package/src/models/config.ts +41 -9
- package/src/schema/ConfigSchema.ts +15 -4
- package/src/schema/autogeneratedSchema.json +1808 -2074
- package/src/schema/tramvai.spec.ts +89 -184
- package/src/typings/configEntry/application.ts +85 -87
- package/src/typings/configEntry/child-app.ts +10 -30
- package/src/typings/configEntry/cli.ts +271 -0
- package/src/typings/configEntry/common.ts +26 -278
- package/src/typings/configEntry/module.ts +11 -30
- package/src/typings/configEntry/package.ts +3 -1
- package/src/ui/commander.ts +1 -1
- package/src/utils/applyTemplate.ts +2 -2
- package/src/utils/detectPortSync.ts +7 -0
- package/src/utils/safeRequire.ts +6 -1
- package/src/utils/webpackBuild.ts +4 -3
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.d.ts +0 -37
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.js +0 -241
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.js.map +0 -1
- package/lib/library/webpack/plugins/DedupePlugin/index.d.ts +0 -1
- package/lib/library/webpack/plugins/DedupePlugin/index.js +0 -6
- package/lib/library/webpack/plugins/DedupePlugin/index.js.map +0 -1
- package/lib/typings/configEntry/CheckAsyncTsConfig.d.ts +0 -13
- package/lib/typings/configEntry/CheckAsyncTsConfig.js.map +0 -1
- package/src/library/webpack/plugins/DedupePlugin/DedupePlugin.spec.ts +0 -95
- package/src/library/webpack/plugins/DedupePlugin/DedupePlugin.ts +0 -307
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/node_modules/package-esm-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/node_modules/package-esm-dep/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/node_modules/package-esm-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/node_modules/package-esm-dep/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/package-lock.json +0 -0
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/package.json +0 -14
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/src/index.js +0 -9
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/tramvai.json +0 -67
- package/src/library/webpack/plugins/DedupePlugin/__integration__/DedupePlugin.test.ts +0 -90
- package/src/library/webpack/plugins/DedupePlugin/index.ts +0 -1
- package/src/typings/configEntry/CheckAsyncTsConfig.ts +0 -15
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Provider } from '@tinkoff/dippy';
|
|
2
|
+
import { provide } from '@tinkoff/dippy';
|
|
2
3
|
import { CLOSE_HANDLER_TOKEN, INIT_HANDLER_TOKEN } from '../../tokens';
|
|
3
4
|
import {
|
|
4
5
|
CONFIG_MANAGER_TOKEN,
|
|
@@ -7,74 +8,50 @@ import {
|
|
|
7
8
|
STATIC_SERVER_TOKEN,
|
|
8
9
|
} from '../../../../di/tokens';
|
|
9
10
|
import type { ChildAppConfigEntry } from '../../../../typings/configEntry/child-app';
|
|
10
|
-
import type { Params } from '../../index';
|
|
11
|
-
import { ConfigManager } from '../../../../config/configManager';
|
|
12
11
|
import { closeWorkerPoolTranspiler } from '../../../../library/webpack/utils/workersPool';
|
|
13
12
|
import { stopServer } from '../../utils/stopServer';
|
|
14
13
|
import { createServer } from '../../utils/createServer';
|
|
15
14
|
import { listenServer } from '../../utils/listenServer';
|
|
15
|
+
import { createConfigManager, DEFAULT_STATIC_MODULE_PORT } from '../../../../config/configManager';
|
|
16
|
+
import { detectPortSync } from '../../../../utils/detectPortSync';
|
|
16
17
|
|
|
17
18
|
export const sharedProviders: readonly Provider[] = [
|
|
18
|
-
{
|
|
19
|
+
provide({
|
|
19
20
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
|
-
useFactory: ({
|
|
21
|
-
configEntry,
|
|
22
|
-
parameters,
|
|
23
|
-
}: {
|
|
24
|
-
configEntry: ChildAppConfigEntry;
|
|
25
|
-
parameters: Params;
|
|
26
|
-
}) => {
|
|
27
|
-
return new ConfigManager(configEntry, {
|
|
21
|
+
useFactory: ({ configEntry, parameters }) =>
|
|
22
|
+
createConfigManager(configEntry as ChildAppConfigEntry, {
|
|
28
23
|
...parameters,
|
|
29
24
|
env: 'development',
|
|
30
|
-
port: parameters.port ??
|
|
31
|
-
|
|
32
|
-
});
|
|
33
|
-
},
|
|
25
|
+
port: detectPortSync(parameters.port ?? DEFAULT_STATIC_MODULE_PORT),
|
|
26
|
+
}),
|
|
34
27
|
deps: {
|
|
35
28
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
36
29
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
37
30
|
},
|
|
38
|
-
},
|
|
39
|
-
{
|
|
31
|
+
}),
|
|
32
|
+
provide({
|
|
40
33
|
provide: STATIC_SERVER_TOKEN,
|
|
41
34
|
useFactory: createServer,
|
|
42
|
-
},
|
|
43
|
-
{
|
|
35
|
+
}),
|
|
36
|
+
provide({
|
|
44
37
|
provide: INIT_HANDLER_TOKEN,
|
|
45
38
|
multi: true,
|
|
46
|
-
useFactory: ({
|
|
47
|
-
staticServer,
|
|
48
|
-
parameters,
|
|
49
|
-
}: {
|
|
50
|
-
staticServer: typeof STATIC_SERVER_TOKEN;
|
|
51
|
-
parameters: Params;
|
|
52
|
-
}) => {
|
|
39
|
+
useFactory: ({ staticServer, configManager }) => {
|
|
53
40
|
return async function staticServerListen() {
|
|
54
|
-
const { host
|
|
55
|
-
|
|
56
|
-
try {
|
|
57
|
-
await listenServer(staticServer, host, port);
|
|
58
|
-
} catch (error) {
|
|
59
|
-
if ((error as any).code === 'EADDRINUSE') {
|
|
60
|
-
throw new Error(
|
|
61
|
-
`Address '${host}:${port}' in use, either release this port or use options --port --host`
|
|
62
|
-
);
|
|
63
|
-
}
|
|
41
|
+
const { host, port } = configManager;
|
|
64
42
|
|
|
65
|
-
|
|
66
|
-
}
|
|
43
|
+
await listenServer(staticServer, host, port);
|
|
67
44
|
};
|
|
68
45
|
},
|
|
69
46
|
deps: {
|
|
70
47
|
staticServer: STATIC_SERVER_TOKEN,
|
|
71
|
-
|
|
48
|
+
configManager: CONFIG_MANAGER_TOKEN,
|
|
72
49
|
},
|
|
73
|
-
},
|
|
74
|
-
{
|
|
50
|
+
}),
|
|
51
|
+
provide({
|
|
75
52
|
provide: CLOSE_HANDLER_TOKEN,
|
|
76
53
|
multi: true,
|
|
77
|
-
useFactory: ({ staticServer }
|
|
54
|
+
useFactory: ({ staticServer }) => {
|
|
78
55
|
return () => {
|
|
79
56
|
return stopServer(staticServer);
|
|
80
57
|
};
|
|
@@ -82,11 +59,11 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
82
59
|
deps: {
|
|
83
60
|
staticServer: STATIC_SERVER_TOKEN,
|
|
84
61
|
},
|
|
85
|
-
},
|
|
86
|
-
{
|
|
62
|
+
}),
|
|
63
|
+
provide({
|
|
87
64
|
provide: CLOSE_HANDLER_TOKEN,
|
|
88
65
|
multi: true,
|
|
89
|
-
useFactory: ({ configManager }
|
|
66
|
+
useFactory: ({ configManager }) => {
|
|
90
67
|
return async () => {
|
|
91
68
|
await closeWorkerPoolTranspiler(configManager);
|
|
92
69
|
};
|
|
@@ -94,5 +71,5 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
94
71
|
deps: {
|
|
95
72
|
configManager: CONFIG_MANAGER_TOKEN,
|
|
96
73
|
},
|
|
97
|
-
},
|
|
74
|
+
}),
|
|
98
75
|
] as const;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Provider } from '@tinkoff/dippy';
|
|
2
|
+
import { provide } from '@tinkoff/dippy';
|
|
2
3
|
import { CLOSE_HANDLER_TOKEN, INIT_HANDLER_TOKEN } from '../../tokens';
|
|
3
4
|
import {
|
|
4
5
|
CONFIG_MANAGER_TOKEN,
|
|
@@ -6,75 +7,51 @@ import {
|
|
|
6
7
|
COMMAND_PARAMETERS_TOKEN,
|
|
7
8
|
STATIC_SERVER_TOKEN,
|
|
8
9
|
} from '../../../../di/tokens';
|
|
9
|
-
import
|
|
10
|
-
import type { Params } from '../../index';
|
|
11
|
-
import { ConfigManager } from '../../../../config/configManager';
|
|
10
|
+
import { createConfigManager, DEFAULT_STATIC_MODULE_PORT } from '../../../../config/configManager';
|
|
12
11
|
import { closeWorkerPoolTranspiler } from '../../../../library/webpack/utils/workersPool';
|
|
13
12
|
import { stopServer } from '../../utils/stopServer';
|
|
14
13
|
import { createServer } from '../../utils/createServer';
|
|
15
14
|
import { listenServer } from '../../utils/listenServer';
|
|
15
|
+
import { detectPortSync } from '../../../../utils/detectPortSync';
|
|
16
|
+
import type { ModuleConfigEntry } from '../../../../typings/configEntry/module';
|
|
16
17
|
|
|
17
18
|
export const sharedProviders: readonly Provider[] = [
|
|
18
|
-
{
|
|
19
|
+
provide({
|
|
19
20
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
|
-
useFactory: ({
|
|
21
|
-
configEntry,
|
|
22
|
-
parameters,
|
|
23
|
-
}: {
|
|
24
|
-
configEntry: ModuleConfigEntry;
|
|
25
|
-
parameters: Params;
|
|
26
|
-
}) => {
|
|
27
|
-
return new ConfigManager(configEntry, {
|
|
21
|
+
useFactory: ({ configEntry, parameters }) =>
|
|
22
|
+
createConfigManager(configEntry as ModuleConfigEntry, {
|
|
28
23
|
...parameters,
|
|
29
24
|
env: 'development',
|
|
30
|
-
port: parameters.port ??
|
|
31
|
-
|
|
32
|
-
});
|
|
33
|
-
},
|
|
25
|
+
port: detectPortSync(parameters.port ?? DEFAULT_STATIC_MODULE_PORT),
|
|
26
|
+
}),
|
|
34
27
|
deps: {
|
|
35
28
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
36
29
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
37
30
|
},
|
|
38
|
-
},
|
|
39
|
-
{
|
|
31
|
+
}),
|
|
32
|
+
provide({
|
|
40
33
|
provide: STATIC_SERVER_TOKEN,
|
|
41
34
|
useFactory: createServer,
|
|
42
|
-
},
|
|
43
|
-
{
|
|
35
|
+
}),
|
|
36
|
+
provide({
|
|
44
37
|
provide: INIT_HANDLER_TOKEN,
|
|
45
38
|
multi: true,
|
|
46
|
-
useFactory: ({
|
|
47
|
-
staticServer,
|
|
48
|
-
parameters,
|
|
49
|
-
}: {
|
|
50
|
-
staticServer: typeof STATIC_SERVER_TOKEN;
|
|
51
|
-
parameters: Params;
|
|
52
|
-
}) => {
|
|
39
|
+
useFactory: ({ staticServer, configManager }) => {
|
|
53
40
|
return async function staticServerListen() {
|
|
54
|
-
const { host
|
|
41
|
+
const { host, port } = configManager;
|
|
55
42
|
|
|
56
|
-
|
|
57
|
-
await listenServer(staticServer, host, port);
|
|
58
|
-
} catch (error) {
|
|
59
|
-
if ((error as any).code === 'EADDRINUSE') {
|
|
60
|
-
throw new Error(
|
|
61
|
-
`Address '${host}:${port}' in use, either release this port or use options --port --host`
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
throw error;
|
|
66
|
-
}
|
|
43
|
+
await listenServer(staticServer, host, port);
|
|
67
44
|
};
|
|
68
45
|
},
|
|
69
46
|
deps: {
|
|
70
47
|
staticServer: STATIC_SERVER_TOKEN,
|
|
71
|
-
|
|
48
|
+
configManager: CONFIG_MANAGER_TOKEN,
|
|
72
49
|
},
|
|
73
|
-
},
|
|
74
|
-
{
|
|
50
|
+
}),
|
|
51
|
+
provide({
|
|
75
52
|
provide: CLOSE_HANDLER_TOKEN,
|
|
76
53
|
multi: true,
|
|
77
|
-
useFactory: ({ staticServer }
|
|
54
|
+
useFactory: ({ staticServer }) => {
|
|
78
55
|
return () => {
|
|
79
56
|
return stopServer(staticServer);
|
|
80
57
|
};
|
|
@@ -82,11 +59,11 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
82
59
|
deps: {
|
|
83
60
|
staticServer: STATIC_SERVER_TOKEN,
|
|
84
61
|
},
|
|
85
|
-
},
|
|
86
|
-
{
|
|
62
|
+
}),
|
|
63
|
+
provide({
|
|
87
64
|
provide: CLOSE_HANDLER_TOKEN,
|
|
88
65
|
multi: true,
|
|
89
|
-
useFactory: ({ configManager }
|
|
66
|
+
useFactory: ({ configManager }) => {
|
|
90
67
|
return async () => {
|
|
91
68
|
closeWorkerPoolTranspiler(configManager);
|
|
92
69
|
};
|
|
@@ -94,5 +71,5 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
94
71
|
deps: {
|
|
95
72
|
configManager: CONFIG_MANAGER_TOKEN,
|
|
96
73
|
},
|
|
97
|
-
},
|
|
74
|
+
}),
|
|
98
75
|
] as const;
|
|
@@ -3,6 +3,7 @@ import type { Container } from '@tinkoff/dippy';
|
|
|
3
3
|
import { successBox } from '../../../utils/formatting';
|
|
4
4
|
import { UI_SHOW_BANNER_TOKEN, CONFIG_MANAGER_TOKEN, STDOUT_TOKEN } from '../../../di/tokens';
|
|
5
5
|
import { getDocUrl, getTip } from './tips';
|
|
6
|
+
import { isApplication } from '../../../config/validate';
|
|
6
7
|
|
|
7
8
|
const label = (name) => chalk.bold.cyan(`▸ ${name}:`);
|
|
8
9
|
const link = (url) => chalk.underline.blue(url);
|
|
@@ -24,9 +25,9 @@ export function showBanner(di: Container) {
|
|
|
24
25
|
titleLines.push(`${label('Type')} ${config.type}`);
|
|
25
26
|
}
|
|
26
27
|
titleLines.push(`${label('Modern')} ${config.modern}`);
|
|
27
|
-
titleLines.push(`${label('ReactRefresh')} ${config.hotRefresh}`);
|
|
28
|
+
titleLines.push(`${label('ReactRefresh')} ${config.hotRefresh.enabled}`);
|
|
28
29
|
|
|
29
|
-
if (config.
|
|
30
|
+
if (isApplication(config) && config.fileSystemPages.enabled) {
|
|
30
31
|
titleLines.push(`${label('FileSystemPages')} true`);
|
|
31
32
|
}
|
|
32
33
|
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type { Server } from 'net';
|
|
2
2
|
|
|
3
|
-
export const listenServer = (server: Server, host: string, port: number) => {
|
|
3
|
+
export const listenServer = async (server: Server, host: string, port: number): Promise<void> => {
|
|
4
4
|
return new Promise<void>((resolve, reject) => {
|
|
5
5
|
server.once('error', (error) => {
|
|
6
6
|
reject(error);
|
|
7
7
|
});
|
|
8
|
+
|
|
8
9
|
server.listen(port, host, () => {
|
|
9
10
|
resolve();
|
|
10
11
|
});
|
|
@@ -3,6 +3,7 @@ import { existsSync } from 'fs-extra';
|
|
|
3
3
|
import { sync as resolveSync } from 'resolve';
|
|
4
4
|
import { CONFIG_MANAGER_TOKEN } from '../../../../di/tokens';
|
|
5
5
|
import type { TramvaiTip } from './types';
|
|
6
|
+
import { isApplication } from '../../../../config/validate';
|
|
6
7
|
|
|
7
8
|
const DEFAULT_ROOT_DIR = process.cwd();
|
|
8
9
|
|
|
@@ -22,10 +23,7 @@ Consider to test out swc support.`,
|
|
|
22
23
|
isApplicable(di) {
|
|
23
24
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
24
25
|
|
|
25
|
-
return
|
|
26
|
-
configManager.serve.configurations?.experiments?.transpilation?.loader !== 'swc' &&
|
|
27
|
-
configManager.build.configurations?.experiments?.transpilation?.loader !== 'swc'
|
|
28
|
-
);
|
|
26
|
+
return configManager.experiments?.transpilation?.loader !== 'swc';
|
|
29
27
|
},
|
|
30
28
|
},
|
|
31
29
|
{
|
|
@@ -43,7 +41,7 @@ Consider to test out swc support.`,
|
|
|
43
41
|
isApplicable(di) {
|
|
44
42
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
45
43
|
|
|
46
|
-
return configManager.hotRefresh !== true;
|
|
44
|
+
return configManager.hotRefresh.enabled !== true;
|
|
47
45
|
},
|
|
48
46
|
},
|
|
49
47
|
{
|
|
@@ -53,9 +51,14 @@ It may reduce the boilerplate code required with bundles`,
|
|
|
53
51
|
isApplicable(di) {
|
|
54
52
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
55
53
|
const { rootDir, root } = configManager;
|
|
56
|
-
const { fileSystemPages } = configManager.build.configurations;
|
|
57
54
|
|
|
58
|
-
if (!
|
|
55
|
+
if (!isApplication(configManager)) {
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const { fileSystemPages } = configManager;
|
|
60
|
+
|
|
61
|
+
if (!fileSystemPages.enabled) {
|
|
59
62
|
return true;
|
|
60
63
|
}
|
|
61
64
|
|
|
@@ -107,7 +110,7 @@ So you can remove alias config from tramvai.json`,
|
|
|
107
110
|
isApplicable(di) {
|
|
108
111
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
109
112
|
|
|
110
|
-
return !!configManager.
|
|
113
|
+
return !!configManager.alias;
|
|
111
114
|
},
|
|
112
115
|
},
|
|
113
116
|
{
|
|
@@ -8,24 +8,30 @@ import {
|
|
|
8
8
|
CONFIG_MANAGER_TOKEN,
|
|
9
9
|
} from '../../../di/tokens';
|
|
10
10
|
import type { Params } from '../index';
|
|
11
|
-
import { ConfigManager } from '../../index';
|
|
12
11
|
import type { ConfigEntry } from '../../../typings/configEntry/common';
|
|
13
12
|
import { CLOSE_HANDLER_TOKEN, SERVER_PROCESS_TOKEN } from '../tokens';
|
|
14
13
|
import { DEBUG_ARGV } from '../../../config/constants';
|
|
14
|
+
import { detectPortSync } from '../../../utils/detectPortSync';
|
|
15
15
|
import { safeRequire } from '../../../utils/safeRequire';
|
|
16
|
+
import type { ConfigManager } from '../../../config/configManager';
|
|
17
|
+
import {
|
|
18
|
+
createConfigManager,
|
|
19
|
+
DEFAULT_PORT,
|
|
20
|
+
DEFAULT_STATIC_PORT,
|
|
21
|
+
} from '../../../config/configManager';
|
|
22
|
+
import type { ApplicationConfigEntry } from '../../../typings/configEntry/application';
|
|
16
23
|
|
|
17
24
|
export const applicationsProviders: readonly Provider[] = [
|
|
18
25
|
provide({
|
|
19
26
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
|
-
useFactory: ({ configEntry, parameters }: { configEntry: ConfigEntry; parameters: Params }) =>
|
|
21
|
-
|
|
27
|
+
useFactory: ({ configEntry, parameters }: { configEntry: ConfigEntry; parameters: Params }) =>
|
|
28
|
+
createConfigManager(configEntry, {
|
|
22
29
|
...parameters,
|
|
23
30
|
env: 'production',
|
|
24
|
-
port: parameters.port ?? 3000,
|
|
25
|
-
staticPort: parameters.staticPort ?? 4000,
|
|
26
31
|
buildType: 'client',
|
|
27
|
-
|
|
28
|
-
|
|
32
|
+
port: detectPortSync(parameters.port ?? DEFAULT_PORT),
|
|
33
|
+
staticPort: detectPortSync(parameters.staticPort ?? DEFAULT_STATIC_PORT),
|
|
34
|
+
}),
|
|
29
35
|
deps: {
|
|
30
36
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
31
37
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
@@ -35,19 +41,13 @@ export const applicationsProviders: readonly Provider[] = [
|
|
|
35
41
|
provide: SERVER_PROCESS_TOKEN,
|
|
36
42
|
useFactory: ({ configManager, parameters }) => {
|
|
37
43
|
const { env } = parameters;
|
|
38
|
-
const serverConfigManager =
|
|
44
|
+
const serverConfigManager = (
|
|
45
|
+
configManager as ConfigManager<ApplicationConfigEntry>
|
|
46
|
+
).withSettings({
|
|
39
47
|
buildType: 'server',
|
|
40
48
|
});
|
|
41
|
-
const {
|
|
42
|
-
|
|
43
|
-
port,
|
|
44
|
-
staticPort,
|
|
45
|
-
staticHost,
|
|
46
|
-
build: {
|
|
47
|
-
options: { outputClient },
|
|
48
|
-
},
|
|
49
|
-
} = serverConfigManager;
|
|
50
|
-
const root = serverConfigManager.getBuildPath();
|
|
49
|
+
const { debug, port, staticPort, staticHost, output } = serverConfigManager;
|
|
50
|
+
const root = serverConfigManager.buildPath;
|
|
51
51
|
|
|
52
52
|
return fork(path.resolve(root, 'server.js'), [], {
|
|
53
53
|
execArgv: debug ? DEBUG_ARGV : [],
|
|
@@ -62,7 +62,7 @@ export const applicationsProviders: readonly Provider[] = [
|
|
|
62
62
|
PORT_SERVER: `${port}`,
|
|
63
63
|
ASSETS_PREFIX:
|
|
64
64
|
process.env.ASSETS_PREFIX ??
|
|
65
|
-
`http://${staticHost}:${staticPort}/${
|
|
65
|
+
`http://${staticHost}:${staticPort}/${output.client.replace(/\/$/, '')}/`,
|
|
66
66
|
},
|
|
67
67
|
});
|
|
68
68
|
},
|
|
@@ -5,21 +5,20 @@ import {
|
|
|
5
5
|
CONFIG_ENTRY_TOKEN,
|
|
6
6
|
CONFIG_MANAGER_TOKEN,
|
|
7
7
|
} from '../../../di/tokens';
|
|
8
|
-
import
|
|
9
|
-
import {
|
|
10
|
-
import
|
|
8
|
+
import { createConfigManager, DEFAULT_STATIC_MODULE_PORT } from '../../../config/configManager';
|
|
9
|
+
import type { ChildAppConfigEntry } from '../../../typings/configEntry/child-app';
|
|
10
|
+
import { detectPortSync } from '../../../utils/detectPortSync';
|
|
11
11
|
|
|
12
12
|
export const childAppProviders: readonly Provider[] = [
|
|
13
13
|
provide({
|
|
14
14
|
provide: CONFIG_MANAGER_TOKEN,
|
|
15
|
-
useFactory: ({ configEntry, parameters }
|
|
16
|
-
|
|
15
|
+
useFactory: ({ configEntry, parameters }) =>
|
|
16
|
+
createConfigManager(configEntry as ChildAppConfigEntry, {
|
|
17
17
|
...parameters,
|
|
18
18
|
env: 'production',
|
|
19
|
-
staticPort: parameters.staticPort ??
|
|
19
|
+
staticPort: detectPortSync(parameters.staticPort ?? DEFAULT_STATIC_MODULE_PORT),
|
|
20
20
|
buildType: 'client',
|
|
21
|
-
})
|
|
22
|
-
},
|
|
21
|
+
}),
|
|
23
22
|
deps: {
|
|
24
23
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
25
24
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
@@ -5,11 +5,7 @@ import fastifyCompress from '@fastify/compress';
|
|
|
5
5
|
import fastifyStatic from '@fastify/static';
|
|
6
6
|
import zlib from 'zlib';
|
|
7
7
|
import { CLOSE_HANDLER_TOKEN, INIT_HANDLER_TOKEN, PROCESS_HANDLER_TOKEN } from '../tokens';
|
|
8
|
-
import {
|
|
9
|
-
COMMAND_PARAMETERS_TOKEN,
|
|
10
|
-
CONFIG_MANAGER_TOKEN,
|
|
11
|
-
STATIC_SERVER_TOKEN,
|
|
12
|
-
} from '../../../di/tokens';
|
|
8
|
+
import { CONFIG_MANAGER_TOKEN, STATIC_SERVER_TOKEN } from '../../../di/tokens';
|
|
13
9
|
import { createServer } from '../../start/utils/createServer';
|
|
14
10
|
import { stopServer } from '../../start/utils/stopServer';
|
|
15
11
|
import { listenServer } from '../../start/utils/listenServer';
|
|
@@ -25,19 +21,9 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
25
21
|
multi: true,
|
|
26
22
|
useFactory: ({ staticServer, configManager }) => {
|
|
27
23
|
return async function staticServerListen() {
|
|
28
|
-
const { staticHost
|
|
24
|
+
const { staticHost, staticPort } = configManager;
|
|
29
25
|
|
|
30
|
-
|
|
31
|
-
await listenServer(staticServer, staticHost.replace('localhost', '0.0.0.0'), staticPort);
|
|
32
|
-
} catch (error) {
|
|
33
|
-
if ((error as any).code === 'EADDRINUSE') {
|
|
34
|
-
throw new Error(
|
|
35
|
-
`Address '${staticHost}:${staticPort}' in use, either release this port or use options --staticPort --staticHost`
|
|
36
|
-
);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
throw error;
|
|
40
|
-
}
|
|
26
|
+
await listenServer(staticServer, staticHost.replace('localhost', '0.0.0.0'), staticPort);
|
|
41
27
|
};
|
|
42
28
|
},
|
|
43
29
|
deps: {
|
|
@@ -75,12 +61,12 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
75
61
|
|
|
76
62
|
if (isApplication(configManager)) {
|
|
77
63
|
await app.register(fastifyStatic, {
|
|
78
|
-
root: configManager.
|
|
79
|
-
prefix: `/${configManager.
|
|
64
|
+
root: configManager.buildPath,
|
|
65
|
+
prefix: `/${configManager.output.client.replace(/\/$/, '')}/`,
|
|
80
66
|
});
|
|
81
67
|
} else if (isChildApp(configManager)) {
|
|
82
68
|
await app.register(fastifyStatic, {
|
|
83
|
-
root: configManager.
|
|
69
|
+
root: configManager.buildPath,
|
|
84
70
|
prefix: `/${configManager.name}/`,
|
|
85
71
|
});
|
|
86
72
|
}
|
|
@@ -11,28 +11,35 @@ import type { STATIC_SERVER_TOKEN } from '../../../di/tokens';
|
|
|
11
11
|
import { CONFIG_ROOT_DIR_TOKEN, UI_OS_NOTIFY_TOKEN } from '../../../di/tokens';
|
|
12
12
|
import { WEBPACK_WATCHING_TOKEN, CLOSE_HANDLER_TOKEN } from '../tokens';
|
|
13
13
|
import { close } from '../../../utils/close';
|
|
14
|
+
import { isApplication, isChildApp, isModule } from '../../../config/validate';
|
|
14
15
|
|
|
15
16
|
const getPrefix = (configManager: ConfigManager): string => {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
17
|
+
if (isApplication(configManager)) {
|
|
18
|
+
return '/';
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
if (isChildApp(configManager)) {
|
|
22
|
+
return `/${configManager.name}`;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if (isModule(configManager)) {
|
|
26
|
+
return `/${configManager.name}/:version`;
|
|
23
27
|
}
|
|
24
28
|
|
|
25
29
|
throw new Error(`${configManager.type} is not supported`);
|
|
26
30
|
};
|
|
27
31
|
|
|
28
32
|
const getHotModulePrefix = (configManager: ConfigManager): string => {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
if (isApplication(configManager)) {
|
|
34
|
+
return `/${configManager.output.client}`;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
if (isChildApp(configManager)) {
|
|
38
|
+
return `/${configManager.name}`;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if (isModule(configManager)) {
|
|
42
|
+
return `/${configManager.name}/:version`;
|
|
36
43
|
}
|
|
37
44
|
|
|
38
45
|
throw new Error(`${configManager.type} is not supported`);
|
|
@@ -78,7 +85,7 @@ export const createDevServer = ({
|
|
|
78
85
|
},
|
|
79
86
|
});
|
|
80
87
|
|
|
81
|
-
if (configManager.hotRefresh) {
|
|
88
|
+
if (configManager.hotRefresh.enabled) {
|
|
82
89
|
app.use(getHotModulePrefix(configManager), webpackHotMiddleware(compiler, { log: false }));
|
|
83
90
|
}
|
|
84
91
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type webpack from 'webpack';
|
|
2
2
|
import WebpackBuildNotifierPlugin from 'webpack-build-notifier';
|
|
3
3
|
import type { ConfigManager } from '../../../config/configManager';
|
|
4
|
-
import type {
|
|
4
|
+
import type { CliConfigEntry } from '../../../typings/configEntry/cli';
|
|
5
5
|
|
|
6
6
|
const getStatsByType = (stats: webpack.MultiStats, type: string) => {
|
|
7
7
|
return stats.stats.find((st) => {
|
|
@@ -11,21 +11,21 @@ const getStatsByType = (stats: webpack.MultiStats, type: string) => {
|
|
|
11
11
|
|
|
12
12
|
export const notifier = (
|
|
13
13
|
compiler: webpack.MultiCompiler,
|
|
14
|
-
configManager: ConfigManager<
|
|
14
|
+
configManager: ConfigManager<CliConfigEntry>
|
|
15
15
|
) => {
|
|
16
16
|
const clientNotifier = new WebpackBuildNotifierPlugin({
|
|
17
17
|
successSound: false,
|
|
18
18
|
warningSound: false,
|
|
19
|
-
...configManager.
|
|
20
|
-
...configManager.
|
|
19
|
+
...configManager.notifications,
|
|
20
|
+
...configManager.notifications?.client,
|
|
21
21
|
});
|
|
22
22
|
const serverNotifier = new WebpackBuildNotifierPlugin({
|
|
23
23
|
// отлкючаем нотификацию для одного из нотификатора, чтобы не дублировать
|
|
24
24
|
suppressSuccess: 'always',
|
|
25
25
|
successSound: false,
|
|
26
26
|
warningSound: false,
|
|
27
|
-
...configManager.
|
|
28
|
-
...configManager.
|
|
27
|
+
...configManager.notifications,
|
|
28
|
+
...configManager.notifications?.server,
|
|
29
29
|
});
|
|
30
30
|
|
|
31
31
|
compiler.hooks.done.tap('webpack-build-notifier', (stats) => {
|
|
@@ -22,7 +22,7 @@ export const ProcessWorkerBridge: WorkerBridgeFactory<Worker> = (di) => {
|
|
|
22
22
|
cluster.setupMaster({
|
|
23
23
|
// указываем другой файл для работы cluster.fork
|
|
24
24
|
exec: path.resolve(__dirname, './worker.js'),
|
|
25
|
-
execArgv: [].concat(
|
|
25
|
+
execArgv: ([] as string[]).concat(
|
|
26
26
|
configManager.debug ? DEBUG_ARGV : [],
|
|
27
27
|
configManager.trace ? TRACE_ARGV : []
|
|
28
28
|
),
|
|
@@ -43,8 +43,8 @@ export const ProcessWorkerBridge: WorkerBridgeFactory<Worker> = (di) => {
|
|
|
43
43
|
PORT_SERVER: `${configManager.port}`,
|
|
44
44
|
});
|
|
45
45
|
|
|
46
|
-
worker.process.stdout
|
|
47
|
-
worker.process.stderr
|
|
46
|
+
worker.process.stdout?.pipe(stdout);
|
|
47
|
+
worker.process.stderr?.pipe(stderr);
|
|
48
48
|
|
|
49
49
|
return worker;
|
|
50
50
|
},
|
|
@@ -15,6 +15,13 @@ export const ThreadWorkerBridge: WorkerBridgeFactory<Worker> = (di) => {
|
|
|
15
15
|
// WARN: potentially dangerous code that will lead to bugs in case of run parallel builds from once process
|
|
16
16
|
// as nodejs do not support this for threads - https://github.com/nodejs/node/issues/41673
|
|
17
17
|
// but it is not a very popular usage anyway
|
|
18
|
+
// Found issues:
|
|
19
|
+
// 1. babel-plugin-lodash will reload configs when the cwd is changed
|
|
20
|
+
// and if this happens between file compilations
|
|
21
|
+
// it'll lead to obscure errors inside this plugin as it won't resolve
|
|
22
|
+
// previously resolved modules and there will be the mess
|
|
23
|
+
// [source code](https://github.com/lodash/babel-plugin-lodash/blob/master/src/config.js#L18)
|
|
24
|
+
// but it currently affects only jest tests probably because of jest's workers usage
|
|
18
25
|
process.chdir(di.get(CONFIG_ROOT_DIR_TOKEN));
|
|
19
26
|
|
|
20
27
|
const worker = new Worker(path.resolve(__dirname, './worker.js'), {
|
|
@@ -59,9 +59,13 @@ export const serverRunner = ({
|
|
|
59
59
|
const file = `${Object.keys(config.entryPoints.entries())[0]}.js`;
|
|
60
60
|
const filename = path.resolve(config.output.get('path'), file);
|
|
61
61
|
// настоящая ссылка на файл используется для отладки в debug режиме
|
|
62
|
-
const realFilename = `http://${configManager.staticHost}:${configManager.staticPort}/${configManager.
|
|
62
|
+
const realFilename = `http://${configManager.staticHost}:${configManager.staticPort}/${configManager.output.server}/${file}`;
|
|
63
63
|
const serverCompiler = compiler.compilers.find((comp) => comp.name === 'server');
|
|
64
64
|
|
|
65
|
+
if (!serverCompiler) {
|
|
66
|
+
throw new Error('Server compiler has not found');
|
|
67
|
+
}
|
|
68
|
+
|
|
65
69
|
const fs = serverCompiler.outputFileSystem as any;
|
|
66
70
|
// ThreadWorkerPool is experimental
|
|
67
71
|
// it doesn't work well when running integration tests in tramvai repo
|
|
@@ -76,11 +80,11 @@ export const serverRunner = ({
|
|
|
76
80
|
? ThreadWorkerBridge
|
|
77
81
|
: ProcessWorkerBridge
|
|
78
82
|
);
|
|
79
|
-
let worker: Worker;
|
|
83
|
+
let worker: Worker | null;
|
|
80
84
|
let serverInvalidated = true;
|
|
81
|
-
let workerPort: number;
|
|
82
|
-
let resolveWorkerPort: () => void;
|
|
83
|
-
let workerPortPromise: Promise<void
|
|
85
|
+
let workerPort: number | null;
|
|
86
|
+
let resolveWorkerPort: () => void | null;
|
|
87
|
+
let workerPortPromise: Promise<void> | null;
|
|
84
88
|
let hasExitedUnexpectedly = false;
|
|
85
89
|
|
|
86
90
|
const proxy = createProxyServer({
|
|
@@ -248,8 +252,11 @@ export const serverRunner = ({
|
|
|
248
252
|
workerPort = null;
|
|
249
253
|
workerPortPromise = null;
|
|
250
254
|
|
|
255
|
+
if (worker) {
|
|
256
|
+
pool.release(worker);
|
|
257
|
+
}
|
|
258
|
+
|
|
251
259
|
worker = null;
|
|
252
|
-
pool.release(worker);
|
|
253
260
|
|
|
254
261
|
console.error(EXITED_UNEXPECTEDLY);
|
|
255
262
|
});
|