404

[ Avaa Bypassed ]




Upload:

Command:

botdev@3.16.124.181: ~ $
import { Operator } from '../Operator';
import { async } from '../scheduler/async';
import { Observable } from '../Observable';
import { Subscriber } from '../Subscriber';
import { Subscription } from '../Subscription';
import { isScheduler } from '../util/isScheduler';
import { OperatorFunction, SchedulerAction, SchedulerLike } from '../types';

/* tslint:disable:max-line-length */
export function bufferTime<T>(bufferTimeSpan: number, scheduler?: SchedulerLike): OperatorFunction<T, T[]>;
export function bufferTime<T>(bufferTimeSpan: number, bufferCreationInterval: number | null | undefined, scheduler?: SchedulerLike): OperatorFunction<T, T[]>;
export function bufferTime<T>(bufferTimeSpan: number, bufferCreationInterval: number | null | undefined, maxBufferSize: number, scheduler?: SchedulerLike): OperatorFunction<T, T[]>;
/* tslint:enable:max-line-length */

/**
 * Buffers the source Observable values for a specific time period.
 *
 * <span class="informal">Collects values from the past as an array, and emits
 * those arrays periodically in time.</span>
 *
 * ![](bufferTime.png)
 *
 * Buffers values from the source for a specific time duration `bufferTimeSpan`.
 * Unless the optional argument `bufferCreationInterval` is given, it emits and
 * resets the buffer every `bufferTimeSpan` milliseconds. If
 * `bufferCreationInterval` is given, this operator opens the buffer every
 * `bufferCreationInterval` milliseconds and closes (emits and resets) the
 * buffer every `bufferTimeSpan` milliseconds. When the optional argument
 * `maxBufferSize` is specified, the buffer will be closed either after
 * `bufferTimeSpan` milliseconds or when it contains `maxBufferSize` elements.
 *
 * ## Examples
 *
 * Every second, emit an array of the recent click events
 *
 * ```ts
 * import { fromEvent } from 'rxjs';
 * import { bufferTime } from 'rxjs/operators';
 *
 * const clicks = fromEvent(document, 'click');
 * const buffered = clicks.pipe(bufferTime(1000));
 * buffered.subscribe(x => console.log(x));
 * ```
 *
 * Every 5 seconds, emit the click events from the next 2 seconds
 *
 * ```ts
 * import { fromEvent } from 'rxjs';
 * import { bufferTime } from 'rxjs/operators';
 *
 * const clicks = fromEvent(document, 'click');
 * const buffered = clicks.pipe(bufferTime(2000, 5000));
 * buffered.subscribe(x => console.log(x));
 * ```
 *
 * @see {@link buffer}
 * @see {@link bufferCount}
 * @see {@link bufferToggle}
 * @see {@link bufferWhen}
 * @see {@link windowTime}
 *
 * @param {number} bufferTimeSpan The amount of time to fill each buffer array.
 * @param {number} [bufferCreationInterval] The interval at which to start new
 * buffers.
 * @param {number} [maxBufferSize] The maximum buffer size.
 * @param {SchedulerLike} [scheduler=async] The scheduler on which to schedule the
 * intervals that determine buffer boundaries.
 * @return {Observable<T[]>} An observable of arrays of buffered values.
 * @method bufferTime
 * @owner Observable
 */
export function bufferTime<T>(bufferTimeSpan: number): OperatorFunction<T, T[]> {
  let length: number = arguments.length;

  let scheduler: SchedulerLike = async;
  if (isScheduler(arguments[arguments.length - 1])) {
    scheduler = arguments[arguments.length - 1];
    length--;
  }

  let bufferCreationInterval: number = null;
  if (length >= 2) {
    bufferCreationInterval = arguments[1];
  }

  let maxBufferSize: number = Number.POSITIVE_INFINITY;
  if (length >= 3) {
    maxBufferSize = arguments[2];
  }

  return function bufferTimeOperatorFunction(source: Observable<T>) {
    return source.lift(new BufferTimeOperator<T>(bufferTimeSpan, bufferCreationInterval, maxBufferSize, scheduler));
  };
}

class BufferTimeOperator<T> implements Operator<T, T[]> {
  constructor(private bufferTimeSpan: number,
              private bufferCreationInterval: number,
              private maxBufferSize: number,
              private scheduler: SchedulerLike) {
  }

  call(subscriber: Subscriber<T[]>, source: any): any {
    return source.subscribe(new BufferTimeSubscriber(
      subscriber, this.bufferTimeSpan, this.bufferCreationInterval, this.maxBufferSize, this.scheduler
    ));
  }
}

class Context<T> {
  buffer: T[] = [];
  closeAction: Subscription;
}

interface DispatchCreateArg<T> {
  bufferTimeSpan: number;
  bufferCreationInterval: number;
  subscriber: BufferTimeSubscriber<T>;
  scheduler: SchedulerLike;
}

