Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/ecommerce/node_modules/webpack-dev-middleware/lib/ |
'use strict';
const weblog = require('webpack-log');
module.exports = function ctx(compiler, options) {
const context = {
state: false,
webpackStats: null,
callbacks: [],
options,
compiler,
watching: null,
forceRebuild: false,
};
if (options.logger) {
context.log = options.logger;
} else {
context.log = weblog({
level: options.logLevel || 'info',
name: 'wdm',
timestamp: options.logTime,
});
}
const { log } = context;
function done(stats) {
// We are now on valid state
context.state = true;
context.webpackStats = stats;
// Do the stuff in nextTick, because bundle may be invalidated
// if a change happened while compiling
process.nextTick(() => {
// check if still in valid state
if (!context.state) {
return;
}
// print webpack output
context.options.reporter(context.options, {
log,
state: true,
stats,
});
// execute callback that are delayed
const cbs = context.callbacks;
context.callbacks = [];
cbs.forEach((cb) => {
cb(stats);
});
});
// In lazy mode, we may issue another rebuild
if (context.forceRebuild) {
context.forceRebuild = false;
rebuild();
}
}
function invalid(callback) {
if (context.state) {
context.options.reporter(context.options, {
log,
state: false,
});
}
// We are now in invalid state
context.state = false;
if (typeof callback === 'function') {
callback();
}
}
function rebuild() {
if (context.state) {
context.state = false;
context.compiler.run((err) => {
if (err) {
log.error(err.stack || err);
if (err.details) {
log.error(err.details);
}
}
});
} else {
context.forceRebuild = true;
}
}
context.rebuild = rebuild;
context.compiler.hooks.invalid.tap('WebpackDevMiddleware', invalid);
context.compiler.hooks.run.tap('WebpackDevMiddleware', invalid);
context.compiler.hooks.done.tap('WebpackDevMiddleware', done);
context.compiler.hooks.watchRun.tap(
'WebpackDevMiddleware',
(comp, callback) => {
invalid(callback);
}
);
return context;
};