import type { FilledMangoQuery, MangoQuerySelector, RxDocumentData, RxJsonSchema, RxQueryPlan, RxQueryPlanKey, RxQueryPlanerOpts } from './types/index.d.ts'; export declare const INDEX_MAX: string; /** * Do not use -Infinity here because it would be * transformed to null on JSON.stringify() which can break things * when the query plan is sent to the storage as json. * @link https://stackoverflow.com/a/16644751 * Notice that for IndexedDB IDBKeyRange we have * to transform the value back to -Infinity * before we can use it in IDBKeyRange.bound. */ export declare const INDEX_MIN: number; /** * Returns the query plan which contains * information about how to run the query * and which indexes to use. * * This is used in some storage like Memory, dexie.js and IndexedDB. */ export declare function getQueryPlan(schema: RxJsonSchema>, query: FilledMangoQuery): RxQueryPlan; export declare const LOGICAL_OPERATORS: Set; export declare const LOWER_BOUND_LOGICAL_OPERATORS: Set; export declare const UPPER_BOUND_LOGICAL_OPERATORS: Set; export declare function isSelectorSatisfiedByIndex(index: string[], selector: MangoQuerySelector, startKeys: RxQueryPlanKey[], endKeys: RxQueryPlanKey[]): boolean; export declare function getMatcherQueryOpts(operator: string, operatorValue: any): Partial; /** * Returns a number that determines the quality of the query plan. * Higher number means better query plan. */ export declare function rateQueryPlan(schema: RxJsonSchema>, query: FilledMangoQuery, queryPlan: RxQueryPlan): number;