generate-function

WebJar for generate-function

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

generate-function
Last Version

Last Version

2.3.1
Release Date

Release Date

Type

Type

jar
Description

Description

generate-function
WebJar for generate-function
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/mafintosh/generate-function

Download generate-function

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/generate-function/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>generate-function</artifactId>
    <version>2.3.1</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/generate-function/
implementation 'org.webjars.npm:generate-function:2.3.1'
// https://jarcasting.com/artifacts/org.webjars.npm/generate-function/
implementation ("org.webjars.npm:generate-function:2.3.1")
'org.webjars.npm:generate-function:jar:2.3.1'
<dependency org="org.webjars.npm" name="generate-function" rev="2.3.1">
  <artifact name="generate-function" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='generate-function', version='2.3.1')
)
libraryDependencies += "org.webjars.npm" % "generate-function" % "2.3.1"
[org.webjars.npm/generate-function "2.3.1"]

Dependencies

compile (1)

Group / Artifact Type Version
org.webjars.npm : is-property jar [1.0.2,2)

Project Modules

There are no modules declared in this project.

generate-function

Module that helps you write generated functions in Node

npm install generate-function

build status

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

const genfun = require('generate-function')
const { d } = genfun.formats

function addNumber (val) {
  const gen = genfun()

  gen(`
    function add (n) {
      return n + ${d(val)} // supports format strings to insert values
    }
  `)

  return gen.toFunction() // will compile the function
}

const 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)

function multiply (a, b) {
  return a * b
}

function addAndMultiplyNumber (val) {
  const gen = genfun()
  
  gen(`
    function (n) {
      if (typeof n !== 'number') {
        throw new Error('argument should be a number')
      }
      const result = multiply(${d(val)}, n + ${d(val)})
      return result
    }
  `)

  // use gen.toString() if you want to see the generated source

  return gen.toFunction({multiply})
}

const addAndMultiply2 = addAndMultiplyNumber(2)

console.log(addAndMultiply2.toString())
console.log('(3 + 2) * 2 =', addAndMultiply2(3))

You can call gen(src) as many times as you want to append more source code to the function.

Variables

If you need a unique safe identifier for the scope of the generated function call str = gen.sym('friendlyName'). These are safe to use for variable names etc.

Object properties

If you need to access an object property use the str = gen.property('objectName', 'propertyName').

This returns 'objectName.propertyName' if propertyName is safe to use as a variable. Otherwise it returns objectName[propertyNameAsString].

If you only pass gen.property('propertyName') it will only return the propertyName part safely

License

MIT

Versions

Version
2.3.1
2.0.0