|
| 1 | +'use strict'; |
| 2 | +var $ = require('../internals/export'); |
| 3 | +var $toString = require('../internals/to-string'); |
| 4 | +var anObject = require('../internals/an-object'); |
| 5 | +var getIteratorDirect = require('../internals/get-iterator-direct'); |
| 6 | +var isNullOrUndefined = require('../internals/is-null-or-undefined'); |
| 7 | +var iterate = require('../internals/iterate'); |
| 8 | +var iteratorClose = require('../internals/iterator-close'); |
| 9 | +var uncurryThis = require('../internals/function-uncurry-this'); |
| 10 | + |
| 11 | +var stringConcat = uncurryThis(''.concat); |
| 12 | + |
| 13 | +// `Iterator.prototype.join` method |
| 14 | +// https://bakkot.github.io/proposal-iterator-join/ |
| 15 | +// dependency: es.iterator.constructor |
| 16 | +$({ target: 'Iterator', proto: true, real: true, forced: true }, { |
| 17 | + join: function join(separator) { |
| 18 | + var O = anObject(this); |
| 19 | + var sep; |
| 20 | + try { |
| 21 | + sep = separator === undefined ? ',' : $toString(separator); |
| 22 | + } catch (error) { |
| 23 | + iteratorClose(O, 'throw', error); |
| 24 | + } |
| 25 | + var first = true; |
| 26 | + var result = ''; |
| 27 | + var iterated = getIteratorDirect(O); |
| 28 | + iterate(iterated, function (value) { |
| 29 | + if (first) { |
| 30 | + first = false; |
| 31 | + } else { |
| 32 | + result = stringConcat(result, sep); |
| 33 | + } |
| 34 | + if (isNullOrUndefined(value)) return; |
| 35 | + result = stringConcat(result, $toString(value)); |
| 36 | + }, { IS_RECORD: true }); |
| 37 | + return result; |
| 38 | + }, |
| 39 | +}); |
0 commit comments