UNPKG

next

Version:

The React Framework

103 lines (102 loc) 3.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = loadJsConfig; var _path = _interopRequireDefault(require("path")); var _fileExists = require("../lib/file-exists"); var Log = _interopRequireWildcard(require("./output/log")); var _getTypeScriptConfiguration = require("../lib/typescript/getTypeScriptConfiguration"); var _fs = require("fs"); var _isError = _interopRequireDefault(require("../lib/is-error")); var _codeFrame = require("next/dist/compiled/babel/code-frame"); async function loadJsConfig(dir, config) { var ref; let typeScriptPath; try { typeScriptPath = require.resolve('typescript', { paths: [ dir ] }); } catch (_) {} const tsConfigPath = _path.default.join(dir, config.typescript.tsconfigPath); const useTypeScript = Boolean(typeScriptPath && await (0, _fileExists).fileExists(tsConfigPath)); let jsConfig; // jsconfig is a subset of tsconfig if (useTypeScript) { if (config.typescript.tsconfigPath !== 'tsconfig.json' && TSCONFIG_WARNED === false) { TSCONFIG_WARNED = true; Log.info(`Using tsconfig file: ${config.typescript.tsconfigPath}`); } const ts = await Promise.resolve(require(typeScriptPath)); const tsConfig = await (0, _getTypeScriptConfiguration).getTypeScriptConfiguration(ts, tsConfigPath, true); jsConfig = { compilerOptions: tsConfig.options }; } const jsConfigPath = _path.default.join(dir, 'jsconfig.json'); if (!useTypeScript && await (0, _fileExists).fileExists(jsConfigPath)) { jsConfig = parseJsonFile(jsConfigPath); } let resolvedBaseUrl; if (jsConfig === null || jsConfig === void 0 ? void 0 : (ref = jsConfig.compilerOptions) === null || ref === void 0 ? void 0 : ref.baseUrl) { resolvedBaseUrl = _path.default.resolve(dir, jsConfig.compilerOptions.baseUrl); } return { useTypeScript, jsConfig, resolvedBaseUrl }; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for(var key in obj){ if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } } let TSCONFIG_WARNED = false; function parseJsonFile(filePath) { const JSON5 = require('next/dist/compiled/json5'); const contents = (0, _fs).readFileSync(filePath, 'utf8'); // Special case an empty file if (contents.trim() === '') { return {}; } try { return JSON5.parse(contents); } catch (err) { if (!(0, _isError).default(err)) throw err; const codeFrame = (0, _codeFrame).codeFrameColumns(String(contents), { start: { line: err.lineNumber || 0, column: err.columnNumber || 0 } }, { message: err.message, highlightCode: true }); throw new Error(`Failed to parse "${filePath}":\n${codeFrame}`); } } //# sourceMappingURL=load-jsconfig.js.map