Merge pull request #154 from maraoz/refactor/browser-build
Refactor/browser build
This commit is contained in:
commit
303d5731c0
159
browser/build.js
159
browser/build.js
|
@ -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'));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue