#![forbid(unsafe_code)]
use std::fmt;
use itertools::Itertools;
use merc_data::DataExpression;
#[derive(Debug, Default, Clone)]
pub struct RewriteSpecification {
rewrite_rules: Vec<Rule>,
}
impl RewriteSpecification {
pub fn new(rewrite_rules: Vec<Rule>) -> RewriteSpecification {
RewriteSpecification {
rewrite_rules,
}
}
pub fn rewrite_rules(&self) -> &[Rule] {
&self.rewrite_rules
}
}
#[derive(Clone, Debug, Eq, Hash, PartialEq, Ord, PartialOrd)]
pub struct Condition {
pub lhs: DataExpression,
pub rhs: DataExpression,
pub equality: bool,
}
#[derive(Debug, Clone, Eq, PartialEq, Hash, Ord, PartialOrd)]
pub struct Rule {
pub conditions: Vec<Condition>,
pub lhs: DataExpression,
pub rhs: DataExpression,
}
impl fmt::Display for RewriteSpecification {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
for rule in &self.rewrite_rules {
writeln!(f, "{rule}")?;
}
Ok(())
}
}
impl fmt::Display for Rule {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
if self.conditions.is_empty() {
write!(f, "{} = {}", self.lhs, self.rhs)
} else {
write!(
f,
"{} -> {} = {}",
self.conditions.iter().format(", "),
self.lhs,
self.rhs
)
}
}
}
impl fmt::Display for Condition {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
if self.equality {
write!(f, "{} == {}", self.lhs, self.rhs)
} else {
write!(f, "{} <> {}", self.lhs, self.rhs)
}
}
}