UNPKG

@reactivex/ix-es5-esm

Version:

The Interactive Extensions for JavaScript

95 lines (93 loc) 3.77 kB
import { __extends, __generator, __values } from "tslib"; import { IterableX } from '../iterablex.js'; import { arrayIndexOf } from '../../util/arrayindexof.js'; import { comparer as defaultComparer } from '../../util/comparer.js'; function arrayRemove(array, item, comparer) { var idx = arrayIndexOf(array, item, comparer); if (idx === -1) { return false; } array.splice(idx, 1); return true; } /** @ignore */ var IntersectIterable = /** @class */ (function (_super) { __extends(IntersectIterable, _super); function IntersectIterable(first, second, comparer) { var _this = _super.call(this) || this; _this._first = first; _this._second = second; _this._comparer = comparer; return _this; } IntersectIterable.prototype[Symbol.iterator] = function () { var map, _a, _b, secondItem, _c, _d, firstItem, e_1_1; var e_2, _e, e_1, _f; return __generator(this, function (_g) { switch (_g.label) { case 0: map = []; try { for (_a = __values(this._second), _b = _a.next(); !_b.done; _b = _a.next()) { secondItem = _b.value; map.push(secondItem); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_b && !_b.done && (_e = _a.return)) _e.call(_a); } finally { if (e_2) throw e_2.error; } } _g.label = 1; case 1: _g.trys.push([1, 6, 7, 8]); _c = __values(this._first), _d = _c.next(); _g.label = 2; case 2: if (!!_d.done) return [3 /*break*/, 5]; firstItem = _d.value; if (!arrayRemove(map, firstItem, this._comparer)) return [3 /*break*/, 4]; return [4 /*yield*/, firstItem]; case 3: _g.sent(); _g.label = 4; case 4: _d = _c.next(); return [3 /*break*/, 2]; case 5: return [3 /*break*/, 8]; case 6: e_1_1 = _g.sent(); e_1 = { error: e_1_1 }; return [3 /*break*/, 8]; case 7: try { if (_d && !_d.done && (_f = _c.return)) _f.call(_c); } finally { if (e_1) throw e_1.error; } return [7 /*endfinally*/]; case 8: return [2 /*return*/]; } }); }; return IntersectIterable; }(IterableX)); export { IntersectIterable }; /** * Produces the set intersection of two iterable sequences. * * @template TSource The type of the elements of the input sequences. * @param {Iterable<TSource>} second An iterable sequence whose distinct elements that also * appear in the first sequence will be returned. * @param {((x: TSource, y: TSource) => boolean)} [comparer=defaultComparer] An equality comparer to compare values. * @returns {MonoTypeOperatorFunction<TSource>} An operator that returns a sequence that contains the elements that form the set * intersection of two sequences. */ export function intersect(second, comparer) { if (comparer === void 0) { comparer = defaultComparer; } return function intersectOperatorFunction(first) { return new IntersectIterable(first, second, comparer); }; } //# sourceMappingURL=intersect.js.map