diff --git a/CHANGELOG.md b/CHANGELOG.md index f914aa5e..9e636083 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,10 @@ +## [9.0.1](https://github.com/AtomLinter/linter-eslint/compare/v9.0.0...v9.0.1) (2022-03-21) + + +### Bug Fixes + +* detect ESLint >= 8 and tell the user about linter-eslint-node ([#1464](https://github.com/AtomLinter/linter-eslint/issues/1464)) ([1297ab6](https://github.com/AtomLinter/linter-eslint/commit/1297ab6d91679a68b4c37834dc303a741cd13844)) + # [9.0.0](https://github.com/AtomLinter/linter-eslint/compare/v8.6.6...v9.0.0) (2021-10-30) diff --git a/dist/helpers.js b/dist/helpers.js index 38ee0774..3cedb375 100644 --- a/dist/helpers.js +++ b/dist/helpers.js @@ -7,6 +7,7 @@ exports.generateDebugString = generateDebugString; exports.generateUserMessage = generateUserMessage; exports.getDebugInfo = getDebugInfo; exports.handleError = handleError; +exports.isIncompatibleEslint = isIncompatibleEslint; exports.killWorker = killWorker; exports.processESLintMessages = processESLintMessages; exports.processJobResponse = processJobResponse; @@ -24,6 +25,8 @@ var _util = require("util"); var _atom = require("atom"); +var _electron = require("electron"); + var _rules = _interopRequireDefault(require("./rules")); var _editor = require("./validate/editor"); @@ -31,10 +34,13 @@ 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 +// eslint-disable-next-line import/no-unresolved const asyncRandomBytes = (0, _util.promisify)(_crypto.randomBytes); const rules = new _rules.default(); exports.rules = rules; let worker = null; +let isIncompatibleEslintVersion = false; +let seenIncompatibleVersionNotification = false; /** * Start the worker process if it hasn't already been started */ @@ -73,6 +79,10 @@ function killWorker() { worker = null; } } + +function isIncompatibleEslint() { + return isIncompatibleEslintVersion; +} /** * Send a job to the worker and return the results * @param {Object} config Configuration for the job to send to the worker @@ -102,12 +112,14 @@ async function sendJob(config) { // 'task:error' event const errSub = worker.on(`workerError:${config.emitKey}`, ({ msg, - stack + stack, + name }) => { // Re-throw errors from the task const error = new Error(msg); // Set the stack to the one given to us by the worker error.stack = stack; + error.name = name; errSub.dispose(); // eslint-disable-next-line no-use-before-define responseSub.dispose(); @@ -217,6 +229,43 @@ function generateUserMessage(textEditor, options) { } }]; } + +function isNewPackageInstalled() { + return atom.packages.isPackageLoaded('linter-eslint-node') || atom.packages.isPackageDisabled('linter-eslint-node'); +} + +function showIncompatibleVersionNotification(message) { + const notificationEnabled = atom.config.get('linter-eslint.advanced.showIncompatibleVersionNotification'); + + if (!notificationEnabled || seenIncompatibleVersionNotification || isNewPackageInstalled()) { + return; + } // Show this message only once per session. + + + seenIncompatibleVersionNotification = true; + const notification = atom.notifications.addWarning('linter-eslint: Incompatible version', { + description: message, + dismissable: true, + buttons: [{ + text: 'Install linter-eslint-node', + + onDidClick() { + _electron.shell.openExternal('https://atom.io/packages/linter-eslint-node'); + + notification.dismiss(); + } + + }, { + text: 'Don\'t show this notification again', + + onDidClick() { + atom.config.set('linter-eslint.advanced.showIncompatibleVersionNotification', false); + notification.dismiss(); + } + + }] + }); +} /** * Generates a message to the user in order to nicely display the Error being * thrown instead of depending on generic error handling. @@ -229,11 +278,22 @@ function generateUserMessage(textEditor, options) { function handleError(textEditor, error) { const { stack, - message - } = error; // Only show the first line of the message as the excerpt + message, + name + } = error; // We want this specific worker error to show up as a notification so that we + // can include a button for installing the new package. + + if (name === 'IncompatibleESLintError') { + isIncompatibleEslintVersion = true; + killWorker(); + showIncompatibleVersionNotification(message); + return; + } // Only show the first line of the message as the excerpt + const excerpt = `Error while running ESLint: ${message.split('\n')[0]}.`; - const description = `
${message}\n
${stack}
`; + const description = `
${message}\n
${stack}
`; // eslint-disable-next-line consistent-return + return generateUserMessage(textEditor, { severity: 'error', excerpt, @@ -407,4 +467,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":["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 +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/helpers.js"],"names":["asyncRandomBytes","randomBytes","rules","Rules","worker","isIncompatibleEslintVersion","seenIncompatibleVersionNotification","startWorker","Task","require","resolve","on","obj","console","log","JSON","parse","ex","started","start","killWorker","terminate","isIncompatibleEslint","sendJob","config","childProcess","connected","emitKey","toString","Promise","reject","errSub","msg","stack","name","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","isNewPackageInstalled","isPackageLoaded","isPackageDisabled","showIncompatibleVersionNotification","message","notificationEnabled","notification","addWarning","dismissable","buttons","text","onDidClick","shell","openExternal","dismiss","set","handleError","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","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'\n// eslint-disable-next-line import/no-unresolved\nimport { shell } from 'electron'\nimport Rules from './rules'\nimport { throwIfInvalidPoint } from './validate/editor'\n\nconst asyncRandomBytes = promisify(randomBytes)\nexport const rules = new Rules()\nlet worker = null\nlet isIncompatibleEslintVersion = false\nlet seenIncompatibleVersionNotification = false\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\nexport function isIncompatibleEslint() {\n  return isIncompatibleEslintVersion\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, name }) => {\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      error.name = name\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\nfunction isNewPackageInstalled() {\n  return atom.packages.isPackageLoaded('linter-eslint-node')\n   || atom.packages.isPackageDisabled('linter-eslint-node')\n}\n\nfunction showIncompatibleVersionNotification(message) {\n  const notificationEnabled = atom.config.get('linter-eslint.advanced.showIncompatibleVersionNotification')\n  if (!notificationEnabled || seenIncompatibleVersionNotification || isNewPackageInstalled()) {\n    return\n  }\n\n  // Show this message only once per session.\n  seenIncompatibleVersionNotification = true\n  const notification = atom.notifications.addWarning(\n    'linter-eslint: Incompatible version',\n    {\n      description: message,\n      dismissable: true,\n      buttons: [\n        {\n          text: 'Install linter-eslint-node',\n          onDidClick() {\n            shell.openExternal('https://atom.io/packages/linter-eslint-node')\n            notification.dismiss()\n          }\n        },\n        {\n          text: 'Don\\'t show this notification again',\n          onDidClick() {\n            atom.config.set('linter-eslint.advanced.showIncompatibleVersionNotification', false)\n            notification.dismiss()\n          }\n        }\n      ]\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, name } = error\n  // We want this specific worker error to show up as a notification so that we\n  // can include a button for installing the new package.\n  if (name === 'IncompatibleESLintError') {\n    isIncompatibleEslintVersion = true\n    killWorker()\n    showIncompatibleVersionNotification(message)\n    return\n  }\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  // eslint-disable-next-line consistent-return\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/main.js b/dist/main.js index 8c9b3115..6dd585cc 100644 --- a/dist/main.js +++ b/dist/main.js @@ -175,6 +175,13 @@ module.exports = { return null; } + if (helpers.isIncompatibleEslint()) { + // The project's version of ESLint doesn't work with this package. Once + // this is detected, we won't try to send any jobs until the window is + // reloaded. + return null; + } + const filePath = textEditor.getPath(); if (!filePath) { @@ -242,6 +249,13 @@ module.exports = { return; } + if (helpers.isIncompatibleEslint()) { + // The project's version of ESLint doesn't work with this package. Once + // this is detected, we won't try to send any jobs until the window is + // reloaded. + return; + } + if (textEditor.isModified()) { // Abort for invalid or unsaved text editors const message = 'Linter-ESLint: Please save before fixing'; @@ -277,9 +291,13 @@ module.exports = { atom.notifications.addSuccess(response); } } catch (err) { + if (err.name === 'IncompatibleESLintError') { + return; + } + atom.notifications.addWarning(err.message); } } }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/main.js"],"names":["idleCallbacks","Set","makeIdleCallback","work","callbackId","callBack","delete","window","requestIdleCallback","add","scheduleIdleTasks","linterEslintInstallPeerPackages","require","install","linterEslintStartWorker","helpers","startWorker","atom","inSpecMode","scopes","showRule","lintHtmlFiles","ignoredRulesWhenModified","ignoredRulesWhenFixing","ignoreFixableRulesWhileTyping","idsToIgnoredRules","ruleIds","Array","from","reduce","ids","id","Object","assign","module","exports","activate","subscriptions","CompositeDisposable","embeddedScope","config","observe","value","push","indexOf","splice","length","prototype","apply","includes","workspace","observeTextEditors","editor","onDidSave","get","fixJob","commands","debugString","generateDebugString","notificationOptions","detail","dismissable","notifications","addInfo","contextMenu","label","command","shouldDisplay","evt","activeEditor","getActiveTextEditor","evtIsActiveEditor","path","some","elem","component","deactivate","forEach","callbackID","cancelIdleCallback","clear","killWorker","dispose","provideLinter","name","grammarScopes","scope","lintsOnChange","lint","textEditor","isTextEditor","filePath","getPath","generateUserMessage","severity","excerpt","text","getText","rules","isModified","ignoredRules","getFixableRules","ruleId","response","sendJob","type","contents","projectPath","project","relativizePath","processJobResponse","error","handleError","isSave","message","addError","keys","addSuccess","err","addWarning"],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies, import/extensions\nimport { CompositeDisposable } from 'atom'\nimport { hasValidScope } from './validate/editor'\nimport * as helpers from './helpers'\nimport { migrateConfigOptions } from './migrate-config-options'\n\n// Internal variables\nconst idleCallbacks = new Set()\n\nconst makeIdleCallback = (work) => {\n  let callbackId\n  const callBack = () => {\n    idleCallbacks.delete(callbackId)\n    work()\n  }\n  callbackId = window.requestIdleCallback(callBack)\n  idleCallbacks.add(callbackId)\n}\n\nconst scheduleIdleTasks = () => {\n  const linterEslintInstallPeerPackages = () => {\n    require('atom-package-deps').install('linter-eslint')\n  }\n  const linterEslintStartWorker = () => {\n    helpers.startWorker()\n  }\n\n  if (!atom.inSpecMode()) {\n    makeIdleCallback(linterEslintInstallPeerPackages)\n    makeIdleCallback(linterEslintStartWorker)\n  }\n}\n\n// Configuration\nconst scopes = []\nlet showRule\nlet lintHtmlFiles\nlet ignoredRulesWhenModified\nlet ignoredRulesWhenFixing\nlet ignoreFixableRulesWhileTyping\n\n// Internal functions\n/**\n * Given an Array or iterable containing a list of Rule IDs, return an Object\n * to be sent to ESLint's configuration that disables those rules.\n * @param  {[iterable]} ruleIds Iterable containing ruleIds to ignore\n * @return {Object}             Object containing properties for each rule to ignore\n */\nconst idsToIgnoredRules = (ruleIds) => (\n  Array.from(ruleIds).reduce(\n    // 0 is the severity to turn off a rule\n    (ids, id) => Object.assign(ids, { [id]: 0 }),\n    {}\n  ))\n\nmodule.exports = {\n  activate() {\n    this.subscriptions = new CompositeDisposable()\n\n    migrateConfigOptions()\n\n    const embeddedScope = 'source.js.embedded.html'\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.lintHtmlFiles',\n      (value) => {\n        lintHtmlFiles = value\n        if (lintHtmlFiles) {\n          scopes.push(embeddedScope)\n        } else if (scopes.indexOf(embeddedScope) !== -1) {\n          scopes.splice(scopes.indexOf(embeddedScope), 1)\n        }\n      }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.scopes',\n      (value) => {\n        // Remove any old scopes\n        scopes.splice(0, scopes.length)\n        // Add the current scopes\n        Array.prototype.push.apply(scopes, value)\n        // Ensure HTML linting still works if the setting is updated\n        if (lintHtmlFiles && !scopes.includes(embeddedScope)) {\n          scopes.push(embeddedScope)\n        }\n      }\n    ))\n\n    this.subscriptions.add(atom.workspace.observeTextEditors((editor) => {\n      editor.onDidSave(async () => {\n        if (hasValidScope(editor, scopes)\n          && atom.config.get('linter-eslint.autofix.fixOnSave')\n        ) {\n          await this.fixJob(true)\n        }\n      })\n    }))\n\n    this.subscriptions.add(atom.commands.add('atom-text-editor', {\n      'linter-eslint:debug': async () => {\n        const debugString = await helpers.generateDebugString()\n        const notificationOptions = { detail: debugString, dismissable: true }\n        atom.notifications.addInfo('linter-eslint debugging information', notificationOptions)\n      }\n    }))\n\n    this.subscriptions.add(atom.commands.add('atom-text-editor', {\n      'linter-eslint:fix-file': async () => {\n        await this.fixJob()\n      }\n    }))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.advanced.showRuleIdInMessage',\n      (value) => { showRule = value }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.disabling.rulesToSilenceWhileTyping',\n      (ids) => { ignoredRulesWhenModified = ids }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.autofix.rulesToDisableWhileFixing',\n      (ids) => { ignoredRulesWhenFixing = idsToIgnoredRules(ids) }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.autofix.ignoreFixableRulesWhileTyping',\n      (value) => { ignoreFixableRulesWhileTyping = value }\n    ))\n\n    this.subscriptions.add(atom.contextMenu.add({\n      'atom-text-editor:not(.mini), .overlayer': [{\n        label: 'ESLint Fix',\n        command: 'linter-eslint:fix-file',\n        shouldDisplay: (evt) => {\n          const activeEditor = atom.workspace.getActiveTextEditor()\n          if (!activeEditor) {\n            return false\n          }\n          // Black magic!\n          // Compares the private component property of the active TextEditor\n          //   against the components of the elements\n          const evtIsActiveEditor = evt.path.some((elem) => (\n            // Atom v1.19.0+\n            elem.component && activeEditor.component\n              && elem.component === activeEditor.component))\n          // Only show if it was the active editor and it is a valid scope\n          return evtIsActiveEditor && hasValidScope(activeEditor, scopes)\n        }\n      }]\n    }))\n\n    scheduleIdleTasks()\n  },\n\n  deactivate() {\n    idleCallbacks.forEach((callbackID) => window.cancelIdleCallback(callbackID))\n    idleCallbacks.clear()\n    if (helpers) {\n      // If the helpers module hasn't been loaded then there was no chance a\n      // worker was started anyway.\n      helpers.killWorker()\n    }\n    this.subscriptions.dispose()\n  },\n\n  provideLinter() {\n    return {\n      name: 'ESLint',\n      grammarScopes: scopes,\n      scope: 'file',\n      lintsOnChange: true,\n      /**\n       * @param {import(\"atom\").TextEditor} textEditor\n       * @returns {Promise<import(\"atom/linter\").Message[]>}\n       */\n      lint: async (textEditor) => {\n        if (!atom.workspace.isTextEditor(textEditor)) {\n          // If we somehow get fed an invalid TextEditor just immediately return\n          return null\n        }\n\n        const filePath = textEditor.getPath()\n        if (!filePath) {\n          // The editor currently has no path, we can't report messages back to\n          // Linter so just return null\n          return null\n        }\n\n        if (filePath.includes('://')) {\n          // If the path is a URL (Nuclide remote file) return a message\n          // telling the user we are unable to work on remote files.\n          return helpers.generateUserMessage(textEditor, {\n            severity: 'warning',\n            excerpt: 'Remote file open, linter-eslint is disabled for this file.',\n          })\n        }\n\n        const text = textEditor.getText()\n\n        let rules = {}\n        if (textEditor.isModified()) {\n          if (ignoreFixableRulesWhileTyping) {\n            // Note that the fixable rules will only have values after the first lint job\n            const ignoredRules = new Set(helpers.rules.getFixableRules())\n            ignoredRulesWhenModified.forEach((ruleId) => ignoredRules.add(ruleId))\n            rules = idsToIgnoredRules(ignoredRules)\n          } else {\n            rules = idsToIgnoredRules(ignoredRulesWhenModified)\n          }\n        }\n\n        try {\n          const response = await helpers.sendJob({\n            type: 'lint',\n            contents: text,\n            config: atom.config.get('linter-eslint'),\n            rules,\n            filePath,\n            projectPath: atom.project.relativizePath(filePath)[0] || ''\n          })\n          if (textEditor.getText() !== text) {\n            /*\n            The editor text has been modified since the lint was triggered,\n            as we can't be sure that the results will map properly back to\n            the new contents, simply return `null` to tell the\n            `provideLinter` consumer not to update the saved results.\n            */\n            return null\n          }\n          return helpers.processJobResponse(response, textEditor, showRule)\n        } catch (error) {\n          return helpers.handleError(textEditor, error)\n        }\n      }\n    }\n  },\n\n  async fixJob(isSave = false) {\n    const textEditor = atom.workspace.getActiveTextEditor()\n\n    if (!textEditor || !atom.workspace.isTextEditor(textEditor)) {\n      // Silently return if the TextEditor is invalid\n      return\n    }\n\n    if (textEditor.isModified()) {\n      // Abort for invalid or unsaved text editors\n      const message = 'Linter-ESLint: Please save before fixing'\n      atom.notifications.addError(message)\n    }\n\n    const filePath = textEditor.getPath()\n    const projectPath = atom.project.relativizePath(filePath)[0]\n\n    // Get the text from the editor, so we can use executeOnText\n    const text = textEditor.getText()\n    // Do not try to make fixes on an empty file\n    if (text.length === 0) {\n      return\n    }\n\n    let rules = {}\n    if (Object.keys(ignoredRulesWhenFixing).length > 0) {\n      rules = ignoredRulesWhenFixing\n    }\n\n    try {\n      const response = await helpers.sendJob({\n        type: 'fix',\n        config: atom.config.get('linter-eslint'),\n        contents: text,\n        rules,\n        filePath,\n        projectPath\n      })\n      if (!isSave) {\n        atom.notifications.addSuccess(response)\n      }\n    } catch (err) {\n      atom.notifications.addWarning(err.message)\n    }\n  },\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/main.js"],"names":["idleCallbacks","Set","makeIdleCallback","work","callbackId","callBack","delete","window","requestIdleCallback","add","scheduleIdleTasks","linterEslintInstallPeerPackages","require","install","linterEslintStartWorker","helpers","startWorker","atom","inSpecMode","scopes","showRule","lintHtmlFiles","ignoredRulesWhenModified","ignoredRulesWhenFixing","ignoreFixableRulesWhileTyping","idsToIgnoredRules","ruleIds","Array","from","reduce","ids","id","Object","assign","module","exports","activate","subscriptions","CompositeDisposable","embeddedScope","config","observe","value","push","indexOf","splice","length","prototype","apply","includes","workspace","observeTextEditors","editor","onDidSave","get","fixJob","commands","debugString","generateDebugString","notificationOptions","detail","dismissable","notifications","addInfo","contextMenu","label","command","shouldDisplay","evt","activeEditor","getActiveTextEditor","evtIsActiveEditor","path","some","elem","component","deactivate","forEach","callbackID","cancelIdleCallback","clear","killWorker","dispose","provideLinter","name","grammarScopes","scope","lintsOnChange","lint","textEditor","isTextEditor","isIncompatibleEslint","filePath","getPath","generateUserMessage","severity","excerpt","text","getText","rules","isModified","ignoredRules","getFixableRules","ruleId","response","sendJob","type","contents","projectPath","project","relativizePath","processJobResponse","error","handleError","isSave","message","addError","keys","addSuccess","err","addWarning"],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies, import/extensions\nimport { CompositeDisposable } from 'atom'\nimport { hasValidScope } from './validate/editor'\nimport * as helpers from './helpers'\nimport { migrateConfigOptions } from './migrate-config-options'\n\n// Internal variables\nconst idleCallbacks = new Set()\n\nconst makeIdleCallback = (work) => {\n  let callbackId\n  const callBack = () => {\n    idleCallbacks.delete(callbackId)\n    work()\n  }\n  callbackId = window.requestIdleCallback(callBack)\n  idleCallbacks.add(callbackId)\n}\n\nconst scheduleIdleTasks = () => {\n  const linterEslintInstallPeerPackages = () => {\n    require('atom-package-deps').install('linter-eslint')\n  }\n  const linterEslintStartWorker = () => {\n    helpers.startWorker()\n  }\n\n  if (!atom.inSpecMode()) {\n    makeIdleCallback(linterEslintInstallPeerPackages)\n    makeIdleCallback(linterEslintStartWorker)\n  }\n}\n\n// Configuration\nconst scopes = []\nlet showRule\nlet lintHtmlFiles\nlet ignoredRulesWhenModified\nlet ignoredRulesWhenFixing\nlet ignoreFixableRulesWhileTyping\n\n// Internal functions\n/**\n * Given an Array or iterable containing a list of Rule IDs, return an Object\n * to be sent to ESLint's configuration that disables those rules.\n * @param  {[iterable]} ruleIds Iterable containing ruleIds to ignore\n * @return {Object}             Object containing properties for each rule to ignore\n */\nconst idsToIgnoredRules = (ruleIds) => (\n  Array.from(ruleIds).reduce(\n    // 0 is the severity to turn off a rule\n    (ids, id) => Object.assign(ids, { [id]: 0 }),\n    {}\n  ))\n\nmodule.exports = {\n  activate() {\n    this.subscriptions = new CompositeDisposable()\n\n    migrateConfigOptions()\n\n    const embeddedScope = 'source.js.embedded.html'\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.lintHtmlFiles',\n      (value) => {\n        lintHtmlFiles = value\n        if (lintHtmlFiles) {\n          scopes.push(embeddedScope)\n        } else if (scopes.indexOf(embeddedScope) !== -1) {\n          scopes.splice(scopes.indexOf(embeddedScope), 1)\n        }\n      }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.scopes',\n      (value) => {\n        // Remove any old scopes\n        scopes.splice(0, scopes.length)\n        // Add the current scopes\n        Array.prototype.push.apply(scopes, value)\n        // Ensure HTML linting still works if the setting is updated\n        if (lintHtmlFiles && !scopes.includes(embeddedScope)) {\n          scopes.push(embeddedScope)\n        }\n      }\n    ))\n\n    this.subscriptions.add(atom.workspace.observeTextEditors((editor) => {\n      editor.onDidSave(async () => {\n        if (hasValidScope(editor, scopes)\n          && atom.config.get('linter-eslint.autofix.fixOnSave')\n        ) {\n          await this.fixJob(true)\n        }\n      })\n    }))\n\n    this.subscriptions.add(atom.commands.add('atom-text-editor', {\n      'linter-eslint:debug': async () => {\n        const debugString = await helpers.generateDebugString()\n        const notificationOptions = { detail: debugString, dismissable: true }\n        atom.notifications.addInfo('linter-eslint debugging information', notificationOptions)\n      }\n    }))\n\n    this.subscriptions.add(atom.commands.add('atom-text-editor', {\n      'linter-eslint:fix-file': async () => {\n        await this.fixJob()\n      }\n    }))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.advanced.showRuleIdInMessage',\n      (value) => { showRule = value }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.disabling.rulesToSilenceWhileTyping',\n      (ids) => { ignoredRulesWhenModified = ids }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.autofix.rulesToDisableWhileFixing',\n      (ids) => { ignoredRulesWhenFixing = idsToIgnoredRules(ids) }\n    ))\n\n    this.subscriptions.add(atom.config.observe(\n      'linter-eslint.autofix.ignoreFixableRulesWhileTyping',\n      (value) => { ignoreFixableRulesWhileTyping = value }\n    ))\n\n    this.subscriptions.add(atom.contextMenu.add({\n      'atom-text-editor:not(.mini), .overlayer': [{\n        label: 'ESLint Fix',\n        command: 'linter-eslint:fix-file',\n        shouldDisplay: (evt) => {\n          const activeEditor = atom.workspace.getActiveTextEditor()\n          if (!activeEditor) {\n            return false\n          }\n          // Black magic!\n          // Compares the private component property of the active TextEditor\n          //   against the components of the elements\n          const evtIsActiveEditor = evt.path.some((elem) => (\n            // Atom v1.19.0+\n            elem.component && activeEditor.component\n              && elem.component === activeEditor.component))\n          // Only show if it was the active editor and it is a valid scope\n          return evtIsActiveEditor && hasValidScope(activeEditor, scopes)\n        }\n      }]\n    }))\n\n    scheduleIdleTasks()\n  },\n\n  deactivate() {\n    idleCallbacks.forEach((callbackID) => window.cancelIdleCallback(callbackID))\n    idleCallbacks.clear()\n    if (helpers) {\n      // If the helpers module hasn't been loaded then there was no chance a\n      // worker was started anyway.\n      helpers.killWorker()\n    }\n    this.subscriptions.dispose()\n  },\n\n  provideLinter() {\n    return {\n      name: 'ESLint',\n      grammarScopes: scopes,\n      scope: 'file',\n      lintsOnChange: true,\n      /**\n       * @param {import(\"atom\").TextEditor} textEditor\n       * @returns {Promise<import(\"atom/linter\").Message[]>}\n       */\n      lint: async (textEditor) => {\n        if (!atom.workspace.isTextEditor(textEditor)) {\n          // If we somehow get fed an invalid TextEditor just immediately return\n          return null\n        }\n\n        if (helpers.isIncompatibleEslint()) {\n          // The project's version of ESLint doesn't work with this package. Once\n          // this is detected, we won't try to send any jobs until the window is\n          // reloaded.\n          return null\n        }\n\n        const filePath = textEditor.getPath()\n        if (!filePath) {\n          // The editor currently has no path, we can't report messages back to\n          // Linter so just return null\n          return null\n        }\n\n        if (filePath.includes('://')) {\n          // If the path is a URL (Nuclide remote file) return a message\n          // telling the user we are unable to work on remote files.\n          return helpers.generateUserMessage(textEditor, {\n            severity: 'warning',\n            excerpt: 'Remote file open, linter-eslint is disabled for this file.',\n          })\n        }\n\n        const text = textEditor.getText()\n\n        let rules = {}\n        if (textEditor.isModified()) {\n          if (ignoreFixableRulesWhileTyping) {\n            // Note that the fixable rules will only have values after the first lint job\n            const ignoredRules = new Set(helpers.rules.getFixableRules())\n            ignoredRulesWhenModified.forEach((ruleId) => ignoredRules.add(ruleId))\n            rules = idsToIgnoredRules(ignoredRules)\n          } else {\n            rules = idsToIgnoredRules(ignoredRulesWhenModified)\n          }\n        }\n\n        try {\n          const response = await helpers.sendJob({\n            type: 'lint',\n            contents: text,\n            config: atom.config.get('linter-eslint'),\n            rules,\n            filePath,\n            projectPath: atom.project.relativizePath(filePath)[0] || ''\n          })\n          if (textEditor.getText() !== text) {\n            /*\n            The editor text has been modified since the lint was triggered,\n            as we can't be sure that the results will map properly back to\n            the new contents, simply return `null` to tell the\n            `provideLinter` consumer not to update the saved results.\n            */\n            return null\n          }\n          return helpers.processJobResponse(response, textEditor, showRule)\n        } catch (error) {\n          return helpers.handleError(textEditor, error)\n        }\n      }\n    }\n  },\n\n  async fixJob(isSave = false) {\n    const textEditor = atom.workspace.getActiveTextEditor()\n\n    if (!textEditor || !atom.workspace.isTextEditor(textEditor)) {\n      // Silently return if the TextEditor is invalid\n      return\n    }\n\n    if (helpers.isIncompatibleEslint()) {\n      // The project's version of ESLint doesn't work with this package. Once\n      // this is detected, we won't try to send any jobs until the window is\n      // reloaded.\n      return\n    }\n\n    if (textEditor.isModified()) {\n      // Abort for invalid or unsaved text editors\n      const message = 'Linter-ESLint: Please save before fixing'\n      atom.notifications.addError(message)\n    }\n\n    const filePath = textEditor.getPath()\n    const projectPath = atom.project.relativizePath(filePath)[0]\n\n    // Get the text from the editor, so we can use executeOnText\n    const text = textEditor.getText()\n    // Do not try to make fixes on an empty file\n    if (text.length === 0) {\n      return\n    }\n\n    let rules = {}\n    if (Object.keys(ignoredRulesWhenFixing).length > 0) {\n      rules = ignoredRulesWhenFixing\n    }\n\n    try {\n      const response = await helpers.sendJob({\n        type: 'fix',\n        config: atom.config.get('linter-eslint'),\n        contents: text,\n        rules,\n        filePath,\n        projectPath\n      })\n      if (!isSave) {\n        atom.notifications.addSuccess(response)\n      }\n    } catch (err) {\n      if (err.name === 'IncompatibleESLintError') {\n        return\n      }\n      atom.notifications.addWarning(err.message)\n    }\n  },\n}\n"]} \ No newline at end of file diff --git a/dist/worker-helpers.js b/dist/worker-helpers.js index 41a15d90..6aa89e67 100644 --- a/dist/worker-helpers.js +++ b/dist/worker-helpers.js @@ -37,6 +37,15 @@ const Cache = { NODE_PREFIX_PATH: null, LAST_MODULES_PATH: null }; + +class IncompatibleESLintError extends Error { + constructor(version) { + // eslint-disable-next-line max-len + super(`The version of ESLint used in this project is ${version}, which is incompatible with this package. The \`linter-eslint-node\` Atom package provides support for ESLint versions 8 and higher.\n\nYou can disable this notice in the linter-eslint package settings under **Uncommon → Notify when incompatible ESLint is detected**.`); + this.name = 'IncompatibleESLintError'; + } + +} /** * Takes a path and translates `~` to the user's home directory, and replaces * all environment variables with their value. @@ -44,6 +53,7 @@ const Cache = { * @return {string} The cleaned path */ + const cleanPath = path => path ? (0, _resolveEnv.default)(_fsPlus.default.normalize(path)) : ''; /** * @returns {string} @@ -144,6 +154,31 @@ function findESLintDirectory(modulesDir, config, projectPath, fallbackForGlobal path: Cache.ESLINT_LOCAL_PATH, type: 'bundled fallback' }; +} // Given an ESLint module path, checks its version and throws if the version is +// too new for this package to support. + + +function checkForIncompatibleESLint(directory) { + let packageMeta; + + try { + // eslint-disable-next-line import/no-dynamic-require + packageMeta = require(_path.default.join(directory, 'package.json')); + + if (!packageMeta || !packageMeta.version) { + return; + } + } catch (_) { + return; + } // We don't need sophisticated parsing logic here; we just need to look at + // the major version. + + + const m = packageMeta.version.match(/^([\d]+)\./); + + if (m && Number(m[1]) > 7) { + throw new IncompatibleESLintError(packageMeta.version); + } } /** * @param {string} modulesDir @@ -157,11 +192,22 @@ function getESLintFromDirectory(modulesDir, config, projectPath) { const { path: ESLintDirectory } = findESLintDirectory(modulesDir, config, projectPath); + let eslint; try { // eslint-disable-next-line import/no-dynamic-require - return require(ESLintDirectory); + eslint = require(ESLintDirectory); + + if (!('CLIEngine' in eslint)) { + checkForIncompatibleESLint(ESLintDirectory); + } + + return eslint; } catch (e) { + // If this is the result of an incompatible ESLint, an error will be + // thrown; otherwise we should proceed with the local-path fallback. + checkForIncompatibleESLint(ESLintDirectory); + if (config.global.useGlobalEslint && e.code === 'MODULE_NOT_FOUND') { throw new Error('ESLint not found, try restarting Atom to clear caches.'); } // eslint-disable-next-line import/no-dynamic-require @@ -332,4 +378,4 @@ function getRules(cliEngine) { function didRulesChange(currentRules, newRules) { return !(currentRules.size === newRules.size && Array.from(currentRules.keys()).every(ruleId => newRules.has(ruleId))); } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker-helpers.js"],"names":["Cache","ESLINT_LOCAL_PATH","Path","normalize","join","__dirname","NODE_PREFIX_PATH","LAST_MODULES_PATH","cleanPath","path","fs","getNodePrefixPath","npmCommand","process","platform","ChildProcess","spawnSync","env","PATH","output","toString","trim","e","errMsg","Error","isDirectory","dirPath","isDir","statSync","fallbackForGlobalErrorThrown","findESLintDirectory","modulesDir","config","projectPath","fallbackForGlobal","eslintDir","locationType","global","useGlobalEslint","configGlobal","globalNodePath","prefixPath","advanced","localNodeModules","isAbsolute","type","console","error","getESLintFromDirectory","ESLintDirectory","require","code","refreshModulesPath","NODE_PATH","Module","_initPaths","getESLintInstance","fileDir","dirname","log","args","obj","length","str","JSON","stringify","Util","inspect","emit","getConfigForFile","eslint","filePath","cli","CLIEngine","getRelativePath","ignoreFile","disableEslintIgnore","ignoreDir","chdir","relative","basename","getCLIEngineOptions","rules","fileConfig","cliEngineConfig","ignore","fix","rulePaths","eslintRulesDirs","map","rulesDir","filter","eslintrcPath","configFile","getRules","cliEngine","Object","prototype","hasOwnProperty","call","linter","Map","didRulesChange","currentRules","newRules","size","Array","from","keys","every","ruleId","has"],"mappings":"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","sourcesContent":["/* global emit */\n\nimport Path from 'path';\nimport Util from 'util';\nimport fs from 'fs-plus'\nimport ChildProcess from 'child_process'\nimport resolveEnv from 'resolve-env'\nimport { findCached } from 'atom-linter'\nimport getPath from 'consistent-path'\n\nconst Cache = {\n  ESLINT_LOCAL_PATH: Path.normalize(Path.join(__dirname, '..', 'node_modules', 'eslint')),\n  NODE_PREFIX_PATH: null,\n  LAST_MODULES_PATH: null\n}\n\n/**\n * Takes a path and translates `~` to the user's home directory, and replaces\n * all environment variables with their value.\n * @param  {string} path The path to remove \"strangeness\" from\n * @return {string}      The cleaned path\n */\nconst cleanPath = (path) => (path ? resolveEnv(fs.normalize(path)) : '')\n\n/**\n * @returns {string}\n */\nexport function getNodePrefixPath() {\n  if (Cache.NODE_PREFIX_PATH === null) {\n    const npmCommand = process.platform === 'win32' ? 'npm.cmd' : 'npm'\n    try {\n      Cache.NODE_PREFIX_PATH = ChildProcess.spawnSync(npmCommand, ['get', 'prefix'], {\n        env: { ...process.env, PATH: getPath() }\n      }).output[1].toString().trim()\n    } catch (e) {\n      const errMsg = 'Unable to execute `npm get prefix`. Please make sure '\n        + 'Atom is getting $PATH correctly.'\n      throw new Error(errMsg)\n    }\n  }\n  return Cache.NODE_PREFIX_PATH\n}\n\n/**\n * @param {string} dirPath\n * @returns {boolean}\n */\nfunction isDirectory(dirPath) {\n  let isDir\n  try {\n    isDir = fs.statSync(dirPath).isDirectory()\n  } catch (e) {\n    isDir = false\n  }\n  return isDir\n}\n\nlet fallbackForGlobalErrorThrown = false\n\n/**\n * @param {string} modulesDir\n * @param {object} config\n * @param {string} projectPath\n * @param {boolean} fallbackForGlobal\n * @returns {{ path: string, type: 'local project' | 'global' | 'advanced specified' | 'bundled fallback' }}\n */\nexport function findESLintDirectory(modulesDir, config, projectPath, fallbackForGlobal = false) {\n  let eslintDir = null\n  let locationType = null\n  if (config.global.useGlobalEslint && !fallbackForGlobal) {\n    locationType = 'global'\n    const configGlobal = cleanPath(config.global.globalNodePath)\n    const prefixPath = configGlobal || getNodePrefixPath()\n    // NPM on Windows and Yarn on all platforms\n    eslintDir = Path.join(prefixPath, 'node_modules', 'eslint')\n    if (!isDirectory(eslintDir)) {\n      // NPM on platforms other than Windows\n      eslintDir = Path.join(prefixPath, 'lib', 'node_modules', 'eslint')\n    }\n  } else if (!config.advanced.localNodeModules) {\n    locationType = 'local project'\n    eslintDir = Path.join(modulesDir || '', 'eslint')\n  } else if (Path.isAbsolute(cleanPath(config.advanced.localNodeModules))) {\n    locationType = 'advanced specified'\n    eslintDir = Path.join(cleanPath(config.advanced.localNodeModules), 'eslint')\n  } else {\n    locationType = 'advanced specified'\n    eslintDir = Path.join(projectPath || '', cleanPath(config.advanced.localNodeModules), 'eslint')\n  }\n\n  if (isDirectory(eslintDir)) {\n    return {\n      path: eslintDir,\n      type: locationType,\n    }\n  }\n\n  if (config.global.useGlobalEslint && !fallbackForGlobal) {\n    if (!fallbackForGlobalErrorThrown) {\n      // Throw the error only once to prevent performance issues\n      fallbackForGlobalErrorThrown = true\n      console.error(`Global ESLint is not found, falling back to other Eslint installations...\n        Please ensure the global Node path is set correctly.\n        If you wanted to use a local installation of Eslint, disable Global Eslint option in the linter-eslint config.`)\n    }\n    return findESLintDirectory(modulesDir, config, projectPath, true)\n  }\n\n  return {\n    path: Cache.ESLINT_LOCAL_PATH,\n    type: 'bundled fallback',\n  }\n}\n\n/**\n * @param {string} modulesDir\n * @param {object} config\n * @param {string} projectPath\n * @returns {import(\"eslint\")}\n */\nexport function getESLintFromDirectory(modulesDir, config, projectPath) {\n  const { path: ESLintDirectory } = findESLintDirectory(modulesDir, config, projectPath)\n  try {\n    // eslint-disable-next-line import/no-dynamic-require\n    return require(ESLintDirectory)\n  } catch (e) {\n    if (config.global.useGlobalEslint && e.code === 'MODULE_NOT_FOUND') {\n      throw new Error('ESLint not found, try restarting Atom to clear caches.')\n    }\n    // eslint-disable-next-line import/no-dynamic-require\n    return require(Cache.ESLINT_LOCAL_PATH)\n  }\n}\n\n/**\n * @param {string} modulesDir\n */\nexport function refreshModulesPath(modulesDir) {\n  if (Cache.LAST_MODULES_PATH !== modulesDir) {\n    Cache.LAST_MODULES_PATH = modulesDir\n    process.env.NODE_PATH = modulesDir || ''\n    // eslint-disable-next-line no-underscore-dangle\n    require('module').Module._initPaths()\n  }\n}\n\n/**\n * @param {string} fileDir\n * @param {object} config\n * @param {string} projectPath\n * @returns {import(\"eslint\")}\n */\nexport function getESLintInstance(fileDir, config, projectPath) {\n  const modulesDir = Path.dirname(findCached(fileDir, 'node_modules/eslint') || '')\n  refreshModulesPath(modulesDir)\n  return getESLintFromDirectory(modulesDir, config, projectPath)\n}\n\n/**\n * console.log\n * @param  {any} args\n * @return {void}\n */\nexport function log(...args) {\n  const obj = args.length === 1 ? args[0] : args\n  let str\n  try {\n    str = JSON.stringify(obj)\n  } catch (e) {\n    str = Util.inspect(obj)\n  }\n\n  emit('log', str)\n}\n\n/**\n * @param {import(\"eslint\")} eslint\n * @param {string} filePath\n */\nexport function getConfigForFile(eslint, filePath) {\n  const cli = new eslint.CLIEngine()\n  try {\n    return cli.getConfigForFile(filePath)\n  } catch (e) {\n    // No configuration was found\n    return null\n  }\n}\n\n/**\n * @param {string} fileDir\n * @param {string} filePath\n * @param {object} config\n * @param {string} projectPath\n * @returns {string}\n */\nexport function getRelativePath(fileDir, filePath, config, projectPath) {\n  const ignoreFile = config.advanced.disableEslintIgnore ? null : findCached(fileDir, '.eslintignore')\n\n  // If we can find an .eslintignore file, we can set cwd there\n  // (because they are expected to be at the project root)\n  if (ignoreFile) {\n    const ignoreDir = Path.dirname(ignoreFile)\n    process.chdir(ignoreDir)\n    return Path.relative(ignoreDir, filePath)\n  }\n  // Otherwise, we'll set the cwd to the atom project root as long as that exists\n  if (projectPath) {\n    process.chdir(projectPath)\n    return Path.relative(projectPath, filePath)\n  }\n  // If all else fails, use the file location itself\n  process.chdir(fileDir)\n  return Path.basename(filePath)\n}\n\n/**\n * @param {string} type\n * @param {string[]} rules\n * @param {object} config\n * @param {string} filePath\n * @param {object} fileConfig\n */\nexport function getCLIEngineOptions(type, config, rules, filePath, fileConfig) {\n  const cliEngineConfig = {\n    rules,\n    ignore: !config.advanced.disableEslintIgnore,\n    fix: type === 'fix'\n  }\n\n  cliEngineConfig.rulePaths = config.advanced.eslintRulesDirs.map((path) => {\n    const rulesDir = cleanPath(path)\n    if (!Path.isAbsolute(rulesDir)) {\n      return findCached(Path.dirname(filePath), rulesDir)\n    }\n    return rulesDir\n  }).filter((path) => path)\n\n  if (fileConfig === null && config.global.eslintrcPath) {\n    // If we didn't find a configuration use the fallback from the settings\n    cliEngineConfig.configFile = cleanPath(config.global.eslintrcPath)\n  }\n\n  return cliEngineConfig\n}\n\n/**\n * Gets the list of rules used for a lint job\n * @param  {import(\"eslint\").CLIEngine} cliEngine The CLIEngine instance used for the lint job\n * @return {Map}              A Map of the rules used, rule names as keys, rule\n *                            properties as the contents.\n */\nexport function getRules(cliEngine) {\n  // Pull the list of rules used directly from the CLIEngine\n  if (typeof cliEngine.getRules === 'function') {\n    return cliEngine.getRules()\n  }\n\n  // Attempt to use the internal (undocumented) `linter` instance attached to\n  // the CLIEngine to get the loaded rules (including plugin rules).\n  // Added in ESLint v4\n  if (Object.prototype.hasOwnProperty.call(cliEngine, 'linter')) {\n    return cliEngine.linter.getRules()\n  }\n\n  // Older versions of ESLint don't (easily) support getting a list of rules\n  return new Map()\n}\n\n/**\n * Given an exiting rule list and a new rule list, determines whether there\n * have been changes.\n * NOTE: This only accounts for presence of the rules, changes to their metadata\n * are not taken into account.\n * @param  {Map} newRules     A Map of the new rules\n * @param  {Map} currentRules A Map of the current rules\n * @return {boolean}             Whether or not there were changes\n */\nexport function didRulesChange(currentRules, newRules) {\n  return !(currentRules.size === newRules.size\n    && Array.from(currentRules.keys()).every((ruleId) => newRules.has(ruleId)))\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker-helpers.js"],"names":["Cache","ESLINT_LOCAL_PATH","Path","normalize","join","__dirname","NODE_PREFIX_PATH","LAST_MODULES_PATH","IncompatibleESLintError","Error","constructor","version","name","cleanPath","path","fs","getNodePrefixPath","npmCommand","process","platform","ChildProcess","spawnSync","env","PATH","output","toString","trim","e","errMsg","isDirectory","dirPath","isDir","statSync","fallbackForGlobalErrorThrown","findESLintDirectory","modulesDir","config","projectPath","fallbackForGlobal","eslintDir","locationType","global","useGlobalEslint","configGlobal","globalNodePath","prefixPath","advanced","localNodeModules","isAbsolute","type","console","error","checkForIncompatibleESLint","directory","packageMeta","require","_","m","match","Number","getESLintFromDirectory","ESLintDirectory","eslint","code","refreshModulesPath","NODE_PATH","Module","_initPaths","getESLintInstance","fileDir","dirname","log","args","obj","length","str","JSON","stringify","Util","inspect","emit","getConfigForFile","filePath","cli","CLIEngine","getRelativePath","ignoreFile","disableEslintIgnore","ignoreDir","chdir","relative","basename","getCLIEngineOptions","rules","fileConfig","cliEngineConfig","ignore","fix","rulePaths","eslintRulesDirs","map","rulesDir","filter","eslintrcPath","configFile","getRules","cliEngine","Object","prototype","hasOwnProperty","call","linter","Map","didRulesChange","currentRules","newRules","size","Array","from","keys","every","ruleId","has"],"mappings":"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","sourcesContent":["/* global emit */\n\nimport Path from 'path'\nimport Util from 'util'\nimport fs from 'fs-plus'\nimport ChildProcess from 'child_process'\nimport resolveEnv from 'resolve-env'\nimport { findCached } from 'atom-linter'\nimport getPath from 'consistent-path'\n\nconst Cache = {\n  ESLINT_LOCAL_PATH: Path.normalize(Path.join(__dirname, '..', 'node_modules', 'eslint')),\n  NODE_PREFIX_PATH: null,\n  LAST_MODULES_PATH: null\n}\n\nclass IncompatibleESLintError extends Error {\n  constructor(version) {\n    // eslint-disable-next-line max-len\n    super(`The version of ESLint used in this project is ${version}, which is incompatible with this package. The \\`linter-eslint-node\\` Atom package provides support for ESLint versions 8 and higher.\\n\\nYou can disable this notice in the linter-eslint package settings under **Uncommon → Notify when incompatible ESLint is detected**.`)\n    this.name = 'IncompatibleESLintError'\n  }\n}\n\n/**\n * Takes a path and translates `~` to the user's home directory, and replaces\n * all environment variables with their value.\n * @param  {string} path The path to remove \"strangeness\" from\n * @return {string}      The cleaned path\n */\nconst cleanPath = (path) => (path ? resolveEnv(fs.normalize(path)) : '')\n\n/**\n * @returns {string}\n */\nexport function getNodePrefixPath() {\n  if (Cache.NODE_PREFIX_PATH === null) {\n    const npmCommand = process.platform === 'win32' ? 'npm.cmd' : 'npm'\n    try {\n      Cache.NODE_PREFIX_PATH = ChildProcess.spawnSync(npmCommand, ['get', 'prefix'], {\n        env: { ...process.env, PATH: getPath() }\n      }).output[1].toString().trim()\n    } catch (e) {\n      const errMsg = 'Unable to execute `npm get prefix`. Please make sure '\n        + 'Atom is getting $PATH correctly.'\n      throw new Error(errMsg)\n    }\n  }\n  return Cache.NODE_PREFIX_PATH\n}\n\n/**\n * @param {string} dirPath\n * @returns {boolean}\n */\nfunction isDirectory(dirPath) {\n  let isDir\n  try {\n    isDir = fs.statSync(dirPath).isDirectory()\n  } catch (e) {\n    isDir = false\n  }\n  return isDir\n}\n\nlet fallbackForGlobalErrorThrown = false\n\n/**\n * @param {string} modulesDir\n * @param {object} config\n * @param {string} projectPath\n * @param {boolean} fallbackForGlobal\n * @returns {{ path: string, type: 'local project' | 'global' | 'advanced specified' | 'bundled fallback' }}\n */\nexport function findESLintDirectory(modulesDir, config, projectPath, fallbackForGlobal = false) {\n  let eslintDir = null\n  let locationType = null\n  if (config.global.useGlobalEslint && !fallbackForGlobal) {\n    locationType = 'global'\n    const configGlobal = cleanPath(config.global.globalNodePath)\n    const prefixPath = configGlobal || getNodePrefixPath()\n    // NPM on Windows and Yarn on all platforms\n    eslintDir = Path.join(prefixPath, 'node_modules', 'eslint')\n    if (!isDirectory(eslintDir)) {\n      // NPM on platforms other than Windows\n      eslintDir = Path.join(prefixPath, 'lib', 'node_modules', 'eslint')\n    }\n  } else if (!config.advanced.localNodeModules) {\n    locationType = 'local project'\n    eslintDir = Path.join(modulesDir || '', 'eslint')\n  } else if (Path.isAbsolute(cleanPath(config.advanced.localNodeModules))) {\n    locationType = 'advanced specified'\n    eslintDir = Path.join(cleanPath(config.advanced.localNodeModules), 'eslint')\n  } else {\n    locationType = 'advanced specified'\n    eslintDir = Path.join(projectPath || '', cleanPath(config.advanced.localNodeModules), 'eslint')\n  }\n\n  if (isDirectory(eslintDir)) {\n    return {\n      path: eslintDir,\n      type: locationType,\n    }\n  }\n\n  if (config.global.useGlobalEslint && !fallbackForGlobal) {\n    if (!fallbackForGlobalErrorThrown) {\n      // Throw the error only once to prevent performance issues\n      fallbackForGlobalErrorThrown = true\n      console.error(`Global ESLint is not found, falling back to other Eslint installations...\n        Please ensure the global Node path is set correctly.\n        If you wanted to use a local installation of Eslint, disable Global Eslint option in the linter-eslint config.`)\n    }\n    return findESLintDirectory(modulesDir, config, projectPath, true)\n  }\n\n  return {\n    path: Cache.ESLINT_LOCAL_PATH,\n    type: 'bundled fallback',\n  }\n}\n\n// Given an ESLint module path, checks its version and throws if the version is\n// too new for this package to support.\nfunction checkForIncompatibleESLint(directory) {\n  let packageMeta\n  try {\n    // eslint-disable-next-line import/no-dynamic-require\n    packageMeta = require(Path.join(directory, 'package.json'))\n    if (!packageMeta || !packageMeta.version) {\n      return\n    }\n  } catch (_) {\n    return\n  }\n  // We don't need sophisticated parsing logic here; we just need to look at\n  // the major version.\n  const m = packageMeta.version.match(/^([\\d]+)\\./)\n  if (m && Number(m[1]) > 7) {\n    throw new IncompatibleESLintError(packageMeta.version)\n  }\n}\n\n/**\n * @param {string} modulesDir\n * @param {object} config\n * @param {string} projectPath\n * @returns {import(\"eslint\")}\n */\nexport function getESLintFromDirectory(modulesDir, config, projectPath) {\n  const { path: ESLintDirectory } = findESLintDirectory(modulesDir, config, projectPath)\n  let eslint\n  try {\n    // eslint-disable-next-line import/no-dynamic-require\n    eslint = require(ESLintDirectory)\n    if (!('CLIEngine' in eslint)) {\n      checkForIncompatibleESLint(ESLintDirectory)\n    }\n    return eslint\n  } catch (e) {\n    // If this is the result of an incompatible ESLint, an error will be\n    // thrown; otherwise we should proceed with the local-path fallback.\n    checkForIncompatibleESLint(ESLintDirectory)\n\n    if (config.global.useGlobalEslint && e.code === 'MODULE_NOT_FOUND') {\n      throw new Error('ESLint not found, try restarting Atom to clear caches.')\n    }\n    // eslint-disable-next-line import/no-dynamic-require\n    return require(Cache.ESLINT_LOCAL_PATH)\n  }\n}\n\n/**\n * @param {string} modulesDir\n */\nexport function refreshModulesPath(modulesDir) {\n  if (Cache.LAST_MODULES_PATH !== modulesDir) {\n    Cache.LAST_MODULES_PATH = modulesDir\n    process.env.NODE_PATH = modulesDir || ''\n    // eslint-disable-next-line no-underscore-dangle\n    require('module').Module._initPaths()\n  }\n}\n\n/**\n * @param {string} fileDir\n * @param {object} config\n * @param {string} projectPath\n * @returns {import(\"eslint\")}\n */\nexport function getESLintInstance(fileDir, config, projectPath) {\n  const modulesDir = Path.dirname(findCached(fileDir, 'node_modules/eslint') || '')\n  refreshModulesPath(modulesDir)\n  return getESLintFromDirectory(modulesDir, config, projectPath)\n}\n\n/**\n * console.log\n * @param  {any} args\n * @return {void}\n */\nexport function log(...args) {\n  const obj = args.length === 1 ? args[0] : args\n  let str\n  try {\n    str = JSON.stringify(obj)\n  } catch (e) {\n    str = Util.inspect(obj)\n  }\n\n  emit('log', str)\n}\n\n/**\n * @param {import(\"eslint\")} eslint\n * @param {string} filePath\n */\nexport function getConfigForFile(eslint, filePath) {\n  const cli = new eslint.CLIEngine()\n  try {\n    return cli.getConfigForFile(filePath)\n  } catch (e) {\n    // No configuration was found\n    return null\n  }\n}\n\n/**\n * @param {string} fileDir\n * @param {string} filePath\n * @param {object} config\n * @param {string} projectPath\n * @returns {string}\n */\nexport function getRelativePath(fileDir, filePath, config, projectPath) {\n  const ignoreFile = config.advanced.disableEslintIgnore ? null : findCached(fileDir, '.eslintignore')\n\n  // If we can find an .eslintignore file, we can set cwd there\n  // (because they are expected to be at the project root)\n  if (ignoreFile) {\n    const ignoreDir = Path.dirname(ignoreFile)\n    process.chdir(ignoreDir)\n    return Path.relative(ignoreDir, filePath)\n  }\n  // Otherwise, we'll set the cwd to the atom project root as long as that exists\n  if (projectPath) {\n    process.chdir(projectPath)\n    return Path.relative(projectPath, filePath)\n  }\n  // If all else fails, use the file location itself\n  process.chdir(fileDir)\n  return Path.basename(filePath)\n}\n\n/**\n * @param {string} type\n * @param {string[]} rules\n * @param {object} config\n * @param {string} filePath\n * @param {object} fileConfig\n */\nexport function getCLIEngineOptions(type, config, rules, filePath, fileConfig) {\n  const cliEngineConfig = {\n    rules,\n    ignore: !config.advanced.disableEslintIgnore,\n    fix: type === 'fix'\n  }\n\n  cliEngineConfig.rulePaths = config.advanced.eslintRulesDirs.map((path) => {\n    const rulesDir = cleanPath(path)\n    if (!Path.isAbsolute(rulesDir)) {\n      return findCached(Path.dirname(filePath), rulesDir)\n    }\n    return rulesDir\n  }).filter((path) => path)\n\n  if (fileConfig === null && config.global.eslintrcPath) {\n    // If we didn't find a configuration use the fallback from the settings\n    cliEngineConfig.configFile = cleanPath(config.global.eslintrcPath)\n  }\n\n  return cliEngineConfig\n}\n\n/**\n * Gets the list of rules used for a lint job\n * @param  {import(\"eslint\").CLIEngine} cliEngine The CLIEngine instance used for the lint job\n * @return {Map}              A Map of the rules used, rule names as keys, rule\n *                            properties as the contents.\n */\nexport function getRules(cliEngine) {\n  // Pull the list of rules used directly from the CLIEngine\n  if (typeof cliEngine.getRules === 'function') {\n    return cliEngine.getRules()\n  }\n\n  // Attempt to use the internal (undocumented) `linter` instance attached to\n  // the CLIEngine to get the loaded rules (including plugin rules).\n  // Added in ESLint v4\n  if (Object.prototype.hasOwnProperty.call(cliEngine, 'linter')) {\n    return cliEngine.linter.getRules()\n  }\n\n  // Older versions of ESLint don't (easily) support getting a list of rules\n  return new Map()\n}\n\n/**\n * Given an exiting rule list and a new rule list, determines whether there\n * have been changes.\n * NOTE: This only accounts for presence of the rules, changes to their metadata\n * are not taken into account.\n * @param  {Map} newRules     A Map of the new rules\n * @param  {Map} currentRules A Map of the current rules\n * @return {boolean}             Whether or not there were changes\n */\nexport function didRulesChange(currentRules, newRules) {\n  return !(currentRules.size === newRules.size\n    && Array.from(currentRules.keys()).every((ruleId) => newRules.has(ruleId)))\n}\n"]} \ No newline at end of file diff --git a/dist/worker.js b/dist/worker.js index 9cad07de..33971edc 100644 --- a/dist/worker.js +++ b/dist/worker.js @@ -119,9 +119,10 @@ module.exports = async () => { } catch (workerErr) { emit(`workerError:${emitKey}`, { msg: workerErr.message, - stack: workerErr.stack + stack: workerErr.stack, + name: workerErr.name }); } }); }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker.js"],"names":["process","title","rulesMetadata","Map","shouldSendRules","lintJob","cliEngineOptions","contents","eslint","filePath","cliEngine","CLIEngine","report","executeOnText","rules","Helpers","getRules","didRulesChange","clear","forEach","properties","rule","set","fixJob","outputFixes","results","length","messages","module","exports","on","jobConfig","type","config","projectPath","emitKey","advanced","disableFSCache","FindCache","fileDir","Path","dirname","getESLintInstance","fileConfig","getConfigForFile","disabling","disableWhenNoEslintConfig","emit","relativeFilePath","getRelativePath","getCLIEngineOptions","response","updatedRules","Array","from","modulesDir","findESLintDirectory","workerErr","msg","message","stack"],"mappings":"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","sourcesContent":["/* global emit */\n\nimport * as Path from 'path'\nimport { FindCache, findCached } from 'atom-linter'\nimport * as Helpers from './worker-helpers'\n\nprocess.title = 'linter-eslint helper'\n\nconst rulesMetadata = new Map()\nlet shouldSendRules = false\n\n/**\n * The return of {getCLIEngineOptions} function\n * @typedef {object} CliEngineOptions\n * @property {string[]} rules\n * @property {boolean} ignore\n * @property {boolean} fix\n * @property {string[]} rulePaths\n * @property {string | undefined} configFile\n */\n\n/**\n * @param {CliEngineOptions} cliEngineOptions\n * @param {string} contents\n * @param {import(\"eslint\")} eslint\n * @param {string} filePath\n */\nfunction lintJob(cliEngineOptions, contents, eslint, filePath) {\n  const cliEngine = new eslint.CLIEngine(cliEngineOptions)\n  const report = cliEngine.executeOnText(contents, filePath)\n  const rules = Helpers.getRules(cliEngine)\n  shouldSendRules = Helpers.didRulesChange(rulesMetadata, rules)\n  if (shouldSendRules) {\n    // Rebuild rulesMetadata\n    rulesMetadata.clear()\n    rules.forEach((properties, rule) => rulesMetadata.set(rule, properties))\n  }\n  return report\n}\n\n/**\n * @param {CliEngineOptions} cliEngineOptions\n * @param {string} contents\n * @param {string} filePath\n * @param {import(\"eslint\")} eslint\n */\nfunction fixJob(cliEngineOptions, contents, eslint, filePath) {\n  const report = lintJob(cliEngineOptions, contents, eslint, filePath)\n\n  eslint.CLIEngine.outputFixes(report)\n\n  if (!report.results.length || !report.results[0].messages.length) {\n    return 'Linter-ESLint: Fix complete.'\n  }\n  return 'Linter-ESLint: Fix attempt complete, but linting errors remain.'\n}\n\nmodule.exports = async () => {\n  process.on('message', (jobConfig) => {\n    // We catch all worker errors so that we can create a separate error emitter\n    // for each emitKey, rather than adding multiple listeners for `task:error`\n    const {\n      contents, type, config, filePath, projectPath, rules, emitKey\n    } = jobConfig\n    try {\n      if (config.advanced.disableFSCache) {\n        FindCache.clear()\n      }\n\n      const fileDir = Path.dirname(filePath)\n      const eslint = Helpers.getESLintInstance(fileDir, config, projectPath)\n\n      const fileConfig = Helpers.getConfigForFile(eslint, filePath)\n      if (fileConfig === null && config.disabling.disableWhenNoEslintConfig) {\n        emit(emitKey, { messages: [] })\n        return\n      }\n\n      const relativeFilePath = Helpers.getRelativePath(fileDir, filePath, config, projectPath)\n\n      const cliEngineOptions = Helpers\n        .getCLIEngineOptions(type, config, rules, relativeFilePath, fileConfig)\n\n      let response\n      if (type === 'lint') {\n        const report = lintJob(cliEngineOptions, contents, eslint, filePath)\n        response = {\n          messages: report.results.length ? report.results[0].messages : []\n        }\n        if (shouldSendRules) {\n          // You can't emit Maps, convert to Array of Arrays to send back.\n          response.updatedRules = Array.from(rulesMetadata)\n        }\n      } else if (type === 'fix') {\n        response = fixJob(cliEngineOptions, contents, eslint, filePath)\n      } else if (type === 'debug') {\n        const modulesDir = Path.dirname(findCached(fileDir, 'node_modules/eslint') || '')\n        response = Helpers.findESLintDirectory(modulesDir, config, projectPath)\n      }\n      emit(emitKey, response)\n    } catch (workerErr) {\n      emit(`workerError:${emitKey}`, { msg: workerErr.message, stack: workerErr.stack })\n    }\n  })\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker.js"],"names":["process","title","rulesMetadata","Map","shouldSendRules","lintJob","cliEngineOptions","contents","eslint","filePath","cliEngine","CLIEngine","report","executeOnText","rules","Helpers","getRules","didRulesChange","clear","forEach","properties","rule","set","fixJob","outputFixes","results","length","messages","module","exports","on","jobConfig","type","config","projectPath","emitKey","advanced","disableFSCache","FindCache","fileDir","Path","dirname","getESLintInstance","fileConfig","getConfigForFile","disabling","disableWhenNoEslintConfig","emit","relativeFilePath","getRelativePath","getCLIEngineOptions","response","updatedRules","Array","from","modulesDir","findESLintDirectory","workerErr","msg","message","stack","name"],"mappings":"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","sourcesContent":["/* global emit */\n\nimport * as Path from 'path'\nimport { FindCache, findCached } from 'atom-linter'\nimport * as Helpers from './worker-helpers'\n\nprocess.title = 'linter-eslint helper'\n\nconst rulesMetadata = new Map()\nlet shouldSendRules = false\n\n/**\n * The return of {getCLIEngineOptions} function\n * @typedef {object} CliEngineOptions\n * @property {string[]} rules\n * @property {boolean} ignore\n * @property {boolean} fix\n * @property {string[]} rulePaths\n * @property {string | undefined} configFile\n */\n\n/**\n * @param {CliEngineOptions} cliEngineOptions\n * @param {string} contents\n * @param {import(\"eslint\")} eslint\n * @param {string} filePath\n */\nfunction lintJob(cliEngineOptions, contents, eslint, filePath) {\n  const cliEngine = new eslint.CLIEngine(cliEngineOptions)\n  const report = cliEngine.executeOnText(contents, filePath)\n  const rules = Helpers.getRules(cliEngine)\n  shouldSendRules = Helpers.didRulesChange(rulesMetadata, rules)\n  if (shouldSendRules) {\n    // Rebuild rulesMetadata\n    rulesMetadata.clear()\n    rules.forEach((properties, rule) => rulesMetadata.set(rule, properties))\n  }\n  return report\n}\n\n/**\n * @param {CliEngineOptions} cliEngineOptions\n * @param {string} contents\n * @param {string} filePath\n * @param {import(\"eslint\")} eslint\n */\nfunction fixJob(cliEngineOptions, contents, eslint, filePath) {\n  const report = lintJob(cliEngineOptions, contents, eslint, filePath)\n\n  eslint.CLIEngine.outputFixes(report)\n\n  if (!report.results.length || !report.results[0].messages.length) {\n    return 'Linter-ESLint: Fix complete.'\n  }\n  return 'Linter-ESLint: Fix attempt complete, but linting errors remain.'\n}\n\nmodule.exports = async () => {\n  process.on('message', (jobConfig) => {\n    // We catch all worker errors so that we can create a separate error emitter\n    // for each emitKey, rather than adding multiple listeners for `task:error`\n    const {\n      contents, type, config, filePath, projectPath, rules, emitKey\n    } = jobConfig\n    try {\n      if (config.advanced.disableFSCache) {\n        FindCache.clear()\n      }\n\n      const fileDir = Path.dirname(filePath)\n      const eslint = Helpers.getESLintInstance(fileDir, config, projectPath)\n\n      const fileConfig = Helpers.getConfigForFile(eslint, filePath)\n      if (fileConfig === null && config.disabling.disableWhenNoEslintConfig) {\n        emit(emitKey, { messages: [] })\n        return\n      }\n\n      const relativeFilePath = Helpers.getRelativePath(fileDir, filePath, config, projectPath)\n\n      const cliEngineOptions = Helpers\n        .getCLIEngineOptions(type, config, rules, relativeFilePath, fileConfig)\n\n      let response\n      if (type === 'lint') {\n        const report = lintJob(cliEngineOptions, contents, eslint, filePath)\n        response = {\n          messages: report.results.length ? report.results[0].messages : []\n        }\n        if (shouldSendRules) {\n          // You can't emit Maps, convert to Array of Arrays to send back.\n          response.updatedRules = Array.from(rulesMetadata)\n        }\n      } else if (type === 'fix') {\n        response = fixJob(cliEngineOptions, contents, eslint, filePath)\n      } else if (type === 'debug') {\n        const modulesDir = Path.dirname(findCached(fileDir, 'node_modules/eslint') || '')\n        response = Helpers.findESLintDirectory(modulesDir, config, projectPath)\n      }\n      emit(emitKey, response)\n    } catch (workerErr) {\n      emit(`workerError:${emitKey}`, {\n        msg: workerErr.message,\n        stack: workerErr.stack,\n        name: workerErr.name\n      })\n    }\n  })\n}\n"]} \ No newline at end of file diff --git a/package.json b/package.json index 0c391f19..291b249c 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "linter-eslint", "main": "./dist/main.js", - "version": "9.0.0", + "version": "9.0.1", "description": "Lint JavaScript on the fly, using ESLint (v7 or older)", "repository": "https://github.com/AtomLinter/linter-eslint.git", "license": "MIT",