summaryrefslogtreecommitdiffstats
path: root/lib/templating/renderFile.js
diff options
context:
space:
mode:
authorSamy Pessé <samypesse@gmail.com>2016-04-25 15:36:18 +0200
committerSamy Pessé <samypesse@gmail.com>2016-04-25 15:36:18 +0200
commit0c2dc06cb721a437480d5a10611511b8f84b00a8 (patch)
treefd944c625c0eebd1f5f39770d58abe8aa8b5d447 /lib/templating/renderFile.js
parent4552ccd7d76a1bf958481e24a695dd3b68e6c232 (diff)
downloadgitbook-0c2dc06cb721a437480d5a10611511b8f84b00a8.zip
gitbook-0c2dc06cb721a437480d5a10611511b8f84b00a8.tar.gz
gitbook-0c2dc06cb721a437480d5a10611511b8f84b00a8.tar.bz2
Fix resolution of theme's templates
Diffstat (limited to 'lib/templating/renderFile.js')
-rw-r--r--lib/templating/renderFile.js37
1 files changed, 24 insertions, 13 deletions
diff --git a/lib/templating/renderFile.js b/lib/templating/renderFile.js
index 13a9c5b..9b74e5b 100644
--- a/lib/templating/renderFile.js
+++ b/lib/templating/renderFile.js
@@ -1,27 +1,38 @@
var Promise = require('../utils/promise');
-
-var replaceShortcuts = require('./replaceShortcuts');
+var error = require('../utils/error');
+var render = require('./render');
/**
Render a template
@param {TemplateEngine} engine
@param {String} filePath
- @param {String} content
- @param {Object} ctx
+ @param {Object} context
@return {Promise<String>}
*/
-function renderTemplateFile(engine, filePath, content, context) {
- context = context || {};
- var env = engine.toNunjucks();
+function renderTemplateFile(engine, filePath, context) {
+ var loader = engine.getLoader();
+
+ return Promise()
+ .then(function() {
+ if (!loader.async) {
+ return loader.getSource(filePath);
+ }
+
+ var deferred = Promise.defer();
+ loader.getSource(filePath, deferred.makeNodeResolver());
+ return deferred.promise;
+ })
+ .then(function(result) {
+ if (!result) {
+ throw error.TemplateError(new Error('Not found'), {
+ filename: filePath
+ });
+ }
- content = replaceShortcuts(engine, filePath, content);
+ return render(engine, result.path, result.src, context);
+ });
- return Promise.nfcall(
- env.render.bind(env),
- content,
- context
- );
}
module.exports = renderTemplateFile;