diff --git a/dist/browser/eta.dev.js b/dist/browser/eta.dev.js index ada3e88..d9ad059 100644 --- a/dist/browser/eta.dev.js +++ b/dist/browser/eta.dev.js @@ -4,6 +4,42 @@ (global = global || self, factory(global.Eta = {})); }(this, (function (exports) { 'use strict'; + function setPrototypeOf(obj, proto) { + if (Object.setPrototypeOf) { + Object.setPrototypeOf(obj, proto); + } + else { + obj.__proto__ = proto; + } + } + function EtaErr(message) { + var err = new Error(message); + setPrototypeOf(err, EtaErr.prototype); + return err; + } + EtaErr.prototype = Object.create(Error.prototype, { + name: { value: 'Eta Error', enumerable: false } + }); + // TODO: Class transpilation adds a lot to the bundle size + function ParseErr(message, str, indx) { + var whitespace = str.slice(0, indx).split(/\n/); + var lineNo = whitespace.length; + var colNo = whitespace[lineNo - 1].length + 1; + message += + ' at line ' + + lineNo + + ' col ' + + colNo + + ':\n\n' + + ' ' + + str.split(/\n/)[lineNo - 1] + + '\n' + + ' ' + + Array(colNo).join(' ') + + '^'; + throw EtaErr(message); + } + // TODO: allow '-' to trim up until newline. Use [^\S\n\r] instead of \s // TODO: only include trimLeft polyfill if not in ES6 /* END TYPES */ @@ -111,53 +147,39 @@ } } } - var prefixes = ''; - if (env.parse.exec) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.exec; - } - if (env.parse.interpolate) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.interpolate; - } - if (env.parse.raw) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.raw; - } - var parseReg = new RegExp('([^]*?)' + - env.tags[0] + - '(-|_)?\\s*(' + - prefixes + - ')?\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|'); + var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\s*(' + prefixes + ')?', 'g'); + var parseCloseReg = new RegExp('\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + env.tags[1], 'g'); // TODO: benchmark having the \s* on either side vs using str.trim() var m; - while ((m = parseReg.exec(str)) !== null) { + while ((m = parseOpenReg.exec(str)) !== null) { lastIndex = m[0].length + m.index; - var i = m.index; var precedingString = m[1]; var wsLeft = m[2]; var prefix = m[3] || ''; // by default either ~, =, or empty - var content = m[4]; pushString(precedingString, wsLeft); - trimLeftOfNextStr = m[5]; - var currentType = ''; - if (prefix === env.parse.exec) { - currentType = 'e'; - } - else if (prefix === env.parse.raw) { - currentType = 'r'; + parseCloseReg.lastIndex = lastIndex; + var closeTag = parseCloseReg.exec(str); + if (closeTag) { + var content = closeTag[1]; + trimLeftOfNextStr = closeTag[2]; + parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex; + var currentType = ''; + if (prefix === env.parse.exec) { + currentType = 'e'; + } + else if (prefix === env.parse.raw) { + currentType = 'r'; + } + else if (prefix === env.parse.interpolate) { + currentType = 'i'; + } + buffer.push({ t: currentType, val: content }); } - else if (prefix === env.parse.interpolate) { - currentType = 'i'; + else { + ParseErr('unclosed tag', str, lastIndex); } - buffer.push({ t: currentType, val: content }); } pushString(str.slice(lastIndex, str.length), false); if (env.plugins) { @@ -256,23 +278,6 @@ /* END TYPES */ var templates = new Cacher({}); - function setPrototypeOf(obj, proto) { - if (Object.setPrototypeOf) { - Object.setPrototypeOf(obj, proto); - } - else { - obj.__proto__ = proto; - } - } - function EtaErr(message) { - var err = new Error(message); - setPrototypeOf(err, EtaErr.prototype); - return err; - } - EtaErr.prototype = Object.create(Error.prototype, { - name: { value: 'Eta Error', enumerable: false } - }); - /* END TYPES */ function includeHelper(templateNameOrPath, data) { var template = this.templates.get(templateNameOrPath); diff --git a/dist/browser/eta.dev.js.map b/dist/browser/eta.dev.js.map index 29ed784..83d784b 100644 --- a/dist/browser/eta.dev.js.map +++ b/dist/browser/eta.dev.js.map @@ -1 +1 @@ -{"version":3,"file":"eta.dev.js","sources":["../../src/utils.ts","../../src/parse.ts","../../src/compile-string.ts","../../src/storage.ts","../../src/containers.ts","../../src/err.ts","../../src/config.ts","../../src/compile.ts","../../src/render.ts"],"sourcesContent":["// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = ''\n\n if (env.parse.exec) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.exec\n }\n if (env.parse.interpolate) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.interpolate\n }\n if (env.parse.raw) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.raw\n }\n\n var parseReg = new RegExp(\n '([^]*?)' +\n env.tags[0] +\n '(-|_)?\\\\s*(' +\n prefixes +\n ')?\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n var i = m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n var content = m[4]\n\n pushString(precedingString, wsLeft)\n trimLeftOfNextStr = m[5]\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n"],"names":["Parse"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"eta.dev.js","sources":["../../src/err.ts","../../src/utils.ts","../../src/parse.ts","../../src/compile-string.ts","../../src/storage.ts","../../src/containers.ts","../../src/config.ts","../../src/compile.ts","../../src/render.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|')\n\n var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\\\s*(' + prefixes + ')?', 'g')\n var parseCloseReg = new RegExp(\n '\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseOpenReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n\n pushString(precedingString, wsLeft)\n\n parseCloseReg.lastIndex = lastIndex\n var closeTag = parseCloseReg.exec(str)\n if (closeTag) {\n var content = closeTag[1]\n trimLeftOfNextStr = closeTag[2]\n parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n } else {\n ParseErr('unclosed tag', str, lastIndex)\n }\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n"],"names":["Parse"],"mappings":"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"} \ No newline at end of file diff --git a/dist/browser/eta.min.js b/dist/browser/eta.min.js index fd5e5a2..dd1a197 100644 --- a/dist/browser/eta.min.js +++ b/dist/browser/eta.min.js @@ -1,2 +1,2 @@ -!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e=e||self).Eta={})}(this,(function(e){"use strict";var t=new Function("return this;")().Promise;function r(e,t,r){for(var n in t)a=t,o=n,Object.prototype.hasOwnProperty.call(a,o)&&(e[n]=t[n]);var a,o;return e}var n={"&":"&","<":"<",'"':""","'":"'"};function a(e){return n[e]}function o(e,t){var r=[],n=!1,a=0;function o(e,a){if(e){var o=e.replace(/\\|'/g,"\\$&");(o=(o=function(e,t,r,n){var a,o;return"string"==typeof t.autoTrim?a=o=t.autoTrim:Array.isArray(t.autoTrim)&&(a=t.autoTrim[1],o=t.autoTrim[0]),(r||!1===r)&&(a=r),(n||!1===n)&&(o=n),"slurp"===a&&"slurp"===o?e.trim():("_"===a||"slurp"===a?e=String.prototype.trimLeft?e.trimLeft():e.replace(/^[\s\uFEFF\xA0]+/,""):"-"!==a&&"nl"!==a||(e=e.replace(/^(?:\n|\r|\r\n)/,"")),"_"===o||"slurp"===o?e=String.prototype.trimRight?e.trimRight():e.replace(/[\s\uFEFF\xA0]+$/,""):"-"!==o&&"nl"!==o||(e=e.replace(/(?:\n|\r|\r\n)$/,"")),e)}(o,t,n,a)).replace(/\n/g,"\\n").replace(/\r/g,"\\r"))&&r.push(o)}}var i="";t.parse.exec&&(i&&(i+="|"),i+=t.parse.exec),t.parse.interpolate&&(i&&(i+="|"),i+=t.parse.interpolate),t.parse.raw&&(i&&(i+="|"),i+=t.parse.raw);for(var c,s=new RegExp("([^]*?)"+t.tags[0]+"(-|_)?\\s*("+i+")?\\s*((?:[^]*?(?:'(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r'\\\\])*?'|`(?:\\\\[\\s\\w\"'\\\\`]|[^\\\\`])*?`|\"(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r\"\\\\])*?\"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?"+t.tags[1],"g");null!==(c=s.exec(e));){a=c[0].length+c.index;var p=c.index,u=c[1],f=c[2],l=c[3]||"",h=c[4];o(u,f),n=c[5];var g="";l===t.parse.exec?g="e":l===t.parse.raw?g="r":l===t.parse.interpolate&&(g="i"),r.push({t:g,val:h})}if(o(e.slice(a,e.length),!1),t.plugins)for(p=0;p"],parse:{interpolate:"=",raw:"~",exec:""},async:!1,templates:c,cache:!1,plugins:[],useWith:!1,e:function(e){var t=String(e);return/[&<"']/.test(t)?t.replace(/[&<"']/g,a):t},include:p};function f(e,t){var n={};return r(n,u),t&&r(n,t),e&&r(n,e),n}function l(e,t){var r,n=f(t||{});if(n.async)try{r=new Function("return (async function(){}).constructor;")()}catch(e){throw e instanceof SyntaxError?s("This environment doesn't support async/await"):e}else r=Function;try{return new r(n.varName,"E","cb",i(e,n))}catch(t){throw t instanceof SyntaxError?s("Bad template syntax\n\n"+t.message+"\n"+Array(t.message.length+1).join("=")+"\n"+i(e,n)):t}}function h(e,t){var r;return t.cache&&t.name&&t.templates.get(t.name)?t.templates.get(t.name):(r="function"==typeof e?e:l(e,t),t.cache&&t.name&&t.templates.define(t.name,r),r)}p.bind(u),e.compile=l,e.compileToString=i,e.defaultConfig=u,e.getConfig=f,e.parse=o,e.render=function(e,r,n,a){var o=f(n||{});if(!o.async)return h(e,o)(r,o);if(!a){if("function"==typeof t)return new t((function(t,n){try{t(h(e,o)(r,o))}catch(e){n(e)}}));throw s("Please provide a callback function, this env doesn't support Promises")}try{h(e,o)(r,o,a)}catch(e){return a(e)}},e.templates=c,Object.defineProperty(e,"__esModule",{value:!0})})); +!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e=e||self).Eta={})}(this,(function(e){"use strict";function t(e){var r,n,a=new Error(e);return r=a,n=t.prototype,Object.setPrototypeOf?Object.setPrototypeOf(r,n):r.__proto__=n,a}function r(e,r,n){var a=r.slice(0,n).split(/\n/),o=a.length,i=a[o-1].length+1;throw t(e+=" at line "+o+" col "+i+":\n\n "+r.split(/\n/)[o-1]+"\n "+Array(i).join(" ")+"^")}t.prototype=Object.create(Error.prototype,{name:{value:"Eta Error",enumerable:!1}});var n=new Function("return this;")().Promise;function a(e,t,r){for(var n in t)a=t,o=n,Object.prototype.hasOwnProperty.call(a,o)&&(e[n]=t[n]);var a,o;return e}var o={"&":"&","<":"<",'"':""","'":"'"};function i(e){return o[e]}function s(e,t){var n=[],a=!1,o=0;function i(e,r){if(e){var o=e.replace(/\\|'/g,"\\$&");(o=(o=function(e,t,r,n){var a,o;return"string"==typeof t.autoTrim?a=o=t.autoTrim:Array.isArray(t.autoTrim)&&(a=t.autoTrim[1],o=t.autoTrim[0]),(r||!1===r)&&(a=r),(n||!1===n)&&(o=n),"slurp"===a&&"slurp"===o?e.trim():("_"===a||"slurp"===a?e=String.prototype.trimLeft?e.trimLeft():e.replace(/^[\s\uFEFF\xA0]+/,""):"-"!==a&&"nl"!==a||(e=e.replace(/^(?:\n|\r|\r\n)/,"")),"_"===o||"slurp"===o?e=String.prototype.trimRight?e.trimRight():e.replace(/[\s\uFEFF\xA0]+$/,""):"-"!==o&&"nl"!==o||(e=e.replace(/(?:\n|\r|\r\n)$/,"")),e)}(o,t,a,r)).replace(/\n/g,"\\n").replace(/\r/g,"\\r"))&&n.push(o)}}for(var s,c=(t.parse.exec+t.parse.interpolate+t.parse.raw).split("").join("|"),p=new RegExp("([^]*?)"+t.tags[0]+"(-|_)?\\s*("+c+")?","g"),u=new RegExp("\\s*((?:[^]*?(?:'(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r'\\\\])*?'|`(?:\\\\[\\s\\w\"'\\\\`]|[^\\\\`])*?`|\"(?:\\\\[\\s\\w\"'\\\\`]|[^\\n\\r\"\\\\])*?\"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?"+t.tags[1],"g");null!==(s=p.exec(e));){o=s[0].length+s.index;var l=s[1],f=s[2],h=s[3]||"";i(l,f),u.lastIndex=o;var g=u.exec(e);if(g){var v=g[1];a=g[2],p.lastIndex=o=u.lastIndex;var m="";h===t.parse.exec?m="e":h===t.parse.raw?m="r":h===t.parse.interpolate&&(m="i"),n.push({t:m,val:v})}else r("unclosed tag",e,o)}if(i(e.slice(o,e.length),!1),t.plugins)for(var y=0;y"],parse:{interpolate:"=",raw:"~",exec:""},async:!1,templates:p,cache:!1,plugins:[],useWith:!1,e:function(e){var t=String(e);return/[&<"']/.test(t)?t.replace(/[&<"']/g,i):t},include:u};function f(e,t){var r={};return a(r,l),t&&a(r,t),e&&a(r,e),r}function h(e,r){var n,a=f(r||{});if(a.async)try{n=new Function("return (async function(){}).constructor;")()}catch(e){throw e instanceof SyntaxError?t("This environment doesn't support async/await"):e}else n=Function;try{return new n(a.varName,"E","cb",c(e,a))}catch(r){throw r instanceof SyntaxError?t("Bad template syntax\n\n"+r.message+"\n"+Array(r.message.length+1).join("=")+"\n"+c(e,a)):r}}function g(e,t){var r;return t.cache&&t.name&&t.templates.get(t.name)?t.templates.get(t.name):(r="function"==typeof e?e:h(e,t),t.cache&&t.name&&t.templates.define(t.name,r),r)}u.bind(l),e.compile=h,e.compileToString=c,e.defaultConfig=l,e.getConfig=f,e.parse=s,e.render=function(e,r,a,o){var i=f(a||{});if(!i.async)return g(e,i)(r,i);if(!o){if("function"==typeof n)return new n((function(t,n){try{t(g(e,i)(r,i))}catch(e){n(e)}}));throw t("Please provide a callback function, this env doesn't support Promises")}try{g(e,i)(r,i,o)}catch(e){return o(e)}},e.templates=p,Object.defineProperty(e,"__esModule",{value:!0})})); //# sourceMappingURL=eta.min.js.map diff --git a/dist/browser/eta.min.js.map b/dist/browser/eta.min.js.map index 3eceb3e..60dd9fa 100644 --- a/dist/browser/eta.min.js.map +++ b/dist/browser/eta.min.js.map @@ -1 +1 @@ -{"version":3,"file":"eta.min.js","sources":["../../src/utils.ts","../../src/parse.ts","../../src/compile-string.ts","../../src/storage.ts","../../src/containers.ts","../../src/err.ts","../../src/config.ts","../../src/compile.ts","../../src/render.ts"],"sourcesContent":["// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = ''\n\n if (env.parse.exec) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.exec\n }\n if (env.parse.interpolate) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.interpolate\n }\n if (env.parse.raw) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.raw\n }\n\n var parseReg = new RegExp(\n '([^]*?)' +\n env.tags[0] +\n '(-|_)?\\\\s*(' +\n prefixes +\n ')?\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n var i = m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n var content = m[4]\n\n pushString(precedingString, wsLeft)\n trimLeftOfNextStr = m[5]\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n"],"names":["promiseImpl","Function","Promise","copyProps","toObj","fromObj","notConfig","key","obj","prop","Object","prototype","hasOwnProperty","call","escMap","&","<","\"","'","replaceChar","s","parse","str","env","buffer","trimLeftOfNextStr","lastIndex","pushString","strng","shouldTrimRightOfString","stringToPush","replace","wsLeft","wsRight","leftTrim","rightTrim","autoTrim","Array","isArray","trim","String","trimLeft","trimRight","trimWS","push","prefixes","exec","interpolate","raw","m","parseReg","RegExp","tags","length","index","i","precedingString","prefix","content","currentType","t","val","slice","plugins","plugin","processAST","compileToString","Parse","res","useWith","varName","buff","buffLength","returnStr","currentBlock","type","autoEscape","compileScope","processFnString","templates","cache","this","Cacher","cacheObj","EtaErr","message","proto","err","Error","setPrototypeOf","__proto__","includeHelper","templateNameOrPath","data","template","get","create","name","value","enumerable","defaultConfig","async","e","newStr","test","include","getConfig","override","baseConfig","compile","ctor","options","SyntaxError","join","handleCache","templateFunc","define","bind","cb","resolve","reject"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"eta.min.js","sources":["../../src/err.ts","../../src/utils.ts","../../src/parse.ts","../../src/compile-string.ts","../../src/storage.ts","../../src/containers.ts","../../src/config.ts","../../src/compile.ts","../../src/render.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|')\n\n var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\\\s*(' + prefixes + ')?', 'g')\n var parseCloseReg = new RegExp(\n '\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseOpenReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n\n pushString(precedingString, wsLeft)\n\n parseCloseReg.lastIndex = lastIndex\n var closeTag = parseCloseReg.exec(str)\n if (closeTag) {\n var content = closeTag[1]\n trimLeftOfNextStr = closeTag[2]\n parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n } else {\n ParseErr('unclosed tag', str, lastIndex)\n }\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n"],"names":["EtaErr","message","obj","proto","err","Error","prototype","Object","setPrototypeOf","__proto__","ParseErr","str","indx","whitespace","slice","split","lineNo","length","colNo","Array","join","create","name","value","enumerable","promiseImpl","Function","Promise","copyProps","toObj","fromObj","notConfig","key","prop","hasOwnProperty","call","escMap","&","<","\"","'","replaceChar","s","parse","env","buffer","trimLeftOfNextStr","lastIndex","pushString","strng","shouldTrimRightOfString","stringToPush","replace","wsLeft","wsRight","leftTrim","rightTrim","autoTrim","isArray","trim","String","trimLeft","trimRight","trimWS","push","m","prefixes","exec","interpolate","raw","parseOpenReg","RegExp","tags","parseCloseReg","index","precedingString","prefix","closeTag","content","currentType","t","val","plugins","i","plugin","processAST","compileToString","Parse","res","useWith","varName","buff","buffLength","returnStr","currentBlock","type","autoEscape","compileScope","processFnString","templates","cache","this","Cacher","cacheObj","includeHelper","templateNameOrPath","data","template","get","defaultConfig","async","e","newStr","test","include","getConfig","override","baseConfig","compile","ctor","options","SyntaxError","handleCache","templateFunc","define","bind","cb","resolve","reject"],"mappings":"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"} \ No newline at end of file diff --git a/dist/eta.cjs.js b/dist/eta.cjs.js index 24f072d..b0809e0 100644 --- a/dist/eta.cjs.js +++ b/dist/eta.cjs.js @@ -17,7 +17,26 @@ function EtaErr(message) { } EtaErr.prototype = Object.create(Error.prototype, { name: { value: 'Eta Error', enumerable: false } -}); +}); +// TODO: Class transpilation adds a lot to the bundle size +function ParseErr(message, str, indx) { + var whitespace = str.slice(0, indx).split(/\n/); + var lineNo = whitespace.length; + var colNo = whitespace[lineNo - 1].length + 1; + message += + ' at line ' + + lineNo + + ' col ' + + colNo + + ':\n\n' + + ' ' + + str.split(/\n/)[lineNo - 1] + + '\n' + + ' ' + + Array(colNo).join(' ') + + '^'; + throw EtaErr(message); +} // TODO: allow '-' to trim up until newline. Use [^\S\n\r] instead of \s // TODO: only include trimLeft polyfill if not in ES6 @@ -126,53 +145,39 @@ function parse(str, env) { } } } - var prefixes = ''; - if (env.parse.exec) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.exec; - } - if (env.parse.interpolate) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.interpolate; - } - if (env.parse.raw) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.raw; - } - var parseReg = new RegExp('([^]*?)' + - env.tags[0] + - '(-|_)?\\s*(' + - prefixes + - ')?\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|'); + var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\s*(' + prefixes + ')?', 'g'); + var parseCloseReg = new RegExp('\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + env.tags[1], 'g'); // TODO: benchmark having the \s* on either side vs using str.trim() var m; - while ((m = parseReg.exec(str)) !== null) { + while ((m = parseOpenReg.exec(str)) !== null) { lastIndex = m[0].length + m.index; - var i = m.index; var precedingString = m[1]; var wsLeft = m[2]; var prefix = m[3] || ''; // by default either ~, =, or empty - var content = m[4]; pushString(precedingString, wsLeft); - trimLeftOfNextStr = m[5]; - var currentType = ''; - if (prefix === env.parse.exec) { - currentType = 'e'; - } - else if (prefix === env.parse.raw) { - currentType = 'r'; + parseCloseReg.lastIndex = lastIndex; + var closeTag = parseCloseReg.exec(str); + if (closeTag) { + var content = closeTag[1]; + trimLeftOfNextStr = closeTag[2]; + parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex; + var currentType = ''; + if (prefix === env.parse.exec) { + currentType = 'e'; + } + else if (prefix === env.parse.raw) { + currentType = 'r'; + } + else if (prefix === env.parse.interpolate) { + currentType = 'i'; + } + buffer.push({ t: currentType, val: content }); } - else if (prefix === env.parse.interpolate) { - currentType = 'i'; + else { + ParseErr('unclosed tag', str, lastIndex); } - buffer.push({ t: currentType, val: content }); } pushString(str.slice(lastIndex, str.length), false); if (env.plugins) { diff --git a/dist/eta.cjs.js.map b/dist/eta.cjs.js.map index e92287b..06473ed 100644 --- a/dist/eta.cjs.js.map +++ b/dist/eta.cjs.js.map @@ -1 +1 @@ -{"version":3,"file":"eta.cjs.js","sources":["../src/err.ts","../src/utils.ts","../src/parse.ts","../src/compile-string.ts","../src/storage.ts","../src/containers.ts","../src/config.ts","../src/compile.ts","../src/file-utils.ts","../src/file-handlers.ts","../src/file-helpers.ts","../src/render.ts","../src/index.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = ''\n\n if (env.parse.exec) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.exec\n }\n if (env.parse.interpolate) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.interpolate\n }\n if (env.parse.raw) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.raw\n }\n\n var parseReg = new RegExp(\n '([^]*?)' +\n env.tags[0] +\n '(-|_)?\\\\s*(' +\n prefixes +\n ')?\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n var i = m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n var content = m[4]\n\n pushString(precedingString, wsLeft)\n trimLeftOfNextStr = m[5]\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","var fs = require('fs')\nvar path = require('path')\nvar _BOM = /^\\uFEFF/\n\n// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport Compile from './compile'\nimport { getConfig } from './config'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\ninterface PartialFileConfig extends PartialConfig {\n filename: string\n}\n\ninterface FileConfig extends EtaConfig {\n filename: string\n}\n\n/* END TYPES */\n\n/**\n * Get the path to the included file from the parent file path and the\n * specified path.\n *\n * @param {String} name specified path\n * @param {String} parentfile parent file path\n * @param {Boolean} [isDir=false] whether parent file path is a directory\n * @return {String}\n */\n\nfunction getWholeFilePath (name: string, parentfile: string, isDirectory?: boolean) {\n var includePath = path.resolve(\n isDirectory ? parentfile : path.dirname(parentfile), // returns directory the parent file is in\n name // file\n )\n var ext = path.extname(name)\n if (!ext) {\n includePath += '.eta'\n }\n return includePath\n}\n\n/**\n * Get the path to the included file by Options\n *\n * @param {String} path specified path\n * @param {Options} options compilation options\n * @return {String}\n */\n\nfunction getPath (path: string, options: EtaConfig) {\n var includePath\n var filePath\n var views = options.views\n var match = /^[A-Za-z]+:\\\\|^\\//.exec(path)\n\n // Abs path\n if (match && match.length) {\n includePath = getWholeFilePath(path.replace(/^\\/*/, ''), options.root || '/', true)\n } else {\n // Relative paths\n // Look relative to a passed filename first\n if (options.filename) {\n filePath = getWholeFilePath(path, options.filename)\n if (fs.existsSync(filePath)) {\n includePath = filePath\n }\n }\n // Then look in any views directories\n if (!includePath) {\n if (\n Array.isArray(views) &&\n views.some(function (v) {\n filePath = getWholeFilePath(path, v, true)\n return fs.existsSync(filePath)\n })\n ) {\n includePath = filePath\n }\n }\n if (!includePath) {\n throw EtaErr('Could not find the include file \"' + path + '\"')\n }\n }\n return includePath\n}\n\nfunction readFile (filePath: string) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(_BOM, '') // TODO: is replacing BOM's necessary?\n}\n\nfunction loadFile (filePath: string, options: PartialFileConfig): TemplateFunction {\n var config = getConfig(options)\n var template = readFile(filePath)\n try {\n var compiledTemplate = Compile(template, config)\n config.templates.define((config as FileConfig).filename, compiledTemplate)\n return compiledTemplate\n } catch (e) {\n throw EtaErr('Loading file: ' + filePath + ' failed')\n }\n}\n\nexport { getPath, readFile, loadFile }\n","// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport compile from './compile'\nimport { getConfig } from './config'\nimport { getPath, readFile, loadFile } from './file-utils'\nimport { promiseImpl, copyProps } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\nexport type CallbackFn = (err: Error | null, str?: string) => void\n\ninterface FileOptions extends EtaConfig {\n filename: string\n}\n\ninterface DataObj {\n settings?: {\n [key: string]: any\n }\n [key: string]: any\n}\n\n/* END TYPES */\n\n/**\n * Get the template from a string or a file, either compiled on-the-fly or\n * read from cache (if enabled), and cache the template if needed.\n *\n * If `options.cache` is true, this function reads the file from\n * `options.filename` so it must be set prior to calling this function.\n *\n * @param {Options} options compilation options\n * @param {String} [template] template source\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned.\n * @static\n */\n\nfunction handleCache (options: FileOptions): TemplateFunction {\n var filename = options.filename\n\n if (options.cache) {\n var func = options.templates.get(filename)\n if (func) {\n return func\n } else {\n return loadFile(filename, options)\n }\n }\n\n return compile(readFile(filename), options)\n}\n\n/**\n * Try calling handleCache with the given options and data and call the\n * callback with the result. If an error occurs, call the callback with\n * the error. Used by renderFile().\n *\n * @param {Options} options compilation options\n * @param {Object} data template data\n * @param {RenderFileCallback} cb callback\n * @static\n */\n\nfunction tryHandleCache (options: FileOptions, data: object, cb: CallbackFn) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n}\n\n/**\n * Get the template function.\n *\n * If `options.cache` is `true`, then the template is cached.\n *\n * @param {String} path path for the specified file\n * @param {Options} options compilation options\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned\n * @static\n */\n\nfunction includeFile (path: string, options: EtaConfig) {\n // the below creates a new options object, using the parent filepath of the old options object and the path\n var newFileOptions = getConfig({ filename: getPath(path, options) }, options)\n // TODO: make sure properties are currectly copied over\n return handleCache(newFileOptions as FileOptions)\n}\n\nfunction renderFile (filename: string, data: DataObj, cb?: CallbackFn) {\n var Config: FileOptions = getConfig((data as PartialConfig) || {}) as FileOptions\n // TODO: make sure above doesn't error. We do set filename down below\n\n if (data.settings) {\n // Pull a few things from known locations\n if (data.settings.views) {\n Config.views = data.settings.views\n }\n if (data.settings['view cache']) {\n Config.cache = true\n }\n // Undocumented after Express 2, but still usable, esp. for\n // items that are unsafe to be passed along with data, like `root`\n var viewOpts = data.settings['view options']\n\n if (viewOpts) {\n copyProps(Config, viewOpts)\n }\n }\n\n Config.filename = filename // Make sure filename is right\n\n return tryHandleCache(Config, data, cb as CallbackFn)\n}\n\nexport { includeFile, renderFile }\n","import { includeFile } from './file-handlers'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface GenericData {\n [index: string]: any\n}\n\n/* END TYPES */\n\nexport function includeFileHelper (this: EtaConfig, path: string, data: GenericData): string {\n return includeFile(path, this)(data, this)\n}\n\n// export function extendsFileHelper(path: string, data: GenericData, config: EtaConfig): string {\n// var data: GenericData = content.params[1] || {}\n\n// data.content = content.exec()\n// for (var i = 0; i < blocks.length; i++) {\n// var currentBlock = blocks[i]\n// data[currentBlock.name] = currentBlock.exec()\n// }\n\n// return includeFile(content.params[0], config)(data, config)\n// }\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n","/* Export file stuff */\nimport { includeFileHelper } from './file-helpers'\nimport { defaultConfig } from './config'\n\n/* TYPES */\n\n/* END TYPES */\n\ndefaultConfig.includeFile = includeFileHelper\nincludeFileHelper.bind(defaultConfig)\n\nexport { renderFile, renderFile as __express } from './file-handlers'\nexport { loadFile } from './file-utils'\n\n/* End file stuff */\n\nexport { default as compileToString } from './compile-string'\nexport { default as compile } from './compile'\nexport { default as parse } from './parse'\nexport { default as render } from './render'\nexport { templates } from './containers'\nexport { defaultConfig, getConfig } from './config'\n"],"names":["Parse","Compile","handleCache"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"eta.cjs.js","sources":["../src/err.ts","../src/utils.ts","../src/parse.ts","../src/compile-string.ts","../src/storage.ts","../src/containers.ts","../src/config.ts","../src/compile.ts","../src/file-utils.ts","../src/file-handlers.ts","../src/file-helpers.ts","../src/render.ts","../src/index.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|')\n\n var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\\\s*(' + prefixes + ')?', 'g')\n var parseCloseReg = new RegExp(\n '\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseOpenReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n\n pushString(precedingString, wsLeft)\n\n parseCloseReg.lastIndex = lastIndex\n var closeTag = parseCloseReg.exec(str)\n if (closeTag) {\n var content = closeTag[1]\n trimLeftOfNextStr = closeTag[2]\n parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n } else {\n ParseErr('unclosed tag', str, lastIndex)\n }\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","var fs = require('fs')\nvar path = require('path')\nvar _BOM = /^\\uFEFF/\n\n// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport Compile from './compile'\nimport { getConfig } from './config'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\ninterface PartialFileConfig extends PartialConfig {\n filename: string\n}\n\ninterface FileConfig extends EtaConfig {\n filename: string\n}\n\n/* END TYPES */\n\n/**\n * Get the path to the included file from the parent file path and the\n * specified path.\n *\n * @param {String} name specified path\n * @param {String} parentfile parent file path\n * @param {Boolean} [isDir=false] whether parent file path is a directory\n * @return {String}\n */\n\nfunction getWholeFilePath (name: string, parentfile: string, isDirectory?: boolean) {\n var includePath = path.resolve(\n isDirectory ? parentfile : path.dirname(parentfile), // returns directory the parent file is in\n name // file\n )\n var ext = path.extname(name)\n if (!ext) {\n includePath += '.eta'\n }\n return includePath\n}\n\n/**\n * Get the path to the included file by Options\n *\n * @param {String} path specified path\n * @param {Options} options compilation options\n * @return {String}\n */\n\nfunction getPath (path: string, options: EtaConfig) {\n var includePath\n var filePath\n var views = options.views\n var match = /^[A-Za-z]+:\\\\|^\\//.exec(path)\n\n // Abs path\n if (match && match.length) {\n includePath = getWholeFilePath(path.replace(/^\\/*/, ''), options.root || '/', true)\n } else {\n // Relative paths\n // Look relative to a passed filename first\n if (options.filename) {\n filePath = getWholeFilePath(path, options.filename)\n if (fs.existsSync(filePath)) {\n includePath = filePath\n }\n }\n // Then look in any views directories\n if (!includePath) {\n if (\n Array.isArray(views) &&\n views.some(function (v) {\n filePath = getWholeFilePath(path, v, true)\n return fs.existsSync(filePath)\n })\n ) {\n includePath = filePath\n }\n }\n if (!includePath) {\n throw EtaErr('Could not find the include file \"' + path + '\"')\n }\n }\n return includePath\n}\n\nfunction readFile (filePath: string) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(_BOM, '') // TODO: is replacing BOM's necessary?\n}\n\nfunction loadFile (filePath: string, options: PartialFileConfig): TemplateFunction {\n var config = getConfig(options)\n var template = readFile(filePath)\n try {\n var compiledTemplate = Compile(template, config)\n config.templates.define((config as FileConfig).filename, compiledTemplate)\n return compiledTemplate\n } catch (e) {\n throw EtaErr('Loading file: ' + filePath + ' failed')\n }\n}\n\nexport { getPath, readFile, loadFile }\n","// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport compile from './compile'\nimport { getConfig } from './config'\nimport { getPath, readFile, loadFile } from './file-utils'\nimport { promiseImpl, copyProps } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\nexport type CallbackFn = (err: Error | null, str?: string) => void\n\ninterface FileOptions extends EtaConfig {\n filename: string\n}\n\ninterface DataObj {\n settings?: {\n [key: string]: any\n }\n [key: string]: any\n}\n\n/* END TYPES */\n\n/**\n * Get the template from a string or a file, either compiled on-the-fly or\n * read from cache (if enabled), and cache the template if needed.\n *\n * If `options.cache` is true, this function reads the file from\n * `options.filename` so it must be set prior to calling this function.\n *\n * @param {Options} options compilation options\n * @param {String} [template] template source\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned.\n * @static\n */\n\nfunction handleCache (options: FileOptions): TemplateFunction {\n var filename = options.filename\n\n if (options.cache) {\n var func = options.templates.get(filename)\n if (func) {\n return func\n } else {\n return loadFile(filename, options)\n }\n }\n\n return compile(readFile(filename), options)\n}\n\n/**\n * Try calling handleCache with the given options and data and call the\n * callback with the result. If an error occurs, call the callback with\n * the error. Used by renderFile().\n *\n * @param {Options} options compilation options\n * @param {Object} data template data\n * @param {RenderFileCallback} cb callback\n * @static\n */\n\nfunction tryHandleCache (options: FileOptions, data: object, cb: CallbackFn) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n}\n\n/**\n * Get the template function.\n *\n * If `options.cache` is `true`, then the template is cached.\n *\n * @param {String} path path for the specified file\n * @param {Options} options compilation options\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned\n * @static\n */\n\nfunction includeFile (path: string, options: EtaConfig) {\n // the below creates a new options object, using the parent filepath of the old options object and the path\n var newFileOptions = getConfig({ filename: getPath(path, options) }, options)\n // TODO: make sure properties are currectly copied over\n return handleCache(newFileOptions as FileOptions)\n}\n\nfunction renderFile (filename: string, data: DataObj, cb?: CallbackFn) {\n var Config: FileOptions = getConfig((data as PartialConfig) || {}) as FileOptions\n // TODO: make sure above doesn't error. We do set filename down below\n\n if (data.settings) {\n // Pull a few things from known locations\n if (data.settings.views) {\n Config.views = data.settings.views\n }\n if (data.settings['view cache']) {\n Config.cache = true\n }\n // Undocumented after Express 2, but still usable, esp. for\n // items that are unsafe to be passed along with data, like `root`\n var viewOpts = data.settings['view options']\n\n if (viewOpts) {\n copyProps(Config, viewOpts)\n }\n }\n\n Config.filename = filename // Make sure filename is right\n\n return tryHandleCache(Config, data, cb as CallbackFn)\n}\n\nexport { includeFile, renderFile }\n","import { includeFile } from './file-handlers'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface GenericData {\n [index: string]: any\n}\n\n/* END TYPES */\n\nexport function includeFileHelper (this: EtaConfig, path: string, data: GenericData): string {\n return includeFile(path, this)(data, this)\n}\n\n// export function extendsFileHelper(path: string, data: GenericData, config: EtaConfig): string {\n// var data: GenericData = content.params[1] || {}\n\n// data.content = content.exec()\n// for (var i = 0; i < blocks.length; i++) {\n// var currentBlock = blocks[i]\n// data[currentBlock.name] = currentBlock.exec()\n// }\n\n// return includeFile(content.params[0], config)(data, config)\n// }\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n","/* Export file stuff */\nimport { includeFileHelper } from './file-helpers'\nimport { defaultConfig } from './config'\n\n/* TYPES */\n\n/* END TYPES */\n\ndefaultConfig.includeFile = includeFileHelper\nincludeFileHelper.bind(defaultConfig)\n\nexport { renderFile, renderFile as __express } from './file-handlers'\nexport { loadFile } from './file-utils'\n\n/* End file stuff */\n\nexport { default as compileToString } from './compile-string'\nexport { default as compile } from './compile'\nexport { default as parse } from './parse'\nexport { default as render } from './render'\nexport { templates } from './containers'\nexport { defaultConfig, getConfig } from './config'\n"],"names":["Parse","Compile","handleCache"],"mappings":"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"} \ No newline at end of file diff --git a/dist/eta.es.js b/dist/eta.es.js index 4b1020e..ffa9f28 100644 --- a/dist/eta.es.js +++ b/dist/eta.es.js @@ -13,7 +13,26 @@ function EtaErr(message) { } EtaErr.prototype = Object.create(Error.prototype, { name: { value: 'Eta Error', enumerable: false } -}); +}); +// TODO: Class transpilation adds a lot to the bundle size +function ParseErr(message, str, indx) { + var whitespace = str.slice(0, indx).split(/\n/); + var lineNo = whitespace.length; + var colNo = whitespace[lineNo - 1].length + 1; + message += + ' at line ' + + lineNo + + ' col ' + + colNo + + ':\n\n' + + ' ' + + str.split(/\n/)[lineNo - 1] + + '\n' + + ' ' + + Array(colNo).join(' ') + + '^'; + throw EtaErr(message); +} // TODO: allow '-' to trim up until newline. Use [^\S\n\r] instead of \s // TODO: only include trimLeft polyfill if not in ES6 @@ -122,53 +141,39 @@ function parse(str, env) { } } } - var prefixes = ''; - if (env.parse.exec) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.exec; - } - if (env.parse.interpolate) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.interpolate; - } - if (env.parse.raw) { - if (prefixes) { - prefixes += '|'; - } - prefixes += env.parse.raw; - } - var parseReg = new RegExp('([^]*?)' + - env.tags[0] + - '(-|_)?\\s*(' + - prefixes + - ')?\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|'); + var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\s*(' + prefixes + ')?', 'g'); + var parseCloseReg = new RegExp('\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + env.tags[1], 'g'); // TODO: benchmark having the \s* on either side vs using str.trim() var m; - while ((m = parseReg.exec(str)) !== null) { + while ((m = parseOpenReg.exec(str)) !== null) { lastIndex = m[0].length + m.index; - var i = m.index; var precedingString = m[1]; var wsLeft = m[2]; var prefix = m[3] || ''; // by default either ~, =, or empty - var content = m[4]; pushString(precedingString, wsLeft); - trimLeftOfNextStr = m[5]; - var currentType = ''; - if (prefix === env.parse.exec) { - currentType = 'e'; - } - else if (prefix === env.parse.raw) { - currentType = 'r'; + parseCloseReg.lastIndex = lastIndex; + var closeTag = parseCloseReg.exec(str); + if (closeTag) { + var content = closeTag[1]; + trimLeftOfNextStr = closeTag[2]; + parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex; + var currentType = ''; + if (prefix === env.parse.exec) { + currentType = 'e'; + } + else if (prefix === env.parse.raw) { + currentType = 'r'; + } + else if (prefix === env.parse.interpolate) { + currentType = 'i'; + } + buffer.push({ t: currentType, val: content }); } - else if (prefix === env.parse.interpolate) { - currentType = 'i'; + else { + ParseErr('unclosed tag', str, lastIndex); } - buffer.push({ t: currentType, val: content }); } pushString(str.slice(lastIndex, str.length), false); if (env.plugins) { diff --git a/dist/eta.es.js.map b/dist/eta.es.js.map index 32b7502..5f5b583 100644 --- a/dist/eta.es.js.map +++ b/dist/eta.es.js.map @@ -1 +1 @@ -{"version":3,"file":"eta.es.js","sources":["../src/err.ts","../src/utils.ts","../src/parse.ts","../src/compile-string.ts","../src/storage.ts","../src/containers.ts","../src/config.ts","../src/compile.ts","../src/file-utils.ts","../src/file-handlers.ts","../src/file-helpers.ts","../src/render.ts","../src/index.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = ''\n\n if (env.parse.exec) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.exec\n }\n if (env.parse.interpolate) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.interpolate\n }\n if (env.parse.raw) {\n if (prefixes) {\n prefixes += '|'\n }\n prefixes += env.parse.raw\n }\n\n var parseReg = new RegExp(\n '([^]*?)' +\n env.tags[0] +\n '(-|_)?\\\\s*(' +\n prefixes +\n ')?\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n var i = m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n var content = m[4]\n\n pushString(precedingString, wsLeft)\n trimLeftOfNextStr = m[5]\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","var fs = require('fs')\nvar path = require('path')\nvar _BOM = /^\\uFEFF/\n\n// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport Compile from './compile'\nimport { getConfig } from './config'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\ninterface PartialFileConfig extends PartialConfig {\n filename: string\n}\n\ninterface FileConfig extends EtaConfig {\n filename: string\n}\n\n/* END TYPES */\n\n/**\n * Get the path to the included file from the parent file path and the\n * specified path.\n *\n * @param {String} name specified path\n * @param {String} parentfile parent file path\n * @param {Boolean} [isDir=false] whether parent file path is a directory\n * @return {String}\n */\n\nfunction getWholeFilePath (name: string, parentfile: string, isDirectory?: boolean) {\n var includePath = path.resolve(\n isDirectory ? parentfile : path.dirname(parentfile), // returns directory the parent file is in\n name // file\n )\n var ext = path.extname(name)\n if (!ext) {\n includePath += '.eta'\n }\n return includePath\n}\n\n/**\n * Get the path to the included file by Options\n *\n * @param {String} path specified path\n * @param {Options} options compilation options\n * @return {String}\n */\n\nfunction getPath (path: string, options: EtaConfig) {\n var includePath\n var filePath\n var views = options.views\n var match = /^[A-Za-z]+:\\\\|^\\//.exec(path)\n\n // Abs path\n if (match && match.length) {\n includePath = getWholeFilePath(path.replace(/^\\/*/, ''), options.root || '/', true)\n } else {\n // Relative paths\n // Look relative to a passed filename first\n if (options.filename) {\n filePath = getWholeFilePath(path, options.filename)\n if (fs.existsSync(filePath)) {\n includePath = filePath\n }\n }\n // Then look in any views directories\n if (!includePath) {\n if (\n Array.isArray(views) &&\n views.some(function (v) {\n filePath = getWholeFilePath(path, v, true)\n return fs.existsSync(filePath)\n })\n ) {\n includePath = filePath\n }\n }\n if (!includePath) {\n throw EtaErr('Could not find the include file \"' + path + '\"')\n }\n }\n return includePath\n}\n\nfunction readFile (filePath: string) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(_BOM, '') // TODO: is replacing BOM's necessary?\n}\n\nfunction loadFile (filePath: string, options: PartialFileConfig): TemplateFunction {\n var config = getConfig(options)\n var template = readFile(filePath)\n try {\n var compiledTemplate = Compile(template, config)\n config.templates.define((config as FileConfig).filename, compiledTemplate)\n return compiledTemplate\n } catch (e) {\n throw EtaErr('Loading file: ' + filePath + ' failed')\n }\n}\n\nexport { getPath, readFile, loadFile }\n","// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport compile from './compile'\nimport { getConfig } from './config'\nimport { getPath, readFile, loadFile } from './file-utils'\nimport { promiseImpl, copyProps } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\nexport type CallbackFn = (err: Error | null, str?: string) => void\n\ninterface FileOptions extends EtaConfig {\n filename: string\n}\n\ninterface DataObj {\n settings?: {\n [key: string]: any\n }\n [key: string]: any\n}\n\n/* END TYPES */\n\n/**\n * Get the template from a string or a file, either compiled on-the-fly or\n * read from cache (if enabled), and cache the template if needed.\n *\n * If `options.cache` is true, this function reads the file from\n * `options.filename` so it must be set prior to calling this function.\n *\n * @param {Options} options compilation options\n * @param {String} [template] template source\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned.\n * @static\n */\n\nfunction handleCache (options: FileOptions): TemplateFunction {\n var filename = options.filename\n\n if (options.cache) {\n var func = options.templates.get(filename)\n if (func) {\n return func\n } else {\n return loadFile(filename, options)\n }\n }\n\n return compile(readFile(filename), options)\n}\n\n/**\n * Try calling handleCache with the given options and data and call the\n * callback with the result. If an error occurs, call the callback with\n * the error. Used by renderFile().\n *\n * @param {Options} options compilation options\n * @param {Object} data template data\n * @param {RenderFileCallback} cb callback\n * @static\n */\n\nfunction tryHandleCache (options: FileOptions, data: object, cb: CallbackFn) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n}\n\n/**\n * Get the template function.\n *\n * If `options.cache` is `true`, then the template is cached.\n *\n * @param {String} path path for the specified file\n * @param {Options} options compilation options\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned\n * @static\n */\n\nfunction includeFile (path: string, options: EtaConfig) {\n // the below creates a new options object, using the parent filepath of the old options object and the path\n var newFileOptions = getConfig({ filename: getPath(path, options) }, options)\n // TODO: make sure properties are currectly copied over\n return handleCache(newFileOptions as FileOptions)\n}\n\nfunction renderFile (filename: string, data: DataObj, cb?: CallbackFn) {\n var Config: FileOptions = getConfig((data as PartialConfig) || {}) as FileOptions\n // TODO: make sure above doesn't error. We do set filename down below\n\n if (data.settings) {\n // Pull a few things from known locations\n if (data.settings.views) {\n Config.views = data.settings.views\n }\n if (data.settings['view cache']) {\n Config.cache = true\n }\n // Undocumented after Express 2, but still usable, esp. for\n // items that are unsafe to be passed along with data, like `root`\n var viewOpts = data.settings['view options']\n\n if (viewOpts) {\n copyProps(Config, viewOpts)\n }\n }\n\n Config.filename = filename // Make sure filename is right\n\n return tryHandleCache(Config, data, cb as CallbackFn)\n}\n\nexport { includeFile, renderFile }\n","import { includeFile } from './file-handlers'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface GenericData {\n [index: string]: any\n}\n\n/* END TYPES */\n\nexport function includeFileHelper (this: EtaConfig, path: string, data: GenericData): string {\n return includeFile(path, this)(data, this)\n}\n\n// export function extendsFileHelper(path: string, data: GenericData, config: EtaConfig): string {\n// var data: GenericData = content.params[1] || {}\n\n// data.content = content.exec()\n// for (var i = 0; i < blocks.length; i++) {\n// var currentBlock = blocks[i]\n// data[currentBlock.name] = currentBlock.exec()\n// }\n\n// return includeFile(content.params[0], config)(data, config)\n// }\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n","/* Export file stuff */\nimport { includeFileHelper } from './file-helpers'\nimport { defaultConfig } from './config'\n\n/* TYPES */\n\n/* END TYPES */\n\ndefaultConfig.includeFile = includeFileHelper\nincludeFileHelper.bind(defaultConfig)\n\nexport { renderFile, renderFile as __express } from './file-handlers'\nexport { loadFile } from './file-utils'\n\n/* End file stuff */\n\nexport { default as compileToString } from './compile-string'\nexport { default as compile } from './compile'\nexport { default as parse } from './parse'\nexport { default as render } from './render'\nexport { templates } from './containers'\nexport { defaultConfig, getConfig } from './config'\n"],"names":["Parse","Compile","handleCache"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"eta.es.js","sources":["../src/err.ts","../src/utils.ts","../src/parse.ts","../src/compile-string.ts","../src/storage.ts","../src/containers.ts","../src/config.ts","../src/compile.ts","../src/file-utils.ts","../src/file-handlers.ts","../src/file-helpers.ts","../src/render.ts","../src/index.ts"],"sourcesContent":["function setPrototypeOf (obj: any, proto: any) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(obj, proto)\n } else {\n obj.__proto__ = proto\n }\n}\n\nexport default function EtaErr (message: string): Error {\n var err = new Error(message)\n setPrototypeOf(err, EtaErr.prototype)\n return err\n}\n\nEtaErr.prototype = Object.create(Error.prototype, {\n name: { value: 'Eta Error', enumerable: false }\n})\n\n// TODO: Class transpilation adds a lot to the bundle size\n\nexport function ParseErr (message: string, str: string, indx: number) {\n var whitespace = str.slice(0, indx).split(/\\n/)\n\n var lineNo = whitespace.length\n var colNo = whitespace[lineNo - 1].length + 1\n message +=\n ' at line ' +\n lineNo +\n ' col ' +\n colNo +\n ':\\n\\n' +\n ' ' +\n str.split(/\\n/)[lineNo - 1] +\n '\\n' +\n ' ' +\n Array(colNo).join(' ') +\n '^'\n throw EtaErr(message)\n}\n","// TODO: allow '-' to trim up until newline. Use [^\\S\\n\\r] instead of \\s\n// TODO: only include trimLeft polyfill if not in ES6\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface EscapeMap {\n '&': '&'\n '<': '<'\n '\"': '"'\n \"'\": '''\n [index: string]: string\n}\n\n/* END TYPES */\n\nexport var promiseImpl = new Function('return this;')().Promise\n\nexport function hasOwnProp (obj: object, prop: string) {\n return Object.prototype.hasOwnProperty.call(obj, prop)\n}\n\nexport function copyProps (toObj: T, fromObj: T, notConfig?: boolean) {\n for (var key in fromObj) {\n if (hasOwnProp((fromObj as unknown) as object, key)) {\n toObj[key] = fromObj[key]\n }\n }\n return toObj\n}\n\nfunction trimWS (\n str: string,\n env: EtaConfig,\n wsLeft: string | false,\n wsRight?: string | false\n): string {\n var leftTrim\n var rightTrim\n\n if (typeof env.autoTrim === 'string') {\n leftTrim = rightTrim = env.autoTrim\n } else if (Array.isArray(env.autoTrim)) {\n // kinda confusing\n // but _}} will trim the left side of the following string\n leftTrim = env.autoTrim[1]\n rightTrim = env.autoTrim[0]\n }\n\n if (wsLeft || wsLeft === false) {\n leftTrim = wsLeft\n }\n\n if (wsRight || wsRight === false) {\n rightTrim = wsRight\n }\n\n if (leftTrim === 'slurp' && rightTrim === 'slurp') {\n return str.trim()\n }\n\n if (leftTrim === '_' || leftTrim === 'slurp') {\n // console.log('trimming left' + leftTrim)\n // full slurp\n if (String.prototype.trimLeft) {\n str = str.trimLeft()\n } else {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+/, '')\n }\n } else if (leftTrim === '-' || leftTrim === 'nl') {\n // console.log('trimming left nl' + leftTrim)\n // nl trim\n str = str.replace(/^(?:\\n|\\r|\\r\\n)/, '')\n }\n\n if (rightTrim === '_' || rightTrim === 'slurp') {\n // console.log('trimming right' + rightTrim)\n // full slurp\n if (String.prototype.trimRight) {\n str = str.trimRight()\n } else {\n str = str.replace(/[\\s\\uFEFF\\xA0]+$/, '')\n }\n } else if (rightTrim === '-' || rightTrim === 'nl') {\n // console.log('trimming right nl' + rightTrim)\n // nl trim\n str = str.replace(/(?:\\n|\\r|\\r\\n)$/, '') // TODO: make sure this gets \\r\\n\n }\n\n return str\n}\n\nvar escMap: EscapeMap = {\n '&': '&',\n '<': '<',\n '\"': '"',\n \"'\": '''\n}\n\nfunction replaceChar (s: string): string {\n return escMap[s]\n}\n\nfunction XMLEscape (str: any) {\n // To deal with XSS. Based on Escape implementations of Mustache.JS and Marko, then customized.\n var newStr = String(str)\n if (/[&<\"']/.test(newStr)) {\n return newStr.replace(/[&<\"']/g, replaceChar)\n } else {\n return newStr\n }\n}\n\nexport { trimWS, XMLEscape }\n","import EtaErr, { ParseErr } from './err'\nimport { trimWS } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\nexport type TagType = 'r' | 'e' | 'i' | ''\n\nexport interface TemplateObject {\n t: TagType\n val: string\n}\n\nexport type AstObject = string | TemplateObject\n\n/* END TYPES */\n\nexport default function parse(str: string, env: EtaConfig): Array {\n var buffer: Array = []\n var trimLeftOfNextStr: string | false = false\n var lastIndex = 0\n\n function pushString(strng: string, shouldTrimRightOfString?: string | false) {\n if (strng) {\n // if string is truthy it must be of type 'string'\n // replace \\ with \\\\, ' with \\'\n var stringToPush = strng.replace(/\\\\|'/g, '\\\\$&')\n\n // TODO: benchmark replace( /(\\\\|')/g, '\\\\$1')\n stringToPush = trimWS(\n stringToPush,\n env,\n trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined\n shouldTrimRightOfString\n )\n\n stringToPush = stringToPush.replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r')\n\n if (stringToPush) {\n buffer.push(stringToPush)\n }\n }\n }\n\n var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|')\n\n var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\\\s*(' + prefixes + ')?', 'g')\n var parseCloseReg = new RegExp(\n '\\\\s*((?:[^]*?(?:\\'(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\\'\\\\\\\\])*?\\'|`(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\\\\\`])*?`|\"(?:\\\\\\\\[\\\\s\\\\w\"\\'\\\\\\\\`]|[^\\\\n\\\\r\"\\\\\\\\])*?\"|\\\\/\\\\*[^]*?\\\\*\\\\/)?)*?)\\\\s*(-|_)?' +\n env.tags[1],\n 'g'\n )\n // TODO: benchmark having the \\s* on either side vs using str.trim()\n\n var m\n\n while ((m = parseOpenReg.exec(str)) !== null) {\n lastIndex = m[0].length + m.index\n\n var precedingString = m[1]\n var wsLeft = m[2]\n var prefix = m[3] || '' // by default either ~, =, or empty\n\n pushString(precedingString, wsLeft)\n\n parseCloseReg.lastIndex = lastIndex\n var closeTag = parseCloseReg.exec(str)\n if (closeTag) {\n var content = closeTag[1]\n trimLeftOfNextStr = closeTag[2]\n parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex\n\n var currentType: TagType = ''\n if (prefix === env.parse.exec) {\n currentType = 'e'\n } else if (prefix === env.parse.raw) {\n currentType = 'r'\n } else if (prefix === env.parse.interpolate) {\n currentType = 'i'\n }\n\n buffer.push({ t: currentType, val: content })\n } else {\n ParseErr('unclosed tag', str, lastIndex)\n }\n }\n\n pushString(str.slice(lastIndex, str.length), false)\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processAST) {\n buffer = plugin.processAST(buffer, env)\n }\n }\n }\n\n return buffer\n}\n","import Parse from './parse'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { AstObject } from './parse'\n\n/* END TYPES */\n\nexport default function compileToString (str: string, env: EtaConfig) {\n var buffer: Array = Parse(str, env)\n\n var res =\n \"var tR='';\" +\n (env.useWith ? 'with(' + env.varName + '||{}){' : '') +\n compileScope(buffer, env) +\n 'if(cb){cb(null,tR)} return tR' +\n (env.useWith ? '}' : '')\n\n if (env.plugins) {\n for (var i = 0; i < env.plugins.length; i++) {\n var plugin = env.plugins[i]\n if (plugin.processFnString) {\n res = plugin.processFnString(res, env)\n }\n }\n }\n\n return res\n\n // TODO: is `return cb()` necessary, or could we just do `cb()`\n}\n\nfunction compileScope (buff: Array, env: EtaConfig) {\n var i = 0\n var buffLength = buff.length\n var returnStr = ''\n\n for (i; i < buffLength; i++) {\n var currentBlock = buff[i]\n if (typeof currentBlock === 'string') {\n var str = currentBlock\n\n // we know string exists\n returnStr += \"tR+='\" + str + \"';\"\n } else {\n var type = currentBlock.t // ~, s, !, ?, r\n var content = currentBlock.val || ''\n\n if (type === 'r') {\n // raw\n returnStr += 'tR+=' + content + ';'\n } else if (type === 'i') {\n // interpolate\n if (env.autoEscape) {\n content = 'E.e(' + content + ')'\n }\n returnStr += 'tR+=' + content + ';'\n // reference\n } else if (type === 'e') {\n // execute\n returnStr += content + '\\n' // you need a \\n in case you have <% } %>\n }\n }\n }\n\n return returnStr\n}\n","import { copyProps } from './utils'\n\n/* TYPES */\n\ninterface Dict {\n // Basically, an object where all keys point to a value of the same type\n [key: string]: T\n}\n\n/* END TYPES */\n\nclass Cacher {\n constructor (private cache: Dict) {}\n define (key: string, val: T) {\n this.cache[key] = val\n }\n get (key: string) {\n // string | array.\n // TODO: allow array of keys to look down\n // TODO: create plugin to allow referencing helpers, filters with dot notation\n return this.cache[key]\n }\n remove (key: string) {\n delete this.cache[key]\n }\n reset () {\n this.cache = {}\n }\n load (cacheObj: Dict) {\n // TODO: this will err with deep objects and `storage` or `plugins` keys.\n // Update Feb 26: EDITED so it shouldn't err\n copyProps(this.cache, cacheObj, true)\n }\n}\n\nexport { Cacher }\n","import { Cacher } from './storage'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\nimport { TemplateFunction } from './compile'\n\n/* END TYPES */\n\nvar templates = new Cacher({})\n\n/* ASYNC LOOP FNs */\n\nexport { templates }\n","import { templates } from './containers'\nimport { copyProps, XMLEscape } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { TemplateFunction } from './compile'\nimport { Cacher } from './storage'\n\ntype trimConfig = 'nl' | 'slurp' | false\n\nexport interface EtaConfig {\n varName: string\n autoTrim: trimConfig | [trimConfig, trimConfig]\n autoEscape: boolean\n tags: [string, string]\n parse: {\n interpolate: string\n raw: string\n exec: string\n }\n e: (str: string) => string\n plugins: Array<{ processFnString?: Function; processAST?: Function }>\n async: boolean\n templates: Cacher\n cache: boolean\n views?: string | Array\n root?: string\n filename?: string\n name?: string\n 'view cache'?: boolean\n useWith?: boolean\n [index: string]: any\n}\n\nexport type PartialConfig = {\n [P in keyof EtaConfig]?: EtaConfig[P]\n}\n\n/* END TYPES */\n\nfunction includeHelper (this: EtaConfig, templateNameOrPath: string, data: object): string {\n var template = this.templates.get(templateNameOrPath)\n if (!template) {\n throw EtaErr('Could not fetch template \"' + templateNameOrPath + '\"')\n }\n return template(data, this)\n}\n\nvar defaultConfig: EtaConfig = {\n varName: 'it',\n autoTrim: [false, 'nl'],\n autoEscape: true,\n tags: ['<%', '%>'],\n parse: {\n interpolate: '=',\n raw: '~',\n exec: ''\n },\n async: false,\n templates: templates,\n cache: false,\n plugins: [],\n useWith: false,\n e: XMLEscape,\n include: includeHelper\n}\n\nincludeHelper.bind(defaultConfig)\n\nfunction getConfig (override: PartialConfig, baseConfig?: EtaConfig): EtaConfig {\n // TODO: run more tests on this\n\n var res: PartialConfig = {} // Linked\n copyProps(res, defaultConfig) // Creates deep clone of res, 1 layer deep\n\n if (baseConfig) {\n copyProps(res, baseConfig)\n }\n\n if (override) {\n copyProps(res, override)\n }\n\n return res as EtaConfig\n}\n\nexport { defaultConfig, getConfig }\n","import compileToString from './compile-string'\nimport { getConfig } from './config'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { CallbackFn } from './file-handlers'\nexport type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string\n\n/* END TYPES */\n\nexport default function compile (str: string, env?: PartialConfig): TemplateFunction {\n var options: EtaConfig = getConfig(env || {})\n var ctor // constructor\n\n /* ASYNC HANDLING */\n // The below code is modified from mde/ejs. All credit should go to them.\n if (options.async) {\n // Have to use generated function for this, since in envs without support,\n // it breaks in parsing\n try {\n ctor = new Function('return (async function(){}).constructor;')()\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\"This environment doesn't support async/await\")\n } else {\n throw e\n }\n }\n } else {\n ctor = Function\n }\n /* END ASYNC HANDLING */\n try {\n return new ctor(\n options.varName,\n 'E', // EtaConfig\n 'cb', // optional callback\n compileToString(str, options)\n ) as TemplateFunction // eslint-disable-line no-new-func\n } catch (e) {\n if (e instanceof SyntaxError) {\n throw EtaErr(\n 'Bad template syntax\\n\\n' +\n e.message +\n '\\n' +\n Array(e.message.length + 1).join('=') +\n '\\n' +\n compileToString(str, options)\n )\n } else {\n throw e\n }\n }\n}\n","var fs = require('fs')\nvar path = require('path')\nvar _BOM = /^\\uFEFF/\n\n// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport Compile from './compile'\nimport { getConfig } from './config'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\ninterface PartialFileConfig extends PartialConfig {\n filename: string\n}\n\ninterface FileConfig extends EtaConfig {\n filename: string\n}\n\n/* END TYPES */\n\n/**\n * Get the path to the included file from the parent file path and the\n * specified path.\n *\n * @param {String} name specified path\n * @param {String} parentfile parent file path\n * @param {Boolean} [isDir=false] whether parent file path is a directory\n * @return {String}\n */\n\nfunction getWholeFilePath (name: string, parentfile: string, isDirectory?: boolean) {\n var includePath = path.resolve(\n isDirectory ? parentfile : path.dirname(parentfile), // returns directory the parent file is in\n name // file\n )\n var ext = path.extname(name)\n if (!ext) {\n includePath += '.eta'\n }\n return includePath\n}\n\n/**\n * Get the path to the included file by Options\n *\n * @param {String} path specified path\n * @param {Options} options compilation options\n * @return {String}\n */\n\nfunction getPath (path: string, options: EtaConfig) {\n var includePath\n var filePath\n var views = options.views\n var match = /^[A-Za-z]+:\\\\|^\\//.exec(path)\n\n // Abs path\n if (match && match.length) {\n includePath = getWholeFilePath(path.replace(/^\\/*/, ''), options.root || '/', true)\n } else {\n // Relative paths\n // Look relative to a passed filename first\n if (options.filename) {\n filePath = getWholeFilePath(path, options.filename)\n if (fs.existsSync(filePath)) {\n includePath = filePath\n }\n }\n // Then look in any views directories\n if (!includePath) {\n if (\n Array.isArray(views) &&\n views.some(function (v) {\n filePath = getWholeFilePath(path, v, true)\n return fs.existsSync(filePath)\n })\n ) {\n includePath = filePath\n }\n }\n if (!includePath) {\n throw EtaErr('Could not find the include file \"' + path + '\"')\n }\n }\n return includePath\n}\n\nfunction readFile (filePath: string) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(_BOM, '') // TODO: is replacing BOM's necessary?\n}\n\nfunction loadFile (filePath: string, options: PartialFileConfig): TemplateFunction {\n var config = getConfig(options)\n var template = readFile(filePath)\n try {\n var compiledTemplate = Compile(template, config)\n config.templates.define((config as FileConfig).filename, compiledTemplate)\n return compiledTemplate\n } catch (e) {\n throw EtaErr('Loading file: ' + filePath + ' failed')\n }\n}\n\nexport { getPath, readFile, loadFile }\n","// express is set like: app.engine('html', require('eta').renderFile)\n\nimport EtaErr from './err'\nimport compile from './compile'\nimport { getConfig } from './config'\nimport { getPath, readFile, loadFile } from './file-utils'\nimport { promiseImpl, copyProps } from './utils'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\n\nexport type CallbackFn = (err: Error | null, str?: string) => void\n\ninterface FileOptions extends EtaConfig {\n filename: string\n}\n\ninterface DataObj {\n settings?: {\n [key: string]: any\n }\n [key: string]: any\n}\n\n/* END TYPES */\n\n/**\n * Get the template from a string or a file, either compiled on-the-fly or\n * read from cache (if enabled), and cache the template if needed.\n *\n * If `options.cache` is true, this function reads the file from\n * `options.filename` so it must be set prior to calling this function.\n *\n * @param {Options} options compilation options\n * @param {String} [template] template source\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned.\n * @static\n */\n\nfunction handleCache (options: FileOptions): TemplateFunction {\n var filename = options.filename\n\n if (options.cache) {\n var func = options.templates.get(filename)\n if (func) {\n return func\n } else {\n return loadFile(filename, options)\n }\n }\n\n return compile(readFile(filename), options)\n}\n\n/**\n * Try calling handleCache with the given options and data and call the\n * callback with the result. If an error occurs, call the callback with\n * the error. Used by renderFile().\n *\n * @param {Options} options compilation options\n * @param {Object} data template data\n * @param {RenderFileCallback} cb callback\n * @static\n */\n\nfunction tryHandleCache (options: FileOptions, data: object, cb: CallbackFn) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n}\n\n/**\n * Get the template function.\n *\n * If `options.cache` is `true`, then the template is cached.\n *\n * @param {String} path path for the specified file\n * @param {Options} options compilation options\n * @return {(TemplateFunction|ClientFunction)}\n * Depending on the value of `options.client`, either type might be returned\n * @static\n */\n\nfunction includeFile (path: string, options: EtaConfig) {\n // the below creates a new options object, using the parent filepath of the old options object and the path\n var newFileOptions = getConfig({ filename: getPath(path, options) }, options)\n // TODO: make sure properties are currectly copied over\n return handleCache(newFileOptions as FileOptions)\n}\n\nfunction renderFile (filename: string, data: DataObj, cb?: CallbackFn) {\n var Config: FileOptions = getConfig((data as PartialConfig) || {}) as FileOptions\n // TODO: make sure above doesn't error. We do set filename down below\n\n if (data.settings) {\n // Pull a few things from known locations\n if (data.settings.views) {\n Config.views = data.settings.views\n }\n if (data.settings['view cache']) {\n Config.cache = true\n }\n // Undocumented after Express 2, but still usable, esp. for\n // items that are unsafe to be passed along with data, like `root`\n var viewOpts = data.settings['view options']\n\n if (viewOpts) {\n copyProps(Config, viewOpts)\n }\n }\n\n Config.filename = filename // Make sure filename is right\n\n return tryHandleCache(Config, data, cb as CallbackFn)\n}\n\nexport { includeFile, renderFile }\n","import { includeFile } from './file-handlers'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig } from './config'\n\ninterface GenericData {\n [index: string]: any\n}\n\n/* END TYPES */\n\nexport function includeFileHelper (this: EtaConfig, path: string, data: GenericData): string {\n return includeFile(path, this)(data, this)\n}\n\n// export function extendsFileHelper(path: string, data: GenericData, config: EtaConfig): string {\n// var data: GenericData = content.params[1] || {}\n\n// data.content = content.exec()\n// for (var i = 0; i < blocks.length; i++) {\n// var currentBlock = blocks[i]\n// data[currentBlock.name] = currentBlock.exec()\n// }\n\n// return includeFile(content.params[0], config)(data, config)\n// }\n","import compile from './compile'\nimport { getConfig } from './config'\nimport { promiseImpl } from './utils'\nimport EtaErr from './err'\n\n/* TYPES */\n\nimport { EtaConfig, PartialConfig } from './config'\nimport { TemplateFunction } from './compile'\nimport { CallbackFn } from './file-handlers'\n\n/* END TYPES */\n\nfunction handleCache (template: string | TemplateFunction, options: EtaConfig): TemplateFunction {\n var templateFunc\n\n if (options.cache && options.name && options.templates.get(options.name)) {\n return options.templates.get(options.name)\n }\n\n if (typeof template === 'function') {\n templateFunc = template\n } else {\n templateFunc = compile(template, options)\n }\n\n if (options.cache && options.name) {\n options.templates.define(options.name, templateFunc)\n }\n\n return templateFunc\n}\n\nexport default function render (\n template: string | TemplateFunction,\n data: object,\n env?: PartialConfig,\n cb?: CallbackFn\n) {\n var options = getConfig(env || {})\n\n if (options.async) {\n var result\n if (!cb) {\n // No callback, try returning a promise\n if (typeof promiseImpl === 'function') {\n return new promiseImpl(function (resolve: Function, reject: Function) {\n try {\n result = handleCache(template, options)(data, options)\n resolve(result)\n } catch (err) {\n reject(err)\n }\n })\n } else {\n throw EtaErr(\"Please provide a callback function, this env doesn't support Promises\")\n }\n } else {\n try {\n handleCache(template, options)(data, options, cb)\n } catch (err) {\n return cb(err)\n }\n }\n } else {\n return handleCache(template, options)(data, options)\n }\n}\n","/* Export file stuff */\nimport { includeFileHelper } from './file-helpers'\nimport { defaultConfig } from './config'\n\n/* TYPES */\n\n/* END TYPES */\n\ndefaultConfig.includeFile = includeFileHelper\nincludeFileHelper.bind(defaultConfig)\n\nexport { renderFile, renderFile as __express } from './file-handlers'\nexport { loadFile } from './file-utils'\n\n/* End file stuff */\n\nexport { default as compileToString } from './compile-string'\nexport { default as compile } from './compile'\nexport { default as parse } from './parse'\nexport { default as render } from './render'\nexport { templates } from './containers'\nexport { defaultConfig, getConfig } from './config'\n"],"names":["Parse","Compile","handleCache"],"mappings":"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"} \ No newline at end of file diff --git a/dist/types/parse-old.d.ts b/dist/types/parse-old.d.ts new file mode 100644 index 0000000..4f22e0d --- /dev/null +++ b/dist/types/parse-old.d.ts @@ -0,0 +1,8 @@ +import { EtaConfig } from './config'; +export declare type TagType = 'r' | 'e' | 'i' | ''; +export interface TemplateObject { + t: TagType; + val: string; +} +export declare type AstObject = string | TemplateObject; +export default function parse(str: string, env: EtaConfig): Array; diff --git a/dist/types/parse-orig.d.ts b/dist/types/parse-orig.d.ts new file mode 100644 index 0000000..4f22e0d --- /dev/null +++ b/dist/types/parse-orig.d.ts @@ -0,0 +1,8 @@ +import { EtaConfig } from './config'; +export declare type TagType = 'r' | 'e' | 'i' | ''; +export interface TemplateObject { + t: TagType; + val: string; +} +export declare type AstObject = string | TemplateObject; +export default function parse(str: string, env: EtaConfig): Array; diff --git a/src/parse-old.ts b/src/parse-old.ts new file mode 100644 index 0000000..54520e3 --- /dev/null +++ b/src/parse-old.ts @@ -0,0 +1,98 @@ +import EtaErr, { ParseErr } from './err' +import { trimWS } from './utils' + +/* TYPES */ + +import { EtaConfig } from './config' + +export type TagType = 'r' | 'e' | 'i' | '' + +export interface TemplateObject { + t: TagType + val: string +} + +export type AstObject = string | TemplateObject + +/* END TYPES */ + +export default function parse (str: string, env: EtaConfig): Array { + var buffer: Array = [] + var trimLeftOfNextStr: string | false = false + var lastIndex = 0 + + function pushString (strng: string, shouldTrimRightOfString?: string | false) { + if (strng) { + // if string is truthy it must be of type 'string' + // replace \ with \\, ' with \' + var stringToPush = strng.replace(/\\|'/g, '\\$&') + + // TODO: benchmark replace( /(\\|')/g, '\\$1') + stringToPush = trimWS( + stringToPush, + env, + trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined + shouldTrimRightOfString + ) + + stringToPush = stringToPush.replace(/\n/g, '\\n').replace(/\r/g, '\\r') + + if (stringToPush) { + buffer.push(stringToPush) + } + } + } + + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|') + + var parseReg = new RegExp( + '([^]*?)' + + env.tags[0] + + '(-|_)?\\s*(' + + prefixes + + ')?\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + + env.tags[1], + 'g' + ) + + // TODO: benchmark having the \s* on either side vs using str.trim() + + var m + + while ((m = parseReg.exec(str)) !== null) { + lastIndex = m[0].length + m.index + var i = m.index + + var precedingString = m[1] + var wsLeft = m[2] + var prefix = m[3] || '' // by default either ~, =, or empty + var content = m[4] + + pushString(precedingString, wsLeft) + trimLeftOfNextStr = m[5] + + var currentType: TagType = '' + if (prefix === env.parse.exec) { + currentType = 'e' + } else if (prefix === env.parse.raw) { + currentType = 'r' + } else if (prefix === env.parse.interpolate) { + currentType = 'i' + } + + buffer.push({ t: currentType, val: content }) + } + + pushString(str.slice(lastIndex, str.length), false) + + if (env.plugins) { + for (var i = 0; i < env.plugins.length; i++) { + var plugin = env.plugins[i] + if (plugin.processAST) { + buffer = plugin.processAST(buffer, env) + } + } + } + + return buffer +} diff --git a/src/parse-orig.ts b/src/parse-orig.ts new file mode 100644 index 0000000..fe9ae70 --- /dev/null +++ b/src/parse-orig.ts @@ -0,0 +1,120 @@ +import { ParseErr } from './err' +import { trimWS } from './utils' + +/* TYPES */ + +import { EtaConfig } from './config' + +export type TagType = 'r' | 'e' | 'i' | '' + +export interface TemplateObject { + t: TagType + val: string +} + +export type AstObject = string | TemplateObject + +/* END TYPES */ + +export default function parse (str: string, env: EtaConfig): Array { + var buffer: Array = [] + + var tagCloseRegExp = new RegExp( + '\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"' + // matches strings + '|\\/\\*[^]*?\\*\\/|((-|_)?' + + env.tags[1] + + ')', + 'g' + ) + + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|') + + var tagOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\s*(' + prefixes + ')?', 'g') + var startInd = 0 + var trimLeftOfNextStr: string | false = false + + function pushString (strng: string, shouldTrimRightOfString?: string | false) { + if (strng) { + // if string is truthy it must be of type 'string' + // replace \ with \\, ' with \' + var stringToPush = strng.replace(/\\|'/g, '\\$&') + + // TODO: benchmark replace( /(\\|')/g, '\\$1') + stringToPush = trimWS( + stringToPush, + env, + trimLeftOfNextStr, // this will only be false on the first str, the next ones will be null or undefined + shouldTrimRightOfString + ) + + stringToPush = stringToPush.replace(/\n/g, '\\n').replace(/\r/g, '\\r') + + if (stringToPush) { + buffer.push(stringToPush) + } + } + } + + // Random TODO: parentObj.b doesn't need to have t: # + var tagOpenMatch + // tslint:disable-next-line:no-conditional-assignment + while ((tagOpenMatch = tagOpenReg.exec(str)) !== null) { + var precedingString = tagOpenMatch[1] + var shouldTrimRightOfString = tagOpenMatch[2] + var prefix = tagOpenMatch[3] || '' + + var currentType: TagType = '' + + if (prefix === env.parse.exec) { + currentType = 'e' + } else if (prefix === env.parse.raw) { + currentType = 'r' + } else if (prefix === env.parse.interpolate) { + currentType = 'i' + } + + pushString(precedingString, shouldTrimRightOfString) + startInd = tagOpenMatch.index + tagOpenMatch[0].length + + tagCloseRegExp.lastIndex = startInd + + var currentObj: TemplateObject | false = false + + var m + // tslint:disable-next-line:no-conditional-assignment + while ((m = tagCloseRegExp.exec(str)) !== null) { + if (m[1]) { + // tagClose, not a string or comment + var wsControl = m[2] + var i = m.index + + var val = str.slice(startInd, i).trim() + startInd = i + m[0].length + tagOpenReg.lastIndex = startInd + // console.log('tagClose: ' + startInd) + trimLeftOfNextStr = wsControl + currentObj = { t: currentType, val: val } + break + } + } + + if (currentObj) { + buffer.push(currentObj) + } else { + ParseErr('unclosed tag', str, startInd) + } + } + + pushString(str.slice(startInd, str.length), false) + + // console.log(JSON.stringify(buffer)) + if (env.plugins) { + for (var i = 0; i < env.plugins.length; i++) { + var plugin = env.plugins[i] + if (plugin.processAST) { + buffer = plugin.processAST(buffer, env) + } + } + } + return buffer // Return buffer +} diff --git a/src/parse.ts b/src/parse.ts index 8d772bb..aaa2256 100644 --- a/src/parse.ts +++ b/src/parse.ts @@ -43,63 +43,47 @@ export default function parse (str: string, env: EtaConfig): Array { } } - var prefixes = '' + var prefixes = (env.parse.exec + env.parse.interpolate + env.parse.raw).split('').join('|') - if (env.parse.exec) { - if (prefixes) { - prefixes += '|' - } - prefixes += env.parse.exec - } - if (env.parse.interpolate) { - if (prefixes) { - prefixes += '|' - } - prefixes += env.parse.interpolate - } - if (env.parse.raw) { - if (prefixes) { - prefixes += '|' - } - prefixes += env.parse.raw - } - - var parseReg = new RegExp( - '([^]*?)' + - env.tags[0] + - '(-|_)?\\s*(' + - prefixes + - ')?\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + + var parseOpenReg = new RegExp('([^]*?)' + env.tags[0] + '(-|_)?\\s*(' + prefixes + ')?', 'g') + var parseCloseReg = new RegExp( + '\\s*((?:[^]*?(?:\'(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r\'\\\\])*?\'|`(?:\\\\[\\s\\w"\'\\\\`]|[^\\\\`])*?`|"(?:\\\\[\\s\\w"\'\\\\`]|[^\\n\\r"\\\\])*?"|\\/\\*[^]*?\\*\\/)?)*?)\\s*(-|_)?' + env.tags[1], 'g' ) - // TODO: benchmark having the \s* on either side vs using str.trim() var m - while ((m = parseReg.exec(str)) !== null) { + while ((m = parseOpenReg.exec(str)) !== null) { lastIndex = m[0].length + m.index - var i = m.index var precedingString = m[1] var wsLeft = m[2] var prefix = m[3] || '' // by default either ~, =, or empty - var content = m[4] pushString(precedingString, wsLeft) - trimLeftOfNextStr = m[5] - - var currentType: TagType = '' - if (prefix === env.parse.exec) { - currentType = 'e' - } else if (prefix === env.parse.raw) { - currentType = 'r' - } else if (prefix === env.parse.interpolate) { - currentType = 'i' - } - buffer.push({ t: currentType, val: content }) + parseCloseReg.lastIndex = lastIndex + var closeTag = parseCloseReg.exec(str) + if (closeTag) { + var content = closeTag[1] + trimLeftOfNextStr = closeTag[2] + parseOpenReg.lastIndex = lastIndex = parseCloseReg.lastIndex + + var currentType: TagType = '' + if (prefix === env.parse.exec) { + currentType = 'e' + } else if (prefix === env.parse.raw) { + currentType = 'r' + } else if (prefix === env.parse.interpolate) { + currentType = 'i' + } + + buffer.push({ t: currentType, val: content }) + } else { + ParseErr('unclosed tag', str, lastIndex) + } } pushString(str.slice(lastIndex, str.length), false)