ast.rs 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. use std::fmt;
  2. pub use crate::lexer::Located;
  3. pub type StrRef = string_interner::DefaultSymbol;
  4. pub type Name = Located<StrRef>;
  5. pub struct ASTArena {
  6. strings: string_interner::StringInterner,
  7. exprs: Vec<Expr>,
  8. }
  9. impl Default for ASTArena {
  10. fn default() -> Self {
  11. Self::new()
  12. }
  13. }
  14. impl ASTArena {
  15. pub fn new() -> ASTArena {
  16. ASTArena {
  17. strings: string_interner::StringInterner::new(),
  18. exprs: vec![Expr::Nil],
  19. }
  20. }
  21. pub fn expr_nil(&self) -> ExprId {
  22. ExprId { idx: 0 }
  23. }
  24. pub fn add_expr(&mut self, e: Expr) -> ExprId {
  25. let idx = self.exprs.len();
  26. self.exprs.push(e);
  27. ExprId { idx }
  28. }
  29. pub fn add_string(&mut self, s: &str) -> string_interner::DefaultSymbol {
  30. self.strings.get_or_intern(s)
  31. }
  32. pub fn show_stmt(&self, stmt: &Stmt, f: &mut fmt::Formatter) -> fmt::Result {
  33. match stmt {
  34. Stmt::Puts(expr) => {
  35. write!(f, "Puts ")?;
  36. self.show_expr(&self[expr.item], f, 0)
  37. }
  38. Stmt::Fix(name) => writeln!(f, "Fix {}", &self[name.item]),
  39. Stmt::Assn(fixed, name, expr) => {
  40. write!(
  41. f,
  42. "Assn {} {} ",
  43. if *fixed { "fixed" } else { "" },
  44. &self[name.item]
  45. )?;
  46. self.show_expr(&self[expr.item], f, 0)
  47. }
  48. Stmt::LitAssn(fixed, name, strs) => {
  49. write!(
  50. f,
  51. "LitAssn {} {}, [ ",
  52. if *fixed { "fixed" } else { "" },
  53. &self[name.item],
  54. )?;
  55. for str in strs.iter() {
  56. let s = &self[str.item];
  57. write!(f, " {} ", s)?;
  58. }
  59. writeln!(f, "]")
  60. }
  61. }
  62. }
  63. fn indent(&self, f: &mut fmt::Formatter, depth: usize) -> fmt::Result {
  64. for _ in 0..depth {
  65. write!(f, " ")?;
  66. }
  67. Ok(())
  68. }
  69. fn show_pat(&self, pat: &Pat, f: &mut fmt::Formatter) -> fmt::Result {
  70. match pat {
  71. Pat::Wildcard => write!(f, "_"),
  72. Pat::Var(n) => write!(f, "{}", &self[n.item]),
  73. Pat::Lit(Literal::Atom(n)) => write!(f, "{}", &self[n.item]),
  74. Pat::Lit(lit) => write!(f, "{:?}", lit),
  75. Pat::Tup(tup) => {
  76. write!(f, "Tup( ")?;
  77. for t in tup {
  78. self.show_pat(t, f)?;
  79. write!(f, " ")?;
  80. }
  81. write!(f, ")")
  82. }
  83. }
  84. }
  85. fn show_expr(&self, expr: &Expr, f: &mut fmt::Formatter, depth: usize) -> fmt::Result {
  86. match expr {
  87. Expr::Nil => writeln!(f, "Nil"),
  88. Expr::Var(v) => writeln!(f, "Var({})", &self[v.item]),
  89. Expr::Lit(Literal::Atom(n)) => writeln!(f, "Lit(Atom({}))", &self[n.item]),
  90. Expr::Lit(lit) => writeln!(f, "{:?}", lit),
  91. Expr::Range(from, to) => {
  92. writeln!(f, "Range(")?;
  93. self.indent(f, depth + 2)?;
  94. self.show_expr(&self[*from], f, depth + 2)?;
  95. self.indent(f, depth + 2)?;
  96. self.show_expr(&self[*to], f, depth + 2)?;
  97. self.indent(f, depth)?;
  98. writeln!(f, ")")
  99. }
  100. Expr::Ap(func, arg) => {
  101. writeln!(f, "Ap(")?;
  102. self.indent(f, depth + 2)?;
  103. self.show_expr(&self[*func], f, depth + 2)?;
  104. self.indent(f, depth + 2)?;
  105. self.show_expr(&self[*arg], f, depth + 2)?;
  106. self.indent(f, depth)?;
  107. writeln!(f, ")")
  108. }
  109. Expr::Tup(expr) => {
  110. writeln!(f, "Tup(")?;
  111. for e in expr {
  112. self.indent(f, depth + 2)?;
  113. self.show_expr(&self[*e], f, depth + 2)?;
  114. }
  115. self.indent(f, depth)?;
  116. writeln!(f, ")")
  117. }
  118. Expr::Cat(expr) => {
  119. writeln!(f, "Cat(")?;
  120. for e in expr {
  121. self.indent(f, depth + 2)?;
  122. self.show_expr(&self[*e], f, depth + 2)?;
  123. }
  124. self.indent(f, depth)?;
  125. writeln!(f, ")")
  126. }
  127. Expr::Chc(expr) => {
  128. writeln!(f, "Chc(")?;
  129. for e in expr {
  130. if let Some(s) = e.weight {
  131. self.indent(f, depth + 2)?;
  132. writeln!(f, "{}:", s)?;
  133. self.indent(f, depth + 4)?;
  134. self.show_expr(&self[e.value], f, depth + 4)?;
  135. } else {
  136. self.indent(f, depth + 2)?;
  137. self.show_expr(&self[e.value], f, depth + 2)?;
  138. }
  139. }
  140. self.indent(f, depth)?;
  141. writeln!(f, ")")
  142. }
  143. Expr::Let(fixed, name, expr, body) => {
  144. writeln!(
  145. f,
  146. "Let({}{}",
  147. if *fixed { "fixed " } else { "" },
  148. &self[name.item]
  149. )?;
  150. self.indent(f, depth + 2)?;
  151. self.show_expr(&self[*expr], f, depth + 2)?;
  152. self.indent(f, depth + 2)?;
  153. self.show_expr(&self[*body], f, depth + 2)?;
  154. self.indent(f, depth)?;
  155. writeln!(f, ")")
  156. }
  157. Expr::Fun(cases) => {
  158. writeln!(f, "Fun(")?;
  159. for case in cases {
  160. self.indent(f, depth + 2)?;
  161. self.show_pat(&case.pat, f)?;
  162. writeln!(f, " =>")?;
  163. self.indent(f, depth + 4)?;
  164. self.show_expr(&self[case.expr], f, depth + 4)?;
  165. }
  166. self.indent(f, depth)?;
  167. writeln!(f, ")")
  168. }
  169. Expr::Case(expr, cases) => {
  170. writeln!(f, "Case(")?;
  171. self.indent(f, depth)?;
  172. self.show_expr(&self[*expr], f, depth)?;
  173. for case in cases {
  174. self.indent(f, depth + 2)?;
  175. self.show_pat(&case.pat, f)?;
  176. writeln!(f, " =>")?;
  177. self.indent(f, depth + 4)?;
  178. self.show_expr(&self[case.expr], f, depth + 4)?;
  179. }
  180. self.indent(f, depth)?;
  181. writeln!(f, ")")
  182. }
  183. }
  184. }
  185. }
  186. impl std::ops::Index<string_interner::DefaultSymbol> for ASTArena {
  187. type Output = str;
  188. fn index(&self, sf: string_interner::DefaultSymbol) -> &str {
  189. self.strings.resolve(sf).unwrap()
  190. }
  191. }
  192. impl std::ops::Index<ExprRef> for ASTArena {
  193. type Output = Expr;
  194. fn index(&self, rf: ExprRef) -> &Self::Output {
  195. &self.exprs[rf.item.idx]
  196. }
  197. }
  198. impl std::ops::Index<ExprId> for ASTArena {
  199. type Output = Expr;
  200. fn index(&self, rf: ExprId) -> &Self::Output {
  201. &self.exprs[rf.idx]
  202. }
  203. }
  204. /// A `Printable` struct is a bundle of another value and an
  205. /// `ASTArena`, which allows us to fetch the various indices and
  206. /// dereference the interned strings.
  207. pub struct Printable<'a, T> {
  208. arena: &'a ASTArena,
  209. value: &'a T,
  210. }
  211. impl<'a> std::fmt::Debug for Printable<'a, Stmt> {
  212. fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
  213. self.arena.show_stmt(self.value, f)
  214. }
  215. }
  216. impl<'a> std::fmt::Debug for Printable<'a, Expr> {
  217. fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
  218. self.arena.show_expr(self.value, f, 0)
  219. }
  220. }
  221. /// A top-level Matzo statement
  222. #[derive(Debug, Clone)]
  223. pub enum Stmt {
  224. /// evaluate and print the value of an expression
  225. Puts(ExprRef),
  226. /// replace a named item with the forced version of that item
  227. Fix(Name),
  228. /// assign a value to a name which may or may not be forced
  229. Assn(bool, Name, ExprRef),
  230. /// assign one of a set of strings to a name, which may or may not
  231. /// be forced
  232. LitAssn(bool, Name, Vec<Name>),
  233. }
  234. impl Stmt {
  235. pub fn show<'a>(&'a self, ast: &'a ASTArena) -> Printable<'a, Stmt> {
  236. Printable {
  237. arena: ast,
  238. value: self,
  239. }
  240. }
  241. }
  242. /// A Matzo expression
  243. #[derive(Debug, Clone)]
  244. pub enum Expr {
  245. Var(Name),
  246. Cat(Vec<ExprRef>),
  247. Chc(Vec<Choice>),
  248. Lit(Literal),
  249. Ap(ExprRef, ExprRef),
  250. Tup(Vec<ExprRef>),
  251. Let(bool, Name, ExprRef, ExprRef),
  252. Fun(Vec<Case>),
  253. Range(ExprRef, ExprRef),
  254. Case(ExprRef, Vec<Case>),
  255. Nil,
  256. }
  257. pub type ExprRef = Located<ExprId>;
  258. #[derive(Debug, Copy, Clone, PartialEq, Eq)]
  259. pub struct ExprId {
  260. idx: usize,
  261. }
  262. impl ExprId {
  263. pub fn nil(&self) -> bool {
  264. self.idx == 0
  265. }
  266. }
  267. /// A single case in an anonymous function or `case` statement
  268. #[derive(Debug, Clone)]
  269. pub struct Case {
  270. pub pat: Pat,
  271. pub expr: ExprRef,
  272. }
  273. /// A pattern, e.g. in an anonymous function or `case` statement
  274. #[derive(Debug, Clone)]
  275. pub enum Pat {
  276. Var(Name),
  277. Wildcard,
  278. Lit(Literal),
  279. Tup(Vec<Pat>),
  280. }
  281. /// A single element in a choice, with an optional weight (which
  282. /// defaults to 1) and a value
  283. #[derive(Debug, Clone)]
  284. pub struct Choice {
  285. pub weight: Option<i64>,
  286. pub value: ExprRef,
  287. }
  288. impl Choice {
  289. /// Fetch a weight from a `Choice`, defaulting to 1
  290. pub fn weight(&self) -> i64 {
  291. self.weight.unwrap_or(1)
  292. }
  293. }
  294. /// An atomic literal: a string, a number, or an atom
  295. #[derive(Debug, Clone)]
  296. pub enum Literal {
  297. Str(String),
  298. Atom(Name),
  299. Num(i64),
  300. }
  301. impl PartialEq for Literal {
  302. fn eq(&self, other: &Literal) -> bool {
  303. match (self, other) {
  304. (Literal::Str(s1), Literal::Str(s2)) => s1 == s2,
  305. (Literal::Atom(a1), Literal::Atom(a2)) => a1.item == a2.item,
  306. (Literal::Num(n1), Literal::Num(n2)) => n1 == n2,
  307. (_, _) => false,
  308. }
  309. }
  310. }