Buckets:
| var iterate = require('./lib/iterate.js') | |
| , initState = require('./lib/state.js') | |
| , terminator = require('./lib/terminator.js') | |
| ; | |
| // Public API | |
| module.exports = parallel; | |
| /** | |
| * Runs iterator over provided array elements in parallel | |
| * | |
| * @param {array|object} list - array or object (named list) to iterate over | |
| * @param {function} iterator - iterator to run | |
| * @param {function} callback - invoked when all elements processed | |
| * @returns {function} - jobs terminator | |
| */ | |
| function parallel(list, iterator, callback) | |
| { | |
| var state = initState(list); | |
| while (state.index < (state['keyedList'] || list).length) | |
| { | |
| iterate(list, iterator, state, function(error, result) | |
| { | |
| if (error) | |
| { | |
| callback(error, result); | |
| return; | |
| } | |
| // looks like it's the last one | |
| if (Object.keys(state.jobs).length === 0) | |
| { | |
| callback(null, state.results); | |
| return; | |
| } | |
| }); | |
| state.index++; | |
| } | |
| return terminator.bind(state, callback); | |
| } | |
Xet Storage Details
- Size:
- 1.02 kB
- Xet hash:
- 3fd6455851dd91ec8fa80b50ca68080d5af76e4208fb7ab119ebdc42552cf58d
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.