Comparing version 0.7.2 to 0.8.0
26
ejs.js
@@ -0,1 +1,2 @@ | ||
ejs = (function(){ | ||
@@ -54,3 +55,3 @@ // CommonJS require() | ||
* EJS | ||
* Copyright(c) 2010 TJ Holowaychuk <tj@vision-media.ca> | ||
* Copyright(c) 2012 TJ Holowaychuk <tj@vision-media.ca> | ||
* MIT Licensed | ||
@@ -70,3 +71,3 @@ */ | ||
exports.version = '0.6.1'; | ||
exports.version = '0.7.2'; | ||
@@ -173,2 +174,3 @@ /** | ||
var consumeEOL = false; | ||
for (var i = 0, len = str.length; i < len; ++i) { | ||
@@ -199,3 +201,8 @@ if (str.slice(i, open.length + i) == open) { | ||
, n = 0; | ||
if ('-' == js[js.length-1]){ | ||
js = js.substring(0, js.length - 2); | ||
consumeEOL = true; | ||
} | ||
while (~(n = js.indexOf("\n", n))) n++, lineno++; | ||
@@ -213,4 +220,8 @@ if (js.substr(0, 1) == ':') js = filtered(js); | ||
} else if (str.substr(i, 1) == "\n") { | ||
buf.push("\\n"); | ||
lineno++; | ||
if (consumeEOL) { | ||
consumeEOL = false; | ||
} else { | ||
buf.push("\\n"); | ||
lineno++; | ||
} | ||
} else { | ||
@@ -317,3 +328,3 @@ buf.push(str.substr(i, 1)); | ||
var str = options.cache | ||
? exports.cache[key] || (exports.cache[key] = fs.readFileSync(path, 'utf8')) | ||
? cache[key] || (cache[key] = fs.readFileSync(path, 'utf8')) | ||
: fs.readFileSync(path, 'utf8'); | ||
@@ -574,1 +585,4 @@ | ||
}); // module: utils.js | ||
return require("ejs"); | ||
})(); |
@@ -1,2 +0,1 @@ | ||
// CommonJS require() | ||
function require(p){if("fs"==p)return{};var path=require.resolve(p),mod=require.modules[path];if(!mod)throw new Error('failed to require "'+p+'"');mod.exports||(mod.exports={},mod.call(mod.exports,mod,mod.exports,require.relative(path)));return mod.exports}require.modules={},require.resolve=function(path){var orig=path,reg=path+".js",index=path+"/index.js";return require.modules[reg]&®||require.modules[index]&&index||orig},require.register=function(path,fn){require.modules[path]=fn},require.relative=function(parent){return function(p){if("."!=p.substr(0,1))return require(p);var path=parent.split("/"),segs=p.split("/");path.pop();for(var i=0;i<segs.length;i++){var seg=segs[i];".."==seg?path.pop():"."!=seg&&path.push(seg)}return require(path.join("/"))}},require.register("ejs.js",function(module,exports,require){var utils=require("./utils"),fs=require("fs");exports.version="0.6.1";var filters=exports.filters=require("./filters"),cache={};exports.clearCache=function(){cache={}};function filtered(js){return js.substr(1).split("|").reduce(function(js,filter){var parts=filter.split(":"),name=parts.shift(),args=parts.shift()||"";args&&(args=", "+args);return"filters."+name+"("+js+args+")"})}function rethrow(err,str,filename,lineno){var lines=str.split("\n"),start=Math.max(lineno-3,0),end=Math.min(lines.length,lineno+3),context=lines.slice(start,end).map(function(line,i){var curr=i+start+1;return(curr==lineno?" >> ":" ")+curr+"| "+line}).join("\n");err.path=filename,err.message=(filename||"ejs")+":"+lineno+"\n"+context+"\n\n"+err.message;throw err}var parse=exports.parse=function(str,options){var options=options||{},open=options.open||exports.open||"<%",close=options.close||exports.close||"%>",buf=["var buf = [];","\nwith (locals) {","\n buf.push('"],lineno=1;for(var i=0,len=str.length;i<len;++i)if(str.slice(i,open.length+i)==open){i+=open.length;var prefix,postfix,line="__stack.lineno="+lineno;switch(str.substr(i,1)){case"=":prefix="', escape(("+line+", ",postfix=")), '",++i;break;case"-":prefix="', ("+line+", ",postfix="), '",++i;break;default:prefix="');"+line+";",postfix="; buf.push('"}var end=str.indexOf(close,i),js=str.substring(i,end),start=i,n=0;while(~(n=js.indexOf("\n",n)))n++,lineno++;js.substr(0,1)==":"&&(js=filtered(js)),buf.push(prefix,js,postfix),i+=end-start+close.length-1}else str.substr(i,1)=="\\"?buf.push("\\\\"):str.substr(i,1)=="'"?buf.push("\\'"):str.substr(i,1)=="\r"?buf.push(" "):str.substr(i,1)=="\n"?(buf.push("\\n"),lineno++):buf.push(str.substr(i,1));buf.push("');\n}\nreturn buf.join('');");return buf.join("")},compile=exports.compile=function(str,options){options=options||{};var input=JSON.stringify(str),filename=options.filename?JSON.stringify(options.filename):"undefined";str=["var __stack = { lineno: 1, input: "+input+", filename: "+filename+" };",rethrow.toString(),"try {",exports.parse(str,options),"} catch (err) {"," rethrow(err, __stack.input, __stack.filename, __stack.lineno);","}"].join("\n"),options.debug&&console.log(str);var fn=new Function("locals, filters, escape",str);return function(locals){return fn.call(this,locals,filters,utils.escape)}};exports.render=function(str,options){var fn,options=options||{};if(options.cache)if(options.filename)fn=cache[options.filename]||(cache[options.filename]=compile(str,options));else throw new Error('"cache" option requires "filename".');else fn=compile(str,options);options.__proto__=options.locals;return fn.call(options.scope,options)},exports.renderFile=function(path,options,fn){var key=path+":string";"function"==typeof options&&(fn=options,options={}),options.filename=path;try{var str=options.cache?exports.cache[key]||(exports.cache[key]=fs.readFileSync(path,"utf8")):fs.readFileSync(path,"utf8");fn(null,exports.render(str,options))}catch(err){fn(err)}},exports.__express=exports.renderFile,require.extensions?require.extensions[".ejs"]=function(module,filename){source=require("fs").readFileSync(filename,"utf-8"),module._compile(compile(source,{}),filename)}:require.registerExtension&&require.registerExtension(".ejs",function(src){return compile(src,{})})}),require.register("filters.js",function(module,exports,require){exports.first=function(obj){return obj[0]},exports.last=function(obj){return obj[obj.length-1]},exports.capitalize=function(str){str=String(str);return str[0].toUpperCase()+str.substr(1,str.length)},exports.downcase=function(str){return String(str).toLowerCase()},exports.upcase=function(str){return String(str).toUpperCase()},exports.sort=function(obj){return Object.create(obj).sort()},exports.sort_by=function(obj,prop){return Object.create(obj).sort(function(a,b){a=a[prop],b=b[prop];if(a>b)return 1;if(a<b)return-1;return 0})},exports.size=exports.length=function(obj){return obj.length},exports.plus=function(a,b){return Number(a)+Number(b)},exports.minus=function(a,b){return Number(a)-Number(b)},exports.times=function(a,b){return Number(a)*Number(b)},exports.divided_by=function(a,b){return Number(a)/Number(b)},exports.join=function(obj,str){return obj.join(str||", ")},exports.truncate=function(str,len){str=String(str);return str.substr(0,len)},exports.truncate_words=function(str,n){var str=String(str),words=str.split(/ +/);return words.slice(0,n).join(" ")},exports.replace=function(str,pattern,substitution){return String(str).replace(pattern,substitution||"")},exports.prepend=function(obj,val){return Array.isArray(obj)?[val].concat(obj):val+obj},exports.append=function(obj,val){return Array.isArray(obj)?obj.concat(val):obj+val},exports.map=function(arr,prop){return arr.map(function(obj){return obj[prop]})},exports.reverse=function(obj){return Array.isArray(obj)?obj.reverse():String(obj).split("").reverse().join("")},exports.get=function(obj,prop){return obj[prop]},exports.json=function(obj){return JSON.stringify(obj)}}),require.register("utils.js",function(module,exports,require){exports.escape=function(html){return String(html).replace(/&(?!\w+;)/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}}) | ||
ejs=function(){function require(p){if("fs"==p)return{};var path=require.resolve(p),mod=require.modules[path];if(!mod)throw new Error('failed to require "'+p+'"');return mod.exports||(mod.exports={},mod.call(mod.exports,mod,mod.exports,require.relative(path))),mod.exports}return require.modules={},require.resolve=function(path){var orig=path,reg=path+".js",index=path+"/index.js";return require.modules[reg]&®||require.modules[index]&&index||orig},require.register=function(path,fn){require.modules[path]=fn},require.relative=function(parent){return function(p){if("."!=p.substr(0,1))return require(p);var path=parent.split("/"),segs=p.split("/");path.pop();for(var i=0;i<segs.length;i++){var seg=segs[i];".."==seg?path.pop():"."!=seg&&path.push(seg)}return require(path.join("/"))}},require.register("ejs.js",function(module,exports,require){var utils=require("./utils"),fs=require("fs");exports.version="0.7.2";var filters=exports.filters=require("./filters"),cache={};exports.clearCache=function(){cache={}};function filtered(js){return js.substr(1).split("|").reduce(function(js,filter){var parts=filter.split(":"),name=parts.shift(),args=parts.shift()||"";return args&&(args=", "+args),"filters."+name+"("+js+args+")"})}function rethrow(err,str,filename,lineno){var lines=str.split("\n"),start=Math.max(lineno-3,0),end=Math.min(lines.length,lineno+3),context=lines.slice(start,end).map(function(line,i){var curr=i+start+1;return(curr==lineno?" >> ":" ")+curr+"| "+line}).join("\n");throw err.path=filename,err.message=(filename||"ejs")+":"+lineno+"\n"+context+"\n\n"+err.message,err}var parse=exports.parse=function(str,options){var options=options||{},open=options.open||exports.open||"<%",close=options.close||exports.close||"%>",buf=["var buf = [];","\nwith (locals) {","\n buf.push('"],lineno=1,consumeEOL=!1;for(var i=0,len=str.length;i<len;++i)if(str.slice(i,open.length+i)==open){i+=open.length;var prefix,postfix,line="__stack.lineno="+lineno;switch(str.substr(i,1)){case"=":prefix="', escape(("+line+", ",postfix=")), '",++i;break;case"-":prefix="', ("+line+", ",postfix="), '",++i;break;default:prefix="');"+line+";",postfix="; buf.push('"}var end=str.indexOf(close,i),js=str.substring(i,end),start=i,n=0;"-"==js[js.length-1]&&(js=js.substring(0,js.length-2),consumeEOL=!0);while(~(n=js.indexOf("\n",n)))n++,lineno++;js.substr(0,1)==":"&&(js=filtered(js)),buf.push(prefix,js,postfix),i+=end-start+close.length-1}else str.substr(i,1)=="\\"?buf.push("\\\\"):str.substr(i,1)=="'"?buf.push("\\'"):str.substr(i,1)=="\r"?buf.push(" "):str.substr(i,1)=="\n"?consumeEOL?consumeEOL=!1:(buf.push("\\n"),lineno++):buf.push(str.substr(i,1));return buf.push("');\n}\nreturn buf.join('');"),buf.join("")},compile=exports.compile=function(str,options){options=options||{};var input=JSON.stringify(str),filename=options.filename?JSON.stringify(options.filename):"undefined";str=["var __stack = { lineno: 1, input: "+input+", filename: "+filename+" };",rethrow.toString(),"try {",exports.parse(str,options),"} catch (err) {"," rethrow(err, __stack.input, __stack.filename, __stack.lineno);","}"].join("\n"),options.debug&&console.log(str);var fn=new Function("locals, filters, escape",str);return function(locals){return fn.call(this,locals,filters,utils.escape)}};exports.render=function(str,options){var fn,options=options||{};if(options.cache){if(!options.filename)throw new Error('"cache" option requires "filename".');fn=cache[options.filename]||(cache[options.filename]=compile(str,options))}else fn=compile(str,options);return options.__proto__=options.locals,fn.call(options.scope,options)},exports.renderFile=function(path,options,fn){var key=path+":string";"function"==typeof options&&(fn=options,options={}),options.filename=path;try{var str=options.cache?cache[key]||(cache[key]=fs.readFileSync(path,"utf8")):fs.readFileSync(path,"utf8");fn(null,exports.render(str,options))}catch(err){fn(err)}},exports.__express=exports.renderFile,require.extensions?require.extensions[".ejs"]=function(module,filename){source=require("fs").readFileSync(filename,"utf-8"),module._compile(compile(source,{}),filename)}:require.registerExtension&&require.registerExtension(".ejs",function(src){return compile(src,{})})}),require.register("filters.js",function(module,exports,require){exports.first=function(obj){return obj[0]},exports.last=function(obj){return obj[obj.length-1]},exports.capitalize=function(str){return str=String(str),str[0].toUpperCase()+str.substr(1,str.length)},exports.downcase=function(str){return String(str).toLowerCase()},exports.upcase=function(str){return String(str).toUpperCase()},exports.sort=function(obj){return Object.create(obj).sort()},exports.sort_by=function(obj,prop){return Object.create(obj).sort(function(a,b){return a=a[prop],b=b[prop],a>b?1:a<b?-1:0})},exports.size=exports.length=function(obj){return obj.length},exports.plus=function(a,b){return Number(a)+Number(b)},exports.minus=function(a,b){return Number(a)-Number(b)},exports.times=function(a,b){return Number(a)*Number(b)},exports.divided_by=function(a,b){return Number(a)/Number(b)},exports.join=function(obj,str){return obj.join(str||", ")},exports.truncate=function(str,len){return str=String(str),str.substr(0,len)},exports.truncate_words=function(str,n){var str=String(str),words=str.split(/ +/);return words.slice(0,n).join(" ")},exports.replace=function(str,pattern,substitution){return String(str).replace(pattern,substitution||"")},exports.prepend=function(obj,val){return Array.isArray(obj)?[val].concat(obj):val+obj},exports.append=function(obj,val){return Array.isArray(obj)?obj.concat(val):obj+val},exports.map=function(arr,prop){return arr.map(function(obj){return obj[prop]})},exports.reverse=function(obj){return Array.isArray(obj)?obj.reverse():String(obj).split("").reverse().join("")},exports.get=function(obj,prop){return obj[prop]},exports.json=function(obj){return JSON.stringify(obj)}}),require.register("utils.js",function(module,exports,require){exports.escape=function(html){return String(html).replace(/&(?!\w+;)/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}}),require("ejs")}(); |
0.8.0 / 2012-07-25 | ||
================== | ||
* add `<% include file %>` support | ||
* fix wrapping of custom require in build step. Closes #57 | ||
0.7.3 / 2012-04-25 | ||
@@ -3,0 +9,0 @@ ================== |
@@ -13,11 +13,11 @@ | ||
var utils = require('./utils') | ||
, fs = require('fs'); | ||
, path = require('path') | ||
, basename = path.basename | ||
, dirname = path.dirname | ||
, extname = path.extname | ||
, join = path.join | ||
, fs = require('fs') | ||
, read = fs.readFileSync; | ||
/** | ||
* Library version. | ||
*/ | ||
exports.version = '0.7.2'; | ||
/** | ||
* Filters. | ||
@@ -112,10 +112,10 @@ * | ||
, open = options.open || exports.open || '<%' | ||
, close = options.close || exports.close || '%>'; | ||
, close = options.close || exports.close || '%>' | ||
, filename = options.filename | ||
, buf = []; | ||
var buf = [ | ||
"var buf = [];" | ||
, "\nwith (locals) {" | ||
, "\n buf.push('" | ||
]; | ||
buf.push('var buf = [];'); | ||
if (false !== options._with) buf.push('\nwith (locals) {'); | ||
buf.push('\n buf.push(\''); | ||
var lineno = 1; | ||
@@ -148,4 +148,5 @@ | ||
, start = i | ||
, include = null | ||
, n = 0; | ||
if ('-' == js[js.length-1]){ | ||
@@ -155,6 +156,16 @@ js = js.substring(0, js.length - 2); | ||
} | ||
if (0 == js.trim().indexOf('include')) { | ||
var name = js.trim().slice(7).trim(); | ||
if (!filename) throw new Error('filename option is required for includes'); | ||
var path = resolveInclude(name, filename); | ||
include = read(path, 'utf8'); | ||
include = exports.parse(include, { filename: path, _with: false }); | ||
buf.push("' + (function(){" + include + "})() + '"); | ||
js = ''; | ||
} | ||
while (~(n = js.indexOf("\n", n))) n++, lineno++; | ||
if (js.substr(0, 1) == ':') js = filtered(js); | ||
buf.push(prefix, js, postfix); | ||
if (js) buf.push(prefix, js, postfix); | ||
i += end - start + close.length - 1; | ||
@@ -180,3 +191,5 @@ | ||
buf.push("');\n}\nreturn buf.join('');"); | ||
if (false !== options._with) buf.push("');\n}\nreturn buf.join('');") | ||
else buf.push("');\nreturn buf.join('');"); | ||
return buf.join(''); | ||
@@ -214,5 +227,6 @@ }; | ||
if (options.debug) console.log(str); | ||
var fn = new Function('locals, filters, escape', str); | ||
return function(locals){ | ||
return fn.call(this, locals, filters, utils.escape); | ||
return fn.call(this, locals || {}, filters, utils.escape); | ||
} | ||
@@ -278,4 +292,4 @@ }; | ||
var str = options.cache | ||
? cache[key] || (cache[key] = fs.readFileSync(path, 'utf8')) | ||
: fs.readFileSync(path, 'utf8'); | ||
? cache[key] || (cache[key] = read(path, 'utf8')) | ||
: read(path, 'utf8'); | ||
@@ -288,2 +302,18 @@ fn(null, exports.render(str, options)); | ||
/** | ||
* Resolve include `name` relative to `filename`. | ||
* | ||
* @param {String} name | ||
* @param {String} filename | ||
* @return {String} | ||
* @api private | ||
*/ | ||
function resolveInclude(name, filename) { | ||
var path = join(dirname(filename), name); | ||
var ext = extname(name); | ||
if (!ext) path += '.ejs'; | ||
return path; | ||
} | ||
// express support | ||
@@ -290,0 +320,0 @@ |
{ | ||
"name": "ejs", | ||
"description": "Embedded JavaScript templates", | ||
"version": "0.7.2", | ||
"version": "0.8.0", | ||
"author": "TJ Holowaychuk <tj@vision-media.ca>", | ||
"keywords": ["template", "engine", "ejs"], | ||
"devDependencies": { | ||
"mocha": "*" | ||
"mocha": "*", | ||
"should": "*" | ||
}, | ||
@@ -10,0 +11,0 @@ "main": "./lib/ejs.js", |
@@ -19,2 +19,3 @@ | ||
* Filter support for designer-friendly templates | ||
* Includes | ||
* Client-side support | ||
@@ -47,6 +48,22 @@ * Newline slurping with `<% code -%>` or `<% -%>` or `<%= code -%>` or `<%- code -%>` | ||
## Custom tags | ||
## Includes | ||
Custom tags can also be applied globally: | ||
Includes are relative to the template with the `include` statement, | ||
for example if you have "./views/users.ejs" and "./views/user/show.ejs" | ||
you would use `<% include user/show %>`. The included file(s) are literally | ||
included into the template, _no_ IO is performed after compilation, thus | ||
local variables are available to these included templates. | ||
``` | ||
<ul> | ||
<% users.forEach(function(user){ %> | ||
<% include user/show %> | ||
<% }) %> | ||
</ul> | ||
``` | ||
## Custom delimiters | ||
Custom delimiters can also be applied globally: | ||
var ejs = require('ejs'); | ||
@@ -53,0 +70,0 @@ ejs.open = '{{'; |
@@ -91,2 +91,3 @@ | ||
var buf = ''; | ||
buf += 'ejs = (function(){\n'; | ||
buf += '\n// CommonJS require()\n\n'; | ||
@@ -105,2 +106,3 @@ buf += browser.require + '\n\n'; | ||
}); | ||
buf += '\n return require("ejs");\n})();'; | ||
fs.writeFile('ejs.js', buf, function(err){ | ||
@@ -107,0 +109,0 @@ if (err) throw err; |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Non-existent author
Supply chain riskThe package was published by an npm account that no longer exists.
Found 1 instance in 1 package
44
169
47396
2
1239
1
22