use ordered_float::OrderedFloat;
use serde::Serialize;
use mago_span::HasSpan;
use mago_span::Span;
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, Serialize, PartialOrd, Ord)]
pub struct LiteralIntType<'arena> {
pub span: Span,
pub value: u64,
pub raw: &'arena [u8],
}
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, Serialize, PartialOrd, Ord)]
pub struct LiteralFloatType<'arena> {
pub span: Span,
pub value: OrderedFloat<f64>,
pub raw: &'arena [u8],
}
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, Serialize, PartialOrd, Ord)]
pub enum LiteralIntOrFloatType<'arena> {
Int(LiteralIntType<'arena>),
Float(LiteralFloatType<'arena>),
}
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, Serialize, PartialOrd, Ord)]
pub struct LiteralStringType<'arena> {
pub span: Span,
pub value: &'arena [u8], pub raw: &'arena [u8],
}
impl HasSpan for LiteralFloatType<'_> {
fn span(&self) -> Span {
self.span
}
}
impl HasSpan for LiteralIntType<'_> {
fn span(&self) -> Span {
self.span
}
}
impl HasSpan for LiteralIntOrFloatType<'_> {
fn span(&self) -> Span {
match self {
LiteralIntOrFloatType::Int(int) => int.span(),
LiteralIntOrFloatType::Float(float) => float.span(),
}
}
}
impl HasSpan for LiteralStringType<'_> {
fn span(&self) -> Span {
self.span
}
}
impl std::fmt::Display for LiteralIntType<'_> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str(&String::from_utf8_lossy(self.raw))
}
}
impl std::fmt::Display for LiteralFloatType<'_> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str(&String::from_utf8_lossy(self.raw))
}
}
impl std::fmt::Display for LiteralIntOrFloatType<'_> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
LiteralIntOrFloatType::Int(int) => write!(f, "{int}"),
LiteralIntOrFloatType::Float(float) => write!(f, "{float}"),
}
}
}
impl std::fmt::Display for LiteralStringType<'_> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_str(&String::from_utf8_lossy(self.raw))
}
}