This commit is contained in:
Turner 2022-06-27 13:43:21 -07:00 committed by Lucas
parent 41a7b73877
commit c7dfd01a5e
2 changed files with 58 additions and 57 deletions

View File

@ -5,62 +5,61 @@ use uplc::ast::{Constant, Name, Program, Term, Unique};
#[cfg(test)] #[cfg(test)]
mod tests; mod tests;
#[derive(Default)]
pub struct Builder { pub struct Builder {
version: (usize, usize, usize), version: (usize, usize, usize),
term_builder: TermBuilder, term: Term<Name>,
} }
#[derive(Clone)] pub struct Empty {
enum TermBuilder { version: (usize, usize, usize),
Null,
Constant(Constant),
Lambda(Box<TermBuilder>),
} }
impl TermBuilder { pub trait WithTerm
pub fn build_named(&self) -> Term<Name> { where
match self.clone() { Self: Sized,
Self::Null => todo!("Make fallible?"), {
Self::Constant(c) => Term::Constant(c), type Next;
Self::Lambda(term) => Term::Lambda {
parameter_name: Name { fn next(self, term: Term<Name>) -> Self::Next;
text: "i".to_string(),
unique: Unique::new(0), fn with_constant_int(self, int: isize) -> Self::Next {
}, let term = Term::Constant(Constant::Integer(int));
body: Box::new(term.build_named()), self.next(term)
},
} }
fn with_lambda(self) -> Self::Next {
let text = "i_0".to_string();
let unique = Unique::new(0);
let parameter_name = Name { text, unique };
let term = Term::Lambda {
parameter_name,
body: Box::new(Term::Constant(Constant::Integer(1))),
};
self.next(term)
} }
} }
impl Default for TermBuilder { impl WithTerm for Empty {
fn default() -> Self { type Next = Builder;
Self::Null fn next(self, term: Term<Name>) -> Self::Next {
Builder {
version: self.version,
term,
}
} }
} }
impl Builder { impl Builder {
pub fn with_version(&mut self, maj: usize, min: usize, patch: usize) -> &mut Self { pub fn new(maj: usize, min: usize, patch: usize) -> Empty {
self.version = (maj, min, patch); Empty {
self version: (maj, min, patch),
} }
pub fn with_constant_int(&mut self, int: isize) -> &mut Self {
self.term_builder = TermBuilder::Constant(Constant::Integer(int));
self
}
pub fn with_lambda(&mut self, int: isize) -> &mut Self {
let inner = TermBuilder::Constant(Constant::Integer(int));
self.term_builder = TermBuilder::Lambda(Box::new(inner));
self
} }
pub fn build_named(&self) -> Program<Name> { pub fn build_named(&self) -> Program<Name> {
Program { Program {
version: self.version, version: self.version,
term: self.term_builder.build_named(), term: self.term.clone(),
} }
} }
} }

View File

@ -1,4 +1,4 @@
use crate::Builder; use crate::{Builder, WithTerm};
use uplc::parser; use uplc::parser;
#[test] #[test]
@ -8,10 +8,7 @@ fn build_named__with_const() {
(con integer 11) (con integer 11)
)"; )";
let expected = parser::program(code).unwrap(); let expected = parser::program(code).unwrap();
let actual = Builder::default() let actual = Builder::new(11, 22, 33).with_constant_int(11).build_named();
.with_version(11, 22, 33)
.with_constant_int(11)
.build_named();
assert_eq!(expected, actual); assert_eq!(expected, actual);
} }
@ -22,10 +19,7 @@ fn build_named__with_different_const() {
(con integer 22) (con integer 22)
)"; )";
let expected = parser::program(code).unwrap(); let expected = parser::program(code).unwrap();
let actual = Builder::default() let actual = Builder::new(11, 22, 33).with_constant_int(22).build_named();
.with_version(11, 22, 33)
.with_constant_int(22)
.build_named();
assert_eq!(expected, actual); assert_eq!(expected, actual);
} }
@ -36,10 +30,7 @@ fn build_named__with_const_different_version() {
(con integer 11) (con integer 11)
)"; )";
let expected = parser::program(code).unwrap(); let expected = parser::program(code).unwrap();
let actual = Builder::default() let actual = Builder::new(44, 55, 66).with_constant_int(11).build_named();
.with_version(44, 55, 66)
.with_constant_int(11)
.build_named();
assert_eq!(expected, actual); assert_eq!(expected, actual);
} }
@ -50,9 +41,20 @@ fn build_named__with_lam() {
(lam i_0 (con integer 1)) (lam i_0 (con integer 1))
)"; )";
let expected = parser::program(code).unwrap(); let expected = parser::program(code).unwrap();
let actual = Builder::default() let actual = Builder::new(1, 2, 3).with_lambda().build_named();
.with_version(1, 2, 3)
.with_lambda(1)
.build_named();
assert_eq!(expected, actual); assert_eq!(expected, actual);
} }
// #[test]
// fn build_named__with_nested_lam() {
// let code = r"(program
// 1.2.3
// (lam i_0 (lam i_1 (con integer 1)))
// )";
// let expected = parser::program(code).unwrap();
// let actual = Builder::default()
// .with_version(1, 2, 3)
// .with_lambda(1)
// .build_named();
// assert_eq!(expected, actual);
// }