From 53bda087fabef6c269f8eb90adeb240801b5b502 Mon Sep 17 00:00:00 2001 From: emizzle Date: Fri, 22 Jun 2018 15:26:43 +1000 Subject: [PATCH 1/2] Fix for `embark build --contracts` writing into the pipeline --- lib/index.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/lib/index.js b/lib/index.js index 858292ca0..005de9499 100644 --- a/lib/index.js +++ b/lib/index.js @@ -194,7 +194,9 @@ class Embark { engine.startService("libraryManager"); engine.startService("codeRunner"); engine.startService("web3"); - engine.startService("pipeline"); + if(!options.onlyCompile){ + engine.startService("pipeline"); + } engine.startService("deployment", {onlyCompile: options.onlyCompile}); engine.startService("storage"); engine.startService("codeGenerator"); @@ -209,6 +211,9 @@ class Embark { engine.logger.info("Finished deploying".underline); // Necessary log for simple projects. This event is trigger to soon because there is no file // Also, not exiting straight after the deploy leaves time for async afterDeploys to finish + if(options.onlyCompile){ + return callback(); + } engine.logger.info("If you have no files to build, you can exit now with CTRL+C"); engine.events.on('outputDone', callback); } From 1e72a50b3bea3f9f65af180c04741e3551a96989 Mon Sep 17 00:00:00 2001 From: Jonathan Rainville Date: Fri, 22 Jun 2018 11:12:34 -0400 Subject: [PATCH 2/2] skip build if cmpile only --- lib/index.js | 28 +++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/lib/index.js b/lib/index.js index 005de9499..e32d12389 100644 --- a/lib/index.js +++ b/lib/index.js @@ -194,7 +194,7 @@ class Embark { engine.startService("libraryManager"); engine.startService("codeRunner"); engine.startService("web3"); - if(!options.onlyCompile){ + if (!options.onlyCompile) { engine.startService("pipeline"); } engine.startService("deployment", {onlyCompile: options.onlyCompile}); @@ -208,24 +208,30 @@ class Embark { }); }, function waitForWriteFinish(callback) { + if (options.onlyCompile) { + engine.logger.info("Finished compiling".underline); + return callback(null, true); + } engine.logger.info("Finished deploying".underline); - // Necessary log for simple projects. This event is trigger to soon because there is no file - // Also, not exiting straight after the deploy leaves time for async afterDeploys to finish - if(options.onlyCompile){ + if (!engine.config.assetFiles || !Object.keys(engine.config.assetFiles).length) { return callback(); } - engine.logger.info("If you have no files to build, you can exit now with CTRL+C"); - engine.events.on('outputDone', callback); + engine.events.on('outputDone', (err) => { + engine.logger.info(__("finished building").underline); + callback(err, true); + }); } - ], function (err, _result) { + ], function (err, canExit) { if (err) { engine.logger.error(err.message); engine.logger.debug(err.stack); - } else { - engine.logger.info(__("finished building").underline); } - // needed due to child processes - process.exit(); + + if (canExit || !engine.config.contractsConfig.afterDeploy || !engine.config.contractsConfig.afterDeploy.length) { + process.exit(); + } + engine.logger.info(__('Waiting for after deploy to finish...')); + engine.logger.info(__('You can exit with CTRL+C when after deploy completes')); }); }