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.
 |