mirror of
https://github.com/fooflington/selfdefined.git
synced 2025-01-23 01:40:10 +00:00
pug-code-gen
Default code-generator for pug. It generates HTML via a JavaScript template function.
Installation
npm install pug-code-gen
Usage
var generateCode = require('pug-code-gen');
generateCode(ast, options)
Generate a JavaScript function string for the given AST.
ast
is a fully expanded AST for Pug, with all inclusion, extends, and filters resolved.
options
may contain the following properties that have the same meaning as the options with the same names in pug
:
- pretty (boolean): default is
false
- compileDebug (boolean): default is
true
- doctype (string): default is
undefined
- inlineRuntimeFunctions (boolean): default is
false
- globals (array of strings): default is
[]
- self (boolean): default is
false
In addition to above, pug-code-gen
has the following unique options:
- includeSources (object): map of filename to source string; used if
compileDebug
istrue
; default isundefined
- templateName (string): the name of the generated function; default is
'template'
var lex = require('pug-lexer');
var parse = require('pug-parser');
var wrap = require('pug-runtime/wrap');
var generateCode = require('pug-code-gen');
var funcStr = generateCode(parse(lex('p Hello world!')), {
compileDebug: false,
pretty: true,
inlineRuntimeFunctions: false,
templateName: 'helloWorld'
});
//=> 'function helloWorld(locals) { ... }'
var func = wrap(funcStr, 'helloWorld');
func();
//=> '\n<p>Hello world!</p>'
new generateCode.CodeGenerator(ast, options)
The constructor for the internal class of the code generator. You shouldn't need to use this for most purposes.
License
MIT