diff options
author | Samy Pesse <samypesse@gmail.com> | 2016-02-11 17:30:58 +0100 |
---|---|---|
committer | Samy Pesse <samypesse@gmail.com> | 2016-02-11 17:30:58 +0100 |
commit | 98a13cf487e3b2823cfde38ab1d1b8f97f614517 (patch) | |
tree | 81d07c7095822867ba180a79e9a5b1343d81de0e /lib/template | |
parent | 7f9aa214a412f3d173ac52042bd7250aacda6143 (diff) | |
download | gitbook-98a13cf487e3b2823cfde38ab1d1b8f97f614517.zip gitbook-98a13cf487e3b2823cfde38ab1d1b8f97f614517.tar.gz gitbook-98a13cf487e3b2823cfde38ab1d1b8f97f614517.tar.bz2 |
Add conrefs loader for nunjucks
Diffstat (limited to 'lib/template')
-rw-r--r-- | lib/template/index.js | 13 | ||||
-rw-r--r-- | lib/template/loader.js | 75 |
2 files changed, 88 insertions, 0 deletions
diff --git a/lib/template/index.js b/lib/template/index.js index 833ff76..a3021e6 100644 --- a/lib/template/index.js +++ b/lib/template/index.js @@ -7,6 +7,7 @@ var Promise = require('../utils/promise'); var error = require('../utils/error'); var gitbook = require('../gitbook'); var defaultBlocks = require('./blocks'); +var Loader = require('./loader'); // Return extension name for a specific block function blockExtName(name) { @@ -23,6 +24,10 @@ function TemplateEngine(book) { this.book = book; this.log = book.log; + // Create file loader + this.loader = new Loader(this); + + // Create nunjucks instance this.env = new nunjucks.Environment( this.loader, { @@ -57,6 +62,14 @@ function TemplateEngine(book) { this.addBlocks(defaultBlocks); } +// Interpolate a string content to replace shortcuts according to the filetype +TemplateEngine.prototype.interpolate = function(filepath, source) { + var parser = parsers.get(path.extname(filepath)); + var type = parser? parser.name : null; + + return this.applyShortcuts(type, source); +}; + // Add a new custom filter TemplateEngine.prototype.addFilter = function(filterName, func) { try { diff --git a/lib/template/loader.js b/lib/template/loader.js index e69de29..23ffb77 100644 --- a/lib/template/loader.js +++ b/lib/template/loader.js @@ -0,0 +1,75 @@ +var path = require('path'); +var nunjucks = require('nunjucks'); + +var Git = require('../utils/git'); +var pathUtil = require('../utils/path'); + +// The loader should handle relative and git url +var Loader = nunjucks.Loader.extend({ + async: true, + + init: function(engine, opts) { + this.engine = engine; + this.book = engine.book; + this.fs = engine.book.fs; + + this.git = new Git(this.fs.tmpdir()); + }, + + getSource: function(soureURL, callback) { + var that = this; + + this.git.resolveFile(soureURL) + .then(function(filepath) { + // Is local file + if (!filepath) { + filepath = that.book.resolve(soureURL); + } else { + that.book.log.debug.ln('resolve from git', soureURL, 'to', filepath); + } + + // Read file from absolute path + return that.fs.readAsString(filepath) + .then(function(source) { + return that.engine.interpolate(filepath, source); + }) + .then(function(source) { + return { + src: source, + path: filepath, + + // We disable cache since content is modified (shortcuts, ...) + noCache: true + }; + }); + }) + .nodeify(callback); + }, + + resolve: function(from, to) { + // If origin is in the book, we enforce result file to be in the book + if (this.book.isInBook(from)) { + return this.book.resolve( + this.book.relative(path.dirname(from)), + to + ); + } + + // If origin is in a git repository, we resolve file in the git repository + var gitRoot = this.git.resolveRoot(from); + if (gitRoot) { + return pathUtil.resolveInRoot(gitRoot, to); + } + + // If origin is not in the book (include from a git content ref) + return path.resolve(path.dirname(from), to); + }, + + // Handle all files as relative, so that nunjucks pass responsability to 'resolve' + // Only git urls are considered as absolute + isRelative: function(filename) { + return !Git.isUrl(filename); + } +}); + +module.exports = Loader; |