Skip to content

Commit

Permalink
fix(pairwise): make it recursion-proof (ReactiveX#4743)
Browse files Browse the repository at this point in the history
  • Loading branch information
thorn0 authored and BioPhoton committed May 15, 2019
1 parent bfcd819 commit 7815588
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 2 deletions.
25 changes: 24 additions & 1 deletion spec/operators/pairwise-spec.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { hot, cold, expectObservable, expectSubscriptions } from '../helpers/marble-testing';
import { pairwise } from 'rxjs/operators';
import { pairwise, take } from 'rxjs/operators';
import { Subject } from 'rxjs';
import { expect } from 'chai';

declare function asDiagram(arg: string): Function;

Expand Down Expand Up @@ -103,4 +105,25 @@ describe('pairwise operator', () => {
expectObservable(source).toBe(expected);
expectSubscriptions(e1.subscriptions).toBe(e1subs);
});

it('should be recursively re-enterable', () => {
const results = new Array<[string, string]>();

const subject = new Subject<string>();

subject
.pipe(
pairwise(),
take(3)
)
.subscribe(pair => {
results.push(pair);
subject.next('c');
});

subject.next('a');
subject.next('b');

expect(results).to.deep.equal([['a', 'b'], ['b', 'c'], ['c', 'c']]);
});
});
8 changes: 7 additions & 1 deletion src/internal/operators/pairwise.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,12 +70,18 @@ class PairwiseSubscriber<T> extends Subscriber<T> {
}

_next(value: T): void {
let pair: [T, T] | undefined;

if (this.hasPrev) {
this.destination.next([this.prev, value]);
pair = [this.prev, value];
} else {
this.hasPrev = true;
}

this.prev = value;

if (pair) {
this.destination.next(pair);
}
}
}

0 comments on commit 7815588

Please sign in to comment.