eslint-plugin-import
Advanced tools
Comparing version 1.1.0 to 1.2.0
@@ -83,2 +83,2 @@ # no-unresolved | ||
[`import/ignore`]: ../../README.md#import/ignore | ||
[`import/ignore`]: ../../README.md#importignore |
@@ -502,3 +502,2 @@ 'use strict'; | ||
} | ||
''; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/getExports.js"],"names":[],"mappings":"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","file":"core/getExports.js","sourcesContent":["import * as fs from 'fs'\n\nimport { createHash } from 'crypto'\nimport * as doctrine from 'doctrine'\n\nimport parse from './parse'\nimport resolve from './resolve'\nimport isIgnored from './ignore'\n\n// map from settings sha1 => path => export map objects\nconst exportCaches = new Map()\n\nexport default class ExportMap {\n  constructor(path) {\n    this.path = path\n    this.namespace = new Map()\n    // todo: restructure to key on path, value is resolver + map of names\n    this.reexports = new Map()\n    this.dependencies = new Map()\n    this.errors = []\n  }\n\n  get hasDefault() { return this.get('default') != null } // stronger than this.has\n\n  get size() {\n    let size = this.namespace.size + this.reexports.size\n    this.dependencies.forEach(dep => size += dep().size)\n    return size\n  }\n\n  static get(source, context) {\n\n    var path = resolve(source, context)\n    if (path == null) return null\n\n    return ExportMap.for(path, context)\n  }\n\n  static for(path, context) {\n    let exportMap\n\n    const cacheKey = hashObject({\n      settings: context.settings,\n      parserPath: context.parserPath,\n      parserOptions: context.parserOptions,\n    })\n    let exportCache = exportCaches.get(cacheKey)\n    if (exportCache === undefined) {\n      exportCache = new Map()\n      exportCaches.set(cacheKey, exportCache)\n    }\n\n    exportMap = exportCache.get(path)\n    // return cached ignore\n    if (exportMap === null) return null\n\n    const stats = fs.statSync(path)\n    if (exportMap != null) {\n      // date equality check\n      if (exportMap.mtime - stats.mtime === 0) {\n        return exportMap\n      }\n      // future: check content equality?\n    }\n\n    exportMap = ExportMap.parse(path, context)\n    exportMap.mtime = stats.mtime\n\n    // ignore empties, optionally\n    if (exportMap.namespace.size === 0 && isIgnored(path, context)) {\n      exportMap = null\n    }\n\n    exportCache.set(path, exportMap)\n\n    return exportMap\n  }\n\n  static parse(path, context) {\n    var m = new ExportMap(path)\n\n    try {\n      var ast = parse(path, context)\n    } catch (err) {\n      m.errors.push(err)\n      return m // can't continue\n    }\n\n\n    // attempt to collect module doc\n    ast.comments.some(c => {\n      if (c.type !== 'Block') return false\n      try {\n        const doc = doctrine.parse(c.value, { unwrap: true })\n        if (doc.tags.some(t => t.title === 'module')) {\n          m.doc = doc\n          return true\n        }\n      } catch (err) { /* ignore */ }\n      return false\n    })\n\n    const namespaces = new Map()\n\n    function remotePath(node) {\n      return resolve.relative(node.source.value, path, context.settings)\n    }\n\n    function resolveImport(node) {\n      const rp = remotePath(node)\n      if (rp == null) return null\n      return ExportMap.for(rp, context)\n    }\n\n    function getNamespace(identifier) {\n      if (!namespaces.has(identifier.name)) return\n\n      return function () {\n        return resolveImport(namespaces.get(identifier.name))\n      }\n    }\n\n    function addNamespace(object, identifier) {\n      const nsfn = getNamespace(identifier)\n      if (nsfn) {\n        Object.defineProperty(object, 'namespace', { get: nsfn })\n      }\n\n      return object\n    }\n\n\n    ast.body.forEach(function (n) {\n\n      if (n.type === 'ExportDefaultDeclaration') {\n        const exportMeta = captureDoc(n)\n        if (n.declaration.type === 'Identifier') {\n          addNamespace(exportMeta, n.declaration)\n        }\n        m.namespace.set('default', exportMeta)\n        return\n      }\n\n      if (n.type === 'ExportAllDeclaration') {\n        let remoteMap = remotePath(n)\n        if (remoteMap == null) return\n        m.dependencies.set(remoteMap, () => ExportMap.for(remoteMap, context))\n        return\n      }\n\n      // capture namespaces in case of later export\n      if (n.type === 'ImportDeclaration') {\n        let ns\n        if (n.specifiers.some(s => s.type === 'ImportNamespaceSpecifier' && (ns = s))) {\n          namespaces.set(ns.local.name, n)\n        }\n        return\n      }\n\n      if (n.type === 'ExportNamedDeclaration'){\n        // capture declaration\n        if (n.declaration != null) {\n          switch (n.declaration.type) {\n            case 'FunctionDeclaration':\n            case 'ClassDeclaration':\n            case 'TypeAlias': // flowtype with babel-eslint parser\n              m.namespace.set(n.declaration.id.name, captureDoc(n))\n              break\n            case 'VariableDeclaration':\n              n.declaration.declarations.forEach((d) =>\n                recursivePatternCapture(d.id, id => m.namespace.set(id.name, captureDoc(d, n))))\n              break\n          }\n        }\n\n        n.specifiers.forEach((s) => {\n          const exportMeta = {}\n          let local\n\n          switch (s.type) {\n            case 'ExportDefaultSpecifier':\n              if (!n.source) return\n              local = 'default'\n              break\n            case 'ExportNamespaceSpecifier':\n              m.namespace.set(s.exported.name, Object.defineProperty(exportMeta, 'namespace', {\n                get() { return resolveImport(n) },\n              }))\n              return\n            case 'ExportSpecifier':\n              if (!n.source) {\n                m.namespace.set(s.exported.name, addNamespace(exportMeta, s.local))\n                return\n              }\n              // else falls through\n            default:\n              local = s.local.name\n              break\n          }\n\n          // todo: JSDoc\n          m.reexports.set(s.exported.name, { local, getImport: () => resolveImport(n) })\n        })\n      }\n    })\n\n    return m\n  }\n\n  /**\n   * Note that this does not check explicitly re-exported names for existence\n   * in the base namespace, but it will expand all `export * from '...'` exports\n   * if not found in the explicit namespace.\n   * @param  {string}  name\n   * @return {Boolean} true if `name` is exported by this module.\n   */\n  has(name) {\n    if (this.namespace.has(name)) return true\n    if (this.reexports.has(name)) return true\n\n    for (let dep of this.dependencies.values()) {\n      let innerMap = dep()\n\n      // todo: report as unresolved?\n      if (!innerMap) continue\n\n      if (innerMap.has(name)) return true\n    }\n\n    return false\n  }\n\n  get(name) {\n    if (this.namespace.has(name)) return this.namespace.get(name)\n\n    if (this.reexports.has(name)) {\n      const { local, getImport } = this.reexports.get(name)\n          , imported = getImport()\n      if (imported == null) return undefined\n\n      // safeguard against cycles, only if name matches\n      if (imported.path === this.path && local === name) return undefined\n\n      return imported.get(local)\n    }\n\n    for (let dep of this.dependencies.values()) {\n      let innerMap = dep()\n      // todo: report as unresolved?\n      if (!innerMap) continue\n\n      // safeguard against cycles\n      if (innerMap.path === this.path) continue\n\n      let innerValue = innerMap.get(name)\n      if (innerValue !== undefined) return innerValue\n    }\n\n    return undefined\n  }\n\n  forEach(callback, thisArg) {\n    this.namespace.forEach((v, n) =>\n      callback.call(thisArg, v, n, this))\n\n    this.reexports.forEach(({ getImport, local }, name) =>\n      callback.call(thisArg, getImport().get(local), name, this))\n\n    this.dependencies.forEach(dep => dep().forEach((v, n) =>\n      callback.call(thisArg, v, n, this)))\n  }\n\n  // todo: keys, values, entries?\n\n  reportErrors(context, declaration) {\n    context.report({\n      node: declaration.source,\n      message: `Parse errors in imported module '${declaration.source.value}': ` +\n                  `${this.errors\n                        .map(e => `${e.message} (${e.lineNumber}:${e.column})`)\n                        .join(', ')}`,\n    })\n  }\n}\n\n/**\n * parse JSDoc from the first node that has leading comments\n * @param  {...[type]} nodes [description]\n * @return {{doc: object}}\n */\nfunction captureDoc(...nodes) {\n  const metadata = {}\n\n  // 'some' short-circuits on first 'true'\n  nodes.some(n => {\n    if (!n.leadingComments) return false\n\n    // capture XSDoc\n    n.leadingComments.forEach(comment => {\n      // skip non-block comments\n      if (comment.value.slice(0, 4) !== \"*\\n *\") return\n      try {\n        metadata.doc = doctrine.parse(comment.value, { unwrap: true })\n      } catch (err) {\n        /* don't care, for now? maybe add to `errors?` */\n      }\n    })\n    return true\n  })\n\n  return metadata\n}\n\n/**\n * Traverse a pattern/identifier node, calling 'callback'\n * for each leaf identifier.\n * @param  {node}   pattern\n * @param  {Function} callback\n * @return {void}\n */\nexport function recursivePatternCapture(pattern, callback) {\n  switch (pattern.type) {\n    case 'Identifier': // base case\n      callback(pattern)\n      break\n\n    case 'ObjectPattern':\n      pattern.properties.forEach(({ value }) => {\n        recursivePatternCapture(value, callback)\n      })\n      break\n\n    case 'ArrayPattern':\n      pattern.elements.forEach((element) => {\n        if (element == null) return\n        recursivePatternCapture(element, callback)\n      })\n      break\n  }\n}\n\nfunction hashObject(object) {\n  const settingsShasum = createHash('sha1')\n  settingsShasum.update(JSON.stringify(object))\n  return settingsShasum.digest('hex')\n}\n``\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/getExports.js"],"names":[],"mappings":"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","file":"core/getExports.js","sourcesContent":["import * as fs from 'fs'\n\nimport { createHash } from 'crypto'\nimport * as doctrine from 'doctrine'\n\nimport parse from './parse'\nimport resolve from './resolve'\nimport isIgnored from './ignore'\n\n// map from settings sha1 => path => export map objects\nconst exportCaches = new Map()\n\nexport default class ExportMap {\n  constructor(path) {\n    this.path = path\n    this.namespace = new Map()\n    // todo: restructure to key on path, value is resolver + map of names\n    this.reexports = new Map()\n    this.dependencies = new Map()\n    this.errors = []\n  }\n\n  get hasDefault() { return this.get('default') != null } // stronger than this.has\n\n  get size() {\n    let size = this.namespace.size + this.reexports.size\n    this.dependencies.forEach(dep => size += dep().size)\n    return size\n  }\n\n  static get(source, context) {\n\n    var path = resolve(source, context)\n    if (path == null) return null\n\n    return ExportMap.for(path, context)\n  }\n\n  static for(path, context) {\n    let exportMap\n\n    const cacheKey = hashObject({\n      settings: context.settings,\n      parserPath: context.parserPath,\n      parserOptions: context.parserOptions,\n    })\n    let exportCache = exportCaches.get(cacheKey)\n    if (exportCache === undefined) {\n      exportCache = new Map()\n      exportCaches.set(cacheKey, exportCache)\n    }\n\n    exportMap = exportCache.get(path)\n    // return cached ignore\n    if (exportMap === null) return null\n\n    const stats = fs.statSync(path)\n    if (exportMap != null) {\n      // date equality check\n      if (exportMap.mtime - stats.mtime === 0) {\n        return exportMap\n      }\n      // future: check content equality?\n    }\n\n    exportMap = ExportMap.parse(path, context)\n    exportMap.mtime = stats.mtime\n\n    // ignore empties, optionally\n    if (exportMap.namespace.size === 0 && isIgnored(path, context)) {\n      exportMap = null\n    }\n\n    exportCache.set(path, exportMap)\n\n    return exportMap\n  }\n\n  static parse(path, context) {\n    var m = new ExportMap(path)\n\n    try {\n      var ast = parse(path, context)\n    } catch (err) {\n      m.errors.push(err)\n      return m // can't continue\n    }\n\n\n    // attempt to collect module doc\n    ast.comments.some(c => {\n      if (c.type !== 'Block') return false\n      try {\n        const doc = doctrine.parse(c.value, { unwrap: true })\n        if (doc.tags.some(t => t.title === 'module')) {\n          m.doc = doc\n          return true\n        }\n      } catch (err) { /* ignore */ }\n      return false\n    })\n\n    const namespaces = new Map()\n\n    function remotePath(node) {\n      return resolve.relative(node.source.value, path, context.settings)\n    }\n\n    function resolveImport(node) {\n      const rp = remotePath(node)\n      if (rp == null) return null\n      return ExportMap.for(rp, context)\n    }\n\n    function getNamespace(identifier) {\n      if (!namespaces.has(identifier.name)) return\n\n      return function () {\n        return resolveImport(namespaces.get(identifier.name))\n      }\n    }\n\n    function addNamespace(object, identifier) {\n      const nsfn = getNamespace(identifier)\n      if (nsfn) {\n        Object.defineProperty(object, 'namespace', { get: nsfn })\n      }\n\n      return object\n    }\n\n\n    ast.body.forEach(function (n) {\n\n      if (n.type === 'ExportDefaultDeclaration') {\n        const exportMeta = captureDoc(n)\n        if (n.declaration.type === 'Identifier') {\n          addNamespace(exportMeta, n.declaration)\n        }\n        m.namespace.set('default', exportMeta)\n        return\n      }\n\n      if (n.type === 'ExportAllDeclaration') {\n        let remoteMap = remotePath(n)\n        if (remoteMap == null) return\n        m.dependencies.set(remoteMap, () => ExportMap.for(remoteMap, context))\n        return\n      }\n\n      // capture namespaces in case of later export\n      if (n.type === 'ImportDeclaration') {\n        let ns\n        if (n.specifiers.some(s => s.type === 'ImportNamespaceSpecifier' && (ns = s))) {\n          namespaces.set(ns.local.name, n)\n        }\n        return\n      }\n\n      if (n.type === 'ExportNamedDeclaration'){\n        // capture declaration\n        if (n.declaration != null) {\n          switch (n.declaration.type) {\n            case 'FunctionDeclaration':\n            case 'ClassDeclaration':\n            case 'TypeAlias': // flowtype with babel-eslint parser\n              m.namespace.set(n.declaration.id.name, captureDoc(n))\n              break\n            case 'VariableDeclaration':\n              n.declaration.declarations.forEach((d) =>\n                recursivePatternCapture(d.id, id => m.namespace.set(id.name, captureDoc(d, n))))\n              break\n          }\n        }\n\n        n.specifiers.forEach((s) => {\n          const exportMeta = {}\n          let local\n\n          switch (s.type) {\n            case 'ExportDefaultSpecifier':\n              if (!n.source) return\n              local = 'default'\n              break\n            case 'ExportNamespaceSpecifier':\n              m.namespace.set(s.exported.name, Object.defineProperty(exportMeta, 'namespace', {\n                get() { return resolveImport(n) },\n              }))\n              return\n            case 'ExportSpecifier':\n              if (!n.source) {\n                m.namespace.set(s.exported.name, addNamespace(exportMeta, s.local))\n                return\n              }\n              // else falls through\n            default:\n              local = s.local.name\n              break\n          }\n\n          // todo: JSDoc\n          m.reexports.set(s.exported.name, { local, getImport: () => resolveImport(n) })\n        })\n      }\n    })\n\n    return m\n  }\n\n  /**\n   * Note that this does not check explicitly re-exported names for existence\n   * in the base namespace, but it will expand all `export * from '...'` exports\n   * if not found in the explicit namespace.\n   * @param  {string}  name\n   * @return {Boolean} true if `name` is exported by this module.\n   */\n  has(name) {\n    if (this.namespace.has(name)) return true\n    if (this.reexports.has(name)) return true\n\n    for (let dep of this.dependencies.values()) {\n      let innerMap = dep()\n\n      // todo: report as unresolved?\n      if (!innerMap) continue\n\n      if (innerMap.has(name)) return true\n    }\n\n    return false\n  }\n\n  get(name) {\n    if (this.namespace.has(name)) return this.namespace.get(name)\n\n    if (this.reexports.has(name)) {\n      const { local, getImport } = this.reexports.get(name)\n          , imported = getImport()\n      if (imported == null) return undefined\n\n      // safeguard against cycles, only if name matches\n      if (imported.path === this.path && local === name) return undefined\n\n      return imported.get(local)\n    }\n\n    for (let dep of this.dependencies.values()) {\n      let innerMap = dep()\n      // todo: report as unresolved?\n      if (!innerMap) continue\n\n      // safeguard against cycles\n      if (innerMap.path === this.path) continue\n\n      let innerValue = innerMap.get(name)\n      if (innerValue !== undefined) return innerValue\n    }\n\n    return undefined\n  }\n\n  forEach(callback, thisArg) {\n    this.namespace.forEach((v, n) =>\n      callback.call(thisArg, v, n, this))\n\n    this.reexports.forEach(({ getImport, local }, name) =>\n      callback.call(thisArg, getImport().get(local), name, this))\n\n    this.dependencies.forEach(dep => dep().forEach((v, n) =>\n      callback.call(thisArg, v, n, this)))\n  }\n\n  // todo: keys, values, entries?\n\n  reportErrors(context, declaration) {\n    context.report({\n      node: declaration.source,\n      message: `Parse errors in imported module '${declaration.source.value}': ` +\n                  `${this.errors\n                        .map(e => `${e.message} (${e.lineNumber}:${e.column})`)\n                        .join(', ')}`,\n    })\n  }\n}\n\n/**\n * parse JSDoc from the first node that has leading comments\n * @param  {...[type]} nodes [description]\n * @return {{doc: object}}\n */\nfunction captureDoc(...nodes) {\n  const metadata = {}\n\n  // 'some' short-circuits on first 'true'\n  nodes.some(n => {\n    if (!n.leadingComments) return false\n\n    // capture XSDoc\n    n.leadingComments.forEach(comment => {\n      // skip non-block comments\n      if (comment.value.slice(0, 4) !== \"*\\n *\") return\n      try {\n        metadata.doc = doctrine.parse(comment.value, { unwrap: true })\n      } catch (err) {\n        /* don't care, for now? maybe add to `errors?` */\n      }\n    })\n    return true\n  })\n\n  return metadata\n}\n\n/**\n * Traverse a pattern/identifier node, calling 'callback'\n * for each leaf identifier.\n * @param  {node}   pattern\n * @param  {Function} callback\n * @return {void}\n */\nexport function recursivePatternCapture(pattern, callback) {\n  switch (pattern.type) {\n    case 'Identifier': // base case\n      callback(pattern)\n      break\n\n    case 'ObjectPattern':\n      pattern.properties.forEach(({ value }) => {\n        recursivePatternCapture(value, callback)\n      })\n      break\n\n    case 'ArrayPattern':\n      pattern.elements.forEach((element) => {\n        if (element == null) return\n        recursivePatternCapture(element, callback)\n      })\n      break\n  }\n}\n\nfunction hashObject(object) {\n  const settingsShasum = createHash('sha1')\n  settingsShasum.update(JSON.stringify(object))\n  return settingsShasum.digest('hex')\n}\n"]} |
@@ -6,3 +6,8 @@ 'use strict'; | ||
}); | ||
exports.CASE_INSENSITIVE = undefined; | ||
var _stringify = require('babel-runtime/core-js/json/stringify'); | ||
var _stringify2 = _interopRequireDefault(_stringify); | ||
var _typeof2 = require('babel-runtime/helpers/typeof'); | ||
@@ -20,2 +25,6 @@ | ||
var _assign = require('babel-runtime/core-js/object/assign'); | ||
var _assign2 = _interopRequireDefault(_assign); | ||
var _map = require('babel-runtime/core-js/map'); | ||
@@ -34,24 +43,50 @@ | ||
var _crypto = require('crypto'); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var CASE_INSENSITIVE = _fs2.default.existsSync((0, _path.join)(__dirname, 'reSOLVE.js')); | ||
var CASE_INSENSITIVE = exports.CASE_INSENSITIVE = _fs2.default.existsSync((0, _path.join)(__dirname, 'reSOLVE.js')); | ||
// http://stackoverflow.com/a/27382838 | ||
function fileExistsWithCaseSync(filepath) { | ||
var dir = (0, _path.dirname)(filepath); | ||
if (dir === '/' || dir === '.' || /^[A-Z]:\\$/i.test(dir)) return true; | ||
var filenames = _fs2.default.readdirSync(dir); | ||
if (filenames.indexOf((0, _path.basename)(filepath)) === -1) { | ||
return false; | ||
var fileExistsCache = new _map2.default(); | ||
function cachePath(cacheKey, result) { | ||
fileExistsCache.set(cacheKey, { result: result, lastSeen: Date.now() }); | ||
} | ||
function checkCache(cacheKey, _ref) { | ||
var lifetime = _ref.lifetime; | ||
if (fileExistsCache.has(cacheKey)) { | ||
var _fileExistsCache$get = fileExistsCache.get(cacheKey); | ||
var result = _fileExistsCache$get.result; | ||
var lastSeen = _fileExistsCache$get.lastSeen; | ||
// check fresness | ||
if (Date.now() - lastSeen < lifetime * 1000) return result; | ||
} | ||
return fileExistsWithCaseSync(dir); | ||
// cache miss | ||
return undefined; | ||
} | ||
function fileExists(filepath) { | ||
if (CASE_INSENSITIVE) { | ||
// short-circuit if path doesn't exist, ignoring case | ||
return !(!_fs2.default.existsSync(filepath) || !fileExistsWithCaseSync(filepath)); | ||
// http://stackoverflow.com/a/27382838 | ||
function fileExistsWithCaseSync(filepath, cacheSettings) { | ||
var dir = (0, _path.dirname)(filepath); | ||
var result = checkCache(filepath, cacheSettings); | ||
if (result != null) return result; | ||
// base case | ||
if (dir === '/' || dir === '.' || /^[A-Z]:\\$/i.test(dir)) { | ||
result = true; | ||
} else { | ||
return _fs2.default.existsSync(filepath); | ||
var filenames = _fs2.default.readdirSync(dir); | ||
if (filenames.indexOf((0, _path.basename)(filepath)) === -1) { | ||
result = false; | ||
} else { | ||
result = fileExistsWithCaseSync(dir, cacheSettings); | ||
} | ||
} | ||
cachePath(filepath, result); | ||
return result; | ||
} | ||
@@ -61,9 +96,29 @@ | ||
var sourceDir = (0, _path.dirname)(sourceFile), | ||
cacheKey = sourceDir + hashObject(settings) + modulePath; | ||
var cacheSettings = (0, _assign2.default)({ | ||
lifetime: 30 }, // seconds | ||
settings['import/cache']); | ||
// parse infinity | ||
if (cacheSettings.lifetime === '∞' || cacheSettings.lifetime === 'Infinity') { | ||
cacheSettings.lifetime = Infinity; | ||
} | ||
var cachedPath = checkCache(cacheKey, cacheSettings); | ||
if (cachedPath !== undefined) return cachedPath; | ||
function cache(path) { | ||
cachePath(cacheKey, path); | ||
return path; | ||
} | ||
function withResolver(resolver, config) { | ||
// resolve just returns the core module id, which won't appear to exist | ||
try { | ||
var filePath = resolver.resolveImport(modulePath, sourceFile, config); | ||
if (filePath === null) return null; | ||
if (filePath == null) return filePath; | ||
if (filePath === undefined || !fileExists(filePath)) return undefined; | ||
// resolvers imply file existence, this double-check just ensures the case matches | ||
if (CASE_INSENSITIVE && !fileExistsWithCaseSync(filePath, cacheSettings)) return undefined; | ||
@@ -94,3 +149,5 @@ return filePath; | ||
var fullPath = withResolver(resolver, config); | ||
if (fullPath !== undefined) return fullPath; | ||
if (fullPath !== undefined) { | ||
return cache(fullPath); | ||
} | ||
} | ||
@@ -111,2 +168,4 @@ } catch (err) { | ||
} | ||
return cache(undefined); | ||
} | ||
@@ -149,2 +208,8 @@ | ||
resolve.relative = relative; | ||
//# sourceMappingURL=data:application/json;base64,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akMsU0FBSyxJQUFJLEdBQUosSUFBVyxTQUFoQixFQUEyQjtBQUN6QixVQUFJLEdBQUosQ0FBUSxHQUFSLEVBQWEsVUFBVSxHQUFWLENBQWIsRUFEeUI7S0FBM0I7QUFHQSxXQUFPLEdBQVAsQ0FKaUM7R0FBbkM7O0FBT0EsUUFBTSxJQUFJLEtBQUosQ0FBVSx5QkFBVixDQUFOLENBbEJ1QztDQUF6Qzs7Ozs7Ozs7OztBQTZCZSxTQUFTLE9BQVQsQ0FBaUIsQ0FBakIsRUFBb0IsT0FBcEIsRUFBNkI7QUFDMUMsU0FBTyxTQUFVLENBQVYsRUFDVSxRQUFRLFdBQVIsRUFEVixFQUVVLFFBQVEsUUFBUixDQUZqQixDQUQwQztDQUE3QjtBQU1mLFFBQVEsUUFBUixHQUFtQixRQUFuQiIsImZpbGUiOiJjb3JlL3Jlc29sdmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSAnZnMnXG5pbXBvcnQgeyBkaXJuYW1lLCBiYXNlbmFtZSwgam9pbiB9IGZyb20gJ3BhdGgnXG5cbmNvbnN0IENBU0VfSU5TRU5TSVRJVkUgPSBmcy5leGlzdHNTeW5jKGpvaW4oX19kaXJuYW1lLCAncmVTT0xWRS5qcycpKVxuXG4vLyBodHRwOi8vc3RhY2tvdmVyZmxvdy5jb20vYS8yNzM4MjgzOFxuZnVuY3Rpb24gZmlsZUV4aXN0c1dpdGhDYXNlU3luYyhmaWxlcGF0aCkge1xuICB2YXIgZGlyID0gZGlybmFtZShmaWxlcGF0aClcbiAgaWYgKGRpciA9PT0gJy8nIHx8IGRpciA9PT0gJy4nIHx8IC9eW0EtWl06XFxcXCQvaS50ZXN0KGRpcikpIHJldHVybiB0cnVlXG4gIHZhciBmaWxlbmFtZXMgPSBmcy5yZWFkZGlyU3luYyhkaXIpXG4gIGlmIChmaWxlbmFtZXMuaW5kZXhPZihiYXNlbmFtZShmaWxlcGF0aCkpID09PSAtMSkge1xuICAgICAgcmV0dXJuIGZhbHNlXG4gIH1cbiAgcmV0dXJuIGZpbGVFeGlzdHNXaXRoQ2FzZVN5bmMoZGlyKVxufVxuXG5mdW5jdGlvbiBmaWxlRXhpc3RzKGZpbGVwYXRoKSB7XG4gIGlmIChDQVNFX0lOU0VOU0lUSVZFKSB7XG4gICAgLy8gc2hvcnQtY2lyY3VpdCBpZiBwYXRoIGRvZXNuJ3QgZXhpc3QsIGlnbm9yaW5nIGNhc2VcbiAgICByZXR1cm4gISghZnMuZXhpc3RzU3luYyhmaWxlcGF0aCkgfHwgIWZpbGVFeGlzdHNXaXRoQ2FzZVN5bmMoZmlsZXBhdGgpKVxuICB9IGVsc2Uge1xuICAgIHJldHVybiBmcy5leGlzdHNTeW5jKGZpbGVwYXRoKVxuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWxhdGl2ZShtb2R1bGVQYXRoLCBzb3VyY2VGaWxlLCBzZXR0aW5ncykge1xuXG4gIGZ1bmN0aW9uIHdpdGhSZXNvbHZlcihyZXNvbHZlciwgY29uZmlnKSB7XG4gICAgLy8gcmVzb2x2ZSBqdXN0IHJldHVybnMgdGhlIGNvcmUgbW9kdWxlIGlkLCB3aGljaCB3b24ndCBhcHBlYXIgdG8gZXhpc3RcbiAgICB0cnkge1xuICAgICAgY29uc3QgZmlsZVBhdGggPSByZXNvbHZlci5yZXNvbHZlSW1wb3J0KG1vZHVsZVBhdGgsIHNvdXJjZUZpbGUsIGNvbmZpZylcbiAgICAgIGlmIChmaWxlUGF0aCA9PT0gbnVsbCkgcmV0dXJuIG51bGxcblxuICAgICAgaWYgKGZpbGVQYXRoID09PSB1bmRlZmluZWQgfHwgIWZpbGVFeGlzdHMoZmlsZVBhdGgpKSByZXR1cm4gdW5kZWZpbmVkXG5cbiAgICAgIHJldHVybiBmaWxlUGF0aFxuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZFxuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGNvbmZpZ1Jlc29sdmVycyA9IChzZXR0aW5nc1snaW1wb3J0L3Jlc29sdmVyJ11cbiAgICB8fCB7ICdub2RlJzogc2V0dGluZ3NbJ2ltcG9ydC9yZXNvbHZlJ10gfSkgLy8gYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuXG4gIGNvbnN0IHJlc29sdmVycyA9IHJlc29sdmVyUmVkdWNlcihjb25maWdSZXNvbHZlcnMsIG5ldyBNYXAoKSlcblxuICBmb3IgKGxldCBbbmFtZSwgY29uZmlnXSBvZiByZXNvbHZlcnMuZW50cmllcygpKSB7XG4gICAgY29uc3QgcmVzb2x2ZXIgPSByZXF1aXJlKGBlc2xpbnQtaW1wb3J0LXJlc29sdmVyLSR7bmFtZX1gKVxuXG4gICAgbGV0IGZ1bGxQYXRoID0gd2l0aFJlc29sdmVyKHJlc29sdmVyLCBjb25maWcpXG4gICAgaWYgKGZ1bGxQYXRoICE9PSB1bmRlZmluZWQpIHJldHVybiBmdWxsUGF0aFxuICB9XG5cbn1cblxuZnVuY3Rpb24gcmVzb2x2ZXJSZWR1Y2VyKHJlc29sdmVycywgbWFwKSB7XG4gIGlmIChyZXNvbHZlcnMgaW5zdGFuY2VvZiBBcnJheSkge1xuICAgIHJlc29sdmVycy5mb3JFYWNoKHIgPT4gcmVzb2x2ZXJSZWR1Y2VyKHIsIG1hcCkpXG4gICAgcmV0dXJuIG1hcFxuICB9XG5cbiAgaWYgKHR5cGVvZiByZXNvbHZlcnMgPT09ICdzdHJpbmcnKSB7XG4gICAgbWFwLnNldChyZXNvbHZlcnMsIG51bGwpXG4gICAgcmV0dXJuIG1hcFxuICB9XG5cbiAgaWYgKHR5cGVvZiByZXNvbHZlcnMgPT09ICdvYmplY3QnKSB7XG4gICAgZm9yIChsZXQga2V5IGluIHJlc29sdmVycykge1xuICAgICAgbWFwLnNldChrZXksIHJlc29sdmVyc1trZXldKVxuICAgIH1cbiAgICByZXR1cm4gbWFwXG4gIH1cblxuICB0aHJvdyBuZXcgRXJyb3IoJ2ludmFsaWQgcmVzb2x2ZXIgY29uZmlnJylcbn1cblxuLyoqXG4gKiBHaXZlbnRcbiAqIEBwYXJhbSAge3N0cmluZ30gcCAtIG1vZHVsZSBwYXRoXG4gKiBAcGFyYW0gIHtvYmplY3R9IGNvbnRleHQgLSBFU0xpbnQgY29udGV4dFxuICogQHJldHVybiB7c3RyaW5nfSAtIHRoZSBmdWxsIG1vZHVsZSBmaWxlc3lzdGVtIHBhdGg7XG4gKiAgICAgICAgICAgICAgICAgICAgbnVsbCBpZiBwYWNrYWdlIGlzIGNvcmU7XG4gKiAgICAgICAgICAgICAgICAgICAgdW5kZWZpbmVkIGlmIG5vdCBmb3VuZFxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiByZXNvbHZlKHAsIGNvbnRleHQpIHtcbiAgcmV0dXJuIHJlbGF0aXZlKCBwXG4gICAgICAgICAgICAgICAgICwgY29udGV4dC5nZXRGaWxlbmFtZSgpXG4gICAgICAgICAgICAgICAgICwgY29udGV4dC5zZXR0aW5nc1xuICAgICAgICAgICAgICAgICApXG59XG5yZXNvbHZlLnJlbGF0aXZlID0gcmVsYXRpdmVcbiJdfQ== | ||
function hashObject(object) { | ||
var settingsShasum = (0, _crypto.createHash)('sha1'); | ||
settingsShasum.update((0, _stringify2.default)(object)); | ||
return settingsShasum.digest('hex'); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/resolve.js"],"names":[],"mappings":"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","file":"core/resolve.js","sourcesContent":["import fs from 'fs'\nimport { dirname, basename, join } from 'path'\n\nexport const CASE_INSENSITIVE = fs.existsSync(join(__dirname, 'reSOLVE.js'))\n\nconst fileExistsCache = new Map()\n\nfunction cachePath(cacheKey, result) {\n  fileExistsCache.set(cacheKey, { result, lastSeen: Date.now() })\n}\n\nfunction checkCache(cacheKey, { lifetime }) {\n  if (fileExistsCache.has(cacheKey)) {\n    const { result, lastSeen } = fileExistsCache.get(cacheKey)\n    // check fresness\n    if (Date.now() - lastSeen < (lifetime * 1000)) return result\n  }\n  // cache miss\n  return undefined\n}\n\n// http://stackoverflow.com/a/27382838\nfunction fileExistsWithCaseSync(filepath, cacheSettings) {\n  const dir = dirname(filepath)\n\n  let result = checkCache(filepath, cacheSettings)\n  if (result != null) return result\n\n  // base case\n  if (dir === '/' || dir === '.' || /^[A-Z]:\\\\$/i.test(dir)) {\n    result = true\n  } else {\n    const filenames = fs.readdirSync(dir)\n    if (filenames.indexOf(basename(filepath)) === -1) {\n      result = false\n    } else {\n      result = fileExistsWithCaseSync(dir, cacheSettings)\n    }\n  }\n  cachePath(filepath, result)\n  return result\n}\n\nexport function relative(modulePath, sourceFile, settings) {\n\n  const sourceDir = dirname(sourceFile)\n      , cacheKey = sourceDir + hashObject(settings) + modulePath\n\n  const cacheSettings = Object.assign({\n    lifetime: 30,  // seconds\n  }, settings['import/cache'])\n\n  // parse infinity\n  if (cacheSettings.lifetime === '∞' || cacheSettings.lifetime === 'Infinity') {\n    cacheSettings.lifetime = Infinity\n  }\n\n  const cachedPath = checkCache(cacheKey, cacheSettings)\n  if (cachedPath !== undefined) return cachedPath\n\n  function cache(path) {\n    cachePath(cacheKey, path)\n    return path\n  }\n\n  function withResolver(resolver, config) {\n    try {\n      const filePath = resolver.resolveImport(modulePath, sourceFile, config)\n      if (filePath == null) return filePath\n\n      // resolvers imply file existence, this double-check just ensures the case matches\n      if (CASE_INSENSITIVE && !fileExistsWithCaseSync(filePath, cacheSettings)) return undefined\n\n      return filePath\n    } catch (err) {\n      return undefined\n    }\n  }\n\n  const configResolvers = (settings['import/resolver']\n    || { 'node': settings['import/resolve'] }) // backward compatibility\n\n  const resolvers = resolverReducer(configResolvers, new Map())\n\n  for (let [name, config] of resolvers.entries()) {\n    const resolver = require(`eslint-import-resolver-${name}`)\n\n    let fullPath = withResolver(resolver, config)\n    if (fullPath !== undefined) {\n      return cache(fullPath)\n    }\n  }\n\n  return cache(undefined)\n}\n\nfunction resolverReducer(resolvers, map) {\n  if (resolvers instanceof Array) {\n    resolvers.forEach(r => resolverReducer(r, map))\n    return map\n  }\n\n  if (typeof resolvers === 'string') {\n    map.set(resolvers, null)\n    return map\n  }\n\n  if (typeof resolvers === 'object') {\n    for (let key in resolvers) {\n      map.set(key, resolvers[key])\n    }\n    return map\n  }\n\n  throw new Error('invalid resolver config')\n}\n\n/**\n * Givent\n * @param  {string} p - module path\n * @param  {object} context - ESLint context\n * @return {string} - the full module filesystem path;\n *                    null if package is core;\n *                    undefined if not found\n */\nexport default function resolve(p, context) {\n  return relative( p\n                 , context.getFilename()\n                 , context.settings\n                 )\n}\nresolve.relative = relative\n\n\nimport { createHash } from 'crypto'\nfunction hashObject(object) {\n  const settingsShasum = createHash('sha1')\n  settingsShasum.update(JSON.stringify(object))\n  return settingsShasum.digest('hex')\n}\n"]} |
{ | ||
"name": "eslint-plugin-import", | ||
"version": "1.1.0", | ||
"version": "1.2.0", | ||
"description": "Import with sanity.", | ||
@@ -5,0 +5,0 @@ "main": "lib/index.js", |
@@ -174,3 +174,3 @@ # eslint-plugin-import | ||
not report the matching module if no `export`s are found. | ||
In practice, this means rules other than `no-unresolved` will not report on any | ||
In practice, this means rules other than [`no-unresolved`](./docs/rules/no-unresolved.md#ignore) will not report on any | ||
`import`s with (absolute) paths matching this pattern, _unless_ `export`s were | ||
@@ -180,2 +180,4 @@ found when parsing. This allows you to ignore `node_modules` but still properly | ||
`no-unresolved` has its own [`ignore`](./docs/rules/no-unresolved.md#ignore) setting. | ||
**Note**: setting this explicitly will replace the default of `node_modules`, so you | ||
@@ -198,2 +200,31 @@ may need to include it in your own list if you still want to ignore it. Example: | ||
#### `import/cache` | ||
Settings for cache behavior. Memoization is used at various levels to avoid the copious amount of `fs.statSync`/module parse calls required to correctly report errors. | ||
For normal `eslint` console runs, the cache lifetime is irrelevant, as we can strongly assume that files should not be changing during the lifetime of the linter process (and thus, the cache in memory) | ||
For long-lasting processes, like [`eslint_d`] or [`eslint-loader`], however, it's important that there be some notion of staleness. | ||
If you never use [`eslint_d`] or [`eslint-loader`], you may set the cache lifetime to `Infinity` and everything should be fine: | ||
```yaml | ||
# .eslintrc.yml | ||
settings: | ||
import/cache: | ||
lifetime: ∞ # or Infinity | ||
``` | ||
Otherwise, set some integer, and cache entries will be evicted after that many seconds have elapsed: | ||
```yaml | ||
# .eslintrc.yml | ||
settings: | ||
import/cache: | ||
lifetime: 5 # 30 is the default | ||
``` | ||
[`eslint_d`]: https://www.npmjs.com/package/eslint_d | ||
[`eslint-loader`]: https://www.npmjs.com/package/eslint-loader | ||
## SublimeLinter-eslint | ||
@@ -200,0 +231,0 @@ |
@@ -347,2 +347,1 @@ import * as fs from 'fs' | ||
} | ||
`` |
import fs from 'fs' | ||
import { dirname, basename, join } from 'path' | ||
const CASE_INSENSITIVE = fs.existsSync(join(__dirname, 'reSOLVE.js')) | ||
export const CASE_INSENSITIVE = fs.existsSync(join(__dirname, 'reSOLVE.js')) | ||
// http://stackoverflow.com/a/27382838 | ||
function fileExistsWithCaseSync(filepath) { | ||
var dir = dirname(filepath) | ||
if (dir === '/' || dir === '.' || /^[A-Z]:\\$/i.test(dir)) return true | ||
var filenames = fs.readdirSync(dir) | ||
if (filenames.indexOf(basename(filepath)) === -1) { | ||
return false | ||
const fileExistsCache = new Map() | ||
function cachePath(cacheKey, result) { | ||
fileExistsCache.set(cacheKey, { result, lastSeen: Date.now() }) | ||
} | ||
function checkCache(cacheKey, { lifetime }) { | ||
if (fileExistsCache.has(cacheKey)) { | ||
const { result, lastSeen } = fileExistsCache.get(cacheKey) | ||
// check fresness | ||
if (Date.now() - lastSeen < (lifetime * 1000)) return result | ||
} | ||
return fileExistsWithCaseSync(dir) | ||
// cache miss | ||
return undefined | ||
} | ||
function fileExists(filepath) { | ||
if (CASE_INSENSITIVE) { | ||
// short-circuit if path doesn't exist, ignoring case | ||
return !(!fs.existsSync(filepath) || !fileExistsWithCaseSync(filepath)) | ||
// http://stackoverflow.com/a/27382838 | ||
function fileExistsWithCaseSync(filepath, cacheSettings) { | ||
const dir = dirname(filepath) | ||
let result = checkCache(filepath, cacheSettings) | ||
if (result != null) return result | ||
// base case | ||
if (dir === '/' || dir === '.' || /^[A-Z]:\\$/i.test(dir)) { | ||
result = true | ||
} else { | ||
return fs.existsSync(filepath) | ||
const filenames = fs.readdirSync(dir) | ||
if (filenames.indexOf(basename(filepath)) === -1) { | ||
result = false | ||
} else { | ||
result = fileExistsWithCaseSync(dir, cacheSettings) | ||
} | ||
} | ||
cachePath(filepath, result) | ||
return result | ||
} | ||
@@ -28,9 +46,29 @@ | ||
const sourceDir = dirname(sourceFile) | ||
, cacheKey = sourceDir + hashObject(settings) + modulePath | ||
const cacheSettings = Object.assign({ | ||
lifetime: 30, // seconds | ||
}, settings['import/cache']) | ||
// parse infinity | ||
if (cacheSettings.lifetime === '∞' || cacheSettings.lifetime === 'Infinity') { | ||
cacheSettings.lifetime = Infinity | ||
} | ||
const cachedPath = checkCache(cacheKey, cacheSettings) | ||
if (cachedPath !== undefined) return cachedPath | ||
function cache(path) { | ||
cachePath(cacheKey, path) | ||
return path | ||
} | ||
function withResolver(resolver, config) { | ||
// resolve just returns the core module id, which won't appear to exist | ||
try { | ||
const filePath = resolver.resolveImport(modulePath, sourceFile, config) | ||
if (filePath === null) return null | ||
if (filePath == null) return filePath | ||
if (filePath === undefined || !fileExists(filePath)) return undefined | ||
// resolvers imply file existence, this double-check just ensures the case matches | ||
if (CASE_INSENSITIVE && !fileExistsWithCaseSync(filePath, cacheSettings)) return undefined | ||
@@ -52,5 +90,8 @@ return filePath | ||
let fullPath = withResolver(resolver, config) | ||
if (fullPath !== undefined) return fullPath | ||
if (fullPath !== undefined) { | ||
return cache(fullPath) | ||
} | ||
} | ||
return cache(undefined) | ||
} | ||
@@ -94,1 +135,9 @@ | ||
resolve.relative = relative | ||
import { createHash } from 'crypto' | ||
function hashObject(object) { | ||
const settingsShasum = createHash('sha1') | ||
settingsShasum.update(JSON.stringify(object)) | ||
return settingsShasum.digest('hex') | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
218659
2603
301