Skip to content

Commit

Permalink
Merge pull request #69 from eta-dev/chore-deno-fmt
Browse files Browse the repository at this point in the history
chore: deno fmt
  • Loading branch information
shadowtime2000 authored Dec 17, 2020
2 parents e73346f + 1a3416e commit e0fd2d7
Show file tree
Hide file tree
Showing 16 changed files with 547 additions and 448 deletions.
17 changes: 11 additions & 6 deletions deno_dist/browser.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
export { default as compileToString } from './compile-string.ts'
export { default as compile } from './compile.ts'
export { default as parse } from './parse.ts'
export { default as render, renderAsync } from './render.ts'
export { templates } from './containers.ts'
export { config, config as defaultConfig, getConfig, configure } from './config.ts'
export { default as compileToString } from "./compile-string.ts";
export { default as compile } from "./compile.ts";
export { default as parse } from "./parse.ts";
export { default as render, renderAsync } from "./render.ts";
export { templates } from "./containers.ts";
export {
config,
config as defaultConfig,
configure,
getConfig,
} from "./config.ts";
84 changes: 43 additions & 41 deletions deno_dist/compile-string.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import Parse from './parse.ts'
import Parse from "./parse.ts";

/* TYPES */

import type { EtaConfig } from './config.ts'
import type { AstObject } from './parse.ts'
import type { EtaConfig } from "./config.ts";
import type { AstObject } from "./parse.ts";

/* END TYPES */

Expand All @@ -18,38 +18,40 @@ import type { AstObject } from './parse.ts'
* ```
*/

export default function compileToString(str: string, config: EtaConfig): string {
const buffer: Array<AstObject> = Parse(str, config)

let res =
"var tR='',__l,__lP" +
(config.include ? ',include=E.include.bind(E)' : '') +
(config.includeFile ? ',includeFile=E.includeFile.bind(E)' : '') +
'\nfunction layout(p,d){__l=p;__lP=d}\n' +
(config.useWith ? 'with(' + config.varName + '||{}){' : '') +
export default function compileToString(
str: string,
config: EtaConfig,
): string {
const buffer: Array<AstObject> = Parse(str, config);

let res = "var tR='',__l,__lP" +
(config.include ? ",include=E.include.bind(E)" : "") +
(config.includeFile ? ",includeFile=E.includeFile.bind(E)" : "") +
"\nfunction layout(p,d){__l=p;__lP=d}\n" +
(config.useWith ? "with(" + config.varName + "||{}){" : "") +
compileScope(buffer, config) +
(config.includeFile
? 'if(__l)tR=' +
(config.async ? 'await ' : '') +
? "if(__l)tR=" +
(config.async ? "await " : "") +
`includeFile(__l,Object.assign(${config.varName},{body:tR},__lP))\n`
: config.include
? 'if(__l)tR=' +
(config.async ? 'await ' : '') +
? "if(__l)tR=" +
(config.async ? "await " : "") +
`include(__l,Object.assign(${config.varName},{body:tR},__lP))\n`
: '') +
'if(cb){cb(null,tR)} return tR' +
(config.useWith ? '}' : '')
: "") +
"if(cb){cb(null,tR)} return tR" +
(config.useWith ? "}" : "");

if (config.plugins) {
for (let i = 0; i < config.plugins.length; i++) {
const plugin = config.plugins[i]
const plugin = config.plugins[i];
if (plugin.processFnString) {
res = plugin.processFnString(res, config)
res = plugin.processFnString(res, config);
}
}
}

return res
return res;
}

/**
Expand All @@ -66,47 +68,47 @@ export default function compileToString(str: string, config: EtaConfig): string
*/

function compileScope(buff: Array<AstObject>, config: EtaConfig) {
let i = 0
const buffLength = buff.length
let returnStr = ''
let i = 0;
const buffLength = buff.length;
let returnStr = "";

for (i; i < buffLength; i++) {
const currentBlock = buff[i]
if (typeof currentBlock === 'string') {
const str = currentBlock
const currentBlock = buff[i];
if (typeof currentBlock === "string") {
const str = currentBlock;

// we know string exists
returnStr += "tR+='" + str + "'\n"
returnStr += "tR+='" + str + "'\n";
} else {
const type = currentBlock.t // ~, s, !, ?, r
let content = currentBlock.val || ''
const type = currentBlock.t; // ~, s, !, ?, r
let content = currentBlock.val || "";

if (type === 'r') {
if (type === "r") {
// raw

if (config.filter) {
content = 'E.filter(' + content + ')'
content = "E.filter(" + content + ")";
}

returnStr += 'tR+=' + content + '\n'
} else if (type === 'i') {
returnStr += "tR+=" + content + "\n";
} else if (type === "i") {
// interpolate

if (config.filter) {
content = 'E.filter(' + content + ')'
content = "E.filter(" + content + ")";
}

if (config.autoEscape) {
content = 'E.e(' + content + ')'
content = "E.e(" + content + ")";
}
returnStr += 'tR+=' + content + '\n'
returnStr += "tR+=" + content + "\n";
// reference
} else if (type === 'e') {
} else if (type === "e") {
// execute
returnStr += content + '\n' // you need a \n in case you have <% } %>
returnStr += content + "\n"; // you need a \n in case you have <% } %>
}
}
}

return returnStr
return returnStr;
}
51 changes: 30 additions & 21 deletions deno_dist/compile.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
import compileToString from './compile-string.ts'
import { getConfig } from './config.ts'
import EtaErr from './err.ts'
import compileToString from "./compile-string.ts";
import { getConfig } from "./config.ts";
import EtaErr from "./err.ts";

/* TYPES */

import type { EtaConfig, PartialConfig } from './config.ts'
import type { CallbackFn } from './file-handlers.ts'
import { getAsyncFunctionConstructor } from './polyfills.ts'
export type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn) => string
import type { EtaConfig, PartialConfig } from "./config.ts";
import type { CallbackFn } from "./file-handlers.ts";
import { getAsyncFunctionConstructor } from "./polyfills.ts";
export type TemplateFunction = (
data: object,
config: EtaConfig,
cb?: CallbackFn,
) => string;

/* END TYPES */

Expand All @@ -27,34 +31,39 @@ export type TemplateFunction = (data: object, config: EtaConfig, cb?: CallbackFn
* ```
*/

