UNPKG

@angular-devkit/build-webpack

Version:
95 lines (94 loc) 4.12 kB
"use strict"; /** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.dev/license */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.runWebpackDevServer = runWebpackDevServer; const architect_1 = require("@angular-devkit/architect"); const node_assert_1 = __importDefault(require("node:assert")); const node_path_1 = require("node:path"); const rxjs_1 = require("rxjs"); const webpack_1 = __importDefault(require("webpack")); const webpack_dev_server_1 = __importDefault(require("webpack-dev-server")); const utils_1 = require("../../utils"); function runWebpackDevServer(config, context, options = {}) { const createWebpack = (c) => { if (options.webpackFactory) { const result = options.webpackFactory(c); if ((0, rxjs_1.isObservable)(result)) { return result; } else { return (0, rxjs_1.of)(result); } } else { return (0, rxjs_1.of)((0, webpack_1.default)(c)); } }; const createWebpackDevServer = (webpack, config) => { if (options.webpackDevServerFactory) { return new options.webpackDevServerFactory(config, webpack); } return new webpack_dev_server_1.default(config, webpack); }; const { logging: log = (stats, config) => { if (config.stats !== false) { const statsOptions = config.stats === true ? undefined : config.stats; context.logger.info(stats.toString(statsOptions)); } }, shouldProvideStats = true, } = options; return createWebpack({ ...config, watch: false }).pipe((0, rxjs_1.switchMap)((webpackCompiler) => new rxjs_1.Observable((obs) => { (0, node_assert_1.default)(webpackCompiler, 'Webpack compiler factory did not return a compiler instance.'); const devServerConfig = options.devServerConfig || config.devServer || {}; devServerConfig.host ??= 'localhost'; let result; const statsOptions = typeof config.stats === 'boolean' ? undefined : config.stats; webpackCompiler.hooks.done.tap('build-webpack', (stats) => { // Log stats. log(stats, config); obs.next({ ...result, webpackStats: shouldProvideStats ? stats.toJson(statsOptions) : undefined, emittedFiles: (0, utils_1.getEmittedFiles)(stats.compilation), success: !stats.hasErrors(), outputPath: stats.compilation.outputOptions.path, }); }); const devServer = createWebpackDevServer(webpackCompiler, devServerConfig); devServer.startCallback((err) => { if (err) { obs.error(err); return; } const address = devServer.server?.address(); if (!address) { obs.error(new Error(`Dev-server address info is not defined.`)); return; } result = { success: true, port: typeof address === 'string' ? 0 : address.port, family: typeof address === 'string' ? '' : address.family, address: typeof address === 'string' ? address : address.address, }; }); // Teardown logic. Close the server when unsubscribed from. return () => { devServer.stopCallback(() => { }); webpackCompiler.close(() => { }); }; }))); } const builder = (0, architect_1.createBuilder)((options, context) => { const configPath = (0, node_path_1.resolve)(context.workspaceRoot, options.webpackConfig); return (0, rxjs_1.from)((0, utils_1.getWebpackConfig)(configPath)).pipe((0, rxjs_1.switchMap)((config) => runWebpackDevServer(config, context))); }); exports.default = builder;