Package Exports
- eslint-scope
- eslint-scope/lib/definition
- eslint-scope/lib/pattern-visitor
- eslint-scope/lib/reference
- eslint-scope/lib/referencer
- eslint-scope/lib/scope
- eslint-scope/lib/scope-manager
- eslint-scope/lib/variable
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (eslint-scope) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
ESLint Scope
ESLint Scope is the ECMAScript scope analyzer used in ESLint. It is a fork of escope.
Usage
Install:
npm i eslint-scope --save
Example:
var eslintScope = require('eslint-scope');
var espree = require('espree');
var estraverse = require('estraverse');
var ast = espree.parse(code);
var scopeManager = eslintScope.analyze(ast);
var currentScope = scopeManager.acquire(ast); // global scope
estraverse.traverse(ast, {
enter: function(node, parent) {
// do stuff
if (/Function/.test(node.type)) {
currentScope = scopeManager.acquire(node); // get current function scope
}
},
leave: function(node, parent) {
if (/Function/.test(node.type)) {
currentScope = currentScope.upper; // set to parent scope
}
// do stuff
}
});
Contributing
Issues and pull requests will be triaged and responded to as quickly as possible. We operate under the ESLint Contributor Guidelines, so please be sure to read them before contributing. If you're not sure where to dig in, check out the issues.
Build Commands
npm test
- run all linting and testsnpm run lint
- run all linting
License
ESLint Scope is licensed under a permissive BSD 2-clause license.