All files / repl/lib resolve_local_scope.js

100% Statements 77/77
100% Branches 7/7
100% Functions 2/2
100% Lines 77/77

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 7811x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 11x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 2244x 4368x 4368x 4368x 4368x 824x 824x 4870x 4870x 1384x 1958x 1958x 1384x 4870x 824x 4368x 2244x 11x 11x 11x 11x 11x  
/**
* @license Apache-2.0
*
* Copyright (c) 2019 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*    http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
 
'use strict';
 
// MODULES //
 
var walk = require( 'acorn-walk' ).ancestor;
var appendUnique = require( './append_unique.js' );
 
 
// MAIN //
 
/**
* Given an abstract syntax tree (AST) containing resolved local scopes, returns the local scope for a provided AST node.
*
* @private
* @param {AST} ast - abstract syntax tree (AST)
* @param {Node} node - AST node
* @returns {Array} local scope
*/
function resolveScope( ast, node ) {
	var visitors;
	var scope;
 
	visitors = {};
	visitors[ node.type ] = onVisit;
 
	scope = [];
	walk( ast, visitors );
 
	return scope;
 
	/**
	* Callback invoked upon encountering an AST node.
	*
	* @private
	* @param {Node} n - AST node
	* @param {Array} parents - array of parent AST nodes
	*/
	function onVisit( n, parents ) {
		var locals;
		var i;
		var j;
		if ( n === node ) {
			// Note: the direction in which we traverse the list of parents does not matter, as we only care about identifier names, not where they were declared and to what value they are assigned. Meaning, we don't need to concern ourselves with whether a local scope redeclares a variable in a higher scope, as we are only concerned with a general list of identifier names available at the location of the provided AST node.
			for ( i = 0; i < parents.length-1; i++ ) {
				locals = parents[ i ].locals;
				if ( locals ) {
					for ( j = 0; j < locals.length; j++ ) {
						appendUnique( scope, locals[ j ] );
					}
				}
			}
		}
	}
}
 
 
// EXPORTS //
 
module.exports = resolveScope;