Merge pull request #3413 from tsauerwein/ext-browserify
Add support for generic external modules with Browserify
This commit is contained in:
@@ -40,7 +40,8 @@
|
||||
"rbush": "1.3.5",
|
||||
"temp": "0.8.1",
|
||||
"walk": "2.3.4",
|
||||
"wrench": "1.5.8"
|
||||
"wrench": "1.5.8",
|
||||
"browserify": "9.0.3"
|
||||
},
|
||||
"devDependencies": {
|
||||
"clean-css": "2.2.16",
|
||||
|
||||
@@ -3,6 +3,7 @@ var path = require('path');
|
||||
|
||||
var async = require('async');
|
||||
var fse = require('fs-extra');
|
||||
var browserify = require('browserify');
|
||||
|
||||
var pkg = require('../package.json');
|
||||
|
||||
@@ -15,11 +16,22 @@ var buildDir = path.join(root, 'build', 'ol.ext');
|
||||
* @return {Array.<Object>} Array of objects representing external modules.
|
||||
*/
|
||||
function getExternalModules() {
|
||||
return pkg.ext.map(function(name) {
|
||||
return pkg.ext.map(function(item) {
|
||||
if (typeof item === 'string') {
|
||||
return {
|
||||
name: name,
|
||||
main: require.resolve(name)
|
||||
name: item,
|
||||
module: item,
|
||||
main: require.resolve(item),
|
||||
browserify: false
|
||||
};
|
||||
} else {
|
||||
return {
|
||||
module: item.module,
|
||||
name: item.name !== undefined ? item.name : item.module,
|
||||
main: require.resolve(item.module),
|
||||
browserify: item.browserify !== undefined ? item.browserify : false
|
||||
};
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@@ -31,12 +43,8 @@ function getExternalModules() {
|
||||
* wrapped module.
|
||||
*/
|
||||
function wrapModule(mod, callback) {
|
||||
fs.readFile(mod.main, function(err, data) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
var wrapped = 'goog.provide(\'ol.ext.' + mod.name + '\');\n' +
|
||||
var wrap = function(code) {
|
||||
return 'goog.provide(\'ol.ext.' + mod.name + '\');\n' +
|
||||
'/** @typedef {function(*)} */\n' +
|
||||
'ol.ext.' + mod.name + ';\n' +
|
||||
'(function() {\n' +
|
||||
@@ -50,11 +58,29 @@ function wrapModule(mod, callback) {
|
||||
'fileoverviewTags, missingProperties, nonStandardJsDocs, ' +
|
||||
'strictModuleDepCheck, suspiciousCode, undefinedNames, ' +
|
||||
'undefinedVars, unknownDefines, uselessCode, visibility}\n' +
|
||||
' */\n' + data.toString() + '\n' +
|
||||
' */\n' + code + '\n' +
|
||||
'ol.ext.' + mod.name + ' = module.exports;\n' +
|
||||
'})();\n';
|
||||
callback(null, wrapped);
|
||||
};
|
||||
|
||||
if (mod.browserify) {
|
||||
var b = browserify(mod.main, {standalone: mod.name}).
|
||||
bundle(function(err, buf) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
callback(null, wrap(buf.toString()));
|
||||
});
|
||||
} else {
|
||||
fs.readFile(mod.main, function(err, data) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
callback(null, wrap(data.toString()));
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user