import { Parse } from '../../data.js';
import { Dict } from '../../util.js';
import { Split } from '../split.js';
import { OutputNode } from './dataflow.js';
import { FacetNode } from './facet.js';
import { SourceNode } from './source.js';
export interface DataComponent {
    /**
     * A list of unique sources.
     */
    sources: SourceNode[];
    /**
     * Registry of output nodes.
     */
    outputNodes: Dict<OutputNode | FacetNode>;
    /**
     * How often is an output node used. If it is not used, we don't need to
     * instantiate it in the assemble step.
     */
    outputNodeRefCounts: Dict<number>;
    /**
     * The output node before aggregation.
     */
    raw?: OutputNode;
    /**
     * The output node for scale domain before filter invalid.
     */
    preFilterInvalid?: OutputNode;
    /**
     * The output node for scale domain after filter invalid.
     */
    postFilterInvalid?: OutputNode;
    /**
     * The main output node.
     */
    main?: OutputNode;
    /**
     * For facets, we store the reference to the root node.
     */
    facetRoot?: FacetNode;
    /**
     * True if the data for this model is faceted.
     * A dataset is faceted if a parent model is a facet and no new dataset is
     * defined (which would make the data unfaceted again).
     */
    isFaceted: boolean;
    /**
     * Parse properties passed down from ancestors. Helps us to keep track of what has been parsed or is derived.
     */
    ancestorParse?: AncestorParse;
}
/**
 * Class to track interesting properties (see https://15721.courses.cs.cmu.edu/spring2016/papers/graefe-ieee1995.pdf)
 * about how fields have been parsed or whether they have been derived in a transform. We use this to not parse the
 * same field again (or differently).
 */
export declare class AncestorParse extends Split<Parse> {
    readonly explicit: Partial<Parse>;
    readonly implicit: Partial<Parse>;
    parseNothing: boolean;
    constructor(explicit?: Partial<Parse>, implicit?: Partial<Parse>, parseNothing?: boolean);
    clone(): AncestorParse;
}
//# sourceMappingURL=index.d.ts.map