UNPKG

27.5 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const tslib_1 = require("tslib");
4const ts_utils_1 = require("@neo-one/ts-utils");
5const appRootDir = tslib_1.__importStar(require("app-root-dir"));
6const fs = tslib_1.__importStar(require("fs-extra")); // tslint:disable-next-line match-default-export-name
7const glob_1 = tslib_1.__importDefault(require("glob"));
8const path = tslib_1.__importStar(require("path"));
9const typescript_1 = tslib_1.__importDefault(require("typescript"));
10const Context_1 = require("./Context");
11const symbols_1 = require("./symbols");
12function createContext(program, typeChecker, languageService) {
13 return new Context_1.Context(program, typeChecker, languageService, symbols_1.getGlobals(program, typeChecker), symbols_1.getLibs(program, typeChecker), symbols_1.getLibAliases(program, languageService));
14}
15function updateContext(context, files) {
16 const { program, typeChecker, languageService } = createProgram(context.program.getCompilerOptions(), Object.keys(files), createModifyHostFiles(files));
17 return context.update(program, typeChecker, languageService, symbols_1.getGlobals(program, typeChecker), symbols_1.getLibs(program, typeChecker), symbols_1.getLibAliases(program, languageService));
18}
19exports.updateContext = updateContext;
20const doGlob = async (value) => new Promise((resolve, reject) => glob_1.default(value, (error, matches) => {
21 if (error) {
22 reject(error);
23 }
24 else {
25 resolve(matches);
26 }
27}));
28const makeContext = async (rootNames, modifyHost = () => {
29}) => {
30 const tsConfigFilePath = path.resolve(require.resolve('@neo-one/smart-contract-compiler'), '..', '..', 'tsconfig.default.json');
31 const res = typescript_1.default.readConfigFile(tsConfigFilePath, value => fs.readFileSync(value, 'utf8'));
32 const parseConfigHost = {
33 fileExists: fs.existsSync,
34 readDirectory: typescript_1.default.sys.readDirectory,
35 readFile: typescript_1.default.sys.readFile,
36 useCaseSensitiveFileNames: true
37 };
38 const parsed = typescript_1.default.parseJsonConfigFileContent(res.config, parseConfigHost, path.dirname(tsConfigFilePath));
39 const { program, typeChecker, languageService } = createProgram(parsed.options, rootNames, modifyHost);
40 return createContext(program, typeChecker, languageService);
41};
42const createModifyHostFiles = (files) => (host) => {
43 const originalFileExists = host.fileExists === undefined ? typescript_1.default.sys.fileExists : host.fileExists.bind(host); // tslint:disable-next-line no-object-mutation no-any
44 host.fileExists = file => {
45 if (files[file] !== undefined) {
46 return true;
47 }
48 return originalFileExists(file);
49 };
50 const originalReadFile = host.readFile === undefined ? typescript_1.default.sys.readFile : host.readFile.bind(host); // tslint:disable-next-line no-object-mutation no-any
51 host.readFile = (file, ...args) => {
52 const foundFile = files[file];
53 if (foundFile !== undefined) {
54 return foundFile;
55 }
56 return originalReadFile(file, ...args);
57 };
58};
59const createProgram = (options, rootNamesIn // do nothing
60, modifyHost = () => { }) => {
61 const smartContractDir = path.dirname(require.resolve('@neo-one/smart-contract'));
62 const smartContractModule = path.resolve(smartContractDir, 'index.ts');
63 const smartContractFiles = [path.resolve(smartContractDir, 'index.d.ts'), smartContractModule, path.resolve(smartContractDir, 'lib.ts')];
64 const rootNames = [...new Set(rootNamesIn.concat(smartContractFiles).concat(require.resolve('@types/node/index.d.ts')))];
65 const mutableFiles = {}; // initialize the list of files
66 rootNames.forEach(fileName => {
67 mutableFiles[fileName] = {
68 version: 0
69 };
70 });
71 const servicesHost = {
72 getScriptFileNames: () => [...rootNames],
73 getScriptVersion: fileName => {
74 const file = mutableFiles[fileName];
75 return file === undefined ? '' : file.version.toString();
76 },
77 getScriptSnapshot: fileName => {
78 // tslint:disable-next-line no-non-null-assertion
79 if (!servicesHost.fileExists(fileName)) {
80 return undefined;
81 } // tslint:disable-next-line no-non-null-assertion
82 return typescript_1.default.ScriptSnapshot.fromString(servicesHost.readFile(fileName));
83 },
84 getCurrentDirectory: () => process.cwd(),
85 getCompilationSettings: () => options,
86 getDefaultLibFileName: opts => typescript_1.default.getDefaultLibFilePath(opts),
87 fileExists: typescript_1.default.sys.fileExists,
88 readFile: typescript_1.default.sys.readFile,
89 readDirectory: typescript_1.default.sys.readDirectory,
90 resolveModuleNames
91 };
92 const smartContractLibModule = path.resolve(path.dirname(require.resolve('@neo-one/smart-contract-lib')), 'index.ts');
93 function resolveModuleNames(moduleNames, containingFile) {
94 const mutableResolvedModules = []; // tslint:disable-next-line no-loop-statement
95 for (const moduleName of moduleNames) {
96 if (moduleName === '@neo-one/smart-contract') {
97 mutableResolvedModules.push({
98 resolvedFileName: smartContractModule
99 });
100 }
101 else if (moduleName === '@neo-one/smart-contract-lib') {
102 mutableResolvedModules.push({
103 resolvedFileName: smartContractLibModule
104 });
105 }
106 else {
107 const result = typescript_1.default.resolveModuleName(moduleName, containingFile, options, {
108 fileExists: typescript_1.default.sys.fileExists,
109 readFile: typescript_1.default.sys.readFile
110 }); // tslint:disable-next-line no-non-null-assertion
111 mutableResolvedModules.push(result.resolvedModule);
112 }
113 }
114 return mutableResolvedModules;
115 }
116 modifyHost(servicesHost);
117 const languageService = typescript_1.default.createLanguageService(servicesHost, typescript_1.default.createDocumentRegistry());
118 const program = languageService.getProgram();
119 if (program === undefined) {
120 throw new Error('Something went wrong');
121 }
122 return {
123 program,
124 typeChecker: program.getTypeChecker(),
125 languageService
126 };
127};
128exports.createContextForDir = async (dir) => {
129 const files = await doGlob(path.join(dir, '**', '*.ts'));
130 return makeContext(files);
131};
132exports.createContextForPath = async (filePath) => makeContext([filePath]);
133exports.createContextForSnippet = async (code) => {
134 const dir = appRootDir.get();
135 const fileName = path.resolve(dir, 'snippetCode.ts');
136 const context = await makeContext([fileName], createModifyHostFiles({
137 [fileName]: code
138 }));
139 const sourceFile = ts_utils_1.tsUtils.file.getSourceFileOrThrow(context.program, fileName);
140 return {
141 context,
142 sourceFile
143 };
144};
145
146//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["createContext.ts"],"names":["createContext","program","typeChecker","languageService","Context","getGlobals","getLibs","getLibAliases","updateContext","context","files","createProgram","getCompilerOptions","Object","keys","createModifyHostFiles","update","doGlob","value","Promise","resolve","reject","glob","error","matches","makeContext","rootNames","modifyHost","tsConfigFilePath","path","require","res","ts","readConfigFile","fs","readFileSync","parseConfigHost","fileExists","existsSync","readDirectory","sys","readFile","useCaseSensitiveFileNames","parsed","parseJsonConfigFileContent","config","dirname","options","host","originalFileExists","undefined","bind","file","originalReadFile","args","foundFile","rootNamesIn","smartContractDir","smartContractModule","smartContractFiles","Set","concat","mutableFiles","forEach","fileName","version","servicesHost","getScriptFileNames","getScriptVersion","toString","getScriptSnapshot","ScriptSnapshot","fromString","getCurrentDirectory","process","cwd","getCompilationSettings","getDefaultLibFileName","opts","getDefaultLibFilePath","resolveModuleNames","smartContractLibModule","moduleNames","containingFile","mutableResolvedModules","moduleName","push","resolvedFileName","result","resolveModuleName","resolvedModule","createLanguageService","createDocumentRegistry","getProgram","Error","getTypeChecker","createContextForDir","dir","join","createContextForPath","filePath","createContextForSnippet","code","appRootDir","get","sourceFile","tsUtils","getSourceFileOrThrow"],"mappings":"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","file":"neo-one-smart-contract-compiler/src/createContext.js","sourcesContent":["import { tsUtils } from '@neo-one/ts-utils';\nimport * as appRootDir from 'app-root-dir';\nimport * as fs from 'fs-extra';\n// tslint:disable-next-line match-default-export-name\nimport glob from 'glob';\nimport * as path from 'path';\nimport ts from 'typescript';\nimport { Context } from './Context';\nimport { getGlobals, getLibAliases, getLibs } from './symbols';\n\nfunction createContext(program: ts.Program, typeChecker: ts.TypeChecker, languageService: ts.LanguageService): Context {\n  return new Context(\n    program,\n    typeChecker,\n    languageService,\n    getGlobals(program, typeChecker),\n    getLibs(program, typeChecker),\n    getLibAliases(program, languageService),\n  );\n}\n\nexport function updateContext(context: Context, files: { readonly [fileName: string]: string | undefined }): Context {\n  const { program, typeChecker, languageService } = createProgram(\n    context.program.getCompilerOptions(),\n    Object.keys(files),\n    createModifyHostFiles(files),\n  );\n\n  return context.update(\n    program,\n    typeChecker,\n    languageService,\n    getGlobals(program, typeChecker),\n    getLibs(program, typeChecker),\n    getLibAliases(program, languageService),\n  );\n}\n\nconst doGlob = async (value: string) =>\n  new Promise<ReadonlyArray<string>>((resolve, reject) =>\n    glob(value, (error, matches) => {\n      if (error) {\n        reject(error);\n      } else {\n        resolve(matches);\n      }\n    }),\n  );\n\nconst makeContext = async (\n  rootNames: ReadonlyArray<string>,\n  modifyHost: (host: ts.LanguageServiceHost) => void = () => {\n    // do nothing\n  },\n): Promise<Context> => {\n  const tsConfigFilePath = path.resolve(\n    require.resolve('@neo-one/smart-contract-compiler'),\n    '..',\n    '..',\n    'tsconfig.default.json',\n  );\n\n  const res = ts.readConfigFile(tsConfigFilePath, (value) => fs.readFileSync(value, 'utf8'));\n  const parseConfigHost = {\n    fileExists: fs.existsSync,\n    readDirectory: ts.sys.readDirectory,\n    readFile: ts.sys.readFile,\n    useCaseSensitiveFileNames: true,\n  };\n  const parsed = ts.parseJsonConfigFileContent(res.config, parseConfigHost, path.dirname(tsConfigFilePath));\n\n  const { program, typeChecker, languageService } = createProgram(parsed.options, rootNames, modifyHost);\n\n  return createContext(program, typeChecker, languageService);\n};\n\nconst createModifyHostFiles = (files: { readonly [fileName: string]: string | undefined }) => (\n  host: ts.LanguageServiceHost,\n) => {\n  const originalFileExists = host.fileExists === undefined ? ts.sys.fileExists : host.fileExists.bind(host);\n  // tslint:disable-next-line no-object-mutation no-any\n  host.fileExists = (file) => {\n    if (files[file] !== undefined) {\n      return true;\n    }\n\n    return originalFileExists(file);\n  };\n\n  const originalReadFile = host.readFile === undefined ? ts.sys.readFile : host.readFile.bind(host);\n  // tslint:disable-next-line no-object-mutation no-any\n  host.readFile = (file, ...args: any[]) => {\n    const foundFile = files[file];\n    if (foundFile !== undefined) {\n      return foundFile;\n    }\n\n    return originalReadFile(file, ...args);\n  };\n};\n\nconst createProgram = (\n  options: ts.CompilerOptions,\n  rootNamesIn: ReadonlyArray<string>,\n  modifyHost: (host: ts.LanguageServiceHost) => void = () => {\n    // do nothing\n  },\n) => {\n  const smartContractDir = path.dirname(require.resolve('@neo-one/smart-contract'));\n  const smartContractModule = path.resolve(smartContractDir, 'index.ts');\n  const smartContractFiles = [\n    path.resolve(smartContractDir, 'index.d.ts'),\n    smartContractModule,\n    path.resolve(smartContractDir, 'lib.ts'),\n  ];\n\n  const rootNames = [\n    ...new Set(rootNamesIn.concat(smartContractFiles).concat(require.resolve('@types/node/index.d.ts'))),\n  ];\n\n  const mutableFiles: ts.MapLike<{ version: number } | undefined> = {};\n  // initialize the list of files\n  rootNames.forEach((fileName) => {\n    mutableFiles[fileName] = { version: 0 };\n  });\n  const servicesHost: ts.LanguageServiceHost = {\n    getScriptFileNames: () => [...rootNames],\n    getScriptVersion: (fileName) => {\n      const file = mutableFiles[fileName];\n\n      return file === undefined ? '' : file.version.toString();\n    },\n    getScriptSnapshot: (fileName) => {\n      // tslint:disable-next-line no-non-null-assertion\n      if (!servicesHost.fileExists!(fileName)) {\n        return undefined;\n      }\n\n      // tslint:disable-next-line no-non-null-assertion\n      return ts.ScriptSnapshot.fromString(servicesHost.readFile!(fileName)!);\n    },\n    getCurrentDirectory: () => process.cwd(),\n    getCompilationSettings: () => options,\n    getDefaultLibFileName: (opts) => ts.getDefaultLibFilePath(opts),\n    fileExists: ts.sys.fileExists,\n    readFile: ts.sys.readFile,\n    readDirectory: ts.sys.readDirectory,\n    resolveModuleNames,\n  };\n\n  const smartContractLibModule = path.resolve(path.dirname(require.resolve('@neo-one/smart-contract-lib')), 'index.ts');\n  function resolveModuleNames(moduleNames: string[], containingFile: string): ts.ResolvedModule[] {\n    const mutableResolvedModules: ts.ResolvedModule[] = [];\n    // tslint:disable-next-line no-loop-statement\n    for (const moduleName of moduleNames) {\n      if (moduleName === '@neo-one/smart-contract') {\n        mutableResolvedModules.push({ resolvedFileName: smartContractModule });\n      } else if (moduleName === '@neo-one/smart-contract-lib') {\n        mutableResolvedModules.push({ resolvedFileName: smartContractLibModule });\n      } else {\n        const result = ts.resolveModuleName(moduleName, containingFile, options, {\n          fileExists: ts.sys.fileExists,\n          readFile: ts.sys.readFile,\n        });\n        // tslint:disable-next-line no-non-null-assertion\n        mutableResolvedModules.push(result.resolvedModule!);\n      }\n    }\n\n    return mutableResolvedModules;\n  }\n\n  modifyHost(servicesHost);\n\n  const languageService = ts.createLanguageService(servicesHost, ts.createDocumentRegistry());\n  const program = languageService.getProgram();\n  if (program === undefined) {\n    throw new Error('Something went wrong');\n  }\n\n  return {\n    program,\n    typeChecker: program.getTypeChecker(),\n    languageService,\n  };\n};\n\nexport const createContextForDir = async (dir: string): Promise<Context> => {\n  const files = await doGlob(path.join(dir, '**', '*.ts'));\n\n  return makeContext(files);\n};\n\nexport const createContextForPath = async (filePath: string): Promise<Context> => makeContext([filePath]);\n\nexport interface SnippetResult {\n  readonly context: Context;\n  readonly sourceFile: ts.SourceFile;\n}\n\nexport const createContextForSnippet = async (code: string): Promise<SnippetResult> => {\n  const dir = appRootDir.get();\n  const fileName = path.resolve(dir, 'snippetCode.ts');\n\n  const context = await makeContext([fileName], createModifyHostFiles({ [fileName]: code }));\n  const sourceFile = tsUtils.file.getSourceFileOrThrow(context.program, fileName);\n\n  return {\n    context,\n    sourceFile,\n  };\n};\n"]}