Spaces:
Sleeping
Sleeping
| ; | |
| Object.defineProperty(exports, "__esModule", { | |
| value: true | |
| }); | |
| var _concatLimit = require('./concatLimit.js'); | |
| var _concatLimit2 = _interopRequireDefault(_concatLimit); | |
| var _awaitify = require('./internal/awaitify.js'); | |
| var _awaitify2 = _interopRequireDefault(_awaitify); | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
| /** | |
| * Applies `iteratee` to each item in `coll`, concatenating the results. Returns | |
| * the concatenated list. The `iteratee`s are called in parallel, and the | |
| * results are concatenated as they return. The results array will be returned in | |
| * the original order of `coll` passed to the `iteratee` function. | |
| * | |
| * @name concat | |
| * @static | |
| * @memberOf module:Collections | |
| * @method | |
| * @category Collection | |
| * @alias flatMap | |
| * @param {Array|Iterable|AsyncIterable|Object} coll - A collection to iterate over. | |
| * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`, | |
| * which should use an array as its result. Invoked with (item, callback). | |
| * @param {Function} [callback] - A callback which is called after all the | |
| * `iteratee` functions have finished, or an error occurs. Results is an array | |
| * containing the concatenated results of the `iteratee` function. Invoked with | |
| * (err, results). | |
| * @returns A Promise, if no callback is passed | |
| * @example | |
| * | |
| * // dir1 is a directory that contains file1.txt, file2.txt | |
| * // dir2 is a directory that contains file3.txt, file4.txt | |
| * // dir3 is a directory that contains file5.txt | |
| * // dir4 does not exist | |
| * | |
| * let directoryList = ['dir1','dir2','dir3']; | |
| * let withMissingDirectoryList = ['dir1','dir2','dir3', 'dir4']; | |
| * | |
| * // Using callbacks | |
| * async.concat(directoryList, fs.readdir, function(err, results) { | |
| * if (err) { | |
| * console.log(err); | |
| * } else { | |
| * console.log(results); | |
| * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] | |
| * } | |
| * }); | |
| * | |
| * // Error Handling | |
| * async.concat(withMissingDirectoryList, fs.readdir, function(err, results) { | |
| * if (err) { | |
| * console.log(err); | |
| * // [ Error: ENOENT: no such file or directory ] | |
| * // since dir4 does not exist | |
| * } else { | |
| * console.log(results); | |
| * } | |
| * }); | |
| * | |
| * // Using Promises | |
| * async.concat(directoryList, fs.readdir) | |
| * .then(results => { | |
| * console.log(results); | |
| * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] | |
| * }).catch(err => { | |
| * console.log(err); | |
| * }); | |
| * | |
| * // Error Handling | |
| * async.concat(withMissingDirectoryList, fs.readdir) | |
| * .then(results => { | |
| * console.log(results); | |
| * }).catch(err => { | |
| * console.log(err); | |
| * // [ Error: ENOENT: no such file or directory ] | |
| * // since dir4 does not exist | |
| * }); | |
| * | |
| * // Using async/await | |
| * async () => { | |
| * try { | |
| * let results = await async.concat(directoryList, fs.readdir); | |
| * console.log(results); | |
| * // [ 'file1.txt', 'file2.txt', 'file3.txt', 'file4.txt', file5.txt ] | |
| * } catch (err) { | |
| * console.log(err); | |
| * } | |
| * } | |
| * | |
| * // Error Handling | |
| * async () => { | |
| * try { | |
| * let results = await async.concat(withMissingDirectoryList, fs.readdir); | |
| * console.log(results); | |
| * } catch (err) { | |
| * console.log(err); | |
| * // [ Error: ENOENT: no such file or directory ] | |
| * // since dir4 does not exist | |
| * } | |
| * } | |
| * | |
| */ | |
| function concat(coll, iteratee, callback) { | |
| return (0, _concatLimit2.default)(coll, Infinity, iteratee, callback); | |
| } | |
| exports.default = (0, _awaitify2.default)(concat, 3); | |
| module.exports = exports.default; |