mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Rich Trott
d7aa8fa088
|
9 years ago | |
---|---|---|
.. | ||
.npmignore | 9 years ago | |
.travis.yml | 9 years ago | |
README.md | 9 years ago | |
example.js | 9 years ago | |
index.js | 9 years ago | |
package.json | 9 years ago | |
test.js | 9 years ago |
README.md
generate-function
Module that helps you write generated functions in Node
npm install generate-function
Disclamer
Writing code that generates code is hard. You should only use this if you really, really, really need this for performance reasons (like schema validators / parsers etc).
Usage
var genfun = require('generate-function')
var addNumber = function(val) {
var fn = genfun()
('function add(n) {')
('return n + %d', val) // supports format strings to insert values
('}')
return fn.toFunction() // will compile the function
}
var add2 = addNumber(2)
console.log('1+2=', add2(1))
console.log(add2.toString()) // prints the generated function
If you need to close over variables in your generated function pass them to toFunction(scope)
var multiply = function(a, b) {
return a * b
}
var addAndMultiplyNumber = function(val) {
var fn = genfun()
('function(n) {')
('if (typeof n !== "number") {') // ending a line with { will indent the source
('throw new Error("argument should be a number")')
('}')
('var result = multiply(%d, n+%d)', val, val)
('return result')
('}')
// use fn.toString() if you want to see the generated source
return fn.toFunction({
multiply: multiply
})
}
var addAndMultiply2 = addAndMultiplyNumber(2)
console.log('(3 + 2) * 2 =', addAndMultiply2(3))
Related
See generate-object-property if you need to safely generate code that can be used to reference an object property
License
MIT