sibil/types/src/pair.rs
Eryn Wells 929846152e [parser, types] Clean up obj parsers
- Define ListParser, SymParser in their own separate modules
- Add some stuff to types to make working with them more ergonomic
2018-08-23 17:52:56 -07:00

51 lines
1.2 KiB
Rust

/* types/src/pair.rs
* Eryn Wells <eryn@erynwells.me>
*/
use std::any::Any;
use std::fmt;
use super::*;
use object::Object;
pub struct Pair {
car: Obj,
cdr: Obj
}
impl Pair {
pub fn empty() -> Pair {
Pair { car: Obj::Null, cdr: Obj::Null }
}
fn fmt_pair(&self, f: &mut fmt::Formatter) -> fmt::Result {
let r = write!(f, "{}", self.car);
r.and_then(|r| match self.cdr {
Obj::Null => Ok(r), // Don't write anything.
Obj::Ptr(ref next) => {
match next.as_pair() {
Some(next_pair) => write!(f, " ").and_then(|_| next_pair.fmt_pair(f)),
None => write!(f, " . {}", next)
}
}
})
}
}
impl Object for Pair {
fn as_any(&self) -> &Any { self }
fn as_pair(&self) -> Option<&Pair> { Some(self) }
fn as_sym(&self) -> Option<&Sym> { None }
}
impl fmt::Display for Pair {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "(").and_then(|_| self.fmt_pair(f))
.and_then(|_| write!(f, ")"))
}
}
impl fmt::Debug for Pair {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self)
}
}