Nestable Processes Mutate

    abstrate
    TypeScript icon, indicating that this package has built-in type declarations

    2.1.3 • Public • Published

    abstrate

    Abstrate is a library for applications that need to analyze and execute templates.

    At this time, the only rendering engine is one that compatible with the syntax of Go templates.

    Example

    The following example demonstrates rendering a simple template (the first argument), including passing in data (the second argument), and custom variables and functions for the runtime environment (the third argument).

    const Abstrate = require("abstrate")
     
    Abstrate.go.render(
      "{{ $Greeting }}, {{ exclaim .Object }}",
      { Object: "World"},
      {
        variables: { Greeting: "Hello" },
        functions: { exclaim: (string) => { return string + "!" } },
      }
    ) // => "Hello, World!"

    We can also parse the template to an intermediate representation (abstract syntax tree) instead of executing it. This allows the use of custom logic to do static analysis on the templates. For example, one could detect which variables are defined or which functions are used within certain blocks of the template.

    Abstrate = require("abstrate")
     
    Abstrate.go.parse(
      "{{ $Greeting }}, {{ exclaim .Object }}"
    ) /* =>
      [
        {
          type: "variable",
          name: "Greeting",
          beginOffset: 3,
          finalOffset: 12,
        },
        {
          type: "text",
          content: ", ",
          beginOffset: 15,
          finalOffset: 17,
        },
        {
          type: "invoke",
          target: {
            type: "builtin",
            name: "exclaim",
            beginOffset: 20,
            finalOffset: 27,
          },
          args: [
            {
              type: "dot",
              of: {
                type: "root",
                beginOffset: 28,
                finalOffset: 36,
              },
              name: "Object",
              beginOffset: 28,
              finalOffset: 36,
            }
          ],
          beginOffset: 20,
          finalOffset: 36,
        }
      ]
    */

    Known Limitations

    The following sections describe known limitations of this library. Given some time and effort invested, these limitations could be overcome. If fixing one of these limitations is a requirement for you, open an issue ticket and you can become the assignee for fixing it.

    Go Templates

    • HTML-specific escaping/safety rules are only partially implemented. Go uses a rather complicated context-specific model for escaping HTML templates, which has different escaping behavior based on where the templating insertions appear in the HTML syntax, even down to treating certain HTML attribute names as special cases. At this time, Abstrate only fully supports "text" mode of templates from Go, but a partially-implemented HTML escaping mode is available. See the go.htmlEscape tests if you want to give it a try, or if you want to contribute improvements.

    • Some standard runtime functions are missing. Go defines a set of standard/predefined runtime functions for execution, but at this time, Abstrate only implements a subset of them. PRs are welcome to add more of them, as needed. Note that it is also easy to add custom runtime functions to the Abstrate rendering call, so even if a function you need is missing, you are not immediately blocked from using it because you can define it yourself at the caller side if pressed.

    Install

    npm i abstrate

    DownloadsWeekly Downloads

    1

    Version

    2.1.3

    License

    MIT

    Unpacked Size

    150 kB

    Total Files

    18

    Last publish

    Collaborators

    • jemc