mirror of https://github.com/embarklabs/embark.git
refactor run and build functions
This commit is contained in:
parent
f6c8b7a301
commit
0f14c247b0
113
lib/index.js
113
lib/index.js
|
@ -15,6 +15,7 @@ var TemplateGenerator = require('./template_generator.js');
|
||||||
var Blockchain = require('./blockchain.js');
|
var Blockchain = require('./blockchain.js');
|
||||||
var Server = require('./server.js');
|
var Server = require('./server.js');
|
||||||
var Watch = require('./watch.js');
|
var Watch = require('./watch.js');
|
||||||
|
var Pipeline = require('./pipeline.js');
|
||||||
|
|
||||||
var Embark = {
|
var Embark = {
|
||||||
|
|
||||||
|
@ -35,19 +36,45 @@ var Embark = {
|
||||||
},
|
},
|
||||||
|
|
||||||
run: function(env) {
|
run: function(env) {
|
||||||
Embark.deploy(function(abi) {
|
async.waterfall([
|
||||||
Embark.buildAssets(abi);
|
function deployAndGenerateABI(callback) {
|
||||||
var server = new Server({});
|
Embark.deploy(function(abi) {
|
||||||
server.start(function() {
|
callback(null, abi);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
function buildPipeline(abi, callback) {
|
||||||
|
var pipeline = new Pipeline({});
|
||||||
|
pipeline.build(abi);
|
||||||
|
callback();
|
||||||
|
},
|
||||||
|
function startAssetServer(callback) {
|
||||||
|
var server = new Server({});
|
||||||
|
server.start(callback);
|
||||||
|
},
|
||||||
|
function watchFilesForChanges(callback) {
|
||||||
var watch = new Watch();
|
var watch = new Watch();
|
||||||
watch.start();
|
watch.start();
|
||||||
});
|
callback();
|
||||||
|
}
|
||||||
|
], function(err, result) {
|
||||||
|
console.log("finished".underline);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
build: function(env) {
|
build: function(env) {
|
||||||
Embark.deploy(function(abi) {
|
async.waterfall([
|
||||||
Embark.buildAssets(abi);
|
function deployAndGenerateABI(callback) {
|
||||||
|
Embark.deploy(function(abi) {
|
||||||
|
callback(null, abi);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
function buildPipeline(abi, callback) {
|
||||||
|
var pipeline = new Pipeline({});
|
||||||
|
pipeline.build(abi);
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
], function(err, result) {
|
||||||
|
console.log("finished".underline);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -56,67 +83,31 @@ var Embark = {
|
||||||
blockchain.run({env: env});
|
blockchain.run({env: env});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
deploy: function(done) {
|
deploy: function(done) {
|
||||||
async.waterfall([
|
async.waterfall([
|
||||||
function loadConfig(callback) {
|
function loadConfig(callback) {
|
||||||
var contractsManager = Embark.initConfig('config/', 'app/contracts/**/*.sol', 'development');
|
var contractsManager = Embark.initConfig('config/', 'app/contracts/**/*.sol', 'development');
|
||||||
callback(null, contractsManager);
|
|
||||||
},
|
|
||||||
function buildContracts(contractsManager, callback) {
|
|
||||||
contractsManager.build();
|
|
||||||
callback(null, contractsManager);
|
|
||||||
},
|
|
||||||
function deployContracts(contractsManager, callback) {
|
|
||||||
var web3 = new Web3();
|
|
||||||
web3.setProvider(new web3.providers.HttpProvider('http://localhost:8545'));
|
|
||||||
var deploy = new Deploy(web3, contractsManager);
|
|
||||||
deploy.deployAll(function() {
|
|
||||||
callback(null, contractsManager);
|
callback(null, contractsManager);
|
||||||
});
|
},
|
||||||
},
|
function buildContracts(contractsManager, callback) {
|
||||||
function generateABI(contractsManager, callback) {
|
contractsManager.build();
|
||||||
var abiGenerator = new ABIGenerator(contractsManager);
|
callback(null, contractsManager);
|
||||||
callback(null, abiGenerator.generateABI());
|
},
|
||||||
},
|
function deployContracts(contractsManager, callback) {
|
||||||
|
var web3 = new Web3();
|
||||||
|
web3.setProvider(new web3.providers.HttpProvider('http://localhost:8545'));
|
||||||
|
var deploy = new Deploy(web3, contractsManager);
|
||||||
|
deploy.deployAll(function() {
|
||||||
|
callback(null, contractsManager);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
function generateABI(contractsManager, callback) {
|
||||||
|
var abiGenerator = new ABIGenerator(contractsManager);
|
||||||
|
callback(null, abiGenerator.generateABI());
|
||||||
|
},
|
||||||
], function(err, result) {
|
], function(err, result) {
|
||||||
done(result);
|
done(result);
|
||||||
});
|
});
|
||||||
},
|
|
||||||
|
|
||||||
buildAssets: function(abi) {
|
|
||||||
var embarkConfig = JSON.parse(fs.readFileSync("embark.json"));
|
|
||||||
|
|
||||||
var appConfig = embarkConfig.app;
|
|
||||||
|
|
||||||
for(var targetFile in appConfig) {
|
|
||||||
var originalFiles = grunt.file.expand({nonull: true}, appConfig[targetFile]);
|
|
||||||
console.log(originalFiles);
|
|
||||||
// remove duplicates
|
|
||||||
|
|
||||||
var content = originalFiles.filter(function(file) {
|
|
||||||
return file.indexOf('.') >= 0;
|
|
||||||
}).map(function(file) {
|
|
||||||
console.log("reading " + file);
|
|
||||||
if (file === 'embark.js') {
|
|
||||||
return fs.readFileSync("../js/bluebird.js") + fs.readFileSync("../js/web3.js") + fs.readFileSync("../js/embark.js") + "\n" + abi;
|
|
||||||
} else {
|
|
||||||
return fs.readFileSync(file);
|
|
||||||
}
|
|
||||||
}).join("\n");
|
|
||||||
|
|
||||||
var dir = targetFile.split('/').slice(0, -1).join('/');
|
|
||||||
console.log("creating dir " + "dist/" + dir);
|
|
||||||
mkdirp.sync("dist/" + dir);
|
|
||||||
|
|
||||||
//console.log(content);
|
|
||||||
fs.writeFileSync("dist/" + targetFile, content);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
var fs = require('fs');
|
||||||
|
var grunt = require('grunt');
|
||||||
|
var mkdirp = require('mkdirp');
|
||||||
|
|
||||||
|
var Pipeline = function(options) {
|
||||||
|
this.options = options;
|
||||||
|
};
|
||||||
|
|
||||||
|
Pipeline.prototype.build = function(abi) {
|
||||||
|
var embarkConfig = JSON.parse(fs.readFileSync("embark.json"));
|
||||||
|
|
||||||
|
var appConfig = embarkConfig.app;
|
||||||
|
|
||||||
|
for(var targetFile in appConfig) {
|
||||||
|
var originalFiles = grunt.file.expand({nonull: true}, appConfig[targetFile]);
|
||||||
|
console.log(originalFiles);
|
||||||
|
// remove duplicates
|
||||||
|
|
||||||
|
var content = originalFiles.filter(function(file) {
|
||||||
|
return file.indexOf('.') >= 0;
|
||||||
|
}).map(function(file) {
|
||||||
|
console.log("reading " + file);
|
||||||
|
if (file === 'embark.js') {
|
||||||
|
return fs.readFileSync("../js/bluebird.js") + fs.readFileSync("../js/web3.js") + fs.readFileSync("../js/embark.js") + "\n" + abi;
|
||||||
|
} else {
|
||||||
|
return fs.readFileSync(file);
|
||||||
|
}
|
||||||
|
}).join("\n");
|
||||||
|
|
||||||
|
var dir = targetFile.split('/').slice(0, -1).join('/');
|
||||||
|
console.log("creating dir " + "dist/" + dir);
|
||||||
|
mkdirp.sync("dist/" + dir);
|
||||||
|
|
||||||
|
//console.log(content);
|
||||||
|
fs.writeFileSync("dist/" + targetFile, content);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = Pipeline;
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
/*jshint esversion: 6 */
|
||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var chokidar = require('chokidar');
|
var chokidar = require('chokidar');
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue