| 'use strict'; |
| |
| 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; |