interface DispatchCloseArg<T> {
  subscriber: BufferTimeSubscriber<T>;
  context: Context<T>;
}

/**
 * We need this JSDoc comment for affecting ESDoc.
 * @ignore
 * @extends {Ignored}
 */
class BufferTimeSubscriber<T> extends Subscriber<T> {
  private contexts: Array<Context<T>> = [];
  private timespanOnly: boolean;

  constructor(destination: Subscriber<T[]>,
              private bufferTimeSpan: number,
              private bufferCreationInterval: number,
              private maxBufferSize: number,
              private scheduler: SchedulerLike) {
    super(destination);
    const context = this.openContext();
    this.timespanOnly = bufferCreationInterval == null || bufferCreationInterval < 0;
    if (this.timespanOnly) {
      const timeSpanOnlyState = { subscriber: this, context, bufferTimeSpan };
      this.add(context.closeAction = scheduler.schedule(dispatchBufferTimeSpanOnly, bufferTimeSpan, timeSpanOnlyState));
    } else {
      const closeState = { subscriber: this, context };
      const creationState: DispatchCreateArg<T> = { bufferTimeSpan, bufferCreationInterval, subscriber: this, scheduler };
      this.add(context.closeAction = scheduler.schedule<DispatchCloseArg<T>>(dispatchBufferClose, bufferTimeSpan, closeState));
      this.add(scheduler.schedule<DispatchCreateArg<T>>(dispatchBufferCreation, bufferCreationInterval, creationState));
    }
  }

  protected _next(value: T) {
    const contexts = this.contexts;
    const len = contexts.length;
    let filledBufferContext: Context<T>;
    for (let i = 0; i < len; i++) {
      const context = contexts[i];
      const buffer = context.buffer;
      buffer.push(value);
      if (buffer.length == this.maxBufferSize) {
        filledBufferContext = context;
      }
    }

    if (filledBufferContext) {
      this.onBufferFull(filledBufferContext);
    }
  }

  protected _error(err: any) {
    this.contexts.length = 0;
    super._error(err);
  }

  protected _complete() {
    const { contexts, destination } = this;
    while (contexts.length > 0) {
      const context = contexts.shift();
      destination.next(context.buffer);
    }
    super._complete();
  }

  /** @deprecated This is an internal implementation detail, do not use. */
  _unsubscribe() {
    this.contexts = null;
  }

  protected onBufferFull(context: Context<T>) {
    this.closeContext(context);
    const closeAction = context.closeAction;
    closeAction.unsubscribe();
    this.remove(closeAction);

    if (!this.closed && this.timespanOnly) {
      context = this.openContext();
      const bufferTimeSpan = this.bufferTimeSpan;
      const timeSpanOnlyState = { subscriber: this, context, bufferTimeSpan };
      this.add(context.closeAction = this.scheduler.schedule(dispatchBufferTimeSpanOnly, bufferTimeSpan, timeSpanOnlyState));
    }
  }

  openContext(): Context<T> {
    const context: Context<T> = new Context<T>();
    this.contexts.push(context);
    return context;
  }

  closeContext(context: Context<T>) {
    this.destination.next(context.buffer);
    const contexts = this.contexts;

    const spliceIndex = contexts ? contexts.indexOf(context) : -1;
    if (spliceIndex >= 0) {
      contexts.splice(contexts.indexOf(context), 1);
    }
  }
}

function dispatchBufferTimeSpanOnly(this: SchedulerAction<any>, state: any) {
  const subscriber: BufferTimeSubscriber<any> = state.subscriber;

  const prevContext = state.context;
  if (prevContext) {
    subscriber.closeContext(prevContext);
  }

  if (!subscriber.closed) {
    state.context = subscriber.openContext();
    state.context.closeAction = this.schedule(state, state.bufferTimeSpan);
  }
}

function dispatchBufferCreation<T>(this: SchedulerAction<DispatchCreateArg<T>>, state: DispatchCreateArg<T>) {
  const { bufferCreationInterval, bufferTimeSpan, subscriber, scheduler } = state;
  const context = subscriber.openContext();
  const action = <SchedulerAction<DispatchCreateArg<T>>>this;
  if (!subscriber.closed) {
    subscriber.add(context.closeAction = scheduler.schedule<DispatchCloseArg<T>>(dispatchBufferClose, bufferTimeSpan, { subscriber, context }));
    action.schedule(state, bufferCreationInterval);
  }
}

function dispatchBufferClose<T>(arg: DispatchCloseArg<T>) {
  const { subscriber, context } = arg;
  subscriber.closeContext(context);
}

Filemanager

