1 | import ts from 'typescript';
|
2 | import * as file_ from './file';
|
3 | export const printBundle = (programIn, files, substituteNode) => {
|
4 | const program = programIn;
|
5 | const compiler = ts;
|
6 | const host = {
|
7 | getPrependNodes: () => [],
|
8 | getCanonicalFileName: (fileName) => (ts.sys.useCaseSensitiveFileNames ? fileName : fileName.toLowerCase()),
|
9 | getCommonSourceDirectory: program.getCommonSourceDirectory,
|
10 | getCompilerOptions: program.getCompilerOptions,
|
11 | getCurrentDirectory: program.getCurrentDirectory,
|
12 | getNewLine: () => ts.sys.newLine,
|
13 | getSourceFile: program.getSourceFile,
|
14 | getSourceFileByPath: program.getSourceFileByPath,
|
15 | getSourceFiles: program.getSourceFiles,
|
16 | isSourceFileFromExternalLibrary: program.isSourceFileFromExternalLibrary,
|
17 | writeFile: ts.sys.writeFile,
|
18 | readFile: ts.sys.readFile,
|
19 | fileExists: ts.sys.fileExists,
|
20 | directoryExists: ts.sys.directoryExists,
|
21 | };
|
22 | const writer = compiler.createTextWriter(ts.sys.newLine);
|
23 | const sourceMapGenerator = compiler.createSourceMapGenerator(host, 'foo.ts', program.getCurrentDirectory(), program.getCurrentDirectory(), {});
|
24 | const printer = compiler.createPrinter({ ...program.getCompilerOptions(), outFile: 'foo.ts' }, {
|
25 | substituteNode,
|
26 | });
|
27 | printer.writeBundle(ts.createBundle(files), writer, sourceMapGenerator);
|
28 | const resolvedSourceMap = sourceMapGenerator.toJSON();
|
29 | return {
|
30 | text: writer.getText(),
|
31 | sourceMap: {
|
32 | ...resolvedSourceMap,
|
33 | sourcesContent: resolvedSourceMap.sources.map((filePath) => {
|
34 | const foundFile = files.find((file) => file_.getFilePath(file).endsWith(filePath));
|
35 | return foundFile === undefined ? '' : file_.getText(foundFile);
|
36 | }),
|
37 | },
|
38 | };
|
39 | };
|
40 | export const markOriginal = (node) => {
|
41 | node.__originalSet = true;
|
42 | return ts.setSourceMapRange(node, file_.createSourceMapRange(node));
|
43 | };
|
44 | export const setOriginal = (node, original) => {
|
45 | if (!node.__originalSet) {
|
46 | const transformedNode = ts.moveSyntheticComments(ts.setSourceMapRange(ts.setOriginalNode(node, original), file_.createSourceMapRange(original)), original);
|
47 | node.__originalSet = true;
|
48 | return transformedNode;
|
49 | }
|
50 | return node;
|
51 | };
|
52 | export const isOriginal = (node) => !node.__originalSet;
|
53 | const context = {
|
54 | getCompilerOptions: () => ({}),
|
55 | startLexicalEnvironment: () => {
|
56 | },
|
57 | suspendLexicalEnvironment: () => {
|
58 | },
|
59 | resumeLexicalEnvironment: () => {
|
60 | },
|
61 | endLexicalEnvironment: () => undefined,
|
62 | hoistFunctionDeclaration: () => {
|
63 | },
|
64 | hoistVariableDeclaration: () => {
|
65 | },
|
66 | requestEmitHelper: () => {
|
67 | },
|
68 | readEmitHelpers: () => undefined,
|
69 | enableSubstitution: () => {
|
70 | },
|
71 | isSubstitutionEnabled: () => false,
|
72 | onSubstituteNode: (_hint, node) => node,
|
73 | enableEmitNotification: () => {
|
74 | },
|
75 | isEmitNotificationEnabled: () => false,
|
76 | onEmitNode: (hint, node, emitCallback) => {
|
77 | emitCallback(hint, node);
|
78 | },
|
79 | };
|
80 | export const setOriginalRecursive = (start, original) => {
|
81 | const seen = new Set();
|
82 | function visit(node) {
|
83 | if (seen.has(node)) {
|
84 | return node;
|
85 | }
|
86 | seen.add(node);
|
87 | const transformedNode = setOriginal(node, original);
|
88 | return ts.visitEachChild(transformedNode, visit, context);
|
89 | }
|
90 | return visit(start);
|
91 | };
|
92 |
|
93 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["print.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,YAAY,CAAC;AAC5B,OAAO,KAAK,KAAK,MAAM,QAAQ,CAAC;AAMhC,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,SAAqB,EACrB,KAA+B,EAC/B,cAA6D,EACrD,EAAE;IAEV,MAAM,OAAO,GAAQ,SAAS,CAAC;IAE/B,MAAM,QAAQ,GAAQ,EAAE,CAAC;IAEzB,MAAM,IAAI,GAAG;QACX,eAAe,EAAE,GAAG,EAAE,CAAC,EAAE;QACzB,oBAAoB,EAAE,CAAC,QAAgB,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAClH,wBAAwB,EAAE,OAAO,CAAC,wBAAwB;QAC1D,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;QAC9C,mBAAmB,EAAE,OAAO,CAAC,mBAAmB;QAChD,UAAU,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO;QAChC,aAAa,EAAE,OAAO,CAAC,aAAa;QACpC,mBAAmB,EAAE,OAAO,CAAC,mBAAmB;QAChD,cAAc,EAAE,OAAO,CAAC,cAAc;QACtC,+BAA+B,EAAE,OAAO,CAAC,+BAA+B;QACxE,SAAS,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS;QAC3B,QAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ;QACzB,UAAU,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU;QAC7B,eAAe,EAAE,EAAE,CAAC,GAAG,CAAC,eAAe;KACxC,CAAC;IACF,MAAM,MAAM,GAAG,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACzD,MAAM,kBAAkB,GAAG,QAAQ,CAAC,wBAAwB,CAC1D,IAAI,EACJ,QAAQ,EACR,OAAO,CAAC,mBAAmB,EAAE,EAC7B,OAAO,CAAC,mBAAmB,EAAE,EAC7B,EAAE,CACH,CAAC;IACF,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CACpC,EAAE,GAAG,OAAO,CAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EACtD;QACE,cAAc;KACf,CACF,CAAC;IAEF,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,kBAAkB,CAAC,CAAC;IAExE,MAAM,iBAAiB,GAAiB,kBAAkB,CAAC,MAAM,EAAE,CAAC;IAEpE,OAAO;QACL,IAAI,EAAE,MAAM,CAAC,OAAO,EAAE;QACtB,SAAS,EAAE;YACT,GAAG,iBAAiB;YACpB,cAAc,EAAE,iBAAiB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACzD,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAEnF,OAAO,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACjE,CAAC,CAAC;SACH;KACF,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAoB,IAAO,EAAK,EAAE;IAE3D,IAAY,CAAC,aAAa,GAAG,IAAI,CAAC;IAEnC,OAAO,EAAE,CAAC,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC;AACtE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,CAAoB,IAAO,EAAE,QAAiB,EAAK,EAAE;IAE9E,IAAI,CAAE,IAAY,CAAC,aAAa,EAAE;QAChC,MAAM,eAAe,GAAG,EAAE,CAAC,qBAAqB,CAC9C,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,EAAE,KAAK,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC,EAC9F,QAAQ,CACT,CAAC;QAGD,IAAY,CAAC,aAAa,GAAG,IAAI,CAAC;QAEnC,OAAO,eAAe,CAAC;KACxB;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAGF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,IAAa,EAAW,EAAE,CAAC,CAAE,IAAY,CAAC,aAAa,CAAC;AAEnF,MAAM,OAAO,GAA6B;IAExC,kBAAkB,EAAE,GAAuB,EAAE,CAAC,CAAC,EAAU,CAAA;IACzD,uBAAuB,EAAE,GAAS,EAAE;IAEpC,CAAC;IACD,yBAAyB,EAAE,GAAS,EAAE;IAEtC,CAAC;IACD,wBAAwB,EAAE,GAAS,EAAE;IAErC,CAAC;IAED,qBAAqB,EAAE,GAAG,EAAE,CAAC,SAAS;IACtC,wBAAwB,EAAE,GAAS,EAAE;IAErC,CAAC;IACD,wBAAwB,EAAE,GAAS,EAAE;IAErC,CAAC;IACD,iBAAiB,EAAE,GAAS,EAAE;IAE9B,CAAC;IACD,eAAe,EAAE,GAAG,EAAE,CAAC,SAAS;IAChC,kBAAkB,EAAE,GAAS,EAAE;IAE/B,CAAC;IACD,qBAAqB,EAAE,GAAY,EAAE,CAAC,KAAK;IAC3C,gBAAgB,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI;IACvC,sBAAsB,EAAE,GAAS,EAAE;IAEnC,CAAC;IACD,yBAAyB,EAAE,GAAY,EAAE,CAAC,KAAK;IAC/C,UAAU,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,EAAE;QACvC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAoB,KAAQ,EAAE,QAAiB,EAAK,EAAE;IACxF,MAAM,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;IAEvB,SAAS,KAAK,CAAC,IAAa;QAC1B,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAClB,OAAO,IAAI,CAAC;SACb;QACD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEf,MAAM,eAAe,GAAG,WAAW,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAEpD,OAAO,EAAE,CAAC,cAAc,CAAC,eAAe,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;IAED,OAAO,KAAK,CAAC,KAAK,CAAM,CAAC;AAC3B,CAAC,CAAC","file":"neo-one-ts-utils/src/print.js","sourcesContent":["import { RawSourceMap } from 'source-map';\nimport ts from 'typescript';\nimport * as file_ from './file';\n\nexport interface Result {\n  readonly text: string;\n  readonly sourceMap: RawSourceMap;\n}\nexport const printBundle = (\n  programIn: ts.Program,\n  files: readonly ts.SourceFile[],\n  substituteNode: (hint: ts.EmitHint, node: ts.Node) => ts.Node,\n): Result => {\n  // tslint:disable-next-line no-any\n  const program: any = programIn;\n  // tslint:disable-next-line no-any\n  const compiler: any = ts;\n\n  const host = {\n    getPrependNodes: () => [],\n    getCanonicalFileName: (fileName: string) => (ts.sys.useCaseSensitiveFileNames ? fileName : fileName.toLowerCase()),\n    getCommonSourceDirectory: program.getCommonSourceDirectory,\n    getCompilerOptions: program.getCompilerOptions,\n    getCurrentDirectory: program.getCurrentDirectory,\n    getNewLine: () => ts.sys.newLine,\n    getSourceFile: program.getSourceFile,\n    getSourceFileByPath: program.getSourceFileByPath,\n    getSourceFiles: program.getSourceFiles,\n    isSourceFileFromExternalLibrary: program.isSourceFileFromExternalLibrary,\n    writeFile: ts.sys.writeFile,\n    readFile: ts.sys.readFile,\n    fileExists: ts.sys.fileExists,\n    directoryExists: ts.sys.directoryExists,\n  };\n  const writer = compiler.createTextWriter(ts.sys.newLine);\n  const sourceMapGenerator = compiler.createSourceMapGenerator(\n    host,\n    'foo.ts',\n    program.getCurrentDirectory(),\n    program.getCurrentDirectory(),\n    {},\n  );\n  const printer = compiler.createPrinter(\n    { ...program.getCompilerOptions(), outFile: 'foo.ts' },\n    {\n      substituteNode,\n    },\n  );\n\n  printer.writeBundle(ts.createBundle(files), writer, sourceMapGenerator);\n\n  const resolvedSourceMap: RawSourceMap = sourceMapGenerator.toJSON();\n\n  return {\n    text: writer.getText(),\n    sourceMap: {\n      ...resolvedSourceMap,\n      sourcesContent: resolvedSourceMap.sources.map((filePath) => {\n        const foundFile = files.find((file) => file_.getFilePath(file).endsWith(filePath));\n\n        return foundFile === undefined ? '' : file_.getText(foundFile);\n      }),\n    },\n  };\n};\n\nexport const markOriginal = <T extends ts.Node>(node: T): T => {\n  // tslint:disable-next-line no-any no-object-mutation\n  (node as any).__originalSet = true;\n\n  return ts.setSourceMapRange(node, file_.createSourceMapRange(node));\n};\n\nexport const setOriginal = <T extends ts.Node>(node: T, original: ts.Node): T => {\n  // tslint:disable-next-line no-any\n  if (!(node as any).__originalSet) {\n    const transformedNode = ts.moveSyntheticComments(\n      ts.setSourceMapRange(ts.setOriginalNode(node, original), file_.createSourceMapRange(original)),\n      original,\n    );\n\n    // tslint:disable-next-line no-any no-object-mutation\n    (node as any).__originalSet = true;\n\n    return transformedNode;\n  }\n\n  return node;\n};\n\n// tslint:disable-next-line no-any\nexport const isOriginal = (node: ts.Node): boolean => !(node as any).__originalSet;\n\nconst context: ts.TransformationContext = {\n  // tslint:disable-next-line no-any\n  getCompilerOptions: (): ts.CompilerOptions => ({} as any),\n  startLexicalEnvironment: (): void => {\n    // do nothing\n  },\n  suspendLexicalEnvironment: (): void => {\n    // do nothing\n  },\n  resumeLexicalEnvironment: (): void => {\n    // do nothing\n  },\n\n  endLexicalEnvironment: () => undefined,\n  hoistFunctionDeclaration: (): void => {\n    // do nothing\n  },\n  hoistVariableDeclaration: (): void => {\n    // do nothing\n  },\n  requestEmitHelper: (): void => {\n    // do nothing\n  },\n  readEmitHelpers: () => undefined,\n  enableSubstitution: (): void => {\n    // do nothing\n  },\n  isSubstitutionEnabled: (): boolean => false,\n  onSubstituteNode: (_hint, node) => node,\n  enableEmitNotification: (): void => {\n    // do nothing\n  },\n  isEmitNotificationEnabled: (): boolean => false,\n  onEmitNode: (hint, node, emitCallback) => {\n    emitCallback(hint, node);\n  },\n};\n\nexport const setOriginalRecursive = <T extends ts.Node>(start: T, original: ts.Node): T => {\n  const seen = new Set();\n\n  function visit(node: ts.Node): ts.VisitResult<ts.Node> {\n    if (seen.has(node)) {\n      return node;\n    }\n    seen.add(node);\n\n    const transformedNode = setOriginal(node, original);\n\n    return ts.visitEachChild(transformedNode, visit, context);\n  }\n\n  return visit(start) as T;\n};\n"]}
|