summaryrefslogtreecommitdiffstats
path: root/binary-search/binary-search.d.ts
blob: 0395d935829845fbd797e2f26653cebb08c5dbab (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//Typescript type definition for:
//https://github.com/darkskyapp/binary-search
declare module 'binary-search' {

function binarySearch<A, B>(
  haystack: ArrayLike<A>,
  needle: B,
  comparator: (a: A, b: B, index?: number, haystack?: A[]) => any,
  // Notes about comparator return value:
  // * when a<b the comparator's returned value should be:
  //   * negative number or a value such that `+value` is a negative number
  //   * examples: `-1` or the string `"-1"`
  // * when a>b the comparator's returned value should be:
  //   * positive number or a value such that `+value` is a positive number
  //   * examples: `1` or the string `"1"`
  // * when a===b
  //    * any value other than the return cases for a<b and a>b
  //    * examples: undefined, NaN, 'abc'
  low?: number,
  high?: number): number; //returns index of found result or number < 0 if not found
export = binarySearch;
}