80 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
Escope ([escope](http://github.com/estools/escope)) is
 | 
						|
[ECMAScript](http://www.ecma-international.org/publications/standards/Ecma-262.htm)
 | 
						|
scope analyzer extracted from [esmangle project](http://github.com/estools/esmangle).
 | 
						|
 | 
						|
[](https://travis-ci.org/estools/escope)
 | 
						|
 | 
						|
### Example
 | 
						|
 | 
						|
```js
 | 
						|
var escope = require('escope');
 | 
						|
var esprima = require('esprima');
 | 
						|
var estraverse = require('estraverse');
 | 
						|
 | 
						|
var ast = esprima.parse(code);
 | 
						|
var scopeManager = escope.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
 | 
						|
    }
 | 
						|
});
 | 
						|
```
 | 
						|
 | 
						|
### Document
 | 
						|
 | 
						|
Generated JSDoc is [here](http://estools.github.io/escope/).
 | 
						|
 | 
						|
### Demos and Tools
 | 
						|
 | 
						|
Demonstration is [here](http://mazurov.github.io/escope-demo/) by [Sasha Mazurov](https://github.com/mazurov) (twitter: [@mazurov](http://twitter.com/mazurov)). [issue](https://github.com/estools/escope/issues/14)
 | 
						|
 | 
						|

 | 
						|
 | 
						|
 | 
						|
And there are tools constructed on Escope.
 | 
						|
 | 
						|
- [Esmangle](https://github.com/estools/esmangle) is a minifier / mangler / optimizer.
 | 
						|
- [Eslevels](https://github.com/mazurov/eslevels) is a scope levels analyzer and [SublimeText plugin for scope context coloring](https://github.com/mazurov/sublime-levels) is constructed on it.
 | 
						|
- [Esgoggles](https://github.com/keeyipchan/esgoggles) is JavaScript code browser.
 | 
						|
 | 
						|
 | 
						|
### License
 | 
						|
 | 
						|
Copyright (C) 2012-2013 [Yusuke Suzuki](http://github.com/Constellation)
 | 
						|
 (twitter: [@Constellation](http://twitter.com/Constellation)) and other contributors.
 | 
						|
 | 
						|
Redistribution and use in source and binary forms, with or without
 | 
						|
modification, are permitted provided that the following conditions are met:
 | 
						|
 | 
						|
  * Redistributions of source code must retain the above copyright
 | 
						|
    notice, this list of conditions and the following disclaimer.
 | 
						|
 | 
						|
  * Redistributions in binary form must reproduce the above copyright
 | 
						|
    notice, this list of conditions and the following disclaimer in the
 | 
						|
    documentation and/or other materials provided with the distribution.
 | 
						|
 | 
						|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | 
						|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | 
						|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | 
						|
ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
 | 
						|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | 
						|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
						|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 | 
						|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | 
						|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 | 
						|
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 |