File size: 1,446 Bytes
c592d77
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
"use strict";
Object.defineProperty(exports, "__esModule", {
    value: true
});
Object.defineProperty(exports, "runLoaderWorkerPool", {
    enumerable: true,
    get: function() {
        return runLoaderWorkerPool;
    }
});
const _worker_threads = require("worker_threads");
const loaderWorkers = {};
function getPoolId(cwd, filename) {
    return `${cwd}:${filename}`;
}
async function runLoaderWorkerPool(bindings, bindingPath) {
    bindings.registerWorkerScheduler((creation)=>{
        const { options: { filename, cwd } } = creation;
        const poolId = getPoolId(cwd, filename);
        const worker = new _worker_threads.Worker(/* turbopackIgnore: true*/ filename, {
            workerData: {
                bindingPath,
                cwd
            }
        });
        // This will cause handing when run in jest worker, but not as a first level thread of nodejs thread
        // worker.unref()
        const workers = loaderWorkers[poolId] || (loaderWorkers[poolId] = new Map());
        workers.set(worker.threadId, worker);
    }, (termination)=>{
        var _workers_get;
        const { options: { filename, cwd }, workerId } = termination;
        const poolId = getPoolId(cwd, filename);
        const workers = loaderWorkers[poolId];
        (_workers_get = workers.get(workerId)) == null ? void 0 : _workers_get.terminate();
        workers.delete(workerId);
    });
}

//# sourceMappingURL=loaderWorkerPool.js.map