teddit/node_modules/constantinople
2020-11-17 21:44:32 +01:00
..
lib initial commit 2020-11-17 21:44:32 +01:00
src initial commit 2020-11-17 21:44:32 +01:00
test initial commit 2020-11-17 21:44:32 +01:00
.editorconfig initial commit 2020-11-17 21:44:32 +01:00
.gitattributes initial commit 2020-11-17 21:44:32 +01:00
.prettierrc initial commit 2020-11-17 21:44:32 +01:00
.travis.yml initial commit 2020-11-17 21:44:32 +01:00
LICENSE initial commit 2020-11-17 21:44:32 +01:00
package.json initial commit 2020-11-17 21:44:32 +01:00
README.md initial commit 2020-11-17 21:44:32 +01:00
tsconfig.json initial commit 2020-11-17 21:44:32 +01:00

constantinople

Determine whether a JavaScript expression evaluates to a constant (using Babylon). Here it is assumed to be safe to underestimate how constant something is.

Build Status Dependency Status NPM version

Installation

npm install constantinople

Usage

var isConstant = require('constantinople');

if (isConstant('"foo" + 5')) {
  console.dir(isConstant.toConstant('"foo" + 5'));
}
if (isConstant('Math.floor(10.5)', {Math: Math})) {
  console.dir(isConstant.toConstant('Math.floor(10.5)', {Math: Math}));
}

API

isConstant(src, [constants, [options]])

Returns true if src evaluates to a constant, false otherwise. It will also return false if there is a syntax error, which makes it safe to use on potentially ES6 code.

Constants is an object mapping strings to values, where those values should be treated as constants. Note that this makes it a pretty bad idea to have Math in there if the user might make use of Math.random and a pretty bad idea to have Date in there.

Options are directly passed-through to Babylon.

toConstant(src, [constants, [options]])

Returns the value resulting from evaluating src. This method throws an error if the expression is not constant. e.g. toConstant("Math.random()") would throw an error.

Constants is an object mapping strings to values, where those values should be treated as constants. Note that this makes it a pretty bad idea to have Math in there if the user might make use of Math.random and a pretty bad idea to have Date in there.

Options are directly passed-through to Babylon.

License

MIT