From d3e04b5bcb9f930dfe0ce9d0891de579d5bde5cf Mon Sep 17 00:00:00 2001 From: Jasper De Moor Date: Sat, 26 May 2018 21:58:51 +0200 Subject: [PATCH] Fix worker environment variable (#1443) --- src/Logger.js | 2 +- src/worker.js | 18 +++++++++++------- src/workerfarm/WorkerFarm.js | 2 +- src/workerfarm/child.js | 2 ++ 4 files changed, 15 insertions(+), 9 deletions(-) diff --git a/src/Logger.js b/src/Logger.js index 4ea682a4ac2..182d0750fd6 100644 --- a/src/Logger.js +++ b/src/Logger.js @@ -195,7 +195,7 @@ function stringWidth(string) { // If we are in a worker, make a proxy class which will // send the logger calls to the main process via IPC. // These are handled in WorkerFarm and directed to handleMessage above. -if (process.send && process.env.WORKER_TYPE === 'parcel-worker') { +if (process.send && process.env.PARCEL_WORKER_TYPE === 'remote-worker') { const worker = require('./worker'); class LoggerProxy {} for (let method of Object.getOwnPropertyNames(Logger.prototype)) { diff --git a/src/worker.js b/src/worker.js index c77f09de824..1c093dbaa85 100644 --- a/src/worker.js +++ b/src/worker.js @@ -1,18 +1,21 @@ require('v8-compile-cache'); const Pipeline = require('./Pipeline'); -const child = require('./workerfarm/child'); const WorkerFarm = require('./workerfarm/WorkerFarm'); let pipeline; +let child; -function init(options, isLocal = false) { +function setChildReference(childReference) { + child = childReference; +} + +function init(options) { pipeline = new Pipeline(options || {}); - Object.assign(process.env, options.env || {}); + Object.assign(process.env, options.env || {}, { + PARCEL_WORKER_TYPE: child ? 'remote-worker' : 'local-worker' + }); process.env.HMR_PORT = options.hmrPort; process.env.HMR_HOSTNAME = options.hmrHostname; - if (isLocal) { - process.env.WORKER_TYPE = 'parcel-worker'; - } } async function run(path, isWarmUp) { @@ -26,7 +29,7 @@ async function run(path, isWarmUp) { // request.location is a module path relative to src or lib async function addCall(request, awaitResponse = true) { - if (process.send && process.env.WORKER_TYPE === 'parcel-worker') { + if (process.send && process.env.PARCEL_WORKER_TYPE === 'remote-worker') { return child.addCall(request, awaitResponse); } else { return WorkerFarm.getShared().processRequest(request); @@ -36,3 +39,4 @@ async function addCall(request, awaitResponse = true) { exports.init = init; exports.run = run; exports.addCall = addCall; +exports.setChildReference = setChildReference; diff --git a/src/workerfarm/WorkerFarm.js b/src/workerfarm/WorkerFarm.js index 8593225650c..a8614e0afb1 100644 --- a/src/workerfarm/WorkerFarm.js +++ b/src/workerfarm/WorkerFarm.js @@ -205,7 +205,7 @@ class WorkerFarm extends EventEmitter { } init(options) { - this.localWorker.init(options, true); + this.localWorker.init(options); this.initRemoteWorkers(options); } diff --git a/src/workerfarm/child.js b/src/workerfarm/child.js index 1d90afdd7e0..69c4a16181c 100644 --- a/src/workerfarm/child.js +++ b/src/workerfarm/child.js @@ -9,6 +9,8 @@ class Child { this.responseQueue = new Map(); this.responseId = 0; this.maxConcurrentCalls = 10; + + process.env.PARCEL_WORKER_TYPE = 'remote-worker'; } messageListener(data) {