export default function compile(str: string, config?: PartialConfig): TemplateFunction {
const options: EtaConfig = getConfig(config || {})
export default function compile(
str: string,
config?: PartialConfig,
): TemplateFunction {
const options: EtaConfig = getConfig(config || {});

/* ASYNC HANDLING */
// The below code is modified from mde/ejs. All credit should go to them.
const ctor = options.async ? (getAsyncFunctionConstructor() as FunctionConstructor) : Function
const ctor = options.async
? (getAsyncFunctionConstructor() as FunctionConstructor)
: Function;
/* END ASYNC HANDLING */

try {
return new ctor(
options.varName,
'E', // EtaConfig
'cb', // optional callback
compileToString(str, options)
) as TemplateFunction // eslint-disable-line no-new-func
"E", // EtaConfig
"cb", // optional callback
compileToString(str, options),
) as TemplateFunction; // eslint-disable-line no-new-func
} catch (e) {
if (e instanceof SyntaxError) {
throw EtaErr(
'Bad template syntax\n\n' +
"Bad template syntax\n\n" +
e.message +
'\n' +
Array(e.message.length + 1).join('=') +
'\n' +
"\n" +
Array(e.message.length + 1).join("=") +
"\n" +
compileToString(str, options) +
'\n' // This will put an extra newline before the callstack for extra readability
)
"\n", // This will put an extra newline before the callstack for extra readability
);
} else {
throw e
throw e;
}
}
}
Loading

0 comments on commit e0fd2d7

Please sign in to comment.