// Type definitions for linq.js v3.0.4-Beta5 // Project: https://linqjs.codeplex.com/ // Definitions by: neuecc // Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped declare module linqjs { interface IEnumerator { current(): T; moveNext(): boolean; dispose(): void; } interface IEqualityComparer { equals(x: T, y: T): boolean; getHashCode(obj: any): string; } interface ITuple { equals(other: ITuple): boolean; getHashCode(): string; } interface ITupleArray { equals(other: ITupleArray): boolean; getHashCode(): string; } interface Enumerable { Utils: { createLambda(expression: any): (...params: any[]) => any; createEnumerable(getEnumerator: () => IEnumerator): IEnumerable; createEnumerator(initialize: () => void, tryGetNext: () => boolean, dispose: () => void): IEnumerator; getDefaultEqualityComparer(): IEqualityComparer; createEqualityComparer(equals: (x: T, y: T) => boolean, getHashCode: (obj: any) => string): IEqualityComparer; createKeyedEqualityComparer(keySelector: (element: TValue) => TKey): IEqualityComparer; createDictionary(compareSelector: (element: TValue) => TKey): IDictionary; createDictionary(equalityComparer: IEqualityComparer): IDictionary; createList(): IList; createTuple(item1: T1, item2: T2, item3?: T3, item4?: T4, item5?: T5, item6?: T6, item7?: T7, item8?: T8): ITuple; extendTo(type: any, forceAppend?: boolean): void; }; choice(...params: T[]): IEnumerable; cycle(...params: T[]): IEnumerable; empty(): IEnumerable; // from, obj as JScript's IEnumerable or WinMD IIterable is IEnumerable but it can't define. from(): IEnumerable; // empty from(obj: IEnumerable): IEnumerable; from(obj: number): IEnumerable; from(obj: boolean): IEnumerable; from(obj: string): IEnumerable; from(obj: T[]): IEnumerable; from(obj: { length: number; [x: number]: T; }): IEnumerable; from(obj: any): IEnumerable<{ key: string; value: any }>; make(element: T): IEnumerable; matches(input: string, pattern: RegExp): IEnumerable; matches(input: string, pattern: string, flags?: string): IEnumerable; range(start: number, count: number, step?: number): IEnumerable; rangeDown(start: number, count: number, step?: number): IEnumerable; rangeTo(start: number, to: number, step?: number): IEnumerable; repeat(element: T, count?: number): IEnumerable; repeatWithFinalize(initializer: () => T, finalizer: (element: T) => void): IEnumerable; generate(func: () => T, count?: number): IEnumerable; toInfinity(start?: number, step?: number): IEnumerable; toNegativeInfinity(start?: number, step?: number): IEnumerable; unfold(seed: T, func: (value: T) => T): IEnumerable; defer(enumerableFactory: () => IEnumerable): IEnumerable; } interface IEnumerable { constructor(getEnumerator: () => IEnumerator): IEnumerable; getEnumerator(): IEnumerator; // Extension Methods traverseBreadthFirst(func: (element: T) => IEnumerable): IEnumerable; traverseBreadthFirst(func: (element: T) => IEnumerable, resultSelector: (element: T, nestLevel: number) => TResult): IEnumerable; traverseDepthFirst(func: (element: T) => Enumerable): IEnumerable; traverseDepthFirst(func: (element: T) => Enumerable, resultSelector?: (element: T, nestLevel: number) => TResult): IEnumerable; flatten(): IEnumerable; pairwise(selector: (prev: T, current: T) => TResult): IEnumerable; scan(func: (prev: T, current: T) => T): IEnumerable; scan(seed: TAccumulate, func: (prev: TAccumulate, current: T) => TAccumulate): IEnumerable; select(selector: (element: T, index: number) => TResult): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => IEnumerable): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => IEnumerable, resultSelector: (outer: T, inner: TCollection) => TResult): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => TOther[]): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => TCollection[], resultSelector: (outer: T, inner: TCollection) => TResult): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => { length: number; [x: number]: TOther; }): IEnumerable; selectMany(collectionSelector: (element: T, index: number) => { length: number; [x: number]: TCollection; }, resultSelector: (outer: T, inner: TCollection) => TResult): IEnumerable; where(predicate: (element: T, index: number) => boolean): IEnumerable; choose(selector: (element: T, index: number) => T): IEnumerable; ofType(type: any): IEnumerable; zip(second: IEnumerable, resultSelector: (first: T, second: T, index: number) => TResult): IEnumerable; zip(second: { length: number; [x: number]: T; }, resultSelector: (first: T, second: T, index: number) => TResult): IEnumerable; zip(second: T[], resultSelector: (first: T, second: T, index: number) => TResult): IEnumerable; zip(...params: any[]): IEnumerable; // last one is selector merge(...params: IEnumerable[]): IEnumerable; merge(...params: { length: number; [x: number]: T; }[]): IEnumerable; merge(...params: T[][]): IEnumerable; join(inner: IEnumerable, outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; join(inner: { length: number; [x: number]: TInner; }, outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; join(inner: TInner[], outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; groupJoin(inner: IEnumerable, outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; groupJoin(inner: { length: number; [x: number]: TInner; }, outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; groupJoin(inner: TInner[], outerKeySelector: (outer: T) => TKey, innerKeySelector: (inner: TInner) => TKey, resultSelector: (outer: T, inner: TKey) => TResult, compareSelector?: (obj: T) => TKey): IEnumerable; all(predicate: (element: T) => boolean): boolean; any(predicate?: (element: T) => boolean): boolean; isEmpty(): boolean; concat(...sequences: IEnumerable[]): IEnumerable; concat(...sequences: { length: number; [x: number]: T; }[]): IEnumerable; concat(...sequences: T[]): IEnumerable; insert(index: number, second: IEnumerable): IEnumerable; insert(index: number, second: { length: number; [x: number]: T; }): IEnumerable; alternate(alternateValue: T): IEnumerable; alternate(alternateSequence: { length: number; [x: number]: T; }): IEnumerable; alternate(alternateSequence: IEnumerable): IEnumerable; alternate(alternateSequence: T[]): IEnumerable; contains(value: T): boolean; contains(value: T, compareSelector?: (element: T) => TCompare): boolean; contains(value: T, equalityComparer?: IEqualityComparer): boolean; defaultIfEmpty(defaultValue?: T): IEnumerable; distinct(): IEnumerable; distinct(compareSelector: (element: T) => TCompare): IEnumerable; distinctUntilChanged(): IEnumerable; distinctUntilChanged(compareSelector: (element: T) => TCompare): IEnumerable; except(second: { length: number; [x: number]: T; }): IEnumerable; except(second: { length: number; [x: number]: T; }, compareSelector: (element: T) => TCompare): IEnumerable; except(second: IEnumerable): IEnumerable; except(second: IEnumerable, compareSelector: (element: T) => TCompare): IEnumerable; except(second: T[]): IEnumerable; except(second: T[], compareSelector: (element: T) => TCompare): IEnumerable; intersect(second: { length: number; [x: number]: T; }): IEnumerable; intersect(second: { length: number; [x: number]: T; }, compareSelector: (element: T) => TCompare): IEnumerable; intersect(second: IEnumerable): IEnumerable; intersect(second: IEnumerable, compareSelector: (element: T) => TCompare): IEnumerable; intersect(second: T[]): IEnumerable; intersect(second: T[], compareSelector: (element: T) => TCompare): IEnumerable; union(second: { length: number; [x: number]: T; }): IEnumerable; union(second: { length: number; [x: number]: T; }, compareSelector: (element: T) => TCompare): IEnumerable; union(second: IEnumerable): IEnumerable; union(second: IEnumerable, compareSelector: (element: T) => TCompare): IEnumerable; union(second: T[]): IEnumerable; union(second: T[], compareSelector: (element: T) => TCompare): IEnumerable; sequenceEqual(second: { length: number; [x: number]: T; }): boolean; sequenceEqual(second: { length: number; [x: number]: T; }, compareSelector: (element: T) => TCompare): boolean; sequenceEqual(second: IEnumerable): boolean; sequenceEqual(second: IEnumerable, compareSelector: (element: T) => TCompare): boolean; sequenceEqual(second: T[]): boolean; sequenceEqual(second: T[], compareSelector: (element: T) => TCompare): boolean; orderBy(keySelector: (element: T) => TKey): IOrderedEnumerable; orderBy(keySelector: (element: T) => TKey, comparison: (x: TKey, y: TKey) => number): IOrderedEnumerable; orderByDescending(keySelector: (element: T) => TKey): IOrderedEnumerable; orderByDescending(keySelector: (element: T) => TKey, comparison: (x: TKey, y: TKey) => number): IOrderedEnumerable; reverse(): IEnumerable; shuffle(): IEnumerable; weightedSample(weightSelector: (element: T) => number): IEnumerable; // truly, return type is IEnumerable> but Visual Studio + TypeScript Compiler can't compile. groupBy(keySelector: (element: T) => TKey): IEnumerable>; groupBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement): IEnumerable>; groupBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement, resultSelector: (key: TKey, element: IEnumerable) => TResult): IEnumerable; groupBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement, resultSelector: (key: TKey, element: IEnumerable) => TResult, compareSelector: (element: TKey) => TCompare): IEnumerable; // :IEnumerable> partitionBy(keySelector: (element: T) => TKey): IEnumerable>; // :IEnumerable> partitionBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement): IEnumerable>; partitionBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement, resultSelector: (key: TKey, element: IEnumerable) => TResult): IEnumerable; partitionBy(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement, resultSelector: (key: TKey, element: IEnumerable) => TResult, compareSelector: (element: T) => TCompare): IEnumerable; buffer(count: number): IEnumerable; aggregate(func: (prev: T, current: T) => T): T; aggregate(seed: TAccumulate, func: (prev: TAccumulate, current: T) => TAccumulate): TAccumulate; aggregate(seed: TAccumulate, func: (prev: TAccumulate, current: T) => TAccumulate, resultSelector: (last: TAccumulate) => TResult): TResult; average(selector?: (element: T) => number): number; count(predicate?: (element: T, index: number) => boolean): number; max(selector?: (element: T) => number): number; min(selector?: (element: T) => number): number; maxBy(keySelector: (element: T) => TKey): T; minBy(keySelector: (element: T) => TKey): T; sum(selector?: (element: T) => number): number; elementAt(index: number): T; elementAtOrDefault(index: number, defaultValue?: T): T; first(predicate?: (element: T, index: number) => boolean): T; firstOrDefault(predicate?: (element: T, index: number) => boolean, defaultValue?: T): T; last(predicate?: (element: T, index: number) => boolean): T; lastOrDefault(predicate?: (element: T, index: number) => boolean, defaultValue?: T): T; single(predicate?: (element: T, index: number) => boolean): T; singleOrDefault(predicate?: (element: T, index: number) => boolean, defaultValue?: T): T; skip(count: number): IEnumerable; skipWhile(predicate: (element: T, index: number) => boolean): IEnumerable; take(count: number): IEnumerable; takeWhile(predicate: (element: T, index: number) => boolean): IEnumerable; takeExceptLast(count?: number): IEnumerable; takeFromLast(count: number): IEnumerable; indexOf(item: T): number; indexOf(predicate: (element: T, index: number) => boolean): number; lastIndexOf(item: T): number; lastIndexOf(predicate: (element: T, index: number) => boolean): number; asEnumerable(): IEnumerable; cast(): IEnumerable; toArray(): T[]; toList(): IList; // truly, return type is ILookup but Visual Studio + TypeScript Compiler can't compile. toLookup(keySelector: (element: T) => TKey): ILookup; toLookup(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement): ILookup; toLookup(keySelector: (element: T) => TKey, elementSelector: (element: T) => TElement, compareSelector: (key: TKey) => TCompare): ILookup; toObject(keySelector: (element: T) => any, elementSelector?: (element: T) => any): Object; // :IDictionary toDictionary(keySelector: (element: T) => TKey): IDictionary; toDictionary(keySelector: (element: T) => TKey, elementSelector: (element: T) => TValue): IDictionary; toDictionary(keySelector: (element: T) => TKey, elementSelector: (element: T) => TValue, compareSelector: (key: TKey) => TCompare): IDictionary; toJSONString(replacer: (key: string, value: any) => any): string; toJSONString(replacer: any[]): string; toJSONString(replacer: (key: string, value: any) => any, space: any): string; toJSONString(replacer: any[], space: any): string; toJoinedString(separator?: string): string; toJoinedString(separator: string, selector: (element: T, index: number) => TResult): string; doAction(action: (element: T, index: number) => void): IEnumerable; doAction(action: (element: T, index: number) => boolean): IEnumerable; forEach(action: (element: T, index: number) => void): void; forEach(action: (element: T, index: number) => boolean): void; write(separator?: string): void; write(separator: string, selector: (element: T) => TResult): void; writeLine(): void; writeLine(selector: (element: T) => TResult): void; force(): void; letBind(func: (source: IEnumerable) => { length: number; [x: number]: TResult; }): IEnumerable; letBind(func: (source: IEnumerable) => TResult[]): IEnumerable; letBind(func: (source: IEnumerable) => IEnumerable): IEnumerable; share(): IDisposableEnumerable; memoize(): IDisposableEnumerable; catchError(handler: (exception: any) => void): IEnumerable; finallyAction(finallyAction: () => void): IEnumerable; log(): IEnumerable; log(selector: (element: T) => TValue): IEnumerable; trace(message?: string): IEnumerable; trace(message: string, selector: (element: T) => TValue): IEnumerable; } interface IOrderedEnumerable extends IEnumerable { createOrderedEnumerable(keySelector: (element: T) => TKey, comparison: (x: TKey, y: TKey) => number, descending: boolean): IOrderedEnumerable; thenBy(keySelector: (element: T) => TKey) : IOrderedEnumerable; thenBy(keySelector: (element: T) => TKey, comparison: (x: TKey, y: TKey) => number) : IOrderedEnumerable; thenByDescending(keySelector: (element: T) => TKey): IOrderedEnumerable; thenByDescending(keySelector: (element: T) => TKey, comparison: (x: TKey, y: TKey) => number): IOrderedEnumerable; } interface IDisposableEnumerable extends IEnumerable { dispose(): void; } interface IDictionary { add(key: TKey, value: TValue): void; get(key: TKey): TValue; set(key: TKey, value: TValue): boolean; contains(key: TKey): boolean; clear(): void; remove(key: TKey): void; count(): number; toEnumerable(): IEnumerable<{ key: TKey; value: TValue }>; } interface ILookup { count(): number; get(key: TKey): IEnumerable; contains(key: TKey): boolean; toEnumerable(): IEnumerable>; } interface IGrouping extends IEnumerable { key(): TKey; } interface IList extends Array { } } // export definition declare var Enumerable: linqjs.Enumerable;