molstar
Version:
A comprehensive macromolecular library.
50 lines (49 loc) • 3.66 kB
TypeScript
/**
* Copyright (c) 2017-2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
*
* @author David Sehnal <david.sehnal@gmail.com>
*/
import { Interval } from './interval';
declare namespace SortedArray {
const Empty: SortedArray;
const ofUnsortedArray: <T extends number = number>(xs: ArrayLike<number>) => SortedArray<T>;
const ofSingleton: <T extends number = number>(v: number) => SortedArray<T>;
const ofSortedArray: <T extends number = number>(xs: ArrayLike<number>) => SortedArray<T>;
/** create sorted array [min, max] (it DOES contain the max value) */
const ofRange: <T extends number = number>(min: T, max: T) => SortedArray<T>;
/** create sorted array [min, max) (it does NOT contain the max value) */
const ofBounds: <T extends number = number>(min: T, max: T) => SortedArray<T>;
const is: <T extends number = number>(v: any) => v is SortedArray<T>;
const isRange: <T extends number = number>(array: ArrayLike<number>) => boolean;
const has: <T extends number = number>(array: SortedArray<T>, x: T) => boolean;
/** Returns the index of `x` in `set` or -1 if not found. */
const indexOf: <T extends number = number>(array: SortedArray<T>, x: T) => number;
const indexOfInInterval: <T extends number = number>(array: SortedArray<T>, x: number, bounds: Interval) => number;
const indexOfInRange: <T extends number = number>(array: SortedArray<T>, x: number, start: number, end: number) => number;
/** Returns `array[0]` */
const start: <T extends number = number>(array: SortedArray<T>) => T;
/** Returns `array[array.length - 1] + 1` */
const end: <T extends number = number>(array: SortedArray<T>) => T;
const min: <T extends number = number>(array: SortedArray<T>) => T;
const max: <T extends number = number>(array: SortedArray<T>) => T;
const size: <T extends number = number>(array: SortedArray<T>) => number;
const hashCode: <T extends number = number>(array: SortedArray<T>) => number;
const toString: <T extends number = number>(array: SortedArray<T>) => string;
const areEqual: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => boolean;
const areIntersecting: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => boolean;
const isSubset: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => boolean;
const union: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => SortedArray<T>;
const intersect: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => SortedArray<T>;
const subtract: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => SortedArray<T>;
const findPredecessorIndex: <T extends number = number>(array: SortedArray<T>, x: T) => number;
const findPredecessorIndexInInterval: <T extends number = number>(array: SortedArray<T>, x: T, bounds: Interval) => number;
const findRange: <T extends number = number>(array: SortedArray<T>, min: T, max: T) => Interval;
const intersectionSize: <T extends number = number>(a: SortedArray<T>, b: SortedArray<T>) => number;
const deduplicate: <T extends number = number>(array: SortedArray<T>) => SortedArray<T>;
/** Returns indices of xs in the array. E.g. indicesOf([10, 11, 12], [10, 12]) ==> [0, 2] */
const indicesOf: <T extends number = number, I extends number = number>(array: SortedArray<T>, xs: SortedArray<T>) => SortedArray<I>;
}
interface SortedArray<T extends number = number> extends ArrayLike<T> {
'@type': 'int-sorted-array';
}
export { SortedArray };