summaryrefslogtreecommitdiffstats
path: root/lib/parse/include.js
diff options
context:
space:
mode:
authorcodepiano <codepiano.li@gmail.com>2014-11-02 01:34:28 +0800
committercodepiano <codepiano.li@gmail.com>2014-11-02 01:34:28 +0800
commit1502d65286eb36a76b8d0016f7bad64b9bf9f39f (patch)
treef954a62a351413faef03818b49d92a6312d5e4df /lib/parse/include.js
parent9da10e2b25cb8ad919bb8563cfdc81d9e0612341 (diff)
parent0feb672d708e2d73ee159d5a94b614f90c85e9e2 (diff)
downloadgitbook-1502d65286eb36a76b8d0016f7bad64b9bf9f39f.zip
gitbook-1502d65286eb36a76b8d0016f7bad64b9bf9f39f.tar.gz
gitbook-1502d65286eb36a76b8d0016f7bad64b9bf9f39f.tar.bz2
Merge branch 'master' of github.com:GitbookIO/gitbook into fork
Conflicts: lib/parse/page.js
Diffstat (limited to 'lib/parse/include.js')
-rw-r--r--lib/parse/include.js42
1 files changed, 3 insertions, 39 deletions
diff --git a/lib/parse/include.js b/lib/parse/include.js
index 5fba2be..483b184 100644
--- a/lib/parse/include.js
+++ b/lib/parse/include.js
@@ -1,48 +1,12 @@
var _ = require('lodash');
-var fs = require('graceful-fs');
-var path = require('path');
-
-
-// Include helper
-function importInclude(name, paths) {
- return paths
- .map(function(folder) {
- // Try including snippet from FS
- try {
- var fname = path.join(folder, name);
- // Trim trailing newlines/space of imported snippets
- return fs.readFileSync(fname, 'utf8').trimRight();
- } catch(err) {}
- })
- .filter(Boolean)[0];
-}
-
-function includer(ctx, folders) {
- return function(key) {
- key = key.trim();
- return ctx[key] || importInclude(key, folders);
- };
-}
-
-module.exports = function(markdown, folder, ctx) {
- // List of folders to search for includes
- var folders = [];
-
- // Handle folder arg (string or array)
- if(_.isString(folder)) {
- folders = [folder];
- } else if(_.isArray(folder)) {
- folders = folder;
- }
-
- // variable context
- ctx = ctx || {};
+module.exports = function(markdown, includer) {
// Memoized include function (to cache lookups)
- var _include = _.memoize(includer(ctx, folders));
+ var _include = _.memoize(includer);
return markdown.replace(/{{([\s\S]+?)}}/g, function(match, key) {
// If fails leave content as is
+ key = key.trim();
return _include(key) || match;
});
};