UNPKG

73.1 kBJavaScriptView Raw
1"use strict";
2// tslint:disable:no-any
3// tslint:disable:no-unsafe-any
4Object.defineProperty(exports, "__esModule", { value: true });
5const fs_1 = require("fs");
6const path = require("path");
7const error_models_1 = require("../error-models");
8const utils_1 = require("../utils");
9const normalize_environment_1 = require("./normalize-environment");
10function applyProjectConfigWithEnvironment(projectConfig, env) {
11 if (!projectConfig ||
12 !projectConfig.envOverrides ||
13 Object.keys(projectConfig.envOverrides).length === 0) {
14 return;
15 }
16 const buildTargets = [];
17 if (env.production || env.prod) {
18 if (!buildTargets.includes('prod')) {
19 buildTargets.push('prod');
20 }
21 if (!buildTargets.includes('production')) {
22 buildTargets.push('production');
23 }
24 }
25 else if (env.dev || env.development) {
26 buildTargets.push('dev');
27 buildTargets.push('development');
28 }
29 const preDefinedKeys = ['prod', 'production', 'dev', 'development'];
30 Object.keys(env)
31 .filter(key => !preDefinedKeys.includes(key.toLowerCase()) &&
32 !buildTargets.includes(key) &&
33 env[key] &&
34 (typeof env[key] === 'boolean' || env[key] === 'true'))
35 .forEach(key => {
36 buildTargets.push(key);
37 });
38 Object.keys(projectConfig.envOverrides)
39 .forEach((buildTargetKey) => {
40 const targetName = buildTargetKey;
41 const targets = targetName.split(',');
42 targets.forEach(t => {
43 t = t.trim();
44 if (buildTargets.indexOf(t) > -1) {
45 const newConfig = projectConfig.envOverrides[t];
46 if (newConfig && typeof newConfig === 'object') {
47 overrideProjectConfig(projectConfig, newConfig);
48 }
49 }
50 });
51 });
52}
53exports.applyProjectConfigWithEnvironment = applyProjectConfigWithEnvironment;
54// tslint:disable:max-func-body-length
55function applyProjectConfigExtends(projectConfig, projects) {
56 if (!projectConfig.extends) {
57 return;
58 }
59 const extendArray = Array.isArray(projectConfig.extends) ? projectConfig.extends : [projectConfig.extends];
60 for (const extendName of extendArray) {
61 if (!extendName) {
62 continue;
63 }
64 let foundBaseProject = null;
65 if (extendName.startsWith('ngb:') || extendName.startsWith('angular-build:')) {
66 let builtInConfigFileName = extendName.startsWith('ngb:')
67 ? extendName.substr('ngb:'.length).trim()
68 : extendName.substr('angular-build:'.length).trim();
69 if (!builtInConfigFileName) {
70 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${extendName}, check your configuration file - ${projectConfig._configPath}.`);
71 }
72 const targetProjectType = /^lib-/.test(builtInConfigFileName) ? 'lib' : 'app';
73 if (targetProjectType !== projectConfig._projectType) {
74 throw new error_models_1.InvalidConfigError(`Can't extend from different project type, check your configuration file - ${projectConfig._configPath}.`);
75 }
76 builtInConfigFileName = `ngb-${builtInConfigFileName}.json`;
77 let builtInConfigPath = '';
78 if (fs_1.existsSync(path.resolve(__dirname, `../configs/${builtInConfigFileName}`))) {
79 builtInConfigPath = path.resolve(__dirname, `../configs/${builtInConfigFileName}`);
80 }
81 else if (fs_1.existsSync(path.resolve(__dirname, `../../configs/${builtInConfigFileName}`))) {
82 builtInConfigPath = path.resolve(__dirname, `../../configs/${builtInConfigFileName}`);
83 }
84 if (!builtInConfigPath) {
85 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${builtInConfigPath}, check your configuration file - ${projectConfig._configPath}.`);
86 }
87 const config = utils_1.readJsonSync(builtInConfigPath);
88 config._projectType = projectConfig._projectType;
89 config._configPath = builtInConfigPath;
90 const extendLevel = projectConfig._extendLevel || 0;
91 config._extendLevel = extendLevel + 1;
92 foundBaseProject = config;
93 }
94 else if (extendName.startsWith('projects:')) {
95 if (projectConfig._extendLevel || !projects || projects.length < 2) {
96 continue;
97 }
98 const projectName = extendName.substr('projects:'.length).trim();
99 if (!projectName) {
100 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${extendName}, check your configuration file - ${projectConfig._configPath}.`);
101 }
102 const tempFoundProject = projects.find(project => project.name === projectName);
103 if (!tempFoundProject) {
104 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${extendName}, check your configuration file - ${projectConfig._configPath}.`);
105 }
106 if (tempFoundProject._projectType !== projectConfig._projectType) {
107 throw new error_models_1.InvalidConfigError(`Can't extend from different project type, check your configuration file - ${projectConfig._configPath}.`);
108 }
109 if (tempFoundProject.name !== projectConfig.name &&
110 tempFoundProject._index !== projectConfig._index &&
111 (!tempFoundProject._configPath || (tempFoundProject._configPath === projectConfig._configPath))) {
112 foundBaseProject = tempFoundProject;
113 }
114 }
115 else if (projectConfig._configPath) {
116 let destPath = extendName;
117 let projectType = '';
118 let projectName = '';
119 if (extendName.indexOf(':') > 0) {
120 const parts = extendName.split(':');
121 if (parts.length === 3) {
122 [destPath, projectType, projectName] = parts;
123 }
124 }
125 destPath = path.isAbsolute(destPath)
126 ? path.resolve(destPath)
127 : path.resolve(path.dirname(projectConfig._configPath), destPath);
128 if (!fs_1.existsSync(destPath)) {
129 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${destPath}, check your configuration file - ${projectConfig._configPath}.`);
130 }
131 let config = null;
132 try {
133 config = utils_1.readJsonSync(destPath);
134 }
135 catch (jsonErr2) {
136 throw new error_models_1.InvalidConfigError(`Invalid configuration, error: ${jsonErr2.message || jsonErr2}.`);
137 }
138 if (!config) {
139 throw new error_models_1.InvalidConfigError(`Can't extend from non existed config file - ${destPath}, check your configuration file - ${projectConfig._configPath}.`);
140 }
141 if (projectName) {
142 if (projectType !== projectConfig._projectType) {
143 throw new error_models_1.InvalidConfigError(`Can't extend from different project type, check your configuration file - ${projectConfig._configPath}.`);
144 }
145 const angularBuildConfig = config;
146 if (projectConfig._configPath !== destPath) {
147 // Validate schema
148 const schemaFileName = 'schema.json';
149 let schemaPath = '';
150 if (fs_1.existsSync(path.resolve(__dirname, `../schemas/${schemaFileName}`))) {
151 schemaPath = `../schemas/${schemaFileName}`;
152 }
153 else if (fs_1.existsSync(path.resolve(__dirname, `../../schemas/${schemaFileName}`))) {
154 schemaPath = `../../schemas/${schemaFileName}`;
155 }
156 if (!schemaPath) {
157 throw new error_models_1.InternalError("The angular-build schema file doesn't exist.");
158 }
159 // tslint:disable-next-line:non-literal-require
160 const schema = require(schemaPath);
161 if (schema.$schema) {
162 delete schema.$schema;
163 }
164 if (angularBuildConfig.$schema) {
165 delete angularBuildConfig.$schema;
166 }
167 const errors = utils_1.validateSchema(schema, angularBuildConfig);
168 if (errors.length) {
169 const errMsg = errors.map(err => utils_1.formatValidationError(schema, err)).join('\n');
170 throw new error_models_1.InvalidConfigError(`Invalid configuration.\n\n${errMsg}`);
171 }
172 }
173 // Set angular build defaults
174 const angularBuildConfigInternal = angularBuildConfig;
175 angularBuildConfigInternal.libs = angularBuildConfigInternal.libs || [];
176 angularBuildConfigInternal.apps = angularBuildConfigInternal.apps || [];
177 // extends
178 if (projectConfig._projectType === 'lib') {
179 for (let i = 0; i < angularBuildConfigInternal.libs.length; i++) {
180 const libConfig = angularBuildConfigInternal.libs[i];
181 libConfig._index = i;
182 libConfig._projectType = 'lib';
183 libConfig._configPath = destPath;
184 if (libConfig.name === projectName) {
185 foundBaseProject = libConfig;
186 const extendLevel = projectConfig._extendLevel || 0;
187 foundBaseProject._extendLevel = extendLevel + 1;
188 break;
189 }
190 }
191 }
192 else {
193 for (let i = 0; i < angularBuildConfigInternal.apps.length; i++) {
194 const appConfig = angularBuildConfigInternal.apps[i];
195 appConfig._index = i;
196 appConfig._projectType = 'app';
197 appConfig._configPath = destPath;
198 if (appConfig.name === projectName) {
199 foundBaseProject = appConfig;
200 const extendLevel = projectConfig._extendLevel || 0;
201 foundBaseProject._extendLevel = extendLevel + 1;
202 break;
203 }
204 }
205 }
206 }
207 else {
208 // validate
209 const schemaFileName = projectConfig._projectType === 'lib'
210 ? 'lib-project-config-schema.json'
211 : 'app-project-config-schema.json';
212 let schemaPath = '';
213 if (fs_1.existsSync(path.resolve(__dirname, `../schemas/${schemaFileName}`))) {
214 schemaPath = `../schemas/${schemaFileName}`;
215 }
216 else if (fs_1.existsSync(path.resolve(__dirname, `../../schemas/${schemaFileName}`))) {
217 schemaPath = `../../schemas/${schemaFileName}`;
218 }
219 if (!schemaPath) {
220 throw new error_models_1.InternalError("The angular-build schema file doesn't exist.");
221 }
222 // tslint:disable-next-line:non-literal-require
223 const schema = require(schemaPath);
224 if (schema.$schema) {
225 delete schema.$schema;
226 }
227 if (config.$schema) {
228 delete config.$schema;
229 }
230 const errors = utils_1.validateSchema(schema, config);
231 if (errors.length) {
232 const errMsg = errors.map(err => utils_1.formatValidationError(schema, err)).join('\n');
233 throw new error_models_1.InvalidConfigError(`Invalid configuration.\n\n${errMsg}`);
234 }
235 config._projectType = projectConfig._projectType;
236 config._configPath = projectConfig._configPath;
237 const extendLevel = projectConfig._extendLevel || 0;
238 config._extendLevel = extendLevel + 1;
239 foundBaseProject = config;
240 }
241 }
242 if (!foundBaseProject) {
243 continue;
244 }
245 const clonedBaseProject = JSON.parse(JSON.stringify(foundBaseProject));
246 if (clonedBaseProject.extends) {
247 applyProjectConfigExtends(clonedBaseProject, projects);
248 delete clonedBaseProject.extends;
249 }
250 if (clonedBaseProject.name) {
251 delete clonedBaseProject.name;
252 }
253 if (clonedBaseProject.$schema) {
254 delete clonedBaseProject.$schema;
255 }
256 const extendedConfig = Object.assign({}, clonedBaseProject, projectConfig);
257 Object.assign(projectConfig, extendedConfig);
258 }
259}
260exports.applyProjectConfigExtends = applyProjectConfigExtends;
261function getBuildOptionsFromBuilderOptions(options) {
262 const buildOptions = { environment: {} };
263 if (options.environment) {
264 const env = normalize_environment_1.normalizeEnvironment(options.environment);
265 buildOptions.environment = env;
266 delete options.environment;
267 }
268 if (options.filter) {
269 buildOptions.filter = options.filter;
270 delete options.filter;
271 }
272 if (options.verbose != null) {
273 if (options.verbose) {
274 buildOptions.logLevel = 'debug';
275 }
276 delete options.verbose;
277 }
278 if (options.logLevel) {
279 buildOptions.logLevel = options.logLevel;
280 delete options.logLevel;
281 }
282 if (options.progress != null) {
283 if (options.progress) {
284 buildOptions.progress = true;
285 }
286 delete options.progress;
287 }
288 if (options.poll != null) {
289 buildOptions.watchOptions = {
290 poll: options.poll
291 };
292 delete options.poll;
293 }
294 if (options.cleanOutDir != null) {
295 if (options.cleanOutDir) {
296 buildOptions.cleanOutDir = true;
297 }
298 delete options.cleanOutDir;
299 }
300 if (options.watch != null) {
301 if (options.watch) {
302 buildOptions.watch = true;
303 }
304 delete options.watch;
305 }
306 if (options.watchOptions) {
307 buildOptions.watchOptions = Object.assign({}, options.watchOptions);
308 delete options.watchOptions;
309 }
310 if (options.beep != null) {
311 if (options.beep) {
312 buildOptions.beep = true;
313 }
314 delete options.beep;
315 }
316 return buildOptions;
317}
318exports.getBuildOptionsFromBuilderOptions = getBuildOptionsFromBuilderOptions;
319function applyAppConfigCompat(appConfig) {
320 if (appConfig.target && !appConfig.platformTarget) {
321 appConfig.platformTarget = appConfig.target;
322 delete appConfig.target;
323 }
324 if (appConfig.platform && !appConfig.platformTarget) {
325 appConfig.platformTarget = appConfig.platform === 'server' ? 'node' : 'web';
326 delete appConfig.platform;
327 }
328 if (appConfig.outDir && !appConfig.outputPath) {
329 appConfig.outputPath = appConfig.outDir;
330 delete appConfig.outDir;
331 }
332 if (appConfig.main && !appConfig.entry) {
333 appConfig.entry = appConfig.main;
334 delete appConfig.main;
335 }
336 if (appConfig.index && !appConfig.htmlInject) {
337 appConfig.htmlInject = {
338 index: appConfig.index
339 };
340 delete appConfig.index;
341 }
342 if (appConfig.evalSourceMap && !appConfig.sourceMapDevTool) {
343 appConfig.sourceMapDevTool = 'eval';
344 delete appConfig.evalSourceMap;
345 }
346 if (appConfig.deployUrl && !appConfig.publicPath) {
347 appConfig.publicPath = appConfig.deployUrl;
348 delete appConfig.deployUrl;
349 }
350 if (appConfig.assets &&
351 Array.isArray(appConfig.assets) &&
352 (!appConfig.copy || (Array.isArray(appConfig.copy) && !appConfig.copy.length))) {
353 appConfig.copy = appConfig.assets.map((assetEntry) => {
354 if (typeof assetEntry === 'string') {
355 return assetEntry;
356 }
357 return {
358 from: path.join(assetEntry.input, assetEntry.glob || ''),
359 to: assetEntry.output,
360 exclude: assetEntry.ignore
361 };
362 });
363 delete appConfig.assets;
364 }
365 if (appConfig.deleteOutputPath && !appConfig.clean) {
366 appConfig.clean = {
367 beforeBuild: {
368 cleanOutDir: true
369 }
370 };
371 delete appConfig.deleteOutputPath;
372 }
373 if (appConfig.statsJson && !appConfig.bundleAnalyzer) {
374 appConfig.bundleAnalyzer = {
375 generateStatsFile: true
376 };
377 delete appConfig.statsJson;
378 }
379 if (appConfig.bundleDependencies && appConfig.bundleDependencies === 'none') {
380 appConfig.nodeModulesAsExternals = true;
381 const externals = [
382 /^@angular/,
383 (_, request, callback) => {
384 // Absolute & Relative paths are not externals
385 if (request.match(/^\.{0,2}\//)) {
386 callback();
387 return;
388 }
389 try {
390 // Attempt to resolve the module via Node
391 const e = require.resolve(request);
392 if (/node_modules/.test(e)) {
393 // It's a node_module
394 callback(null, request);
395 }
396 else {
397 // It's a system thing (.ie util, fs...)
398 callback();
399 }
400 }
401 catch (e) {
402 // Node couldn't find it, so it must be user-aliased
403 callback();
404 }
405 }
406 ];
407 if (!appConfig.externals) {
408 appConfig.externals = externals;
409 }
410 else {
411 if (Array.isArray(appConfig.externals)) {
412 appConfig.externals = [...appConfig.externals, ...externals];
413 }
414 else {
415 appConfig.externals = [appConfig.externals, ...externals];
416 }
417 }
418 delete appConfig.bundleDependencies;
419 }
420}
421exports.applyAppConfigCompat = applyAppConfigCompat;
422function applyLibConfigCompat(libConfig) {
423 if (libConfig.target && !libConfig.platformTarget) {
424 libConfig.platformTarget = libConfig.target;
425 delete libConfig.target;
426 }
427 if (libConfig.platform && !libConfig.platformTarget) {
428 libConfig.platformTarget = libConfig.platform === 'server' ? 'node' : 'web';
429 delete libConfig.platform;
430 }
431 if (libConfig.outDir && !libConfig.outputPath) {
432 libConfig.outputPath = libConfig.outDir;
433 delete libConfig.outDir;
434 }
435 if (libConfig.assets &&
436 Array.isArray(libConfig.assets) &&
437 (!libConfig.copy || (Array.isArray(libConfig.copy) && !libConfig.copy.length))) {
438 libConfig.copy = libConfig.assets.map(assetEntry => {
439 if (typeof assetEntry === 'string') {
440 return assetEntry;
441 }
442 return {
443 from: path.join(assetEntry.input, assetEntry.glob || ''),
444 to: assetEntry.output,
445 exclude: assetEntry.ignore
446 };
447 });
448 delete libConfig.assets;
449 }
450 if (libConfig.deleteOutputPath && !libConfig.clean) {
451 libConfig.clean = {
452 beforeBuild: {
453 cleanOutDir: true
454 }
455 };
456 delete libConfig.deleteOutputPath;
457 }
458 if (libConfig.bundleDependencies && libConfig.bundleDependencies === 'all') {
459 libConfig.nodeModulesAsExternals = false;
460 }
461}
462exports.applyLibConfigCompat = applyLibConfigCompat;
463function mergeAppProjectConfigWithWebpackCli(appConfig, commandOptions) {
464 if (commandOptions.target && !appConfig.platformTarget) {
465 appConfig.platformTarget = commandOptions.target;
466 }
467 if (commandOptions.outputPublicPath) {
468 appConfig.publicPath = commandOptions.outputPublicPath;
469 }
470 if (commandOptions.devtool) {
471 appConfig.sourceMap = true;
472 appConfig.sourceMapDevTool = commandOptions.devtool;
473 }
474}
475exports.mergeAppProjectConfigWithWebpackCli = mergeAppProjectConfigWithWebpackCli;
476function overrideProjectConfig(oldConfig, newConfig) {
477 if (!newConfig || !oldConfig || typeof newConfig !== 'object' || Object.keys(newConfig).length === 0) {
478 return;
479 }
480 Object.keys(newConfig).filter((key) => key !== 'envOverrides').forEach((key) => {
481 oldConfig[key] = JSON.parse(JSON.stringify(newConfig[key]));
482 });
483}
484//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-configs.js","sourceRoot":"C:/projects/angular-build/","sources":["src/helpers/prepare-configs.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:no-any\n// tslint:disable:no-unsafe-any\n\nimport { existsSync } from 'fs';\nimport * as path from 'path';\n\nimport { InternalError, InvalidConfigError } from '../error-models';\nimport {\n    AngularBuildConfig,\n    AppBuilderOptions,\n    AssetPatternObjectCompat,\n    BuildOptions,\n    BuildOptionsCompat,\n    LibBuilderOptions,\n    ProjectConfigBase\n} from '../interfaces';\nimport {\n    AngularBuildConfigInternal,\n    AppProjectConfigInternal,\n    BuildOptionInternal,\n    LibProjectConfigInternal,\n    ProjectConfigInternal\n} from '../interfaces/internals';\nimport { formatValidationError, readJsonSync, validateSchema } from '../utils';\n\nimport { normalizeEnvironment } from './normalize-environment';\n\nexport function applyProjectConfigWithEnvironment(\n    projectConfig: AppProjectConfigInternal | LibProjectConfigInternal,\n    env: { [key: string]: boolean | string }): void {\n\n    if (!projectConfig ||\n        !projectConfig.envOverrides ||\n        Object.keys(projectConfig.envOverrides).length === 0) {\n        return;\n    }\n\n    const buildTargets: string[] = [];\n\n    if (env.production || env.prod) {\n        if (!buildTargets.includes('prod')) {\n            buildTargets.push('prod');\n        }\n        if (!buildTargets.includes('production')) {\n            buildTargets.push('production');\n        }\n    } else if (env.dev || env.development) {\n        buildTargets.push('dev');\n        buildTargets.push('development');\n    }\n\n    const preDefinedKeys = ['prod', 'production', 'dev', 'development'];\n\n    Object.keys(env)\n        .filter(key => !preDefinedKeys.includes(key.toLowerCase()) &&\n            !buildTargets.includes(key) &&\n            env[key] &&\n            (typeof env[key] === 'boolean' || env[key] === 'true'))\n        .forEach(key => {\n            buildTargets.push(key);\n        });\n\n    Object.keys(projectConfig.envOverrides)\n        .forEach((buildTargetKey: string) => {\n            const targetName = buildTargetKey;\n            const targets = targetName.split(',');\n            targets.forEach(t => {\n                t = t.trim();\n                if (buildTargets.indexOf(t) > -1) {\n                    const newConfig = (projectConfig.envOverrides as any)[t];\n                    if (newConfig && typeof newConfig === 'object') {\n                        overrideProjectConfig(projectConfig, newConfig);\n                    }\n                }\n            });\n        });\n}\n\n// tslint:disable:max-func-body-length\nexport function applyProjectConfigExtends<TConfig extends ProjectConfigBase>(projectConfig:\n    ProjectConfigInternal<TConfig>,\n    projects?: ProjectConfigInternal<TConfig>[]): void {\n    if (!projectConfig.extends) {\n        return;\n    }\n\n    const extendArray = Array.isArray(projectConfig.extends) ? projectConfig.extends : [projectConfig.extends];\n    for (const extendName of extendArray) {\n        if (!extendName) {\n            continue;\n        }\n\n        let foundBaseProject: AppProjectConfigInternal | LibProjectConfigInternal | null | undefined = null;\n\n        if (extendName.startsWith('ngb:') || extendName.startsWith('angular-build:')) {\n            let builtInConfigFileName = extendName.startsWith('ngb:')\n                ? extendName.substr('ngb:'.length).trim()\n                : extendName.substr('angular-build:'.length).trim();\n            if (!builtInConfigFileName) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${extendName}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            const targetProjectType = /^lib-/.test(builtInConfigFileName) ? 'lib' : 'app';\n            if (targetProjectType !== projectConfig._projectType) {\n                throw new InvalidConfigError(\n                    `Can't extend from different project type, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            builtInConfigFileName = `ngb-${builtInConfigFileName}.json`;\n            let builtInConfigPath = '';\n\n            if (existsSync(path.resolve(__dirname, `../configs/${builtInConfigFileName}`))) {\n                builtInConfigPath = path.resolve(__dirname, `../configs/${builtInConfigFileName}`);\n            } else if (existsSync(path.resolve(__dirname, `../../configs/${builtInConfigFileName}`))) {\n                builtInConfigPath = path.resolve(__dirname, `../../configs/${builtInConfigFileName}`);\n            }\n\n            if (!builtInConfigPath) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${builtInConfigPath}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            const config = readJsonSync(builtInConfigPath);\n\n            (config as ProjectConfigInternal<TConfig>)._projectType = projectConfig._projectType;\n            (config as ProjectConfigInternal<TConfig>)._configPath = builtInConfigPath;\n\n            const extendLevel: number = (projectConfig as any)._extendLevel || 0;\n            config._extendLevel = extendLevel + 1;\n\n            foundBaseProject = config;\n        } else if (extendName.startsWith('projects:')) {\n            if ((projectConfig as any)._extendLevel || !projects || projects.length < 2) {\n                continue;\n            }\n\n            const projectName = extendName.substr('projects:'.length).trim();\n            if (!projectName) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${extendName}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            const tempFoundProject =\n                projects.find(project => project.name === projectName);\n\n            if (!tempFoundProject) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${extendName}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            if (tempFoundProject._projectType !== projectConfig._projectType) {\n                throw new InvalidConfigError(\n                    `Can't extend from different project type, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            if (tempFoundProject.name !== projectConfig.name &&\n                tempFoundProject._index !== projectConfig._index &&\n                (!tempFoundProject._configPath || (tempFoundProject._configPath === projectConfig._configPath))) {\n                foundBaseProject = tempFoundProject;\n            }\n        } else if (projectConfig._configPath) {\n            let destPath = extendName;\n            let projectType = '';\n            let projectName = '';\n\n            if (extendName.indexOf(':') > 0) {\n                const parts = extendName.split(':');\n                if (parts.length === 3) {\n                    [destPath, projectType, projectName] = parts;\n                }\n            }\n\n            destPath = path.isAbsolute(destPath)\n                ? path.resolve(destPath)\n                : path.resolve(path.dirname(projectConfig._configPath), destPath);\n\n            if (!existsSync(destPath)) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${destPath}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            let config: any = null;\n\n            try {\n                config = readJsonSync(destPath);\n\n            } catch (jsonErr2) {\n                throw new InvalidConfigError(`Invalid configuration, error: ${jsonErr2.message || jsonErr2}.`);\n            }\n\n            if (!config) {\n                throw new InvalidConfigError(\n                    `Can't extend from non existed config file - ${destPath}, check your configuration file - ${\n                    projectConfig._configPath}.`);\n            }\n\n            if (projectName) {\n                if (projectType !== projectConfig._projectType) {\n                    throw new InvalidConfigError(\n                        `Can't extend from different project type, check your configuration file - ${\n                        projectConfig._configPath}.`);\n                }\n\n                const angularBuildConfig = config as AngularBuildConfig;\n\n                if (projectConfig._configPath !== destPath) {\n                    // Validate schema\n                    const schemaFileName = 'schema.json';\n                    let schemaPath = '';\n                    if (existsSync(path.resolve(__dirname, `../schemas/${schemaFileName}`))) {\n                        schemaPath = `../schemas/${schemaFileName}`;\n                    } else if (existsSync(path.resolve(__dirname, `../../schemas/${schemaFileName}`))) {\n                        schemaPath = `../../schemas/${schemaFileName}`;\n                    }\n\n                    if (!schemaPath) {\n                        throw new InternalError(\"The angular-build schema file doesn't exist.\");\n                    }\n\n                    // tslint:disable-next-line:non-literal-require\n                    const schema = require(schemaPath);\n                    if (schema.$schema) {\n                        delete schema.$schema;\n                    }\n                    if (angularBuildConfig.$schema) {\n                        delete angularBuildConfig.$schema;\n                    }\n\n                    const errors = validateSchema(schema, angularBuildConfig);\n                    if (errors.length) {\n                        const errMsg = errors.map(err => formatValidationError(schema, err)).join('\\n');\n                        throw new InvalidConfigError(\n                            `Invalid configuration.\\n\\n${\n                            errMsg}`);\n                    }\n                }\n\n                // Set angular build defaults\n                const angularBuildConfigInternal = angularBuildConfig as AngularBuildConfigInternal;\n                angularBuildConfigInternal.libs = angularBuildConfigInternal.libs || [];\n                angularBuildConfigInternal.apps = angularBuildConfigInternal.apps || [];\n\n                // extends\n                if (projectConfig._projectType === 'lib') {\n                    for (let i = 0; i < angularBuildConfigInternal.libs.length; i++) {\n                        const libConfig = angularBuildConfigInternal.libs[i];\n\n                        libConfig._index = i;\n                        libConfig._projectType = 'lib';\n                        libConfig._configPath = destPath;\n\n                        if (libConfig.name === projectName) {\n                            foundBaseProject = libConfig;\n\n                            const extendLevel: number = (projectConfig as any)._extendLevel || 0;\n                            (foundBaseProject as any)._extendLevel = extendLevel + 1;\n\n                            break;\n                        }\n                    }\n                } else {\n                    for (let i = 0; i < angularBuildConfigInternal.apps.length; i++) {\n                        const appConfig = angularBuildConfigInternal.apps[i];\n                        appConfig._index = i;\n                        appConfig._projectType = 'app';\n                        appConfig._configPath = destPath;\n\n                        if (appConfig.name === projectName) {\n                            foundBaseProject = appConfig;\n\n                            const extendLevel: number = (projectConfig as any)._extendLevel || 0;\n                            (foundBaseProject as any)._extendLevel = extendLevel + 1;\n\n                            break;\n                        }\n                    }\n                }\n            } else {\n                // validate\n                const schemaFileName = projectConfig._projectType === 'lib'\n                    ? 'lib-project-config-schema.json'\n                    : 'app-project-config-schema.json';\n                let schemaPath = '';\n\n                if (existsSync(path.resolve(__dirname, `../schemas/${schemaFileName}`))) {\n                    schemaPath = `../schemas/${schemaFileName}`;\n                } else if (existsSync(path.resolve(__dirname, `../../schemas/${schemaFileName}`))) {\n                    schemaPath = `../../schemas/${schemaFileName}`;\n                }\n\n                if (!schemaPath) {\n                    throw new InternalError(\"The angular-build schema file doesn't exist.\");\n                }\n\n                // tslint:disable-next-line:non-literal-require\n                const schema = require(schemaPath);\n                if (schema.$schema) {\n                    delete schema.$schema;\n                }\n                if (config.$schema) {\n                    delete config.$schema;\n                }\n\n                const errors = validateSchema(schema, config);\n                if (errors.length) {\n                    const errMsg = errors.map(err => formatValidationError(schema, err)).join('\\n');\n                    throw new InvalidConfigError(\n                        `Invalid configuration.\\n\\n${\n                        errMsg}`);\n                }\n\n                (config as ProjectConfigInternal<TConfig>)._projectType = projectConfig._projectType;\n                (config as ProjectConfigInternal<TConfig>)._configPath = projectConfig._configPath;\n\n                const extendLevel: number = (projectConfig as any)._extendLevel || 0;\n                config._extendLevel = extendLevel + 1;\n\n                foundBaseProject = config;\n            }\n        }\n\n        if (!foundBaseProject) {\n            continue;\n        }\n\n        const clonedBaseProject = JSON.parse(JSON.stringify(foundBaseProject)) as ProjectConfigInternal<TConfig>;\n        if (clonedBaseProject.extends) {\n            applyProjectConfigExtends(clonedBaseProject, projects);\n\n            delete clonedBaseProject.extends;\n        }\n\n        if (clonedBaseProject.name) {\n            delete clonedBaseProject.name;\n        }\n\n        if (clonedBaseProject.$schema) {\n            delete clonedBaseProject.$schema;\n        }\n\n        const extendedConfig = { ...clonedBaseProject, ...projectConfig };\n        Object.assign(projectConfig, extendedConfig);\n    }\n}\n\nexport function getBuildOptionsFromBuilderOptions(options: BuildOptions & BuildOptionsCompat): BuildOptionInternal {\n    const buildOptions: BuildOptionInternal = { environment: {} };\n\n    if (options.environment) {\n        const env = normalizeEnvironment(options.environment);\n        buildOptions.environment = env;\n        delete options.environment;\n    }\n\n    if (options.filter) {\n        buildOptions.filter = options.filter;\n        delete options.filter;\n    }\n\n    if (options.verbose != null) {\n        if (options.verbose) {\n            buildOptions.logLevel = 'debug';\n        }\n        delete options.verbose;\n    }\n\n    if (options.logLevel) {\n        buildOptions.logLevel = options.logLevel;\n        delete options.logLevel;\n    }\n\n    if (options.progress != null) {\n        if (options.progress) {\n            buildOptions.progress = true;\n        }\n        delete options.progress;\n    }\n\n    if (options.poll != null) {\n        buildOptions.watchOptions = {\n            poll: options.poll\n        };\n        delete options.poll;\n    }\n\n    if (options.cleanOutDir != null) {\n        if (options.cleanOutDir) {\n            buildOptions.cleanOutDir = true;\n        }\n        delete options.cleanOutDir;\n    }\n\n    if (options.watch != null) {\n        if (options.watch) {\n            buildOptions.watch = true;\n        }\n        delete options.watch;\n    }\n\n    if (options.watchOptions) {\n        buildOptions.watchOptions = { ...options.watchOptions };\n        delete options.watchOptions;\n    }\n\n    if (options.beep != null) {\n        if (options.beep) {\n            buildOptions.beep = true;\n        }\n        delete options.beep;\n    }\n\n    return buildOptions;\n}\n\nexport function applyAppConfigCompat(appConfig: AppBuilderOptions): void {\n    if (appConfig.target && !appConfig.platformTarget) {\n        appConfig.platformTarget = appConfig.target as any;\n        delete appConfig.target;\n    }\n    if (appConfig.platform && !appConfig.platformTarget) {\n        appConfig.platformTarget = appConfig.platform === 'server' ? 'node' : 'web';\n        delete appConfig.platform;\n    }\n    if (appConfig.outDir && !appConfig.outputPath) {\n        appConfig.outputPath = appConfig.outDir;\n        delete appConfig.outDir;\n    }\n    if (appConfig.main && !appConfig.entry) {\n        appConfig.entry = appConfig.main;\n        delete appConfig.main;\n    }\n    if (appConfig.index && !appConfig.htmlInject) {\n        appConfig.htmlInject = {\n            index: appConfig.index\n        };\n        delete appConfig.index;\n    }\n    if (appConfig.evalSourceMap && !appConfig.sourceMapDevTool) {\n        appConfig.sourceMapDevTool = 'eval';\n        delete appConfig.evalSourceMap;\n    }\n    if (appConfig.deployUrl && !appConfig.publicPath) {\n        appConfig.publicPath = appConfig.deployUrl;\n        delete appConfig.deployUrl;\n    }\n    if (appConfig.assets &&\n        Array.isArray(appConfig.assets) &&\n        (!appConfig.copy || (Array.isArray(appConfig.copy) && !appConfig.copy.length))) {\n        appConfig.copy = appConfig.assets.map((assetEntry: string | AssetPatternObjectCompat) => {\n            if (typeof assetEntry === 'string') {\n                return assetEntry;\n            }\n\n            return {\n                from: path.join(assetEntry.input, assetEntry.glob || ''),\n                to: assetEntry.output,\n                exclude: assetEntry.ignore\n            };\n        });\n        delete appConfig.assets;\n    }\n    if (appConfig.deleteOutputPath && !appConfig.clean) {\n        appConfig.clean = {\n            beforeBuild: {\n                cleanOutDir: true\n            }\n        };\n        delete appConfig.deleteOutputPath;\n    }\n    if (appConfig.statsJson && !appConfig.bundleAnalyzer) {\n        appConfig.bundleAnalyzer = {\n            generateStatsFile: true\n        };\n        delete appConfig.statsJson;\n    }\n    if (appConfig.bundleDependencies && appConfig.bundleDependencies === 'none') {\n        appConfig.nodeModulesAsExternals = true;\n        const externals = [\n            /^@angular/,\n            (_: any, request: any, callback: (error?: any, result?: any) => void) => {\n                // Absolute & Relative paths are not externals\n                if (request.match(/^\\.{0,2}\\//)) {\n                    callback();\n\n                    return;\n                }\n\n                try {\n                    // Attempt to resolve the module via Node\n                    const e = require.resolve(request);\n                    if (/node_modules/.test(e)) {\n                        // It's a node_module\n                        callback(null, request);\n                    } else {\n                        // It's a system thing (.ie util, fs...)\n                        callback();\n                    }\n                } catch (e) {\n                    // Node couldn't find it, so it must be user-aliased\n                    callback();\n                }\n            }\n        ];\n        if (!appConfig.externals) {\n            appConfig.externals = externals as any;\n        } else {\n            if (Array.isArray(appConfig.externals)) {\n                appConfig.externals = [...(appConfig.externals as any[]), ...externals];\n            } else {\n                appConfig.externals = [appConfig.externals as any, ...externals];\n            }\n        }\n        delete appConfig.bundleDependencies;\n    }\n}\n\nexport function applyLibConfigCompat(libConfig: LibBuilderOptions): void {\n    if (libConfig.target && !libConfig.platformTarget) {\n        libConfig.platformTarget = libConfig.target as any;\n        delete libConfig.target;\n    }\n\n    if (libConfig.platform && !libConfig.platformTarget) {\n        libConfig.platformTarget = libConfig.platform === 'server' ? 'node' : 'web';\n        delete libConfig.platform;\n    }\n\n    if (libConfig.outDir && !libConfig.outputPath) {\n        libConfig.outputPath = libConfig.outDir;\n        delete libConfig.outDir;\n    }\n\n    if (libConfig.assets &&\n        Array.isArray(libConfig.assets) &&\n        (!libConfig.copy || (Array.isArray(libConfig.copy) && !libConfig.copy.length))) {\n        libConfig.copy = libConfig.assets.map(assetEntry => {\n            if (typeof assetEntry === 'string') {\n                return assetEntry;\n            }\n\n            return {\n                from: path.join(assetEntry.input, assetEntry.glob || ''),\n                to: assetEntry.output,\n                exclude: assetEntry.ignore\n            };\n        });\n        delete libConfig.assets;\n    }\n\n    if (libConfig.deleteOutputPath && !libConfig.clean) {\n        libConfig.clean = {\n            beforeBuild: {\n                cleanOutDir: true\n            }\n        };\n        delete libConfig.deleteOutputPath;\n    }\n\n    if (libConfig.bundleDependencies && libConfig.bundleDependencies === 'all') {\n        libConfig.nodeModulesAsExternals = false;\n    }\n}\n\nexport function mergeAppProjectConfigWithWebpackCli(appConfig: AppProjectConfigInternal,\n    commandOptions: { [key: string]: any }): void {\n    if (commandOptions.target && !appConfig.platformTarget) {\n        appConfig.platformTarget = commandOptions.target;\n    }\n\n    if (commandOptions.outputPublicPath) {\n        appConfig.publicPath = commandOptions.outputPublicPath;\n    }\n\n    if (commandOptions.devtool) {\n        appConfig.sourceMap = true;\n        appConfig.sourceMapDevTool = commandOptions.devtool;\n    }\n}\n\nfunction overrideProjectConfig(oldConfig: any, newConfig: any): void {\n    if (!newConfig || !oldConfig || typeof newConfig !== 'object' || Object.keys(newConfig).length === 0) {\n        return;\n    }\n\n    Object.keys(newConfig).filter((key: string) => key !== 'envOverrides').forEach((key: string) => {\n        oldConfig[key] = JSON.parse(JSON.stringify(newConfig[key]));\n    });\n}\n"]}
\No newline at end of file