|
1 | | -var ff = require('ff'); |
| 1 | +var path = require('path'); |
2 | 2 | var Promise = require('bluebird'); |
3 | 3 | var api = require('../../api'); |
| 4 | +var DirectoryBuilder = require('../DirectoryBuilder'); |
| 5 | +var fs = require('fs'); |
| 6 | + |
| 7 | +var readDir = Promise.promisify(fs.readdir); |
| 8 | +var stat = Promise.promisify(fs.stat); |
4 | 9 |
|
5 | 10 | exports.getDependencies = function (app, config, cb) { |
6 | 11 | app.reloadModules(); |
7 | 12 |
|
8 | 13 | // allows modules to disable other modules |
9 | | - executeHook('getDependencies', app, config, cb); |
10 | | -} |
| 14 | + executeHook('getDependencies', app, config) |
| 15 | + .nodeify(cb); |
| 16 | +}; |
11 | 17 |
|
12 | 18 | exports.onBeforeBuild = function (app, config, cb) { |
13 | | - executeHook('onBeforeBuild', app, config, cb); |
14 | | -} |
| 19 | + executeHook('onBeforeBuild', app, config) |
| 20 | + .nodeify(cb); |
| 21 | +}; |
15 | 22 |
|
16 | 23 | exports.onAfterBuild = function (app, config, cb) { |
17 | | - executeHook('onAfterBuild', app, config, cb); |
18 | | -} |
| 24 | + executeHook('onAfterBuild', app, config) |
| 25 | + .nodeify(cb); |
| 26 | +}; |
| 27 | + |
| 28 | +exports.getResourceDirectories = function (app, config, cb) { |
| 29 | + var builder = new DirectoryBuilder(app.paths.root); |
| 30 | + builder.add('resources'); |
| 31 | + executeHook('getResourceDirectories', app, config) |
| 32 | + .map(function (res) { |
| 33 | + var module = res.module; |
| 34 | + var directories = res.data; |
| 35 | + directories.forEach(function (directory) { |
| 36 | + var target = path.join('modules', module.name, directory.target); |
| 37 | + builder.add(directory.src, target); |
| 38 | + }); |
| 39 | + console.log(res); |
| 40 | + }) |
| 41 | + .then(function () { |
| 42 | + // add any localized resource directories |
| 43 | + return readDir(app.paths.root); |
| 44 | + }) |
| 45 | + .filter(function (filename) { |
| 46 | + if (/^resources-/.test(filename)) { |
| 47 | + return stat(path.join(app.paths.root, filename)).then(function (info) { |
| 48 | + return info.isDirectory(); |
| 49 | + }, function onStatFail() { |
| 50 | + return false; |
| 51 | + }); |
| 52 | + } |
| 53 | + |
| 54 | + return false; |
| 55 | + }) |
| 56 | + .map(function (filename) { |
| 57 | + builder.add(filename); |
| 58 | + }) |
| 59 | + .then(function () { |
| 60 | + return builder.getDirectories(); |
| 61 | + }) |
| 62 | + .nodeify(cb); |
| 63 | +}; |
19 | 64 |
|
20 | | -function executeHook(buildHook, app, config, cb) { |
| 65 | +function executeHook(buildHook, app, config) { |
21 | 66 | var modules = app.getModules(); |
22 | 67 |
|
23 | | - Promise.all(Object.keys(modules).map(function (moduleName) { |
24 | | - var module = modules[moduleName]; |
25 | | - var buildExtension = module.loadExtension('build'); |
26 | | - if (!buildExtension || !buildExtension[buildHook]) { |
27 | | - return; |
28 | | - } |
| 68 | + return Promise.resolve(Object.keys(modules)) |
| 69 | + .map(function (moduleName) { |
| 70 | + var module = modules[moduleName]; |
| 71 | + var buildExtension = module.loadExtension('build'); |
| 72 | + if (!buildExtension || !buildExtension[buildHook]) { |
| 73 | + return; |
| 74 | + } |
| 75 | + return new Promise(function (resolve, reject) { |
| 76 | + var retVal = buildExtension[buildHook](api, app.toJSON(), config, function (err, res) { |
| 77 | + if (err) { |
| 78 | + reject(err); |
| 79 | + } else { |
| 80 | + resolve(res); |
| 81 | + } |
| 82 | + }); |
29 | 83 |
|
30 | | - return Promise.fromNode(buildExtension[buildHook].bind(buildExtension, api, app.toJSON(), config)); |
31 | | - })).nodeify(cb); |
| 84 | + if (retVal) { resolve(retVal); } |
| 85 | + }) |
| 86 | + .then(function (data) { |
| 87 | + return { |
| 88 | + module: module, |
| 89 | + data: data |
| 90 | + }; |
| 91 | + }); |
| 92 | + }) |
| 93 | + .filter(function (res) { return res; }); |
32 | 94 | } |
0 commit comments