+++ /dev/null
-import { Subject } from '../Subject';
-import { Subscriber } from '../Subscriber';
-import { Subscription } from '../Subscription';
-import { Scheduler } from '../Scheduler';
-import { TestMessage } from './TestMessage';
-import { SubscriptionLog } from './SubscriptionLog';
-import { SubscriptionLoggable } from './SubscriptionLoggable';
-import { applyMixins } from '../util/applyMixins';
-
-/**
- * We need this JSDoc comment for affecting ESDoc.
- * @ignore
- * @extends {Ignored}
- */
-export class HotObservable<T> extends Subject<T> implements SubscriptionLoggable {
- public subscriptions: SubscriptionLog[] = [];
- scheduler: Scheduler;
- logSubscribedFrame: () => number;
- logUnsubscribedFrame: (index: number) => void;
-
- constructor(public messages: TestMessage[],
- scheduler: Scheduler) {
- super();
- this.scheduler = scheduler;
- }
-
- /** @deprecated This is an internal implementation detail, do not use. */
- _subscribe(subscriber: Subscriber<any>): Subscription {
- const subject: HotObservable<T> = this;
- const index = subject.logSubscribedFrame();
- const subscription = new Subscription();
- subscription.add(new Subscription(() => {
- subject.logUnsubscribedFrame(index);
- }));
- subscription.add(super._subscribe(subscriber));
- return subscription;
- }
-
- setup() {
- const subject = this;
- const messagesLength = subject.messages.length;
- /* tslint:disable:no-var-keyword */
- for (var i = 0; i < messagesLength; i++) {
- (() => {
- var message = subject.messages[i];
- /* tslint:enable */
- subject.scheduler.schedule(
- () => { message.notification.observe(subject); },
- message.frame
- );
- })();
- }
- }
-}
-applyMixins(HotObservable, [SubscriptionLoggable]);