2017-05-03 15:35:00 +02:00
|
|
|
/*
|
|
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
|
|
Author Tobias Koppers @sokra
|
|
|
|
*/
|
|
|
|
/*globals __resourceQuery */
|
|
|
|
if(module.hot) {
|
|
|
|
var hotPollInterval = +(__resourceQuery.substr(1)) || (10 * 60 * 1000);
|
2017-08-14 05:01:11 +02:00
|
|
|
var log = require("./log");
|
2017-05-03 15:35:00 +02:00
|
|
|
|
|
|
|
var checkForUpdate = function checkForUpdate(fromUpdate) {
|
|
|
|
if(module.hot.status() === "idle") {
|
|
|
|
module.hot.check(true).then(function(updatedModules) {
|
|
|
|
if(!updatedModules) {
|
2017-08-14 05:01:11 +02:00
|
|
|
if(fromUpdate) log("info", "[HMR] Update applied.");
|
2017-05-03 15:35:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
require("./log-apply-result")(updatedModules, updatedModules);
|
|
|
|
checkForUpdate(true);
|
|
|
|
}).catch(function(err) {
|
|
|
|
var status = module.hot.status();
|
|
|
|
if(["abort", "fail"].indexOf(status) >= 0) {
|
2017-08-14 05:01:11 +02:00
|
|
|
log("warning", "[HMR] Cannot apply update.");
|
|
|
|
log("warning", "[HMR] " + err.stack || err.message);
|
|
|
|
log("warning", "[HMR] You need to restart the application!");
|
2017-05-03 15:35:00 +02:00
|
|
|
} else {
|
2017-08-14 05:01:11 +02:00
|
|
|
log("warning", "[HMR] Update failed: " + err.stack || err.message);
|
2017-05-03 15:35:00 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
setInterval(checkForUpdate, hotPollInterval);
|
|
|
|
} else {
|
|
|
|
throw new Error("[HMR] Hot Module Replacement is disabled.");
|
|
|
|
}
|