From efb79d63e6a2b8ea7427518550f3d0925f3c28d6 Mon Sep 17 00:00:00 2001 From: stelcheck Date: Tue, 29 Aug 2017 16:52:31 +0900 Subject: [PATCH] watch: unwatch before onChange Some IDEs like WebStorm change multiple files at once; this caused and issue where we ended up starting multiple MAGE workers upon restart. --- index.js | 15 +++++++++++---- package.json | 2 +- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/index.js b/index.js index ec7fbd9..2b5d1e3 100755 --- a/index.js +++ b/index.js @@ -14,14 +14,21 @@ var APP_LIB_PATH = path.join(process.cwd(), 'lib'); var debug = require('./debug'); -function watchFiles(onChange) { - watch(APP_LIB_PATH, { +function onceSomeFilesChanged(onChange) { + var called = false; + var watcher = watch(APP_LIB_PATH, { recursive: true }, function (event, name) { if (name.split(path.sep).pop()[0] === '.') { return; } + if (called) { + return; + } + + called = true; + watcher.close(); onChange(event, name); }); } @@ -198,7 +205,7 @@ function connect() { }); // Watch the lib folder for changes - watchFiles(function (event, name) { + onceSomeFilesChanged(function (event, name) { logger.debug('File ' + name + ' was ' + event + 'd, reloading'); saveHistory(repl.history); process.send('reload'); @@ -231,7 +238,7 @@ cluster.on('exit', function (worker) { // spawn a new worker to replace the dead one processManager.emit('workerOffline', worker.id); - watchFiles(function (event, name) { + onceSomeFilesChanged(function (event, name) { logger.debug('File ' + name + ' was ' + event + 'd, reloading'); processManager.createWorker(); }); diff --git a/package.json b/package.json index 03dcbd7..ee28df7 100755 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "mage-console", - "version": "0.3.0", + "version": "0.3.1", "description": "Alternative MAGE development console, with REPL interface", "main": "index.js", "bin": {