tsbuild/ts/tsbuild.classes.compiler.ts

97 lines
2.8 KiB
TypeScript
Raw Permalink Normal View History

2018-07-25 18:56:42 +00:00
// import all the stuff we need
import * as plugins from './tsbuild.plugins';
import { CompilerOptions } from 'typescript';
export { CompilerOptions, ScriptTarget, ModuleKind } from 'typescript';
/**
* the default typescript compilerOptions
*/
export const compilerOptionsDefault: CompilerOptions = {
declaration: true,
emitDecoratorMetadata: true,
experimentalDecorators: true,
inlineSourceMap: true,
noEmitOnError: true,
2020-03-13 19:23:01 +00:00
outDir: 'dist_ts/',
2018-07-25 18:56:42 +00:00
module: plugins.typescript.ModuleKind.CommonJS,
2019-04-30 11:26:49 +00:00
lib: ['lib.es2017.d.ts'],
2018-07-25 18:56:42 +00:00
noImplicitAny: false,
2019-04-30 11:27:42 +00:00
esModuleInterop: true,
2021-10-06 11:33:35 +00:00
target: plugins.typescript.ScriptTarget.ES2017,
importsNotUsedAsValues: plugins.typescript.ImportsNotUsedAsValues.Preserve
2018-07-25 18:56:42 +00:00
};
export const compilerOptionsWebDefault: CompilerOptions = {
...compilerOptionsDefault,
2018-12-05 23:45:22 +00:00
lib: [...compilerOptionsDefault.lib, 'lib.dom.d.ts']
};
2018-07-25 18:56:42 +00:00
/**
* merges compilerOptions with the default compiler options
*/
2019-08-26 14:28:03 +00:00
export const mergeCompilerOptions = (
customTsOptions: CompilerOptions,
argvArg?: any
): CompilerOptions => {
const defaultOptionsToMerge = (() => {
if (argvArg && argvArg.web) {
return compilerOptionsWebDefault;
} else {
return compilerOptionsDefault;
}
})();
2018-07-25 18:56:42 +00:00
// create merged options
2020-03-13 19:23:01 +00:00
const mergedOptions: CompilerOptions = {
...defaultOptionsToMerge,
2018-07-25 18:56:42 +00:00
...customTsOptions
};
return mergedOptions;
};
/**
* the internal main compiler function that compiles the files
*/
export const compiler = (
fileNames: string[],
options: plugins.typescript.CompilerOptions,
2019-08-26 14:28:03 +00:00
argvArg?: any
2018-07-25 18:56:42 +00:00
): Promise<any[]> => {
console.log(`Compiling ${fileNames.length} files...`);
2020-03-13 19:23:01 +00:00
const done = plugins.smartpromise.defer<any[]>();
const program = plugins.typescript.createProgram(fileNames, options);
const emitResult = program.emit();
2018-07-25 18:56:42 +00:00
// implement check only
/*let emitResult = program.emit(undefined,(args) => {
console.log(args)
});*/
2020-03-13 19:23:01 +00:00
const allDiagnostics = plugins.typescript
2018-07-25 18:56:42 +00:00
.getPreEmitDiagnostics(program)
.concat(emitResult.diagnostics);
allDiagnostics.forEach(diagnostic => {
if (diagnostic.file) {
2020-03-13 19:23:01 +00:00
const { line, character } = diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start!);
const message = plugins.typescript.flattenDiagnosticMessageText(diagnostic.messageText, '\n');
2018-07-25 18:56:42 +00:00
console.log(`${diagnostic.file.fileName} (${line + 1},${character + 1}): ${message}`);
} else {
console.log(
`${plugins.typescript.flattenDiagnosticMessageText(diagnostic.messageText, '\n')}`
);
}
});
2018-07-25 18:56:42 +00:00
2020-03-13 19:23:01 +00:00
const exitCode = emitResult.emitSkipped ? 1 : 0;
2018-07-25 18:56:42 +00:00
if (exitCode === 0) {
console.log('TypeScript emit succeeded!');
done.resolve(emitResult.emittedFiles);
} else {
console.error('TypeScript emit failed. Please investigate!');
process.exit(exitCode);
}
return done.promise;
};