| 1234567891011121314151617181920212223242526272829303132 |
- declare type Key = string | number | symbol;
- /**
- * SetArray acts like a `Set` (allowing only one occurrence of a string `key`), but provides the
- * index of the `key` in the backing array.
- *
- * This is designed to allow synchronizing a second array with the contents of the backing array,
- * like how in a sourcemap `sourcesContent[i]` is the source content associated with `source[i]`,
- * and there are never duplicates.
- */
- export declare class SetArray<T extends Key = Key> {
- private _indexes;
- array: readonly T[];
- constructor();
- }
- /**
- * Gets the index associated with `key` in the backing array, if it is already present.
- */
- export declare function get<T extends Key>(setarr: SetArray<T>, key: T): number | undefined;
- /**
- * Puts `key` into the backing array, if it is not already present. Returns
- * the index of the `key` in the backing array.
- */
- export declare function put<T extends Key>(setarr: SetArray<T>, key: T): number;
- /**
- * Pops the last added item out of the SetArray.
- */
- export declare function pop<T extends Key>(setarr: SetArray<T>): void;
- /**
- * Removes the key, if it exists in the set.
- */
- export declare function remove<T extends Key>(setarr: SetArray<T>, key: T): void;
- export {};
|