Skip to content

Instantly share code, notes, and snippets.

@gliviu
Created June 27, 2016 21:56
Show Gist options
  • Save gliviu/538e4b1acd63b85c3a2ba67a3657d6d5 to your computer and use it in GitHub Desktop.
Save gliviu/538e4b1acd63b85c3a2ba67a3657d6d5 to your computer and use it in GitHub Desktop.
'use strict';
var fs = require('fs');
/**
* Limits the number of concurrent file handlers.
* Use it as a wrapper over fs.open() and fs.close().
* Example:
* var fdQueue = new FileDescriptorQueue(8);
* fdQueue.open(path, flags, (err, fd) =>{
* ...
* });
*/
var FileDescriptorQueue = function(maxFilesNo) {
var activeJobs = {};
var pendingJobs = [];
var activeCount = 0;
var open = function(path, flags, callback) {
pendingJobs.push({
path : path,
flags : flags,
callback : callback
});
process();
}
var process = function() {
if (pendingJobs.length > 0 && activeCount < maxFilesNo) {
var job = pendingJobs.shift();
activeJobs[job.fd] = job;
activeCount++;
fs.open(job.path, job.flags, function(err, fd) {
job.callback(err, fd);
});
}
}
var close = function(fd, callback) {
delete activeJobs.fd;
activeCount--;
fs.close(fd, callback);
process();
}
return {
open : open,
close : close
};
}
module.exports = FileDescriptorQueue;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment