mirror of
https://github.com/owncast/owncast.git
synced 2024-10-10 19:16:02 +00:00
1.7 KiB
1.7 KiB
detective
find all calls to require() by walking the AST
example
strings
strings_src.js:
var a = require('a');
var b = require('b');
var c = require('c');
strings.js:
var detective = require('detective');
var fs = require('fs');
var src = fs.readFileSync(__dirname + '/strings_src.js');
var requires = detective(src);
console.dir(requires);
output:
$ node examples/strings.js
[ 'a', 'b', 'c' ]
methods
var detective = require('detective');
detective(src, opts)
Give some source body src, return an array of all the require() calls with
string arguments.
The options parameter opts is passed along to detective.find().
var found = detective.find(src, opts)
Give some source body src, return found with:
found.strings- an array of each string found in arequire()found.expressions- an array of each stringified expression found in arequire()callfound.nodes(whenopts.nodes === true) - an array of AST nodes for each argument found in arequire()call
Optionally:
opts.word- specify a different function name instead of"require"opts.nodes- whentrue, populatefound.nodesopts.isRequire(node)- a function returning whether an ASTCallExpressionnode is a require callopts.parse- supply options directly to acorn with some support for esprima-style optionsrangeandlocopts.ecmaVersion- default: 9
install
With npm do:
npm install detective
license
MIT
