Sha256: bcdddf224b3fef5eda1c0f93bf897694c7f5f9cc496c16d7a8038640cd9514c0
Contents?: true
Size: 1.54 KB
Versions: 5
Compression:
Stored size: 1.54 KB
Contents
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : typeof define === 'function' && define.amd ? define(['exports'], factory) : (factory((global.estreeWalker = global.estreeWalker || {}))); }(this, (function (exports) { 'use strict'; function walk ( ast, ref) { var enter = ref.enter; var leave = ref.leave; visit( ast, null, enter, leave ); } var context = { skip: function () { return context.shouldSkip = true; }, shouldSkip: false }; var childKeys = {}; var toString = Object.prototype.toString; function isArray ( thing ) { return toString.call( thing ) === '[object Array]'; } function visit ( node, parent, enter, leave, prop, index ) { if ( !node ) { return; } if ( enter ) { context.shouldSkip = false; enter.call( context, node, parent, prop, index ); if ( context.shouldSkip ) { return; } } var keys = childKeys[ node.type ] || ( childKeys[ node.type ] = Object.keys( node ).filter( function (key) { return typeof node[ key ] === 'object'; } ) ); for ( var i = 0; i < keys.length; i += 1 ) { var key = keys[i]; var value = node[ key ]; if ( isArray( value ) ) { for ( var j = 0; j < value.length; j += 1 ) { visit( value[j], node, enter, leave, key, j ); } } else if ( value && value.type ) { visit( value, node, enter, leave, key, null ); } } if ( leave ) { leave( node, parent, prop, index ); } } exports.walk = walk; Object.defineProperty(exports, '__esModule', { value: true }); }))); //# sourceMappingURL=estree-walker.umd.js.map
Version data entries
5 entries across 5 versions & 3 rubygems