use vantage_expressions::{Expression, Expressive};
#[derive(Debug, Clone)]
pub struct Identifier {
parts: Vec<String>,
alias: Option<String>,
}
impl Identifier {
pub fn new(name: impl Into<String>) -> Self {
Self {
parts: vec![name.into()],
alias: None,
}
}
pub fn dot_of(mut self, prefix: impl Into<String>) -> Self {
self.parts.insert(0, prefix.into());
self
}
pub fn with_alias(mut self, alias: impl Into<String>) -> Self {
self.alias = Some(alias.into());
self
}
fn render_with(&self, q: char) -> String {
let base = self
.parts
.iter()
.map(|p| format!("{q}{p}{q}"))
.collect::<Vec<_>>()
.join(".");
match &self.alias {
Some(alias) => format!("{base} AS {q}{alias}{q}"),
None => base,
}
}
}
pub fn ident(name: impl Into<String>) -> Identifier {
Identifier::new(name)
}
#[cfg(feature = "sqlite")]
impl Expressive<crate::sqlite::types::AnySqliteType> for Identifier {
fn expr(&self) -> Expression<crate::sqlite::types::AnySqliteType> {
Expression::new(self.render_with('"'), vec![])
}
}
#[cfg(feature = "sqlite")]
impl From<Identifier> for Expression<crate::sqlite::types::AnySqliteType> {
fn from(id: Identifier) -> Self {
id.expr()
}
}
#[cfg(feature = "postgres")]
impl Expressive<crate::postgres::types::AnyPostgresType> for Identifier {
fn expr(&self) -> Expression<crate::postgres::types::AnyPostgresType> {
Expression::new(self.render_with('"'), vec![])
}
}
#[cfg(feature = "postgres")]
impl From<Identifier> for Expression<crate::postgres::types::AnyPostgresType> {
fn from(id: Identifier) -> Self {
id.expr()
}
}
#[cfg(feature = "mysql")]
impl Expressive<crate::mysql::types::AnyMysqlType> for Identifier {
fn expr(&self) -> Expression<crate::mysql::types::AnyMysqlType> {
Expression::new(self.render_with('`'), vec![])
}
}
#[cfg(feature = "mysql")]
impl From<Identifier> for Expression<crate::mysql::types::AnyMysqlType> {
fn from(id: Identifier) -> Self {
id.expr()
}
}