forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ix.d.ts
117 lines (82 loc) · 4.85 KB
/
ix.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Type definitions for IxJS 1.0.6 / ix.js
// Project: https://github.com/Reactive-Extensions/IxJS
// Definitions by: Igor Oleinikov <https://github.com/Igorbek>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
///<reference path="l2o.d.ts"/>
declare namespace Ix {
export interface Observer<T> {
onNext? (value: T): void;
onError? (error: Error): void;
onCompleted? (): void;
}
export interface Enumerable<T> {
isEmpty(): boolean;
minBy<TKey>(keySelector: (item: T) => TKey, comparer: Comparer<TKey, TKey>): Enumerable<T>;
minBy(keySelector: (item: T) => number): Enumerable<T>;
maxBy<TKey>(keySelector: (item: T) => TKey, comparer: Comparer<TKey, TKey>): Enumerable<T>;
maxBy(keySelector: (item: T) => number): Enumerable<T>;
share<TResult>(selector: (source: Enumerable<T>) => Enumerable<TResult>): Enumerable<TResult>;
share(): Enumerable<T>;
publish<TResult>(selector: (source: Enumerable<T>) => Enumerable<TResult>): Enumerable<TResult>;
publish(): Enumerable<T>;
memoize(): Enumerable<T>;
do(onNext: (value: T) => void, onError?: (error: Error) => void, onCompleted?: () => void): Enumerable<T>;
doAction(onNext: (value: T) => void, onError?: (error: Error) => void, onCompleted?: () => void): Enumerable<T>;
do(onbserver: Observer<T>): Enumerable<T>;
doAction(onbserver: Observer<T>): Enumerable<T>;
bufferWithCount(count: number, skip?: number): Enumerable<T>;
ignoreElements(): Enumerable<T>;
distinctBy<TKey>(keySelector: (item: T) => TKey, comparer?: EqualityComparer<TKey, TKey>): Enumerable<T>;
distinctUntilChanged<TKey>(keySelector: (item: T) => TKey, comparer?: EqualityComparer<TKey, TKey>): Enumerable<T>;
distinctUntilChanged(): Enumerable<T>;
// if need to set comparer without keySelector
distinctUntilChanged(_: boolean, comparer: EqualityComparer<T, T>): Enumerable<T>;
expand(selector: (item: T) => Enumerable<T>): Enumerable<T>;
startWith(...values: T[]): Enumerable<T>;
scan<TAccumulate>(seed: TAccumulate, accumulate: (acc: TAccumulate, item: T) => TAccumulate): Enumerable<TAccumulate>;
scan(accumulate: (acc: T, item: T) => T): Enumerable<T>;
takeLast(count: number): Enumerable<T>;
skipLast(count: number): Enumerable<T>;
repeat(count?: number): Enumerable<T>;
catch(handler: (error: Error) => Enumerable<T>): Enumerable<T>;
catchException(handler: (error: Error) => Enumerable<T>): Enumerable<T>;
catch(second: Enumerable<T>, ...other: Enumerable<T>[]): Enumerable<T>;
catchException(second: Enumerable<T>, ...other: Enumerable<T>[]): Enumerable<T>;
// todo: Enumerable<Enumerable<T>>.catch(): Enumerable<T>
//catch<TInner, T extends Enumerable<TInner>>(): Enumerable<TInner>;
finally(finallyAction: () => void): Enumerable<T>;
finallyDo(finallyAction: () => void): Enumerable<T>;
onErrorResumeNext(second: Enumerable<T>): Enumerable<T>;
retry(retryCount?: number): Enumerable<T>;
}
export interface EnumerableStatic {
throw<T>(error: Error): Enumerable<T>;
throwException<T>(error: Error): Enumerable<T>;
defer<T>(enumerableFactory: () => Enumerable<T>): Enumerable<T>;
generate<TState, TResult>(
initialState: TState,
condition: Predicate<TState>,
iterate: (state: TState) => TState,
resultSelector: (state: TState) => TResult): Enumerable<TResult>;
using<TResource extends Disposable, T>(
resourceFactory: () => TResource,
enumerableFactory: (resource: TResource) => Enumerable<T>): Enumerable<T>;
catch<T>(...sources: Enumerable<T>[]): Enumerable<T>;
catchException<T>(...sources: Enumerable<T>[]): Enumerable<T>;
onErrorResumeNext<T>(...sources: Enumerable<T>[]): Enumerable<T>;
while<T>(condition: EnumerablePredicate<Enumerable<T>>, source: Enumerable<T>): Enumerable<T>;
whileDo<T>(condition: EnumerablePredicate<Enumerable<T>>, source: Enumerable<T>): Enumerable<T>;
if<T>(condition: () => boolean, thenSource: Enumerable<T>, elseSource?: Enumerable<T>): Enumerable<T>;
ifThen<T>(condition: () => boolean, thenSource: Enumerable<T>, elseSource?: Enumerable<T>): Enumerable<T>;
doWhile<T>(source: Enumerable<T>, condition: EnumerablePredicate<Enumerable<T>>): Enumerable<T>;
case<T>(selector: () => number, sources: { [key: number]: Enumerable<T>; }, defaultSource?: Enumerable<T>): Enumerable<T>;
case<T>(selector: () => string, sources: { [key: string]: Enumerable<T>; }, defaultSource?: Enumerable<T>): Enumerable<T>;
switchCase<T>(selector: () => number, sources: { [key: number]: Enumerable<T>; }, defaultSource?: Enumerable<T>): Enumerable<T>;
switchCase<T>(selector: () => string, sources: { [key: string]: Enumerable<T>; }, defaultSource?: Enumerable<T>): Enumerable<T>;
for<T, TResult>(source: Enumerable<T>, resultSelector: EnumerableFunc<T, TResult>): Enumerable<TResult>;
forIn<T, TResult>(source: Enumerable<T>, resultSelector: EnumerableFunc<T, TResult>): Enumerable<TResult>;
}
}
declare module "ix" {
export = Ix;
}