import type { NoInfo, RNode } from '../r-bridge/lang-4.x/ast/model/model';
import type { NodeId } from '../r-bridge/lang-4.x/ast/model/processing/node-id';
import { type Enrichment, type EnrichmentElementContent, type EnrichmentSearchArguments, type EnrichmentSearchContent } from './search-executor/search-enrichers';
import type { ReadonlyFlowrAnalysisProvider } from '../project/flowr-analyzer';
/**
 * Yes, for now we do technically not need a wrapper around the RNode, but this allows us to attach caches etc.
 * just for the respective search.
 */
export interface FlowrSearchElement<Info> {
    readonly node: RNode<Info>;
    readonly enrichments?: {
        [E in Enrichment]?: EnrichmentElementContent<E>;
    };
}
export interface FlowrSearchNodeBase<Type extends string, Name extends string, Args extends Record<string, unknown> | undefined> {
    readonly type: Type;
    readonly name: Name;
    readonly args: Args;
}
export type FlowrSearchGeneratorNodeBase<Name extends string, Args extends Record<string, unknown> | undefined> = FlowrSearchNodeBase<'generator', Name, Args>;
export type FlowrSearchTransformerNodeBase<Name extends string, Args extends Record<string, unknown> | undefined> = FlowrSearchNodeBase<'transformer', Name, Args>;
export interface FlowrSearchGetFilter extends Record<string, unknown> {
    /**
     * The node must be in the given line.
     */
    readonly line?: number;
    /**
     * The node must be in the given column.
     */
    readonly column?: number;
    /**
     * The node must have the given name.
     * To treat this name as a regular expression, set {@link FlowrSearchGetFilter#nameIsRegex} to true.
     */
    readonly name?: string;
    /**
     * Only useful in combination with `name`. If true, the name is treated as a regular expression.
     */
    readonly nameIsRegex?: boolean;
    /**
     * The node must have the given id.
     */
    readonly id?: NodeId;
    /**
     * The node must stem form a file with the given path matching the regex
     * Please note that you can address the full path!
     * @example
     * ```ts
     * // matches all files in any 'tests' folder
     * filePath: '.*\\tests\\.*'
     * // matches all files named 'myfile.R' in any folder
     * filePath: '.*\\/myfile\\.R$'
     * ```
     */
    readonly filePathRegex?: string;
}
/** Intentionally, we abstract away from an array to avoid the use of conventional typescript operations */
export declare class FlowrSearchElements<Info = NoInfo, Elements extends FlowrSearchElement<Info>[] = FlowrSearchElement<Info>[]> {
    private elements;
    private enrichments;
    constructor(elements?: Elements);
    add(element: FlowrSearchElement<Info>): this;
    addAll(elements: FlowrSearchElement<Info>[]): this;
    getElements(): Readonly<Elements>;
    mutate<OutElements extends Elements>(mutator: (elements: Elements) => OutElements | Promise<OutElements>): this | Promise<this>;
    /**
     * Enriches this flowr search element collection with the given enrichment.
     * To retrieve enrichment content for a given enrichment type, use {@link enrichmentContent}.
     *
     * Please note that this function does not also enrich individual elements, which is done through {@link enrichElement}. Both functions are called in a concise manner in {@link FlowrSearchBuilder.with}, which is the preferred way to add enrichments to a search.
     */
    enrich<E extends Enrichment>(data: ReadonlyFlowrAnalysisProvider, enrichment: E, args?: EnrichmentSearchArguments<E>): Promise<this>;
    enrichmentContent<E extends Enrichment>(enrichment: E): EnrichmentSearchContent<E>;
}
