import { FlowrAnalyzerFilesContext, type RAnalysisRequest, type ReadOnlyFlowrAnalyzerFilesContext } from './flowr-analyzer-files-context';
import { FlowrAnalyzerDependenciesContext, type ReadOnlyFlowrAnalyzerDependenciesContext } from './flowr-analyzer-dependencies-context';
import { type FlowrAnalyzerPlugin, PluginType } from '../plugins/flowr-analyzer-plugin';
import type { fileProtocol, RParseRequestFromFile, RParseRequests } from '../../r-bridge/retriever';
import { FlowrConfig } from '../../config';
import type { FlowrFileProvider } from './flowr-file';
import type { ReadOnlyFlowrAnalyzerEnvironmentContext } from './flowr-analyzer-environment-context';
import { FlowrAnalyzerEnvironmentContext } from './flowr-analyzer-environment-context';
import type { ReadOnlyFlowrAnalyzerMetaContext } from './flowr-analyzer-meta-context';
import { FlowrAnalyzerMetaContext } from './flowr-analyzer-meta-context';
import type { FlowrAnalyzer } from '../flowr-analyzer';
/**
 * This is a read-only interface to the {@link FlowrAnalyzerContext}.
 * It prevents you from modifying the context, but allows you to inspect it (which is probably what you want when using the {@link FlowrAnalyzer}).
 * If you are a {@link FlowrAnalyzerPlugin} and want to modify the context, you can use the {@link FlowrAnalyzerContext} directly.
 */
export interface ReadOnlyFlowrAnalyzerContext {
    /**
     * The meta context provides access to the project metadata such as name, version, and namespace.
     */
    readonly meta: ReadOnlyFlowrAnalyzerMetaContext;
    /**
     * The files context provides access to the files to be analyzed and their loading order.
     */
    readonly files: ReadOnlyFlowrAnalyzerFilesContext;
    /**
     * The dependencies context provides access to the identified dependencies and their versions.
     */
    readonly deps: ReadOnlyFlowrAnalyzerDependenciesContext;
    /**
     * The environment context provides access to the environment information used during analysis.
     */
    readonly env: ReadOnlyFlowrAnalyzerEnvironmentContext;
    /**
     * The configuration options used by the analyzer.
     */
    readonly config: FlowrConfig;
}
/**
 * This summarizes the other context layers used by the {@link FlowrAnalyzer}.
 * Have a look at the attributes and layers listed below (e.g., {@link files} and {@link deps})
 * to get an idea of the capabilities provided by this context.
 * Besides these, this layer only orchestrates the different steps and layers, providing a collection of convenience methods.
 * In general, you do not have to worry about these details, as the {@link FlowrAnalyzerBuilder} and {@link FlowrAnalyzer} take care of them.
 *
 * To inspect, e.g., the loading order, you can do so via {@link files.loadingOrder.getLoadingOrder}. To get information on a specific library, use
 * {@link deps.getDependency}.
 * If you are just interested in inspecting the context, you can use {@link ReadOnlyFlowrAnalyzerContext} instead (e.g., via {@link inspect}).
 */
export declare class FlowrAnalyzerContext implements ReadOnlyFlowrAnalyzerContext {
    readonly meta: FlowrAnalyzerMetaContext;
    readonly files: FlowrAnalyzerFilesContext;
    readonly deps: FlowrAnalyzerDependenciesContext;
    readonly env: FlowrAnalyzerEnvironmentContext;
    private _analyzer;
    readonly config: FlowrConfig;
    constructor(config: FlowrConfig, plugins: ReadonlyMap<PluginType, readonly FlowrAnalyzerPlugin[]>);
    /**
     * Provides the analyzer associated with this context, if any.
     * This is usually set when the context is used within an analyzer instance.
     * Please note, that this may be `undefined` if the context is used standalone (e.g., during setup or in plugins that do not have access to the analyzer).
     */
    get analyzer(): FlowrAnalyzer | undefined;
    setAnalyzer(analyzer: FlowrAnalyzer): void;
    /** delegate request addition */
    addRequests(requests: readonly RAnalysisRequest[]): void;
    addFile(f: string | FlowrFileProvider | RParseRequestFromFile): void;
    addFiles(f: (string | FlowrFileProvider | RParseRequestFromFile)[]): void;
    /**
     * Get a read-only version of this context.
     * This is useful if you want to pass the context to a place where you do not want it to be modified or just to reduce
     * the available methods.
     */
    inspect(): ReadOnlyFlowrAnalyzerContext;
    /**
     * Reset the context to its initial state, e.g., removing all files, dependencies, and loading orders.
     */
    reset(): void;
}
/**
 * Lifting {@link requestFromInput} to create a full {@link FlowrAnalyzerContext} from input requests.
 * Please use this only for a "quick" setup, or to have compatibility with the pre-project flowR era.
 * Otherwise, refer to a {@link FlowrAnalyzerBuilder} to create a fully customized {@link FlowrAnalyzer} instance.
 * @see {@link requestFromInput} - for details on how inputs are processed into requests.
 * @see {@link contextFromSources} - to create a context from source code strings directly.
 */
export declare function contextFromInput(input: `${typeof fileProtocol}${string}` | string | readonly string[] | RParseRequests, config?: FlowrConfig, plugins?: FlowrAnalyzerPlugin[]): FlowrAnalyzerContext;
/**
 * Create a {@link FlowrAnalyzerContext} from a set of source code strings.
 * @param sources - A record mapping file paths to their source code content.
 * @param config  - Configuration options for the analyzer.
 * @param plugins - Optional plugins to extend the analyzer's functionality.
 * @see {@link contextFromInput}    - to create a context from input requests.
 * @see {@link FlowrInlineTextFile} - to create inline text files for the sources.
 */
export declare function contextFromSources(sources: Record<string, string>, config?: FlowrConfig, plugins?: FlowrAnalyzerPlugin[]): FlowrAnalyzerContext;
