use crate::template::{MaybeValue, PostgresAtomic};
use crate::template_parser::structs::bool_value::Bool;
use crate::template_parser::structs::keyword::SqliteKeyword;
use crate::template_parser::structs::text::Text;
use crate::template_parser::to_sql::SqlSegment;
use crate::{Atomic, Number, Operator, Sign, ToSqlSegment};
use nom::branch::alt;
use nom::bytes::complete::tag_no_case;
use nom::combinator::map;
use nom::IResult;
use taitan_orm_tracing::debug;
use crate::template_parser::structs::atomics::atomic_trait::AtomicTrait;
#[derive(Debug, Clone, PartialEq)]
pub enum SqliteAtomic {
Null,
Number(Number),
Text(Text),
Bool(Bool),
Operator(Operator), Maybe(MaybeValue), Sign(Sign), Keyword(SqliteKeyword),
}
impl AtomicTrait for SqliteAtomic {
fn parse(input: &str) -> IResult<&str, SqliteAtomic> {
debug!("SqliteAtomic parse({})", &input);
let (remaining, parsed) = alt((
map(tag_no_case("null"), |_| SqliteAtomic::Null),
map(Number::parse, SqliteAtomic::Number),
map(Text::parse, SqliteAtomic::Text),
map(Bool::parse, SqliteAtomic::Bool),
map(Sign::parse, SqliteAtomic::Sign), map(Operator::parse, SqliteAtomic::Operator),
map(SqliteKeyword::parse, SqliteAtomic::Keyword),
map(MaybeValue::parse, SqliteAtomic::Maybe),
))(input)?;
debug!("SqliteAtomic parse -> {:?}", &parsed);
Ok((remaining, parsed))
}
}
impl ToSqlSegment for SqliteAtomic {
fn gen_sql_segment(&self) -> SqlSegment {
match self {
SqliteAtomic::Null=>SqlSegment::Simple("NULL".to_string()),
SqliteAtomic::Sign(s) => SqlSegment::Simple(s.to_string()),
SqliteAtomic::Maybe(m) => {
SqlSegment::Simple(m.gen_sql_segment().to_sql(false).to_string())
}
SqliteAtomic::Operator(b) => SqlSegment::Simple(b.to_string()),
SqliteAtomic::Bool(b) => SqlSegment::Simple(b.to_string()),
SqliteAtomic::Text(t) => SqlSegment::Simple(t.to_string()),
SqliteAtomic::Number(n) => SqlSegment::Simple(n.to_string()),
SqliteAtomic::Keyword(k) => SqlSegment::Simple(k.to_string()),
}
}
}