Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
export function runOneBuild(args: string[], inputs?: {[path: string]: string}): boolean {
if (args[0] === '-p') args.shift();
// Strip leading at-signs, used to indicate a params file
const project = args[0].replace(/^@+/, '');
const [parsedOptions, errors] = parseTsconfig(project);
if (errors && errors.length) {
console.error(ng.formatDiagnostics(errors));
return false;
}
const {options: tsOptions, bazelOpts, files, config} = parsedOptions;
const angularCompilerOptions: {[k: string]: unknown} = config['angularCompilerOptions'] || {};
// Allow Bazel users to control some of the bazel options.
// Since TypeScript's "extends" mechanism applies only to "compilerOptions"
// we have to repeat some of their logic to get the user's "angularCompilerOptions".
if (config['extends']) {
// Load the user's config file
// Note: this doesn't handle recursive extends so only a user's top level
// `angularCompilerOptions` will be considered. As this code is going to be
// removed with Ivy, the added complication of handling recursive extends
// is likely not needed.
let userConfigFile = resolveNormalizedPath(path.dirname(project), config['extends']);
if (!userConfigFile.endsWith('.json')) userConfigFile += '.json';
const angularCompilerOptions: {[k: string]: unknown} = config['angularCompilerOptions'] || {};
// Allow Bazel users to control some of the bazel options.
// Since TypeScript's "extends" mechanism applies only to "compilerOptions"
// we have to repeat some of their logic to get the user's "angularCompilerOptions".
if (config['extends']) {
// Load the user's config file
// Note: this doesn't handle recursive extends so only a user's top level
// `angularCompilerOptions` will be considered. As this code is going to be
// removed with Ivy, the added complication of handling recursive extends
// is likely not needed.
let userConfigFile = resolveNormalizedPath(path.dirname(project), config['extends']);
if (!userConfigFile.endsWith('.json')) userConfigFile += '.json';
const {config: userConfig, error} = ts.readConfigFile(userConfigFile, ts.sys.readFile);
if (error) {
console.error(ng.formatDiagnostics([error]));
return false;
}
// All user angularCompilerOptions values that a user has control
// over should be collected here
if (userConfig.angularCompilerOptions) {
angularCompilerOptions['diagnostics'] =
angularCompilerOptions['diagnostics'] || userConfig.angularCompilerOptions.diagnostics;
angularCompilerOptions['trace'] =
angularCompilerOptions['trace'] || userConfig.angularCompilerOptions.trace;
angularCompilerOptions['disableExpressionLowering'] =
angularCompilerOptions['disableExpressionLowering'] ||
userConfig.angularCompilerOptions.disableExpressionLowering;
angularCompilerOptions['disableTypeScriptVersionCheck'] =
angularCompilerOptions['disableTypeScriptVersionCheck'] ||
_diagnose(cancellationToken) {
const allDiagnostics = gather_diagnostics_1.gatherDiagnostics(this._program, this._JitMode, 'TypeChecker', gather_diagnostics_1.DiagnosticMode.Semantic, cancellationToken);
// Report diagnostics.
if (!cancellationToken.isCancellationRequested()) {
const errors = allDiagnostics.filter((d) => d.category === ts.DiagnosticCategory.Error);
const warnings = allDiagnostics.filter((d) => d.category === ts.DiagnosticCategory.Warning);
if (errors.length > 0) {
const message = compiler_cli_1.formatDiagnostics(errors);
this.sendMessage(new type_checker_messages_1.LogMessage('error', 'ERROR in ' + message));
}
else {
// Reset the changed file tracker only if there are no errors.
this._compilerHost.resetChangedFileTracker();
}
if (warnings.length > 0) {
const message = compiler_cli_1.formatDiagnostics(warnings);
this.sendMessage(new type_checker_messages_1.LogMessage('warn', 'WARNING in ' + message));
}
}
}
sendMessage(msg) {
_diagnose(cancellationToken) {
const allDiagnostics = gather_diagnostics_1.gatherDiagnostics(this._program, this._JitMode, 'TypeChecker', gather_diagnostics_1.DiagnosticMode.Semantic, cancellationToken);
// Report diagnostics.
if (!cancellationToken.isCancellationRequested()) {
const errors = allDiagnostics.filter((d) => d.category === ts.DiagnosticCategory.Error);
const warnings = allDiagnostics.filter((d) => d.category === ts.DiagnosticCategory.Warning);
if (errors.length > 0) {
const message = compiler_cli_1.formatDiagnostics(errors);
this.sendMessage(new type_checker_messages_1.LogMessage('error', 'ERROR in ' + message));
}
else {
// Reset the changed file tracker only if there are no errors.
this._compilerHost.resetChangedFileTracker();
}
if (warnings.length > 0) {
const message = compiler_cli_1.formatDiagnostics(warnings);
this.sendMessage(new type_checker_messages_1.LogMessage('warn', 'WARNING in ' + message));
}
}
}
sendMessage(msg) {
this._tsConfigPath = forwardSlashPath(options.tsConfigPath);
// Check the base path.
const maybeBasePath = path.resolve(process.cwd(), this._tsConfigPath);
let basePath = maybeBasePath;
if (fs.statSync(maybeBasePath).isFile()) {
basePath = path.dirname(basePath);
}
if (options.basePath !== undefined) {
basePath = path.resolve(process.cwd(), options.basePath);
}
// Parse the tsconfig contents.
const config = readConfiguration(this._tsConfigPath);
if (config.errors && config.errors.length) {
throw new Error(formatDiagnostics(config.errors));
}
this._rootNames = config.rootNames;
this._compilerOptions = { ...config.options, ...options.compilerOptions };
this._basePath = config.options.basePath || basePath || '';
// Overwrite outDir so we can find generated files next to their .ts origin in compilerHost.
this._compilerOptions.outDir = '';
this._compilerOptions.suppressOutputPathCheck = true;
// Default plugin sourceMap to compiler options setting.
if (!options.hasOwnProperty('sourceMap')) {
options.sourceMap = this._compilerOptions.sourceMap || false;
}
// Force the right sourcemap options.
const expectedOuts = config['angularCompilerOptions']['expectedOut'];
const {basePath} = ng.calcProjectFileAndBasePath(project);
const compilerOpts = ng.createNgCompilerOptions(basePath, config, tsOptions);
const tsHost = ts.createCompilerHost(compilerOpts, true);
const {diagnostics} = compile({
allDepsCompiledWithBazel: ALL_DEPS_COMPILED_WITH_BAZEL,
compilerOpts,
tsHost,
bazelOpts,
files,
inputs,
expectedOuts
});
if (diagnostics.length) {
console.error(ng.formatDiagnostics(diagnostics));
}
return diagnostics.every(d => d.category !== ts.DiagnosticCategory.Error);
}
break;
}
}
if (tsErrors.length > 0) {
const message = ts.formatDiagnosticsWithColorAndContext(tsErrors, compilerHost);
reportError(message);
}
if (tsWarnings.length > 0) {
const message = ts.formatDiagnosticsWithColorAndContext(tsWarnings, compilerHost);
reportWarning(message);
}
if (ngErrors.length > 0) {
const message = formatDiagnostics(ngErrors);
reportError(message);
}
if (ngWarnings.length > 0) {
const message = formatDiagnostics(ngWarnings);
reportWarning(message);
}
}
const message = ts.formatDiagnosticsWithColorAndContext(tsErrors, compilerHost);
reportError(message);
}
if (tsWarnings.length > 0) {
const message = ts.formatDiagnosticsWithColorAndContext(tsWarnings, compilerHost);
reportWarning(message);
}
if (ngErrors.length > 0) {
const message = formatDiagnostics(ngErrors);
reportError(message);
}
if (ngWarnings.length > 0) {
const message = formatDiagnostics(ngWarnings);
reportWarning(message);
}
}