🚀 Launch Week Day 5:Introducing Immutable Scans.Learn More →
Socket
Book a DemoInstallSign in
Socket

token-scope

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

token-scope

A very fast approximation of lexical-scope

latest
Source
npmnpm
Version
1.0.0
Version published
Maintainers
1
Created
Source

token-scope

A very fast approximation of lexical-scope. It takes the source code and returns a list of all identifiers that have the potential to be references to global variables. This just parses the token stream, so it is much less thorough than lexical-scope or using uglify-js to do the same thing. It has the advantage of being vastly faster though. It is good enough to detect that jQuery does not contain require or any of the node.js globals.

Build Status Dependency Status NPM version

Installation

npm install token-scope

Usage

var detect = require('token-scope')
var inspectForRequire = detect(src)

if (inspectForRequire.indexOf('require') != -1) {
  // do more time consuming checks to search for require properly
}

Tests:

var detect = require('token-scope')

describe('detect(src, identifiers)', function () {
  it('returns an array of identifiers that might represent global variable references', function () {
    assert(detect('var x = require("foo")').indexOf('require') != -1)
    assert(detect('var x = foo("require")').indexOf('require') == -1)
  })
})

Benchmarking

To run the benchmarks, download this repository then do:

$ npm install

$ node bench/run.js

This runs 3 different scoping mechanisms on a minified copy of jQuery and report the total time for 10 iterations. They then also check that the result does not include any of the node.js globals. On my machine, this results in the output (note how token-scope results in a lot more potential globals, but still turns out to be good enough to rule out node.js globals):

nametimeoutput
token-scope747msa,b,cy,f,cv,ck,…
ugly-scope1457mssetTimeout,par…
lexical-scope2252mssetTimeout,par…

License

MIT

FAQs

Package last updated on 27 Jun 2013

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts