Compare commits
29 Commits
Author | SHA1 | Date | |
---|---|---|---|
9e94bc56ff | |||
cd549b8aaf | |||
dcf5c6ab22 | |||
00480a27e0 | |||
353c1f6dbd | |||
e540ac8327 | |||
ef1bc5c93a | |||
a76aaa45d2 | |||
d07c7a74e8 | |||
69f6f7460f | |||
f01e07933e | |||
51b5343440 | |||
6815f9bd5d | |||
1b68c19d92 | |||
51cc29d79b | |||
39d94a3daa | |||
c46fcb6ea3 | |||
ff83eae8e4 | |||
b6179bf8fc | |||
8c08cf68d4 | |||
cc7ec18141 | |||
8f5b0a747a | |||
3971df8ad8 | |||
c129560e07 | |||
ea44ec9a14 | |||
dbbcd3d0b5 | |||
abd68e0846 | |||
cfac1c5008 | |||
c4b38d7b41 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -4,3 +4,4 @@ coverage/
|
||||
public/
|
||||
pages/
|
||||
.yarn/
|
||||
tscache
|
||||
|
4
.snyk
Normal file
4
.snyk
Normal file
@ -0,0 +1,4 @@
|
||||
# Snyk (https://snyk.io) policy file, patches or ignores known vulnerabilities.
|
||||
version: v1.12.0
|
||||
ignore: {}
|
||||
patch: {}
|
22
LICENSE
Normal file
22
LICENSE
Normal file
@ -0,0 +1,22 @@
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2018 Lossless GmbH (hello@lossless.com)
|
||||
Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com)
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
3
cli.js
Normal file
3
cli.js
Normal file
@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env node
|
||||
process.env.CLI_CALL_TSRUN = 'true'
|
||||
var index = require("./dist/index.js");
|
3
dist/cli.js
vendored
3
dist/cli.js
vendored
@ -1,3 +0,0 @@
|
||||
#!/usr/bin/env node
|
||||
process.env.CLI_CALL = 'true'
|
||||
var index = require("../dist/index.js");
|
18
dist/index.js
vendored
18
dist/index.js
vendored
@ -1,12 +1,20 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
const tsNode = require("ts-node");
|
||||
const path = require("path");
|
||||
const tsNode = require("./tsnode");
|
||||
tsNode.register({
|
||||
compilerOptions: {
|
||||
lib: ['es2016', 'es2017']
|
||||
}
|
||||
},
|
||||
skipIgnore: true,
|
||||
cacheDirectory: path.join(__dirname, '../tscache')
|
||||
});
|
||||
const pathToLoad = path.join(process.cwd(), process.argv.pop());
|
||||
Promise.resolve().then(() => require(pathToLoad));
|
||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGtDQUFrQztBQUNsQyw2QkFBNkI7QUFFN0IsTUFBTSxDQUFDLFFBQVEsQ0FBQztJQUNkLGVBQWUsRUFBRTtRQUNmLEdBQUcsRUFBRSxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUM7S0FDMUI7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7QUFDaEUscUNBQU8sVUFBVSxHQUFFIn0=
|
||||
if (process.env.CLI_CALL_TSRUN) {
|
||||
// contents of argv array
|
||||
// process.argv[0] -> node Executable
|
||||
// process.argv[1] -> tsrun executable
|
||||
const pathToTsFile = process.argv[2];
|
||||
const pathToLoad = path.join(process.cwd(), pathToTsFile);
|
||||
Promise.resolve().then(() => require(pathToLoad));
|
||||
}
|
||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDZCQUE2QjtBQUM3QixtQ0FBbUM7QUFFbkMsTUFBTSxDQUFDLFFBQVEsQ0FBQztJQUNkLGVBQWUsRUFBRTtRQUNmLEdBQUcsRUFBRSxDQUFFLFFBQVEsRUFBRSxRQUFRLENBQUU7S0FDNUI7SUFDRCxVQUFVLEVBQUUsSUFBSTtJQUNoQixjQUFjLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsWUFBWSxDQUFDO0NBQ25ELENBQUMsQ0FBQztBQUVILElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUU7SUFDOUIseUJBQXlCO0lBQ3pCLHFDQUFxQztJQUNyQyxzQ0FBc0M7SUFDdEMsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUVwQyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxZQUFZLENBQUMsQ0FBQztJQUMxRCxxQ0FBTyxVQUFVLEdBQUU7Q0FDcEIifQ==
|
99
dist/tsnode.d.ts
vendored
Normal file
99
dist/tsnode.d.ts
vendored
Normal file
@ -0,0 +1,99 @@
|
||||
import { BaseError } from 'make-error';
|
||||
import * as _ts from 'typescript';
|
||||
/**
|
||||
* @internal
|
||||
*/
|
||||
export declare const INSPECT_CUSTOM: string | symbol;
|
||||
/**
|
||||
* Common TypeScript interfaces between versions.
|
||||
*/
|
||||
export interface TSCommon {
|
||||
version: typeof _ts.version;
|
||||
sys: typeof _ts.sys;
|
||||
ScriptSnapshot: typeof _ts.ScriptSnapshot;
|
||||
displayPartsToString: typeof _ts.displayPartsToString;
|
||||
createLanguageService: typeof _ts.createLanguageService;
|
||||
getDefaultLibFilePath: typeof _ts.getDefaultLibFilePath;
|
||||
getPreEmitDiagnostics: typeof _ts.getPreEmitDiagnostics;
|
||||
flattenDiagnosticMessageText: typeof _ts.flattenDiagnosticMessageText;
|
||||
transpileModule: typeof _ts.transpileModule;
|
||||
ModuleKind: typeof _ts.ModuleKind;
|
||||
ScriptTarget: typeof _ts.ScriptTarget;
|
||||
findConfigFile: typeof _ts.findConfigFile;
|
||||
readConfigFile: typeof _ts.readConfigFile;
|
||||
parseJsonConfigFileContent: typeof _ts.parseJsonConfigFileContent;
|
||||
formatDiagnostics: typeof _ts.formatDiagnostics;
|
||||
formatDiagnosticsWithColorAndContext: typeof _ts.formatDiagnosticsWithColorAndContext;
|
||||
}
|
||||
/**
|
||||
* Export the current version.
|
||||
*/
|
||||
export declare const VERSION: any;
|
||||
/**
|
||||
* Registration options.
|
||||
*/
|
||||
export interface Options {
|
||||
pretty?: boolean | null;
|
||||
typeCheck?: boolean | null;
|
||||
transpileOnly?: boolean | null;
|
||||
files?: boolean | null;
|
||||
cache?: boolean | null;
|
||||
cacheDirectory?: string;
|
||||
compiler?: string;
|
||||
ignore?: string | string[];
|
||||
project?: string;
|
||||
skipIgnore?: boolean | null;
|
||||
skipProject?: boolean | null;
|
||||
compilerOptions?: object;
|
||||
ignoreDiagnostics?: number | string | Array<number | string>;
|
||||
readFile?: (path: string) => string | undefined;
|
||||
fileExists?: (path: string) => boolean;
|
||||
transformers?: _ts.CustomTransformers;
|
||||
}
|
||||
/**
|
||||
* Information retrieved from type info check.
|
||||
*/
|
||||
export interface TypeInfo {
|
||||
name: string;
|
||||
comment: string;
|
||||
}
|
||||
/**
|
||||
* Default register options.
|
||||
*/
|
||||
export declare const DEFAULTS: Options;
|
||||
/**
|
||||
* Split a string array of values.
|
||||
*/
|
||||
export declare function split(value: string | undefined): string[];
|
||||
/**
|
||||
* Parse a string as JSON.
|
||||
*/
|
||||
export declare function parse(value: string | undefined): object | undefined;
|
||||
/**
|
||||
* Replace backslashes with forward slashes.
|
||||
*/
|
||||
export declare function normalizeSlashes(value: string): string;
|
||||
/**
|
||||
* TypeScript diagnostics error.
|
||||
*/
|
||||
export declare class TSError extends BaseError {
|
||||
diagnosticText: string;
|
||||
diagnosticCodes: number[];
|
||||
name: string;
|
||||
constructor(diagnosticText: string, diagnosticCodes: number[]);
|
||||
}
|
||||
/**
|
||||
* Return type for registering `ts-node`.
|
||||
*/
|
||||
export interface Register {
|
||||
cwd: string;
|
||||
extensions: string[];
|
||||
cachedir: string;
|
||||
ts: TSCommon;
|
||||
compile(code: string, fileName: string, lineOffset?: number): string;
|
||||
getTypeInfo(code: string, fileName: string, position: number): TypeInfo;
|
||||
}
|
||||
/**
|
||||
* Register TypeScript compiler.
|
||||
*/
|
||||
export declare function register(opts?: Options): Register;
|
440
dist/tsnode.js
vendored
Normal file
440
dist/tsnode.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -1,6 +1,5 @@
|
||||
{
|
||||
"npmts": {
|
||||
"cli": true
|
||||
},
|
||||
"npmci": {
|
||||
"npmGlobalTools": [
|
||||
|
486
package-lock.json
generated
486
package-lock.json
generated
@ -1,38 +1,281 @@
|
||||
{
|
||||
"name": "tsrun",
|
||||
"version": "1.0.2",
|
||||
"name": "@gitzone/tsrun",
|
||||
"version": "1.0.16",
|
||||
"lockfileVersion": 1,
|
||||
"requires": true,
|
||||
"dependencies": {
|
||||
"@types/fs-extra": {
|
||||
"version": "5.0.0",
|
||||
"resolved": "https://registry.npmjs.org/@types/fs-extra/-/fs-extra-5.0.0.tgz",
|
||||
"integrity": "sha512-qtxDULQKUenuaDLW003CgC+0T0eiAfH3BrH+vSt87GLzbz5EZ6Ox6mv9rMttvhDOatbb9nYh0E1m7ydoYwUrAg==",
|
||||
"requires": {
|
||||
"@types/node": "*"
|
||||
}
|
||||
},
|
||||
"@types/node": {
|
||||
"version": "10.3.0",
|
||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-10.3.0.tgz",
|
||||
"integrity": "sha512-hWzNviaVFIr1TqcRA8ou49JaSHp+Rfabmnqg2kNvusKqLhPU0rIsGPUj5WJJ7ld4Bb7qdgLmIhLfCD1qS08IVA=="
|
||||
},
|
||||
"@types/vinyl": {
|
||||
"version": "2.0.2",
|
||||
"resolved": "https://registry.npmjs.org/@types/vinyl/-/vinyl-2.0.2.tgz",
|
||||
"integrity": "sha512-2iYpNuOl98SrLPBZfEN9Mh2JCJ2EI9HU35SfgBEb51DcmaHkhp8cKMblYeBqMQiwXMgAD3W60DbQ4i/UdLiXhw==",
|
||||
"requires": {
|
||||
"@types/node": "*"
|
||||
}
|
||||
},
|
||||
"argparse": {
|
||||
"version": "1.0.10",
|
||||
"resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
|
||||
"integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
|
||||
"requires": {
|
||||
"sprintf-js": "~1.0.2"
|
||||
}
|
||||
},
|
||||
"arrify": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz",
|
||||
"integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0="
|
||||
},
|
||||
"balanced-match": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
|
||||
"integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c="
|
||||
},
|
||||
"brace-expansion": {
|
||||
"version": "1.1.11",
|
||||
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
|
||||
"integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
|
||||
"requires": {
|
||||
"balanced-match": "^1.0.0",
|
||||
"concat-map": "0.0.1"
|
||||
}
|
||||
},
|
||||
"buffer-from": {
|
||||
"version": "1.1.0",
|
||||
"resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.0.tgz",
|
||||
"integrity": "sha512-c5mRlguI/Pe2dSZmpER62rSCu0ryKmWddzRYsuXc50U2/g8jMOulc31VZMa4mYx31U5xsmSOpDCgH88Vl9cDGQ=="
|
||||
},
|
||||
"diff": {
|
||||
"version": "3.5.0",
|
||||
"resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz",
|
||||
"integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA=="
|
||||
"clone": {
|
||||
"version": "2.1.1",
|
||||
"resolved": "https://registry.npmjs.org/clone/-/clone-2.1.1.tgz",
|
||||
"integrity": "sha1-0hfR6WERjjrJpLi7oyhVU79kfNs="
|
||||
},
|
||||
"clone-buffer": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/clone-buffer/-/clone-buffer-1.0.0.tgz",
|
||||
"integrity": "sha1-4+JbIHrE5wGvch4staFnksrD3Fg="
|
||||
},
|
||||
"clone-stats": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/clone-stats/-/clone-stats-1.0.0.tgz",
|
||||
"integrity": "sha1-s3gt/4u1R04Yuba/D9/ngvh3doA="
|
||||
},
|
||||
"cloneable-readable": {
|
||||
"version": "1.1.2",
|
||||
"resolved": "https://registry.npmjs.org/cloneable-readable/-/cloneable-readable-1.1.2.tgz",
|
||||
"integrity": "sha512-Bq6+4t+lbM8vhTs/Bef5c5AdEMtapp/iFb6+s4/Hh9MVTt8OLKH7ZOOZSCT+Ys7hsHvqv0GuMPJ1lnQJVHvxpg==",
|
||||
"requires": {
|
||||
"inherits": "^2.0.1",
|
||||
"process-nextick-args": "^2.0.0",
|
||||
"readable-stream": "^2.3.5"
|
||||
}
|
||||
},
|
||||
"concat-map": {
|
||||
"version": "0.0.1",
|
||||
"resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
|
||||
"integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s="
|
||||
},
|
||||
"core-util-is": {
|
||||
"version": "1.0.2",
|
||||
"resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
|
||||
"integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
|
||||
},
|
||||
"define-properties": {
|
||||
"version": "1.1.2",
|
||||
"resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz",
|
||||
"integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=",
|
||||
"requires": {
|
||||
"foreach": "^2.0.5",
|
||||
"object-keys": "^1.0.8"
|
||||
}
|
||||
},
|
||||
"es-abstract": {
|
||||
"version": "1.12.0",
|
||||
"resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.12.0.tgz",
|
||||
"integrity": "sha512-C8Fx/0jFmV5IPoMOFPA9P9G5NtqW+4cOPit3MIuvR2t7Ag2K15EJTpxnHAYTzL+aYQJIESYeXZmDBfOBE1HcpA==",
|
||||
"requires": {
|
||||
"es-to-primitive": "^1.1.1",
|
||||
"function-bind": "^1.1.1",
|
||||
"has": "^1.0.1",
|
||||
"is-callable": "^1.1.3",
|
||||
"is-regex": "^1.0.4"
|
||||
}
|
||||
},
|
||||
"es-to-primitive": {
|
||||
"version": "1.1.1",
|
||||
"resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz",
|
||||
"integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=",
|
||||
"requires": {
|
||||
"is-callable": "^1.1.1",
|
||||
"is-date-object": "^1.0.1",
|
||||
"is-symbol": "^1.0.1"
|
||||
}
|
||||
},
|
||||
"esprima": {
|
||||
"version": "4.0.0",
|
||||
"resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz",
|
||||
"integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw=="
|
||||
},
|
||||
"first-chunk-stream": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/first-chunk-stream/-/first-chunk-stream-2.0.0.tgz",
|
||||
"integrity": "sha1-G97NuOCDwGZLkZRVgVd6Q6nzHXA=",
|
||||
"requires": {
|
||||
"readable-stream": "^2.0.2"
|
||||
}
|
||||
},
|
||||
"foreach": {
|
||||
"version": "2.0.5",
|
||||
"resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz",
|
||||
"integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k="
|
||||
},
|
||||
"fs-extra": {
|
||||
"version": "5.0.0",
|
||||
"resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-5.0.0.tgz",
|
||||
"integrity": "sha512-66Pm4RYbjzdyeuqudYqhFiNBbCIuI9kgRqLPSHIlXHidW8NIQtVdkM1yeZ4lXwuhbTETv3EUGMNHAAw6hiundQ==",
|
||||
"requires": {
|
||||
"graceful-fs": "^4.1.2",
|
||||
"jsonfile": "^4.0.0",
|
||||
"universalify": "^0.1.0"
|
||||
}
|
||||
},
|
||||
"fs.realpath": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
|
||||
"integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8="
|
||||
},
|
||||
"function-bind": {
|
||||
"version": "1.1.1",
|
||||
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
|
||||
"integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
|
||||
},
|
||||
"glob": {
|
||||
"version": "7.1.2",
|
||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
||||
"integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
|
||||
"requires": {
|
||||
"fs.realpath": "^1.0.0",
|
||||
"inflight": "^1.0.4",
|
||||
"inherits": "2",
|
||||
"minimatch": "^3.0.4",
|
||||
"once": "^1.3.0",
|
||||
"path-is-absolute": "^1.0.0"
|
||||
}
|
||||
},
|
||||
"graceful-fs": {
|
||||
"version": "4.1.11",
|
||||
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz",
|
||||
"integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg="
|
||||
},
|
||||
"has": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
|
||||
"integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
|
||||
"requires": {
|
||||
"function-bind": "^1.1.1"
|
||||
}
|
||||
},
|
||||
"home": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/home/-/home-1.0.1.tgz",
|
||||
"integrity": "sha1-lqQjzrSbmDeP9e886uBZpVf53TU=",
|
||||
"requires": {
|
||||
"os-homedir": "^1.0.1"
|
||||
}
|
||||
},
|
||||
"inflight": {
|
||||
"version": "1.0.6",
|
||||
"resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
|
||||
"integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
|
||||
"requires": {
|
||||
"once": "^1.3.0",
|
||||
"wrappy": "1"
|
||||
}
|
||||
},
|
||||
"inherits": {
|
||||
"version": "2.0.3",
|
||||
"resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
|
||||
"integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
|
||||
},
|
||||
"is-callable": {
|
||||
"version": "1.1.3",
|
||||
"resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz",
|
||||
"integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI="
|
||||
},
|
||||
"is-date-object": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz",
|
||||
"integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY="
|
||||
},
|
||||
"is-regex": {
|
||||
"version": "1.0.4",
|
||||
"resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz",
|
||||
"integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=",
|
||||
"requires": {
|
||||
"has": "^1.0.1"
|
||||
}
|
||||
},
|
||||
"is-symbol": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz",
|
||||
"integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI="
|
||||
},
|
||||
"is-utf8": {
|
||||
"version": "0.2.1",
|
||||
"resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz",
|
||||
"integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI="
|
||||
},
|
||||
"isarray": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
|
||||
"integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE="
|
||||
},
|
||||
"js-yaml": {
|
||||
"version": "3.12.0",
|
||||
"resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz",
|
||||
"integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==",
|
||||
"requires": {
|
||||
"argparse": "^1.0.7",
|
||||
"esprima": "^4.0.0"
|
||||
}
|
||||
},
|
||||
"jsonfile": {
|
||||
"version": "4.0.0",
|
||||
"resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
|
||||
"integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=",
|
||||
"requires": {
|
||||
"graceful-fs": "^4.1.6"
|
||||
}
|
||||
},
|
||||
"make-error": {
|
||||
"version": "1.3.4",
|
||||
"resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.4.tgz",
|
||||
"integrity": "sha512-0Dab5btKVPhibSalc9QGXb559ED7G7iLjFXBaj9Wq8O3vorueR5K5jaE3hkG6ZQINyhA/JgG6Qk4qdFQjsYV6g=="
|
||||
},
|
||||
"minimatch": {
|
||||
"version": "3.0.4",
|
||||
"resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
|
||||
"integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
|
||||
"requires": {
|
||||
"brace-expansion": "^1.1.7"
|
||||
}
|
||||
},
|
||||
"minimist": {
|
||||
"version": "1.2.0",
|
||||
"resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz",
|
||||
"integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ="
|
||||
"version": "0.0.8",
|
||||
"resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
|
||||
"integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0="
|
||||
},
|
||||
"mkdirp": {
|
||||
"version": "0.5.1",
|
||||
@ -40,13 +283,124 @@
|
||||
"integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=",
|
||||
"requires": {
|
||||
"minimist": "0.0.8"
|
||||
},
|
||||
"dependencies": {
|
||||
"minimist": {
|
||||
"version": "0.0.8",
|
||||
"resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
|
||||
"integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0="
|
||||
}
|
||||
}
|
||||
},
|
||||
"object-keys": {
|
||||
"version": "1.0.12",
|
||||
"resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.12.tgz",
|
||||
"integrity": "sha512-FTMyFUm2wBcGHnH2eXmz7tC6IwlqQZ6mVZ+6dm6vZ4IQIHjs6FdNsQBuKGPuUUUY6NfJw2PshC08Tn6LzLDOag=="
|
||||
},
|
||||
"object.getownpropertydescriptors": {
|
||||
"version": "2.0.3",
|
||||
"resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz",
|
||||
"integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=",
|
||||
"requires": {
|
||||
"define-properties": "^1.1.2",
|
||||
"es-abstract": "^1.5.1"
|
||||
}
|
||||
},
|
||||
"once": {
|
||||
"version": "1.4.0",
|
||||
"resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
|
||||
"integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
|
||||
"requires": {
|
||||
"wrappy": "1"
|
||||
}
|
||||
},
|
||||
"os-homedir": {
|
||||
"version": "1.0.2",
|
||||
"resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz",
|
||||
"integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M="
|
||||
},
|
||||
"path-is-absolute": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
|
||||
"integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18="
|
||||
},
|
||||
"pify": {
|
||||
"version": "2.3.0",
|
||||
"resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz",
|
||||
"integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw="
|
||||
},
|
||||
"process-nextick-args": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz",
|
||||
"integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw=="
|
||||
},
|
||||
"readable-stream": {
|
||||
"version": "2.3.6",
|
||||
"resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz",
|
||||
"integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==",
|
||||
"requires": {
|
||||
"core-util-is": "~1.0.0",
|
||||
"inherits": "~2.0.3",
|
||||
"isarray": "~1.0.0",
|
||||
"process-nextick-args": "~2.0.0",
|
||||
"safe-buffer": "~5.1.1",
|
||||
"string_decoder": "~1.1.1",
|
||||
"util-deprecate": "~1.0.1"
|
||||
}
|
||||
},
|
||||
"remove-trailing-separator": {
|
||||
"version": "1.1.0",
|
||||
"resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
|
||||
"integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8="
|
||||
},
|
||||
"replace-ext": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/replace-ext/-/replace-ext-1.0.0.tgz",
|
||||
"integrity": "sha1-3mMSg3P8v3w8z6TeWkgMRaZ5WOs="
|
||||
},
|
||||
"require-reload": {
|
||||
"version": "0.2.2",
|
||||
"resolved": "https://registry.npmjs.org/require-reload/-/require-reload-0.2.2.tgz",
|
||||
"integrity": "sha1-KadZGEbK+RtuijzamRaD+V+NfUI="
|
||||
},
|
||||
"safe-buffer": {
|
||||
"version": "5.1.2",
|
||||
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
|
||||
"integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
|
||||
},
|
||||
"smartfile": {
|
||||
"version": "4.2.28",
|
||||
"resolved": "https://registry.npmjs.org/smartfile/-/smartfile-4.2.28.tgz",
|
||||
"integrity": "sha512-zUeAOLYftz8xLfKTs9U1NOuNPTA9jlvTQNr7lDIv84kXnr1AEpDb2Xwy1MdK1w733sBil/RkxtezrkvgRVAnNg==",
|
||||
"requires": {
|
||||
"@types/fs-extra": "5.0.0",
|
||||
"@types/vinyl": "^2.0.2",
|
||||
"fs-extra": "^5.0.0",
|
||||
"glob": "^7.1.2",
|
||||
"js-yaml": "^3.10.0",
|
||||
"require-reload": "0.2.2",
|
||||
"smartpath": "^3.2.8",
|
||||
"smartq": "^1.1.6",
|
||||
"smartrequest": "^1.0.8",
|
||||
"vinyl-file": "^3.0.0"
|
||||
}
|
||||
},
|
||||
"smartpath": {
|
||||
"version": "3.2.8",
|
||||
"resolved": "https://registry.npmjs.org/smartpath/-/smartpath-3.2.8.tgz",
|
||||
"integrity": "sha1-SDS9OouuIpW6rK26I8h6UBlS+UA=",
|
||||
"requires": {
|
||||
"home": "^1.0.1",
|
||||
"typings-global": "^1.0.14"
|
||||
}
|
||||
},
|
||||
"smartq": {
|
||||
"version": "1.1.8",
|
||||
"resolved": "https://registry.npmjs.org/smartq/-/smartq-1.1.8.tgz",
|
||||
"integrity": "sha512-FURlYW/C3bLeZjJcBVyw7bxCyQoCXiXbLCZcDUKznhXHaLu35c8m33/a2H8CA0rtb82lvzN8dRLnBZAcNMzNHQ==",
|
||||
"requires": {
|
||||
"util.promisify": "^1.0.0"
|
||||
}
|
||||
},
|
||||
"smartrequest": {
|
||||
"version": "1.0.13",
|
||||
"resolved": "https://registry.npmjs.org/smartrequest/-/smartrequest-1.0.13.tgz",
|
||||
"integrity": "sha512-OHrvzaxaA8Z8bJr33yxnyJF35nrWyaumsajqXm2Zkv0/2hfWO1NQAj02VVV51rLQfmtU0Hex7Nk19SoC8nOmYg==",
|
||||
"requires": {
|
||||
"smartq": "^1.1.1"
|
||||
}
|
||||
},
|
||||
"source-map": {
|
||||
@ -63,18 +417,42 @@
|
||||
"source-map": "^0.6.0"
|
||||
}
|
||||
},
|
||||
"ts-node": {
|
||||
"version": "6.1.0",
|
||||
"resolved": "https://registry.npmjs.org/ts-node/-/ts-node-6.1.0.tgz",
|
||||
"integrity": "sha512-mw11Bq08RZgrU/bzcVw/Ti9wNyefpOanXgWsHg008wyVHjvFhWxNatVVrciOAu8BcWSECoNOSunRzUokKH8Mmw==",
|
||||
"sprintf-js": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
|
||||
"integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw="
|
||||
},
|
||||
"string_decoder": {
|
||||
"version": "1.1.1",
|
||||
"resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
|
||||
"integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
|
||||
"requires": {
|
||||
"arrify": "^1.0.0",
|
||||
"diff": "^3.1.0",
|
||||
"make-error": "^1.1.1",
|
||||
"minimist": "^1.2.0",
|
||||
"mkdirp": "^0.5.1",
|
||||
"source-map-support": "^0.5.6",
|
||||
"yn": "^2.0.0"
|
||||
"safe-buffer": "~5.1.0"
|
||||
}
|
||||
},
|
||||
"strip-bom": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz",
|
||||
"integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=",
|
||||
"requires": {
|
||||
"is-utf8": "^0.2.0"
|
||||
}
|
||||
},
|
||||
"strip-bom-buf": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/strip-bom-buf/-/strip-bom-buf-1.0.0.tgz",
|
||||
"integrity": "sha1-HLRar1dTD0yvhsf3UXnSyaUd1XI=",
|
||||
"requires": {
|
||||
"is-utf8": "^0.2.1"
|
||||
}
|
||||
},
|
||||
"strip-bom-stream": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/strip-bom-stream/-/strip-bom-stream-2.0.0.tgz",
|
||||
"integrity": "sha1-+H217yYT9paKpUWr/h7HKLaoKco=",
|
||||
"requires": {
|
||||
"first-chunk-stream": "^2.0.0",
|
||||
"strip-bom": "^2.0.0"
|
||||
}
|
||||
},
|
||||
"typescript": {
|
||||
@ -82,6 +460,60 @@
|
||||
"resolved": "https://registry.npmjs.org/typescript/-/typescript-2.9.1.tgz",
|
||||
"integrity": "sha512-h6pM2f/GDchCFlldnriOhs1QHuwbnmj6/v7499eMHqPeW4V2G0elua2eIc2nu8v2NdHV0Gm+tzX83Hr6nUFjQA=="
|
||||
},
|
||||
"typings-global": {
|
||||
"version": "1.0.28",
|
||||
"resolved": "https://registry.npmjs.org/typings-global/-/typings-global-1.0.28.tgz",
|
||||
"integrity": "sha512-6VOwJWEY2971HOMHu/7sURzUXiD4/LiMJPsMAOqkHHAtS3MVpLFE5gzTiHilsH9KY5VE1mBQirWIgWFsDuo90A=="
|
||||
},
|
||||
"universalify": {
|
||||
"version": "0.1.2",
|
||||
"resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
|
||||
"integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg=="
|
||||
},
|
||||
"util-deprecate": {
|
||||
"version": "1.0.2",
|
||||
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
|
||||
"integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
|
||||
},
|
||||
"util.promisify": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz",
|
||||
"integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==",
|
||||
"requires": {
|
||||
"define-properties": "^1.1.2",
|
||||
"object.getownpropertydescriptors": "^2.0.3"
|
||||
}
|
||||
},
|
||||
"vinyl": {
|
||||
"version": "2.2.0",
|
||||
"resolved": "https://registry.npmjs.org/vinyl/-/vinyl-2.2.0.tgz",
|
||||
"integrity": "sha512-MBH+yP0kC/GQ5GwBqrTPTzEfiiLjta7hTtvQtbxBgTeSXsmKQRQecjibMbxIXzVT3Y9KJK+drOz1/k+vsu8Nkg==",
|
||||
"requires": {
|
||||
"clone": "^2.1.1",
|
||||
"clone-buffer": "^1.0.0",
|
||||
"clone-stats": "^1.0.0",
|
||||
"cloneable-readable": "^1.0.0",
|
||||
"remove-trailing-separator": "^1.0.1",
|
||||
"replace-ext": "^1.0.0"
|
||||
}
|
||||
},
|
||||
"vinyl-file": {
|
||||
"version": "3.0.0",
|
||||
"resolved": "https://registry.npmjs.org/vinyl-file/-/vinyl-file-3.0.0.tgz",
|
||||
"integrity": "sha1-sQTZ5ECf+jJfqt1SBkLQo7SIs2U=",
|
||||
"requires": {
|
||||
"graceful-fs": "^4.1.2",
|
||||
"pify": "^2.3.0",
|
||||
"strip-bom-buf": "^1.0.0",
|
||||
"strip-bom-stream": "^2.0.0",
|
||||
"vinyl": "^2.0.1"
|
||||
}
|
||||
},
|
||||
"wrappy": {
|
||||
"version": "1.0.2",
|
||||
"resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
|
||||
"integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8="
|
||||
},
|
||||
"yn": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz",
|
||||
|
25
package.json
25
package.json
@ -1,24 +1,31 @@
|
||||
{
|
||||
"name": "tsrun",
|
||||
"version": "1.0.2",
|
||||
"name": "@gitzone/tsrun",
|
||||
"version": "1.0.16",
|
||||
"description": "run typescript programs efficiently",
|
||||
"main": "dist/index.js",
|
||||
"typings": "dist/index.d.ts",
|
||||
"author": "Lossless GmbH",
|
||||
"license": "MIT",
|
||||
"bin": {
|
||||
"tsrun": "dist/cli.js"
|
||||
"tsrun": "./cli.js"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "(npmts --notest && node dist/cli.js -d test/test.ts)",
|
||||
"test": "(npmts --notest && node ./cli.js test/test.ts)",
|
||||
"format": "(gitzone format)",
|
||||
"build": "echo \"Not needed for now\""
|
||||
"build": "echo \"Not needed for now\"",
|
||||
"postinstall": "ts-node --skip-ignore true --compilerOptions '{\"lib\": [\"ES2015\"]}' scripts/postinstall.ts"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/node": "^10.3.0"
|
||||
},
|
||||
"devDependencies": {},
|
||||
"dependencies": {
|
||||
"@types/node": "^10.3.0",
|
||||
"ts-node": "^6.1.0",
|
||||
"typescript": "^2.9.1"
|
||||
"arrify": "^1.0.1",
|
||||
"make-error": "^1.3.4",
|
||||
"mkdirp": "^0.5.1",
|
||||
"smartfile": "^4.2.28",
|
||||
"source-map-support": "^0.5.6",
|
||||
"typescript": "^2.9.1",
|
||||
"yn": "^2.0.0"
|
||||
},
|
||||
"private": false
|
||||
}
|
||||
|
10
scripts/postinstall.ts
Normal file
10
scripts/postinstall.ts
Normal file
@ -0,0 +1,10 @@
|
||||
// This file takes care of some postinstall actions like clearing the TypeScript cache.
|
||||
import * as smartfile from 'smartfile';
|
||||
import * as path from 'path';
|
||||
|
||||
const run = async () => {
|
||||
const tsCacheDir = path.join(__dirname, '../tscache');
|
||||
await smartfile.fs.ensureEmptyDir(tsCacheDir);
|
||||
}
|
||||
|
||||
run()
|
19
ts/index.ts
19
ts/index.ts
@ -1,11 +1,20 @@
|
||||
import * as tsNode from 'ts-node';
|
||||
import * as path from 'path';
|
||||
import * as tsNode from './tsnode';
|
||||
|
||||
tsNode.register({
|
||||
compilerOptions: {
|
||||
lib: ['es2016', 'es2017']
|
||||
}
|
||||
lib: [ 'es2016', 'es2017' ]
|
||||
},
|
||||
skipIgnore: true,
|
||||
cacheDirectory: path.join(__dirname, '../tscache')
|
||||
});
|
||||
|
||||
const pathToLoad = path.join(process.cwd(), process.argv.pop());
|
||||
import(pathToLoad);
|
||||
if (process.env.CLI_CALL_TSRUN) {
|
||||
// contents of argv array
|
||||
// process.argv[0] -> node Executable
|
||||
// process.argv[1] -> tsrun executable
|
||||
const pathToTsFile = process.argv[2]
|
||||
|
||||
const pathToLoad = path.join(process.cwd(), pathToTsFile);
|
||||
import(pathToLoad);
|
||||
}
|
||||
|
613
ts/tsnode.ts
Normal file
613
ts/tsnode.ts
Normal file
@ -0,0 +1,613 @@
|
||||
import { relative, basename, extname, resolve, dirname, join } from 'path'
|
||||
import { readFileSync, writeFileSync } from 'fs'
|
||||
import { EOL, tmpdir, homedir } from 'os'
|
||||
import sourceMapSupport = require('source-map-support')
|
||||
import mkdirp = require('mkdirp')
|
||||
import crypto = require('crypto')
|
||||
import yn = require('yn')
|
||||
import arrify = require('arrify')
|
||||
import bufferFrom = require('buffer-from')
|
||||
import { BaseError } from 'make-error'
|
||||
import * as util from 'util'
|
||||
import * as _ts from 'typescript'
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*/
|
||||
export const INSPECT_CUSTOM = util.inspect.custom || 'inspect'
|
||||
|
||||
/**
|
||||
* Debugging `ts-node`.
|
||||
*/
|
||||
const shouldDebug = yn(process.env.TS_NODE_DEBUG)
|
||||
const debug = shouldDebug ? console.log.bind(console, 'ts-node') : () => undefined
|
||||
const debugFn = shouldDebug ?
|
||||
<T, U> (key: string, fn: (arg: T) => U) => {
|
||||
return (x: T) => {
|
||||
debug(key, x)
|
||||
return fn(x)
|
||||
}
|
||||
} :
|
||||
<T, U> (_: string, fn: (arg: T) => U) => fn
|
||||
|
||||
/**
|
||||
* Common TypeScript interfaces between versions.
|
||||
*/
|
||||
export interface TSCommon {
|
||||
version: typeof _ts.version
|
||||
sys: typeof _ts.sys
|
||||
ScriptSnapshot: typeof _ts.ScriptSnapshot
|
||||
displayPartsToString: typeof _ts.displayPartsToString
|
||||
createLanguageService: typeof _ts.createLanguageService
|
||||
getDefaultLibFilePath: typeof _ts.getDefaultLibFilePath
|
||||
getPreEmitDiagnostics: typeof _ts.getPreEmitDiagnostics
|
||||
flattenDiagnosticMessageText: typeof _ts.flattenDiagnosticMessageText
|
||||
transpileModule: typeof _ts.transpileModule
|
||||
ModuleKind: typeof _ts.ModuleKind
|
||||
ScriptTarget: typeof _ts.ScriptTarget
|
||||
findConfigFile: typeof _ts.findConfigFile
|
||||
readConfigFile: typeof _ts.readConfigFile
|
||||
parseJsonConfigFileContent: typeof _ts.parseJsonConfigFileContent
|
||||
formatDiagnostics: typeof _ts.formatDiagnostics
|
||||
formatDiagnosticsWithColorAndContext: typeof _ts.formatDiagnosticsWithColorAndContext
|
||||
}
|
||||
|
||||
/**
|
||||
* Export the current version.
|
||||
*/
|
||||
export const VERSION = require('../package.json').version
|
||||
|
||||
/**
|
||||
* Registration options.
|
||||
*/
|
||||
export interface Options {
|
||||
pretty?: boolean | null
|
||||
typeCheck?: boolean | null
|
||||
transpileOnly?: boolean | null
|
||||
files?: boolean | null
|
||||
cache?: boolean | null
|
||||
cacheDirectory?: string
|
||||
compiler?: string
|
||||
ignore?: string | string[]
|
||||
project?: string
|
||||
skipIgnore?: boolean | null
|
||||
skipProject?: boolean | null
|
||||
compilerOptions?: object
|
||||
ignoreDiagnostics?: number | string | Array<number | string>
|
||||
readFile?: (path: string) => string | undefined
|
||||
fileExists?: (path: string) => boolean
|
||||
transformers?: _ts.CustomTransformers
|
||||
}
|
||||
|
||||
/**
|
||||
* Track the project information.
|
||||
*/
|
||||
interface MemoryCache {
|
||||
contents: { [path: string]: string | undefined }
|
||||
versions: { [path: string]: number | undefined }
|
||||
outputs: { [path: string]: string }
|
||||
}
|
||||
|
||||
/**
|
||||
* Information retrieved from type info check.
|
||||
*/
|
||||
export interface TypeInfo {
|
||||
name: string
|
||||
comment: string
|
||||
}
|
||||
|
||||
/**
|
||||
* Default register options.
|
||||
*/
|
||||
export const DEFAULTS: Options = {
|
||||
files: yn(process.env['TS_NODE_FILES']),
|
||||
cache: yn(process.env['TS_NODE_CACHE'], { default: true }),
|
||||
pretty: yn(process.env['TS_NODE_PRETTY']),
|
||||
cacheDirectory: process.env['TS_NODE_CACHE_DIRECTORY'],
|
||||
compiler: process.env['TS_NODE_COMPILER'],
|
||||
compilerOptions: parse(process.env['TS_NODE_COMPILER_OPTIONS']),
|
||||
ignore: split(process.env['TS_NODE_IGNORE']),
|
||||
project: process.env['TS_NODE_PROJECT'],
|
||||
skipIgnore: yn(process.env['TS_NODE_SKIP_IGNORE']),
|
||||
skipProject: yn(process.env['TS_NODE_SKIP_PROJECT']),
|
||||
ignoreDiagnostics: split(process.env['TS_NODE_IGNORE_DIAGNOSTICS']),
|
||||
typeCheck: yn(process.env['TS_NODE_TYPE_CHECK']),
|
||||
transpileOnly: yn(process.env['TS_NODE_TRANSPILE_ONLY'])
|
||||
}
|
||||
|
||||
/**
|
||||
* Default TypeScript compiler options required by `ts-node`.
|
||||
*/
|
||||
const DEFAULT_COMPILER_OPTIONS = {
|
||||
sourceMap: true,
|
||||
inlineSourceMap: false,
|
||||
inlineSources: true,
|
||||
declaration: false,
|
||||
noEmit: false,
|
||||
outDir: '$$ts-node$$'
|
||||
}
|
||||
|
||||
/**
|
||||
* Split a string array of values.
|
||||
*/
|
||||
export function split (value: string | undefined) {
|
||||
return typeof value === 'string' ? value.split(/ *, */g) : undefined
|
||||
}
|
||||
|
||||
/**
|
||||
* Parse a string as JSON.
|
||||
*/
|
||||
export function parse (value: string | undefined): object | undefined {
|
||||
return typeof value === 'string' ? JSON.parse(value) : undefined
|
||||
}
|
||||
|
||||
/**
|
||||
* Replace backslashes with forward slashes.
|
||||
*/
|
||||
export function normalizeSlashes (value: string): string {
|
||||
return value.replace(/\\/g, '/')
|
||||
}
|
||||
|
||||
/**
|
||||
* TypeScript diagnostics error.
|
||||
*/
|
||||
export class TSError extends BaseError {
|
||||
name = 'TSError'
|
||||
|
||||
constructor (public diagnosticText: string, public diagnosticCodes: number[]) {
|
||||
super(`⨯ Unable to compile TypeScript:\n${diagnosticText}`)
|
||||
}
|
||||
|
||||
/**
|
||||
* @internal
|
||||
*/
|
||||
[INSPECT_CUSTOM] () {
|
||||
return this.diagnosticText
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return type for registering `ts-node`.
|
||||
*/
|
||||
export interface Register {
|
||||
cwd: string
|
||||
extensions: string[]
|
||||
cachedir: string
|
||||
ts: TSCommon
|
||||
compile (code: string, fileName: string, lineOffset?: number): string
|
||||
getTypeInfo (code: string, fileName: string, position: number): TypeInfo
|
||||
}
|
||||
|
||||
/**
|
||||
* Return a default temp directory based on home directory of user.
|
||||
*/
|
||||
function getTmpDir (): string {
|
||||
const hash = crypto.createHash('sha256').update(homedir(), 'utf8').digest('hex')
|
||||
|
||||
return join(tmpdir(), `ts-node-${hash}`)
|
||||
}
|
||||
|
||||
/**
|
||||
* Register TypeScript compiler.
|
||||
*/
|
||||
export function register (opts: Options = {}): Register {
|
||||
const options = Object.assign({}, DEFAULTS, opts)
|
||||
const cacheDirectory = options.cacheDirectory || getTmpDir()
|
||||
const originalJsHandler = require.extensions['.js']
|
||||
|
||||
const ignoreDiagnostics = arrify(options.ignoreDiagnostics).concat([
|
||||
6059, // "'rootDir' is expected to contain all source files."
|
||||
18002, // "The 'files' list in config file is empty."
|
||||
18003 // "No inputs were found in config file."
|
||||
]).map(Number)
|
||||
|
||||
const memoryCache: MemoryCache = {
|
||||
contents: Object.create(null),
|
||||
versions: Object.create(null),
|
||||
outputs: Object.create(null)
|
||||
}
|
||||
|
||||
const ignore = options.skipIgnore ? [] : arrify(
|
||||
options.ignore || '/node_modules/'
|
||||
).map(str => new RegExp(str))
|
||||
|
||||
// Install source map support and read from memory cache.
|
||||
sourceMapSupport.install({
|
||||
environment: 'node',
|
||||
retrieveFile (path: string) {
|
||||
return memoryCache.outputs[path]
|
||||
}
|
||||
})
|
||||
|
||||
// Require the TypeScript compiler and configuration.
|
||||
const cwd = process.cwd()
|
||||
const { compilerOptions, project, skipProject } = options
|
||||
const compiler = options.compiler || 'typescript'
|
||||
const typeCheck = options.typeCheck === true || options.transpileOnly !== true
|
||||
const ts: typeof _ts = require(compiler)
|
||||
const transformers = options.transformers || undefined
|
||||
const readFile = options.readFile || ts.sys.readFile
|
||||
const fileExists = options.fileExists || ts.sys.fileExists
|
||||
const config = readConfig(cwd, ts, fileExists, readFile, compilerOptions, project, skipProject)
|
||||
const configDiagnosticList = filterDiagnostics(config.errors, ignoreDiagnostics)
|
||||
const extensions = ['.ts', '.tsx']
|
||||
const fileNames = options.files ? config.fileNames : []
|
||||
|
||||
const cachedir = join(
|
||||
resolve(cwd, cacheDirectory),
|
||||
getCompilerDigest({
|
||||
version: ts.version,
|
||||
options: config.options,
|
||||
fileNames,
|
||||
typeCheck,
|
||||
ignoreDiagnostics,
|
||||
compiler
|
||||
})
|
||||
)
|
||||
|
||||
const diagnosticHost: _ts.FormatDiagnosticsHost = {
|
||||
getNewLine: () => EOL,
|
||||
getCurrentDirectory: () => cwd,
|
||||
getCanonicalFileName: (path) => path
|
||||
}
|
||||
|
||||
const formatDiagnostics = options.pretty
|
||||
? ts.formatDiagnosticsWithColorAndContext
|
||||
: ts.formatDiagnostics
|
||||
|
||||
function createTSError (diagnostics: ReadonlyArray<_ts.Diagnostic>) {
|
||||
const diagnosticText = formatDiagnostics(diagnostics, diagnosticHost)
|
||||
const diagnosticCodes = diagnostics.map(x => x.code)
|
||||
return new TSError(diagnosticText, diagnosticCodes)
|
||||
}
|
||||
|
||||
// Render the configuration errors and exit the script.
|
||||
if (configDiagnosticList.length) throw createTSError(configDiagnosticList)
|
||||
|
||||
// Enable `allowJs` when flag is set.
|
||||
if (config.options.allowJs) {
|
||||
extensions.push('.js')
|
||||
extensions.push('.jsx')
|
||||
}
|
||||
|
||||
// Initialize files from TypeScript into project.
|
||||
for (const path of fileNames) memoryCache.versions[path] = 1
|
||||
|
||||
/**
|
||||
* Get the extension for a transpiled file.
|
||||
*/
|
||||
const getExtension = config.options.jsx === ts.JsxEmit.Preserve ?
|
||||
((path: string) => /\.[tj]sx$/.test(path) ? '.jsx' : '.js') :
|
||||
((_: string) => '.js')
|
||||
|
||||
/**
|
||||
* Create the basic required function using transpile mode.
|
||||
*/
|
||||
let getOutput = function (code: string, fileName: string, lineOffset = 0): SourceOutput {
|
||||
const result = ts.transpileModule(code, {
|
||||
fileName,
|
||||
transformers,
|
||||
compilerOptions: config.options,
|
||||
reportDiagnostics: true
|
||||
})
|
||||
|
||||
const diagnosticList = result.diagnostics ?
|
||||
filterDiagnostics(result.diagnostics, ignoreDiagnostics) :
|
||||
[]
|
||||
|
||||
if (diagnosticList.length) throw createTSError(diagnosticList)
|
||||
|
||||
return [result.outputText, result.sourceMapText as string]
|
||||
}
|
||||
|
||||
let getTypeInfo = function (_code: string, _fileName: string, _position: number): TypeInfo {
|
||||
throw new TypeError(`Type information is unavailable without "--type-check"`)
|
||||
}
|
||||
|
||||
// Use full language services when the fast option is disabled.
|
||||
if (typeCheck) {
|
||||
// Set the file contents into cache.
|
||||
const updateMemoryCache = function (code: string, fileName: string) {
|
||||
if (memoryCache.contents[fileName] !== code) {
|
||||
memoryCache.contents[fileName] = code
|
||||
memoryCache.versions[fileName] = (memoryCache.versions[fileName] || 0) + 1
|
||||
}
|
||||
}
|
||||
|
||||
// Create the compiler host for type checking.
|
||||
const serviceHost = {
|
||||
getScriptFileNames: () => Object.keys(memoryCache.versions),
|
||||
getScriptVersion: (fileName: string) => {
|
||||
const version = memoryCache.versions[fileName]
|
||||
|
||||
// We need to return `undefined` and not a string here because TypeScript will use
|
||||
// `getScriptVersion` and compare against their own version - which can be `undefined`.
|
||||
// If we don't return `undefined` it results in `undefined === "undefined"` and run
|
||||
// `createProgram` again (which is very slow). Using a `string` assertion here to avoid
|
||||
// TypeScript errors from the function signature (expects `(x: string) => string`).
|
||||
return version === undefined ? undefined as any as string : String(version)
|
||||
},
|
||||
getScriptSnapshot (fileName: string) {
|
||||
// Read contents into TypeScript memory cache.
|
||||
if (!Object.prototype.hasOwnProperty.call(memoryCache.contents, fileName)) {
|
||||
memoryCache.contents[fileName] = readFile(fileName)
|
||||
}
|
||||
|
||||
const contents = memoryCache.contents[fileName]
|
||||
if (contents === undefined) return
|
||||
return ts.ScriptSnapshot.fromString(contents)
|
||||
},
|
||||
fileExists: debugFn('fileExists', fileExists),
|
||||
readFile: debugFn('readFile', readFile),
|
||||
readDirectory: debugFn('readDirectory', ts.sys.readDirectory),
|
||||
getDirectories: debugFn('getDirectories', ts.sys.getDirectories),
|
||||
directoryExists: debugFn('directoryExists', ts.sys.directoryExists),
|
||||
getNewLine: () => EOL,
|
||||
getCurrentDirectory: () => cwd,
|
||||
getCompilationSettings: () => config.options,
|
||||
getDefaultLibFileName: () => ts.getDefaultLibFilePath(config.options),
|
||||
getCustomTransformers: () => transformers
|
||||
}
|
||||
|
||||
const service = ts.createLanguageService(serviceHost)
|
||||
|
||||
getOutput = function (code: string, fileName: string, lineOffset: number = 0) {
|
||||
// Must set memory cache before attempting to read file.
|
||||
updateMemoryCache(code, fileName)
|
||||
|
||||
const output = service.getEmitOutput(fileName)
|
||||
|
||||
// Get the relevant diagnostics - this is 3x faster than `getPreEmitDiagnostics`.
|
||||
const diagnostics = service.getCompilerOptionsDiagnostics()
|
||||
.concat(service.getSyntacticDiagnostics(fileName))
|
||||
.concat(service.getSemanticDiagnostics(fileName))
|
||||
|
||||
const diagnosticList = filterDiagnostics(diagnostics, ignoreDiagnostics)
|
||||
|
||||
if (diagnosticList.length) throw createTSError(diagnosticList)
|
||||
|
||||
if (output.emitSkipped) {
|
||||
throw new TypeError(`${relative(cwd, fileName)}: Emit skipped`)
|
||||
}
|
||||
|
||||
// Throw an error when requiring `.d.ts` files.
|
||||
if (output.outputFiles.length === 0) {
|
||||
return ['', ''];
|
||||
}
|
||||
return [output.outputFiles[1].text, output.outputFiles[0].text]
|
||||
}
|
||||
|
||||
getTypeInfo = function (code: string, fileName: string, position: number) {
|
||||
updateMemoryCache(code, fileName)
|
||||
|
||||
const info = service.getQuickInfoAtPosition(fileName, position)
|
||||
const name = ts.displayPartsToString(info ? info.displayParts : [])
|
||||
const comment = ts.displayPartsToString(info ? info.documentation : [])
|
||||
|
||||
return { name, comment }
|
||||
}
|
||||
}
|
||||
|
||||
const compile = readThrough(cachedir, options.cache === true, memoryCache, getOutput, getExtension)
|
||||
const register: Register = { cwd, compile, getTypeInfo, extensions, cachedir, ts }
|
||||
|
||||
// Register the extensions.
|
||||
extensions.forEach(extension => {
|
||||
registerExtension(extension, ignore, register, originalJsHandler)
|
||||
})
|
||||
|
||||
return register
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the filename should be ignored.
|
||||
*/
|
||||
function shouldIgnore (filename: string, ignore: RegExp[]) {
|
||||
const relname = normalizeSlashes(filename)
|
||||
|
||||
return ignore.some(x => x.test(relname))
|
||||
}
|
||||
|
||||
/**
|
||||
* Register the extension for node.
|
||||
*/
|
||||
function registerExtension (
|
||||
ext: string,
|
||||
ignore: RegExp[],
|
||||
register: Register,
|
||||
originalHandler: (m: NodeModule, filename: string) => any
|
||||
) {
|
||||
const old = require.extensions[ext] || originalHandler
|
||||
|
||||
require.extensions[ext] = function (m: any, filename) {
|
||||
if (shouldIgnore(filename, ignore)) {
|
||||
return old(m, filename)
|
||||
}
|
||||
|
||||
const _compile = m._compile
|
||||
|
||||
m._compile = function (code: string, fileName: string) {
|
||||
debug('module._compile', fileName)
|
||||
|
||||
return _compile.call(this, register.compile(code, fileName), fileName)
|
||||
}
|
||||
|
||||
return old(m, filename)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Do post-processing on config options to support `ts-node`.
|
||||
*/
|
||||
function fixConfig (ts: TSCommon, config: _ts.ParsedCommandLine) {
|
||||
// Delete options that *should not* be passed through.
|
||||
delete config.options.out
|
||||
delete config.options.outFile
|
||||
delete config.options.declarationDir
|
||||
delete config.options.declarationMap
|
||||
delete config.options.emitDeclarationOnly
|
||||
|
||||
// Target ES5 output by default (instead of ES3).
|
||||
if (config.options.target === undefined) {
|
||||
config.options.target = ts.ScriptTarget.ES5
|
||||
}
|
||||
|
||||
// Target CommonJS modules by default (instead of magically switching to ES6 when the target is ES6).
|
||||
if (config.options.module === undefined) {
|
||||
config.options.module = ts.ModuleKind.CommonJS
|
||||
}
|
||||
|
||||
return config
|
||||
}
|
||||
|
||||
/**
|
||||
* Load TypeScript configuration.
|
||||
*/
|
||||
function readConfig (
|
||||
cwd: string,
|
||||
ts: TSCommon,
|
||||
fileExists: (path: string) => boolean,
|
||||
readFile: (path: string) => string | undefined,
|
||||
compilerOptions?: object,
|
||||
project?: string | null,
|
||||
noProject?: boolean | null
|
||||
): _ts.ParsedCommandLine {
|
||||
let config = { compilerOptions: {} }
|
||||
let basePath = normalizeSlashes(cwd)
|
||||
let configFileName: string | undefined = undefined
|
||||
|
||||
// Read project configuration when available.
|
||||
if (!noProject) {
|
||||
configFileName = project
|
||||
? normalizeSlashes(resolve(cwd, project))
|
||||
: ts.findConfigFile(normalizeSlashes(cwd), fileExists)
|
||||
|
||||
if (configFileName) {
|
||||
const result = ts.readConfigFile(configFileName, readFile)
|
||||
|
||||
// Return diagnostics.
|
||||
if (result.error) {
|
||||
return { errors: [result.error], fileNames: [], options: {} }
|
||||
}
|
||||
|
||||
config = result.config
|
||||
basePath = normalizeSlashes(dirname(configFileName))
|
||||
}
|
||||
}
|
||||
|
||||
// Override default configuration options `ts-node` requires.
|
||||
config.compilerOptions = Object.assign({}, config.compilerOptions, compilerOptions, DEFAULT_COMPILER_OPTIONS)
|
||||
|
||||
return fixConfig(ts, ts.parseJsonConfigFileContent(config, ts.sys, basePath, undefined, configFileName))
|
||||
}
|
||||
|
||||
/**
|
||||
* Internal source output.
|
||||
*/
|
||||
type SourceOutput = [string, string]
|
||||
|
||||
/**
|
||||
* Wrap the function with caching.
|
||||
*/
|
||||
function readThrough (
|
||||
cachedir: string,
|
||||
shouldCache: boolean,
|
||||
memoryCache: MemoryCache,
|
||||
compile: (code: string, fileName: string, lineOffset?: number) => SourceOutput,
|
||||
getExtension: (fileName: string) => string
|
||||
) {
|
||||
if (shouldCache === false) {
|
||||
return function (code: string, fileName: string, lineOffset?: number) {
|
||||
debug('readThrough', fileName)
|
||||
|
||||
const [value, sourceMap] = compile(code, fileName, lineOffset)
|
||||
const output = updateOutput(value, fileName, sourceMap, getExtension)
|
||||
|
||||
memoryCache.outputs[fileName] = output
|
||||
|
||||
return output
|
||||
}
|
||||
}
|
||||
|
||||
// Make sure the cache directory exists before continuing.
|
||||
mkdirp.sync(cachedir)
|
||||
|
||||
return function (code: string, fileName: string, lineOffset?: number) {
|
||||
debug('readThrough', fileName)
|
||||
|
||||
const cachePath = join(cachedir, getCacheName(code, fileName))
|
||||
const extension = getExtension(fileName)
|
||||
const outputPath = `${cachePath}${extension}`
|
||||
|
||||
try {
|
||||
const output = readFileSync(outputPath, 'utf8')
|
||||
if (isValidCacheContent(output)) {
|
||||
memoryCache.outputs[fileName] = output
|
||||
return output
|
||||
}
|
||||
} catch (err) {/* Ignore. */}
|
||||
|
||||
const [value, sourceMap] = compile(code, fileName, lineOffset)
|
||||
const output = updateOutput(value, fileName, sourceMap, getExtension)
|
||||
|
||||
memoryCache.outputs[fileName] = output
|
||||
writeFileSync(outputPath, output)
|
||||
|
||||
return output
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the output remapping the source map.
|
||||
*/
|
||||
function updateOutput (outputText: string, fileName: string, sourceMap: string, getExtension: (fileName: string) => string) {
|
||||
const base64Map = bufferFrom(updateSourceMap(sourceMap, fileName), 'utf8').toString('base64')
|
||||
const sourceMapContent = `data:application/json;charset=utf-8;base64,${base64Map}`
|
||||
const sourceMapLength = `${basename(fileName)}.map`.length + (getExtension(fileName).length - extname(fileName).length)
|
||||
|
||||
return outputText.slice(0, -sourceMapLength) + sourceMapContent
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the source map contents for improved output.
|
||||
*/
|
||||
function updateSourceMap (sourceMapText: string, fileName: string) {
|
||||
const sourceMap = JSON.parse(sourceMapText)
|
||||
sourceMap.file = fileName
|
||||
sourceMap.sources = [fileName]
|
||||
delete sourceMap.sourceRoot
|
||||
return JSON.stringify(sourceMap)
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the file name for the cache entry.
|
||||
*/
|
||||
function getCacheName (sourceCode: string, fileName: string) {
|
||||
return crypto.createHash('sha256')
|
||||
.update(extname(fileName), 'utf8')
|
||||
.update('\x00', 'utf8')
|
||||
.update(sourceCode, 'utf8')
|
||||
.digest('hex')
|
||||
}
|
||||
|
||||
/**
|
||||
* Ensure the given cached content is valid by sniffing for a base64 encoded '}'
|
||||
* at the end of the content, which should exist if there is a valid sourceMap present.
|
||||
*/
|
||||
function isValidCacheContent (contents: string) {
|
||||
return /(?:9|0=|Q==)$/.test(contents.slice(-3))
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a hash of the current configuration.
|
||||
*/
|
||||
function getCompilerDigest (obj: object) {
|
||||
return crypto.createHash('sha256').update(JSON.stringify(obj), 'utf8').digest('hex')
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter diagnostics.
|
||||
*/
|
||||
function filterDiagnostics (diagnostics: _ts.Diagnostic[], ignore: number[]) {
|
||||
return diagnostics.filter(x => ignore.indexOf(x.code) === -1)
|
||||
}
|
Reference in New Issue
Block a user