UNPKG

apollo-codegen

Version:

Generate API code or type annotations based on a GraphQL schema and query documents

89 lines (76 loc) 2.67 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.ToolError = ToolError; exports.logError = logError; exports.logErrorMessage = logErrorMessage; var _graphql = require('graphql'); var _path = require('path'); var _path2 = _interopRequireDefault(_path); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // ToolError is used for errors that are part of the expected flow // and for which a stack trace should not be printed function ToolError(message) { this.message = message; } ToolError.prototype = Object.create(Error.prototype, { constructor: { value: ToolError }, name: { value: 'ToolError' } }); var isRunningFromXcodeScript = process.env.XCODE_VERSION_ACTUAL; function logError(error) { if (error instanceof ToolError) { logErrorMessage(error.message); } else if (error instanceof _graphql.GraphQLError) { var fileName = error.source && error.source.name; if (error.locations) { var _iteratorNormalCompletion = true; var _didIteratorError = false; var _iteratorError = undefined; try { for (var _iterator = error.locations[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var location = _step.value; logErrorMessage(error.message, fileName, location.line); } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator.return) { _iterator.return(); } } finally { if (_didIteratorError) { throw _iteratorError; } } } } else { logErrorMessage(error.message, fileName); } } else { console.log(error.stack); } } function logErrorMessage(message, fileName, lineNumber) { if (isRunningFromXcodeScript) { if (fileName && lineNumber) { // Prefixing error output with file name, line and 'error: ', // so Xcode will associate it with the right file and display the error inline console.log(`${fileName}:${lineNumber}: error: ${message}`); } else { // Prefixing error output with 'error: ', so Xcode will display it as an error console.log(`error: ${message}`); } } else { if (fileName) { var truncatedFileName = '/' + fileName.split(_path2.default.sep).slice(-4).join(_path2.default.sep); console.log(`...${truncatedFileName}: ${message}`); } else { console.log(`error: ${message}`); } } } //# sourceMappingURL=errors.js.map