Merge pull request #154 from maraoz/refactor/browser-build

Refactor/browser build
This commit is contained in:
Ryan X. Charles 2014-03-14 11:14:08 -04:00
commit 303d5731c0
1 changed files with 97 additions and 62 deletions

View File

@ -1,44 +1,16 @@
'use strict'; 'use strict';
/*
*
* The key parameter 'pack'
* The supplied 'custom_prelude.js' file is needed for
* .load function of soop.
*/
var fs = require('fs'); var fs = require('fs');
var browserify = require('browserify'); var browserify = require('browserify');
var browserPack = require('browser-pack'); var browserPack = require('browser-pack');
var program = require('commander');
// concat browser vendor files
var exec = require('child_process').exec; var exec = require('child_process').exec;
var sys = require('sys'); var sys = require('sys');
var puts = function(error, stdout, stderr) { var puts = function(error, stdout, stderr) {
if (error) console.log(error); if (error) console.log(error);
sys.puts(stdout); //sys.puts(stdout);
sys.puts(stderr); //sys.puts(stderr);
}; };
exec('cd browser; sh concat.sh', puts);
var list = function(val) {
return val.split(',');
};
program
.version('0.0.1')
.option('-a, --includeall', 'Include all submodules.')
.option('-d, --dontminify', 'Don\'t minify the code.')
.option('-s, --submodules <items>', 'Include the listed comma-separated submodules.', list)
.parse(process.argv);
if (!program.includeall && (!program.submodules || program.submodules.length === 0)) {
console.log('Must use either -s or -a option. For more info use the --help option');
process.exit(1);
}
var pack = function (params) { var pack = function (params) {
var file = require.resolve('soop'); var file = require.resolve('soop');
var dir = file.substr(0, file.length - String('soop.js').length); var dir = file.substr(0, file.length - String('soop.js').length);
@ -82,40 +54,103 @@ var modules = [
'util/VersionedData', 'util/VersionedData',
]; ];
var opts = {}; var createBitcore = function(opts) {
opts.pack = pack;
opts.debug = true;
opts.standalone = 'bitcore';
opts.insertGlobals = true;
var b = browserify(opts);
b.require('browserify-bignum/bignumber.js', {expose: 'bignum'} ); opts.dir = opts.dir || '';
b.require('browserify-buffertools/buffertools.js', {expose:'buffertools'});
b.require('base58-native', {expose: 'base58-native'}); // concat browser vendor files
b.require('./bitcore', {expose: 'bitcore'}); exec('cd ' + opts.dir + 'browser; sh concat.sh', puts);
modules.forEach(function(m) {
if (program.includeall || program.submodules.indexOf(m) > -1) { if (!opts.includeall && (!opts.submodules || opts.submodules.length === 0)) {
console.log('Including '+m+' in the browser bundle'); if (!opts.stdout) console.log('Must use either -s or -a option. For more info use the --help option');
b.require('./' + m + '.js' , {expose: './'+m} ); process.exit(1);
} }
});
if (!program.dontminify) { if (opts.submodules) {
b.transform({ for (var i = 0; i < opts.submodules.length; i++) {
global: true var sm = opts.submodules[i];
}, 'uglifyify'); if (modules.indexOf(sm) === -1) throw new Error('Unknown submodule ' + sm);
}
}
var bopts = {
pack: pack,
debug: true,
standalone: 'bitcore',
insertGlobals: true
};
var b = browserify(bopts);
b.require(opts.dir + 'browserify-bignum/bignumber.js', {
expose: 'bignum'
});
b.require(opts.dir + 'browserify-buffertools/buffertools.js', {
expose: 'buffertools'
});
b.require(opts.dir + 'base58-native', {
expose: 'base58-native'
});
b.require('./' + opts.dir + 'bitcore', {
expose: 'bitcore'
});
modules.forEach(function(m) {
if (opts.includeall || opts.submodules.indexOf(m) > -1) {
if (!opts.stdout) console.log('Including ' + m + ' in the browser bundle');
b.require('./' + opts.dir + m + '.js', {
expose: './' + m
});
}
});
if (!opts.dontminify) {
b.transform({
global: true
}, 'uglifyify');
}
var bundle = b.bundle();
return bundle;
};
var createTestData = function() {
var bopts = {
pack: pack,
debug: true,
standalone: 'testdata',
insertGlobals: true
};
var tb = browserify(bopts);
tb.require('./test/testdata', {
expose: 'testdata'
});
tb.transform('brfs');
return tb.bundle();
};
if (require.main === module) {
var list = function(val) {
return val.split(',');
};
var program = require('commander');
program
.version('0.0.1')
.option('-a, --includeall', 'Include all submodules.')
.option('-d, --dontminify', 'Don\'t minify the code.')
.option('-o, --stdout', 'Specify output as stdout')
.option('-D, --dir <dir>', 'Specify a base directory')
.option('-s, --submodules <items>', 'Include the listed comma-separated submodules.', list)
.parse(process.argv);
if (!program.stdout) {
var testBundle = createTestData(program);
testBundle.pipe(fs.createWriteStream('browser/testdata.js'));
}
var bitcoreBundle = createBitcore(program);
bitcoreBundle.pipe(program.stdout ? process.stdout : fs.createWriteStream('browser/bundle.js'));
} }
var bundle = b.bundle(); module.exports.createBitcore = createBitcore;
bundle = bundle.pipe(fs.createWriteStream('browser/bundle.js')); module.exports.createTestData = createTestData;
opts.standalone = 'testdata';
var tb = browserify(opts);
tb.require('./test/testdata', {expose: 'testdata'});
tb.transform('brfs');
tb.bundle().pipe(fs.createWriteStream('browser/testdata.js'));