diff --git a/CHANGELOG.md b/CHANGELOG.md index 164a25e5..f914aa5e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,16 @@ +# [9.0.0](https://github.com/AtomLinter/linter-eslint/compare/v8.6.6...v9.0.0) (2021-10-30) + + +### Bug Fixes + +* update all deps ([099e533](https://github.com/AtomLinter/linter-eslint/commit/099e533977cb75eb785c6daa75737043aa91d406)) +* update eslint to v7 ([#1441](https://github.com/AtomLinter/linter-eslint/issues/1441)) ([3b8b67c](https://github.com/AtomLinter/linter-eslint/commit/3b8b67c25e138cbd027ef24929eb30e88f87a9a7)) + + +### BREAKING CHANGES + +* update eslint to v7 + ## [8.6.6](https://github.com/AtomLinter/linter-eslint/compare/v8.6.5...v8.6.6) (2021-04-13) diff --git a/dist/helpers.js b/dist/helpers.js index 3528e5e8..38ee0774 100644 --- a/dist/helpers.js +++ b/dist/helpers.js @@ -3,22 +3,24 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.startWorker = startWorker; -exports.killWorker = killWorker; -exports.sendJob = sendJob; -exports.getDebugInfo = getDebugInfo; exports.generateDebugString = generateDebugString; exports.generateUserMessage = generateUserMessage; +exports.getDebugInfo = getDebugInfo; exports.handleError = handleError; +exports.killWorker = killWorker; exports.processESLintMessages = processESLintMessages; exports.processJobResponse = processJobResponse; exports.rules = void 0; +exports.sendJob = sendJob; +exports.startWorker = startWorker; var _path = require("path"); var _atomLinter = require("atom-linter"); -var _cryptoRandomString = _interopRequireDefault(require("crypto-random-string")); +var _crypto = require("crypto"); + +var _util = require("util"); var _atom = require("atom"); @@ -29,6 +31,7 @@ var _editor = require("./validate/editor"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // eslint-disable-next-line import/no-extraneous-dependencies, import/extensions +const asyncRandomBytes = (0, _util.promisify)(_crypto.randomBytes); const rules = new _rules.default(); exports.rules = rules; let worker = null; @@ -91,9 +94,8 @@ async function sendJob(config) { // can arrive back in any order. // eslint-disable-next-line no-param-reassign - config.emitKey = (0, _cryptoRandomString.default)({ - length: 10 - }); + config.emitKey = (await asyncRandomBytes(5)).toString('hex'); // 5 bytes = 10 hex characters + return new Promise((resolve, reject) => { // All worker errors are caught and re-emitted along with their associated // emitKey, so that we do not create multiple listeners for the same @@ -405,4 +407,4 @@ async function processJobResponse(response, textEditor, showRule) { return processESLintMessages(response.messages, textEditor, showRule); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/helpers.js"],"names":["rules","Rules","worker","startWorker","Task","require","resolve","on","obj","console","log","JSON","parse","ex","started","start","killWorker","terminate","sendJob","config","childProcess","connected","emitKey","length","Promise","reject","errSub","msg","stack","error","Error","dispose","responseSub","data","send","e","getDebugInfo","textEditor","atom","workspace","getActiveTextEditor","filePath","editorScopes","isTextEditor","getPath","getLastCursor","getScopeDescriptor","getScopesArray","packagePath","packages","resolvePackagePath","linterEslintMeta","undefined","version","get","hoursSinceRestart","Math","round","process","uptime","returnVal","response","type","atomVersion","getVersion","linterEslintVersion","linterEslintConfig","eslintVersion","path","platform","eslintType","eslintPath","notifications","addError","generateDebugString","debug","details","stringify","join","generateUserMessage","options","severity","excerpt","description","location","file","position","handleError","message","split","generateInvalidTrace","msgLine","msgCol","msgEndLine","msgEndCol","eslintFullRange","ruleId","errMsgRange","rangeText","issueURL","titleText","title","encodeURIComponent","body","newIssueURL","url","processESLintMessages","messages","showRule","all","map","fatal","originalMessage","line","column","fix","endLine","endColumn","textBuffer","getBuffer","linterFix","fixRange","Range","positionForCharacterIndex","range","replaceWith","text","max","ret","getRuleUrl","fixLineEnding","ruleAppendix","solutions","err","processJobResponse","Object","prototype","hasOwnProperty","call","replaceRules","updatedRules"],"mappings":"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","sourcesContent":["import { join } from 'path'\nimport { generateRange } from 'atom-linter'\nimport cryptoRandomString from 'crypto-random-string'\n// eslint-disable-next-line import/no-extraneous-dependencies, import/extensions\nimport { Range, Task } from 'atom'\nimport Rules from './rules'\nimport { throwIfInvalidPoint } from './validate/editor'\n\nexport const rules = new Rules()\nlet worker = null\n\n/**\n * Start the worker process if it hasn't already been started\n */\nexport function startWorker() {\n  if (worker === null) {\n    worker = new Task(require.resolve('./worker.js'))\n  }\n\n  worker.on('log', (obj) => {\n    try {\n      console.log(JSON.parse(obj))\n    } catch (ex) {\n      console.log(obj)\n    }\n  })\n\n  if (worker.started) {\n    // Worker start request has already been sent\n    return\n  }\n  // Send empty arguments as we don't use them in the worker\n  worker.start([])\n\n  // NOTE: Modifies the Task of the worker, but it's the only clean way to track this\n  worker.started = true\n}\n\n/**\n * Forces the worker Task to kill itself\n */\nexport function killWorker() {\n  if (worker !== null) {\n    worker.terminate()\n    worker = null\n  }\n}\n\n/**\n * Send a job to the worker and return the results\n * @param  {Object} config Configuration for the job to send to the worker\n * @return {Object|String|Error}        The data returned from the worker\n */\nexport async function sendJob(config) {\n  if (worker && !worker.childProcess.connected) {\n    // Sometimes the worker dies and becomes disconnected\n    // When that happens, it seems that there is no way to recover other\n    // than to kill the worker and create a new one.\n    killWorker()\n  }\n\n  // Ensure the worker is started\n  startWorker()\n\n  // Expand the config with a unique ID to emit on\n  // NOTE: Jobs _must_ have a unique ID as they are completely async and results\n  // can arrive back in any order.\n  // eslint-disable-next-line no-param-reassign\n  config.emitKey = cryptoRandomString({ length: 10 })\n\n  return new Promise((resolve, reject) => {\n    // All worker errors are caught and re-emitted along with their associated\n    // emitKey, so that we do not create multiple listeners for the same\n    // 'task:error' event\n    const errSub = worker.on(`workerError:${config.emitKey}`, ({ msg, stack }) => {\n      // Re-throw errors from the task\n      const error = new Error(msg)\n      // Set the stack to the one given to us by the worker\n      error.stack = stack\n      errSub.dispose()\n      // eslint-disable-next-line no-use-before-define\n      responseSub.dispose()\n      reject(error)\n    })\n    const responseSub = worker.on(config.emitKey, (data) => {\n      errSub.dispose()\n      responseSub.dispose()\n      resolve(data)\n    })\n    // Send the job on to the worker\n    try {\n      worker.send(config)\n    } catch (e) {\n      errSub.dispose()\n      responseSub.dispose()\n      console.error(e)\n    }\n  })\n}\n\nexport async function getDebugInfo() {\n  const textEditor = atom.workspace.getActiveTextEditor()\n  let filePath\n  let editorScopes\n  if (atom.workspace.isTextEditor(textEditor)) {\n    filePath = textEditor.getPath()\n    editorScopes = textEditor.getLastCursor().getScopeDescriptor().getScopesArray()\n  } else {\n    // Somehow this can be called with no active TextEditor, impossible I know...\n    filePath = 'unknown'\n    editorScopes = ['unknown']\n  }\n  const packagePath = atom.packages.resolvePackagePath('linter-eslint')\n  let linterEslintMeta\n  if (packagePath === undefined) {\n    // Apparently for some users the package path fails to resolve\n    linterEslintMeta = { version: 'unknown!' }\n  } else {\n    // eslint-disable-next-line import/no-dynamic-require\n    linterEslintMeta = require(join(packagePath, 'package.json'))\n  }\n  const config = atom.config.get('linter-eslint')\n  const hoursSinceRestart = Math.round((process.uptime() / 3600) * 10) / 10\n  let returnVal\n  try {\n    const response = await sendJob({\n      type: 'debug',\n      config,\n      filePath\n    })\n    returnVal = {\n      atomVersion: atom.getVersion(),\n      linterEslintVersion: linterEslintMeta.version,\n      linterEslintConfig: config,\n      // eslint-disable-next-line import/no-dynamic-require\n      eslintVersion: require(join(response.path, 'package.json')).version,\n      hoursSinceRestart,\n      platform: process.platform,\n      eslintType: response.type,\n      eslintPath: response.path,\n      editorScopes,\n    }\n  } catch (error) {\n    atom.notifications.addError(`${error}`)\n  }\n  return returnVal\n}\n\nexport async function generateDebugString() {\n  const debug = await getDebugInfo()\n  const details = [\n    `Atom version: ${debug.atomVersion}`,\n    `linter-eslint version: ${debug.linterEslintVersion}`,\n    `ESLint version: ${debug.eslintVersion}`,\n    `Hours since last Atom restart: ${debug.hoursSinceRestart}`,\n    `Platform: ${debug.platform}`,\n    `Using ${debug.eslintType} ESLint from: ${debug.eslintPath}`,\n    `Current file's scopes: ${JSON.stringify(debug.editorScopes, null, 2)}`,\n    `linter-eslint configuration: ${JSON.stringify(debug.linterEslintConfig, null, 2)}`\n  ]\n  return details.join('\\n')\n}\n\n/**\n * Turn the given options into a Linter message array\n * @param  {TextEditor} textEditor The TextEditor to use to build the message\n * @param  {Object} options    The parameters used to fill in the message\n * @param  {string} [options.severity='error'] Can be one of: 'error', 'warning', 'info'\n * @param  {string} [options.excerpt=''] Short text to use in the message\n * @param  {string|Function} [options.description] Used to provide additional information\n * @return {import(\"atom/linter\").Message[]} Message to user generated from the parameters\n */\nexport function generateUserMessage(textEditor, options) {\n  const {\n    severity = 'error',\n    excerpt = '',\n    description,\n  } = options\n  return [{\n    severity,\n    excerpt,\n    description,\n    location: {\n      file: textEditor.getPath(),\n      position: generateRange(textEditor),\n    },\n  }]\n}\n\n/**\n * Generates a message to the user in order to nicely display the Error being\n * thrown instead of depending on generic error handling.\n * @param  {import(\"atom\").TextEditor} textEditor The TextEditor to use to build the message\n * @param  {Error} error      Error to generate a message for\n * @return {import(\"atom/linter\").Message[]} Message to user generated from the Error\n */\nexport function handleError(textEditor, error) {\n  const { stack, message } = error\n  // Only show the first line of the message as the excerpt\n  const excerpt = `Error while running ESLint: ${message.split('\\n')[0]}.`\n  const description = `<div style=\"white-space: pre-wrap\">${message}\\n<hr />${stack}</div>`\n  return generateUserMessage(textEditor, { severity: 'error', excerpt, description })\n}\n\nconst generateInvalidTrace = async ({\n  msgLine, msgCol, msgEndLine, msgEndCol,\n  eslintFullRange, filePath, textEditor, ruleId, message\n}) => {\n  let errMsgRange = `${msgLine + 1}:${msgCol}`\n  if (eslintFullRange) {\n    errMsgRange += ` - ${msgEndLine + 1}:${msgEndCol + 1}`\n  }\n  const rangeText = `Requested ${eslintFullRange ? 'start point' : 'range'}: ${errMsgRange}`\n  const issueURL = 'https://github.com/AtomLinter/linter-eslint/issues/new'\n  const titleText = `Invalid position given by '${ruleId}'`\n  const title = encodeURIComponent(titleText)\n  const body = encodeURIComponent([\n    'ESLint returned a point that did not exist in the document being edited.',\n    `Rule: \\`${ruleId}\\``,\n    rangeText,\n    '', '',\n    '<!-- If at all possible, please include code to reproduce this issue! -->',\n    '', '',\n    'Debug information:',\n    '```json',\n    JSON.stringify(await getDebugInfo(), null, 2),\n    '```'\n  ].join('\\n'))\n\n  const location = {\n    file: filePath,\n    position: generateRange(textEditor, 0),\n  }\n  const newIssueURL = `${issueURL}?title=${title}&body=${body}`\n\n  return {\n    severity: 'error',\n    excerpt: `${titleText}. See the description for details. `\n      + 'Click the URL to open a new issue!',\n    url: newIssueURL,\n    location,\n    description: `${rangeText}\\nOriginal message: ${message}`\n  }\n}\n\n/**\n * Given a raw response from ESLint, this processes the messages into a format\n * compatible with the Linter API.\n * @param  {Object}     messages   The messages from ESLint's response\n * @param  {TextEditor} textEditor The Atom::TextEditor of the file the messages belong to\n * @param  {bool}       showRule   Whether to show the rule in the messages\n * @return {Promise}               The messages transformed into Linter messages\n */\nexport async function processESLintMessages(messages, textEditor, showRule) {\n  return Promise.all(messages.map(async ({\n    fatal, message: originalMessage, line, severity, ruleId, column, fix, endLine, endColumn\n  }) => {\n    const message = fatal ? originalMessage.split('\\n')[0] : originalMessage\n    const filePath = textEditor.getPath()\n    const textBuffer = textEditor.getBuffer()\n    let linterFix = null\n    if (fix) {\n      const fixRange = new Range(\n        textBuffer.positionForCharacterIndex(fix.range[0]),\n        textBuffer.positionForCharacterIndex(fix.range[1])\n      )\n      linterFix = {\n        position: fixRange,\n        replaceWith: fix.text\n      }\n    }\n    let msgCol\n    let msgEndLine\n    let msgEndCol\n    let eslintFullRange = false\n\n    /*\n     Note: ESLint positions are 1-indexed, while Atom expects 0-indexed,\n     positions. We are subtracting 1 from these values here so we don't have to\n     keep doing so in later uses.\n     */\n    const msgLine = line - 1\n    if (typeof endColumn === 'number' && typeof endLine === 'number') {\n      eslintFullRange = true\n      // Here we always want the column to be a number\n      msgCol = Math.max(0, column - 1)\n      msgEndLine = endLine - 1\n      msgEndCol = endColumn - 1\n    } else {\n      // We want msgCol to remain undefined if it was initially so\n      // `generateRange` will give us a range over the entire line\n      msgCol = typeof column === 'number' ? column - 1 : column\n    }\n\n    let ret = {\n      severity: severity === 1 ? 'warning' : 'error',\n      location: {\n        file: filePath,\n      }\n    }\n\n    if (ruleId) {\n      ret.url = rules.getRuleUrl(ruleId)\n    }\n\n    // HACK for https://github.com/AtomLinter/linter-eslint/issues/1249\n    let fixLineEnding = false\n    if (ruleId === 'prettier/prettier' && (message === 'Delete `␍`')) {\n      fixLineEnding = true\n    }\n\n    let range\n    try {\n      if (eslintFullRange) {\n        if (!fixLineEnding) {\n          throwIfInvalidPoint(textBuffer, msgLine, msgCol)\n          throwIfInvalidPoint(textBuffer, msgEndLine, msgEndCol)\n        }\n        range = [[msgLine, msgCol], [msgEndLine, msgEndCol]]\n      } else {\n        range = generateRange(textEditor, msgLine, msgCol)\n      }\n      ret.location.position = range\n\n      const ruleAppendix = showRule ? ` (${ruleId || 'Fatal'})` : ''\n      ret.excerpt = `${message}${ruleAppendix}`\n\n      if (linterFix) {\n        ret.solutions = [linterFix]\n      }\n    } catch (err) {\n      ret = await generateInvalidTrace({\n        msgLine,\n        msgCol,\n        msgEndLine,\n        msgEndCol,\n        eslintFullRange,\n        filePath,\n        textEditor,\n        ruleId,\n        message,\n      })\n    }\n\n    return ret\n  }))\n}\n\n/**\n * Processes the response from the lint job\n * @param  {Object}     response   The raw response from the job\n * @param  {TextEditor} textEditor The Atom::TextEditor of the file the messages belong to\n * @param  {bool}       showRule   Whether to show the rule in the messages\n * @return {Promise}               The messages transformed into Linter messages\n */\nexport async function processJobResponse(response, textEditor, showRule) {\n  if (Object.prototype.hasOwnProperty.call(response, 'updatedRules')) {\n    rules.replaceRules(response.updatedRules)\n  }\n  return processESLintMessages(response.messages, textEditor, showRule)\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/helpers.js"],"names":["asyncRandomBytes","randomBytes","rules","Rules","worker","startWorker","Task","require","resolve","on","obj","console","log","JSON","parse","ex","started","start","killWorker","terminate","sendJob","config","childProcess","connected","emitKey","toString","Promise","reject","errSub","msg","stack","error","Error","dispose","responseSub","data","send","e","getDebugInfo","textEditor","atom","workspace","getActiveTextEditor","filePath","editorScopes","isTextEditor","getPath","getLastCursor","getScopeDescriptor","getScopesArray","packagePath","packages","resolvePackagePath","linterEslintMeta","undefined","version","get","hoursSinceRestart","Math","round","process","uptime","returnVal","response","type","atomVersion","getVersion","linterEslintVersion","linterEslintConfig","eslintVersion","path","platform","eslintType","eslintPath","notifications","addError","generateDebugString","debug","details","stringify","join","generateUserMessage","options","severity","excerpt","description","location","file","position","handleError","message","split","generateInvalidTrace","msgLine","msgCol","msgEndLine","msgEndCol","eslintFullRange","ruleId","errMsgRange","rangeText","issueURL","titleText","title","encodeURIComponent","body","newIssueURL","url","processESLintMessages","messages","showRule","all","map","fatal","originalMessage","line","column","fix","endLine","endColumn","textBuffer","getBuffer","linterFix","fixRange","Range","positionForCharacterIndex","range","replaceWith","text","max","ret","getRuleUrl","fixLineEnding","ruleAppendix","solutions","err","processJobResponse","Object","prototype","hasOwnProperty","call","replaceRules","updatedRules"],"mappings":"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","sourcesContent":["import { join } from 'path'\nimport { generateRange } from 'atom-linter'\nimport { randomBytes } from 'crypto'\nimport { promisify } from 'util'\n// eslint-disable-next-line import/no-extraneous-dependencies, import/extensions\nimport { Range, Task } from 'atom'\nimport Rules from './rules'\nimport { throwIfInvalidPoint } from './validate/editor'\n\nconst asyncRandomBytes = promisify(randomBytes)\nexport const rules = new Rules()\nlet worker = null\n\n/**\n * Start the worker process if it hasn't already been started\n */\nexport function startWorker() {\n  if (worker === null) {\n    worker = new Task(require.resolve('./worker.js'))\n  }\n\n  worker.on('log', (obj) => {\n    try {\n      console.log(JSON.parse(obj))\n    } catch (ex) {\n      console.log(obj)\n    }\n  })\n\n  if (worker.started) {\n    // Worker start request has already been sent\n    return\n  }\n  // Send empty arguments as we don't use them in the worker\n  worker.start([])\n\n  // NOTE: Modifies the Task of the worker, but it's the only clean way to track this\n  worker.started = true\n}\n\n/**\n * Forces the worker Task to kill itself\n */\nexport function killWorker() {\n  if (worker !== null) {\n    worker.terminate()\n    worker = null\n  }\n}\n\n/**\n * Send a job to the worker and return the results\n * @param  {Object} config Configuration for the job to send to the worker\n * @return {Object|String|Error}        The data returned from the worker\n */\nexport async function sendJob(config) {\n  if (worker && !worker.childProcess.connected) {\n    // Sometimes the worker dies and becomes disconnected\n    // When that happens, it seems that there is no way to recover other\n    // than to kill the worker and create a new one.\n    killWorker()\n  }\n\n  // Ensure the worker is started\n  startWorker()\n\n  // Expand the config with a unique ID to emit on\n  // NOTE: Jobs _must_ have a unique ID as they are completely async and results\n  // can arrive back in any order.\n  // eslint-disable-next-line no-param-reassign\n  config.emitKey = (await asyncRandomBytes(5)).toString('hex') // 5 bytes = 10 hex characters\n\n  return new Promise((resolve, reject) => {\n    // All worker errors are caught and re-emitted along with their associated\n    // emitKey, so that we do not create multiple listeners for the same\n    // 'task:error' event\n    const errSub = worker.on(`workerError:${config.emitKey}`, ({ msg, stack }) => {\n      // Re-throw errors from the task\n      const error = new Error(msg)\n      // Set the stack to the one given to us by the worker\n      error.stack = stack\n      errSub.dispose()\n      // eslint-disable-next-line no-use-before-define\n      responseSub.dispose()\n      reject(error)\n    })\n    const responseSub = worker.on(config.emitKey, (data) => {\n      errSub.dispose()\n      responseSub.dispose()\n      resolve(data)\n    })\n    // Send the job on to the worker\n    try {\n      worker.send(config)\n    } catch (e) {\n      errSub.dispose()\n      responseSub.dispose()\n      console.error(e)\n    }\n  })\n}\n\nexport async function getDebugInfo() {\n  const textEditor = atom.workspace.getActiveTextEditor()\n  let filePath\n  let editorScopes\n  if (atom.workspace.isTextEditor(textEditor)) {\n    filePath = textEditor.getPath()\n    editorScopes = textEditor.getLastCursor().getScopeDescriptor().getScopesArray()\n  } else {\n    // Somehow this can be called with no active TextEditor, impossible I know...\n    filePath = 'unknown'\n    editorScopes = ['unknown']\n  }\n  const packagePath = atom.packages.resolvePackagePath('linter-eslint')\n  let linterEslintMeta\n  if (packagePath === undefined) {\n    // Apparently for some users the package path fails to resolve\n    linterEslintMeta = { version: 'unknown!' }\n  } else {\n    // eslint-disable-next-line import/no-dynamic-require\n    linterEslintMeta = require(join(packagePath, 'package.json'))\n  }\n  const config = atom.config.get('linter-eslint')\n  const hoursSinceRestart = Math.round((process.uptime() / 3600) * 10) / 10\n  let returnVal\n  try {\n    const response = await sendJob({\n      type: 'debug',\n      config,\n      filePath\n    })\n    returnVal = {\n      atomVersion: atom.getVersion(),\n      linterEslintVersion: linterEslintMeta.version,\n      linterEslintConfig: config,\n      // eslint-disable-next-line import/no-dynamic-require\n      eslintVersion: require(join(response.path, 'package.json')).version,\n      hoursSinceRestart,\n      platform: process.platform,\n      eslintType: response.type,\n      eslintPath: response.path,\n      editorScopes,\n    }\n  } catch (error) {\n    atom.notifications.addError(`${error}`)\n  }\n  return returnVal\n}\n\nexport async function generateDebugString() {\n  const debug = await getDebugInfo()\n  const details = [\n    `Atom version: ${debug.atomVersion}`,\n    `linter-eslint version: ${debug.linterEslintVersion}`,\n    `ESLint version: ${debug.eslintVersion}`,\n    `Hours since last Atom restart: ${debug.hoursSinceRestart}`,\n    `Platform: ${debug.platform}`,\n    `Using ${debug.eslintType} ESLint from: ${debug.eslintPath}`,\n    `Current file's scopes: ${JSON.stringify(debug.editorScopes, null, 2)}`,\n    `linter-eslint configuration: ${JSON.stringify(debug.linterEslintConfig, null, 2)}`\n  ]\n  return details.join('\\n')\n}\n\n/**\n * Turn the given options into a Linter message array\n * @param  {TextEditor} textEditor The TextEditor to use to build the message\n * @param  {Object} options    The parameters used to fill in the message\n * @param  {string} [options.severity='error'] Can be one of: 'error', 'warning', 'info'\n * @param  {string} [options.excerpt=''] Short text to use in the message\n * @param  {string|Function} [options.description] Used to provide additional information\n * @return {import(\"atom/linter\").Message[]} Message to user generated from the parameters\n */\nexport function generateUserMessage(textEditor, options) {\n  const {\n    severity = 'error',\n    excerpt = '',\n    description,\n  } = options\n  return [{\n    severity,\n    excerpt,\n    description,\n    location: {\n      file: textEditor.getPath(),\n      position: generateRange(textEditor),\n    },\n  }]\n}\n\n/**\n * Generates a message to the user in order to nicely display the Error being\n * thrown instead of depending on generic error handling.\n * @param  {import(\"atom\").TextEditor} textEditor The TextEditor to use to build the message\n * @param  {Error} error      Error to generate a message for\n * @return {import(\"atom/linter\").Message[]} Message to user generated from the Error\n */\nexport function handleError(textEditor, error) {\n  const { stack, message } = error\n  // Only show the first line of the message as the excerpt\n  const excerpt = `Error while running ESLint: ${message.split('\\n')[0]}.`\n  const description = `<div style=\"white-space: pre-wrap\">${message}\\n<hr />${stack}</div>`\n  return generateUserMessage(textEditor, { severity: 'error', excerpt, description })\n}\n\nconst generateInvalidTrace = async ({\n  msgLine, msgCol, msgEndLine, msgEndCol,\n  eslintFullRange, filePath, textEditor, ruleId, message\n}) => {\n  let errMsgRange = `${msgLine + 1}:${msgCol}`\n  if (eslintFullRange) {\n    errMsgRange += ` - ${msgEndLine + 1}:${msgEndCol + 1}`\n  }\n  const rangeText = `Requested ${eslintFullRange ? 'start point' : 'range'}: ${errMsgRange}`\n  const issueURL = 'https://github.com/AtomLinter/linter-eslint/issues/new'\n  const titleText = `Invalid position given by '${ruleId}'`\n  const title = encodeURIComponent(titleText)\n  const body = encodeURIComponent([\n    'ESLint returned a point that did not exist in the document being edited.',\n    `Rule: \\`${ruleId}\\``,\n    rangeText,\n    '', '',\n    '<!-- If at all possible, please include code to reproduce this issue! -->',\n    '', '',\n    'Debug information:',\n    '```json',\n    JSON.stringify(await getDebugInfo(), null, 2),\n    '```'\n  ].join('\\n'))\n\n  const location = {\n    file: filePath,\n    position: generateRange(textEditor, 0),\n  }\n  const newIssueURL = `${issueURL}?title=${title}&body=${body}`\n\n  return {\n    severity: 'error',\n    excerpt: `${titleText}. See the description for details. `\n      + 'Click the URL to open a new issue!',\n    url: newIssueURL,\n    location,\n    description: `${rangeText}\\nOriginal message: ${message}`\n  }\n}\n\n/**\n * Given a raw response from ESLint, this processes the messages into a format\n * compatible with the Linter API.\n * @param  {Object}     messages   The messages from ESLint's response\n * @param  {TextEditor} textEditor The Atom::TextEditor of the file the messages belong to\n * @param  {bool}       showRule   Whether to show the rule in the messages\n * @return {Promise}               The messages transformed into Linter messages\n */\nexport async function processESLintMessages(messages, textEditor, showRule) {\n  return Promise.all(messages.map(async ({\n    fatal, message: originalMessage, line, severity, ruleId, column, fix, endLine, endColumn\n  }) => {\n    const message = fatal ? originalMessage.split('\\n')[0] : originalMessage\n    const filePath = textEditor.getPath()\n    const textBuffer = textEditor.getBuffer()\n    let linterFix = null\n    if (fix) {\n      const fixRange = new Range(\n        textBuffer.positionForCharacterIndex(fix.range[0]),\n        textBuffer.positionForCharacterIndex(fix.range[1])\n      )\n      linterFix = {\n        position: fixRange,\n        replaceWith: fix.text\n      }\n    }\n    let msgCol\n    let msgEndLine\n    let msgEndCol\n    let eslintFullRange = false\n\n    /*\n     Note: ESLint positions are 1-indexed, while Atom expects 0-indexed,\n     positions. We are subtracting 1 from these values here so we don't have to\n     keep doing so in later uses.\n     */\n    const msgLine = line - 1\n    if (typeof endColumn === 'number' && typeof endLine === 'number') {\n      eslintFullRange = true\n      // Here we always want the column to be a number\n      msgCol = Math.max(0, column - 1)\n      msgEndLine = endLine - 1\n      msgEndCol = endColumn - 1\n    } else {\n      // We want msgCol to remain undefined if it was initially so\n      // `generateRange` will give us a range over the entire line\n      msgCol = typeof column === 'number' ? column - 1 : column\n    }\n\n    let ret = {\n      severity: severity === 1 ? 'warning' : 'error',\n      location: {\n        file: filePath,\n      }\n    }\n\n    if (ruleId) {\n      ret.url = rules.getRuleUrl(ruleId)\n    }\n\n    // HACK for https://github.com/AtomLinter/linter-eslint/issues/1249\n    let fixLineEnding = false\n    if (ruleId === 'prettier/prettier' && (message === 'Delete `␍`')) {\n      fixLineEnding = true\n    }\n\n    let range\n    try {\n      if (eslintFullRange) {\n        if (!fixLineEnding) {\n          throwIfInvalidPoint(textBuffer, msgLine, msgCol)\n          throwIfInvalidPoint(textBuffer, msgEndLine, msgEndCol)\n        }\n        range = [[msgLine, msgCol], [msgEndLine, msgEndCol]]\n      } else {\n        range = generateRange(textEditor, msgLine, msgCol)\n      }\n      ret.location.position = range\n\n      const ruleAppendix = showRule ? ` (${ruleId || 'Fatal'})` : ''\n      ret.excerpt = `${message}${ruleAppendix}`\n\n      if (linterFix) {\n        ret.solutions = [linterFix]\n      }\n    } catch (err) {\n      ret = await generateInvalidTrace({\n        msgLine,\n        msgCol,\n        msgEndLine,\n        msgEndCol,\n        eslintFullRange,\n        filePath,\n        textEditor,\n        ruleId,\n        message,\n      })\n    }\n\n    return ret\n  }))\n}\n\n/**\n * Processes the response from the lint job\n * @param  {Object}     response   The raw response from the job\n * @param  {TextEditor} textEditor The Atom::TextEditor of the file the messages belong to\n * @param  {bool}       showRule   Whether to show the rule in the messages\n * @return {Promise}               The messages transformed into Linter messages\n */\nexport async function processJobResponse(response, textEditor, showRule) {\n  if (Object.prototype.hasOwnProperty.call(response, 'updatedRules')) {\n    rules.replaceRules(response.updatedRules)\n  }\n  return processESLintMessages(response.messages, textEditor, showRule)\n}\n"]} \ No newline at end of file diff --git a/dist/validate/editor.js b/dist/validate/editor.js index 7a53baee..85ec8888 100644 --- a/dist/validate/editor.js +++ b/dist/validate/editor.js @@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.hasValidScope = exports.throwIfInvalidPoint = exports.isValidPoint = void 0; +exports.throwIfInvalidPoint = exports.isValidPoint = exports.hasValidScope = void 0; var _throw = _interopRequireDefault(require("./throw")); diff --git a/dist/worker-helpers.js b/dist/worker-helpers.js index 829ee74c..68bcdf17 100644 --- a/dist/worker-helpers.js +++ b/dist/worker-helpers.js @@ -3,17 +3,17 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.getNodePrefixPath = getNodePrefixPath; +exports.didRulesChange = didRulesChange; exports.findESLintDirectory = findESLintDirectory; +exports.getCLIEngineOptions = getCLIEngineOptions; +exports.getConfigForFile = getConfigForFile; exports.getESLintFromDirectory = getESLintFromDirectory; -exports.refreshModulesPath = refreshModulesPath; exports.getESLintInstance = getESLintInstance; -exports.log = log; -exports.getConfigForFile = getConfigForFile; +exports.getNodePrefixPath = getNodePrefixPath; exports.getRelativePath = getRelativePath; -exports.getCLIEngineOptions = getCLIEngineOptions; exports.getRules = getRules; -exports.didRulesChange = didRulesChange; +exports.log = log; +exports.refreshModulesPath = refreshModulesPath; var _path = _interopRequireDefault(require("path")); diff --git a/package.json b/package.json index 0a4e8cea..2f0d7267 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "linter-eslint", "main": "./dist/main.js", - "version": "8.6.6", + "version": "9.0.0", "description": "Lint JavaScript on the fly, using ESLint", "repository": "https://github.com/AtomLinter/linter-eslint.git", "license": "MIT",