use enum_as_inner::EnumAsInner;
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
pub use expr::{Expr, ExprKind, UnOp};
use expr::{InterpolateItem, Range, SwitchCase};
pub use fold::*;
pub use ids::*;
use prqlc_parser::lexer::lr;
pub use transform::*;
pub use utils::*;
use super::pl::QueryDef;
use super::pl::TableExternRef;
mod expr;
mod fold;
mod ids;
mod transform;
mod utils;
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize, JsonSchema)]
pub struct RelationalQuery {
pub def: QueryDef,
pub tables: Vec<TableDecl>,
pub relation: Relation,
}
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize, JsonSchema)]
pub struct Relation {
pub kind: RelationKind,
pub columns: Vec<RelationColumn>,
}
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize, EnumAsInner, JsonSchema)]
pub enum RelationKind {
#[cfg_attr(
feature = "serde_yaml",
serde(with = "serde_yaml::with::singleton_map"),
schemars(with = "TableExternRef")
)]
ExternRef(TableExternRef),
Pipeline(Vec<Transform>),
Literal(RelationLiteral),
SString(Vec<InterpolateItem>),
BuiltInFunction {
name: String,
args: Vec<Expr>,
},
}
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize, JsonSchema)]
pub struct RelationLiteral {
pub columns: Vec<String>,
pub rows: Vec<Vec<lr::Literal>>,
}
#[derive(Debug, PartialEq, Clone, Eq, Hash, Serialize, Deserialize, EnumAsInner, JsonSchema)]
pub enum RelationColumn {
Single(Option<String>),
Wildcard,
}
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize, JsonSchema)]
pub struct TableDecl {
pub id: TId,
pub name: Option<String>,
pub relation: Relation,
}
#[derive(Debug, PartialEq, Eq, Clone, Serialize, Deserialize, JsonSchema)]
pub struct TableRef {
pub source: TId,
pub columns: Vec<(RelationColumn, CId)>,
pub name: Option<String>,
pub prefer_cte: bool,
}