Name Type Size Permission Actions
audit.ts File 4.14 KB 0644
auditTime.ts File 2.38 KB 0644
buffer.ts File 2.54 KB 0644
bufferCount.ts File 4.46 KB 0644
bufferTime.ts File 8.51 KB 0644
bufferToggle.ts File 5.6 KB 0644
bufferWhen.ts File 3.89 KB 0644
catchError.ts File 4.72 KB 0644
combineAll.ts File 2.44 KB 0644
combineLatest.ts File 4.32 KB 0644
concat.ts File 2.18 KB 0644
concatAll.ts File 2.26 KB 0644
concatMap.ts File 3.4 KB 0644
concatMapTo.ts File 3.05 KB 0644
count.ts File 3.78 KB 0644
debounce.ts File 4.88 KB 0644
debounceTime.ts File 4.54 KB 0644
defaultIfEmpty.ts File 2.69 KB 0644
delay.ts File 5.09 KB 0644
delayWhen.ts File 7.7 KB 0644
dematerialize.ts File 2.58 KB 0644
distinct.ts File 4.22 KB 0644
distinctUntilChanged.ts File 3.76 KB 0644
distinctUntilKeyChanged.ts File 2.79 KB 0644
elementAt.ts File 2.56 KB 0644
endWith.ts File 4.06 KB 0644
every.ts File 2.54 KB 0644
exhaust.ts File 3.2 KB 0644
exhaustMap.ts File 5.64 KB 0644
expand.ts File 6.18 KB 0644
filter.ts File 3.69 KB 0644
finalize.ts File 1.3 KB 0644
find.ts File 3.81 KB 0644
findIndex.ts File 1.86 KB 0644
first.ts File 3.36 KB 0644
groupBy.ts File 9.95 KB 0644
ignoreElements.ts File 1.49 KB 0644
index.ts File 4.02 KB 0644
isEmpty.ts File 2.67 KB 0644
last.ts File 2.36 KB 0644
map.ts File 3.04 KB 0644
mapTo.ts File 1.9 KB 0644
materialize.ts File 3.25 KB 0644
max.ts File 1.54 KB 0644
merge.ts File 3.59 KB 0644
mergeAll.ts File 2.43 KB 0644
mergeMap.ts File 6.28 KB 0644
mergeMapTo.ts File 2.56 KB 0644
mergeScan.ts File 4.65 KB 0644
min.ts File 1.54 KB 0644
multicast.ts File 3.46 KB 0644
observeOn.ts File 5.17 KB 0644
onErrorResumeNext.ts File 8.18 KB 0644
pairwise.ts File 2.43 KB 0644
partition.ts File 2.68 KB 0644
pluck.ts File 3.07 KB 0644
publish.ts File 2.51 KB 0644
publishBehavior.ts File 589 B 0644
publishLast.ts File 2.06 KB 0644
publishReplay.ts File 1.47 KB 0644
race.ts File 1.85 KB 0644
reduce.ts File 3.71 KB 0644
refCount.ts File 5 KB 0644
repeat.ts File 3.03 KB 0644
repeatWhen.ts File 4.15 KB 0644
retry.ts File 2.74 KB 0644
retryWhen.ts File 3.45 KB 0644
sample.ts File 2.78 KB 0644
sampleTime.ts File 3.18 KB 0644
scan.ts File 4.13 KB 0644
sequenceEqual.ts File 5.16 KB 0644
share.ts File 1.02 KB 0644
shareReplay.ts File 4.19 KB 0644
single.ts File 3.79 KB 0644
skip.ts File 1.27 KB 0644
skipLast.ts File 2.81 KB 0644
skipUntil.ts File 3.81 KB 0644
skipWhile.ts File 1.95 KB 0644
startWith.ts File 4.35 KB 0644
subscribeOn.ts File 2.56 KB 0644
switchAll.ts File 1.99 KB 0644
switchMap.ts File 6.04 KB 0644
switchMapTo.ts File 2.56 KB 0644
take.ts File 2.74 KB 0644
takeLast.ts File 3.44 KB 0644
takeUntil.ts File 2.79 KB 0644
takeWhile.ts File 3.87 KB 0644
tap.ts File 5.33 KB 0644
throttle.ts File 4.83 KB 0644
throttleTime.ts File 5.83 KB 0644
throwIfEmpty.ts File 2.19 KB 0644
timeInterval.ts File 2.49 KB 0644
timeout.ts File 4.07 KB 0644
timeoutWith.ts File 6.13 KB 0644
timestamp.ts File 1.67 KB 0644
toArray.ts File 1.12 KB 0644
window.ts File 3.72 KB 0644
windowCount.ts File 4.82 KB 0644
windowTime.ts File 9.9 KB 0644
windowToggle.ts File 6.2 KB 0644
windowWhen.ts File 4.57 KB 0644
withLatestFrom.ts File 7.72 KB 0644
zip.ts File 3.35 KB 0644
zipAll.ts File 653 B 0644