ast.rs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. use std::fmt;
  2. pub type Name = string_interner::DefaultSymbol;
  3. pub struct ASTArena {
  4. strings: string_interner::StringInterner,
  5. }
  6. pub struct Debuggable<'a, T> {
  7. arena: &'a ASTArena,
  8. value: &'a T,
  9. }
  10. impl<'a> std::fmt::Debug for Debuggable<'a, Stmt> {
  11. fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
  12. self.arena.show_stmt(self.value, f)
  13. }
  14. }
  15. impl ASTArena {
  16. pub fn new() -> ASTArena {
  17. ASTArena {
  18. strings: string_interner::StringInterner::new(),
  19. }
  20. }
  21. pub fn add_string(&mut self, s: &str) -> Name {
  22. self.strings.get_or_intern(s)
  23. }
  24. pub fn show_stmt(&self, stmt: &Stmt, f: &mut fmt::Formatter) -> fmt::Result {
  25. match stmt {
  26. Stmt::Puts(expr) => {
  27. write!(f, "Puts ")?;
  28. self.show_expr(&expr, f, 0)
  29. }
  30. Stmt::Fix(name) =>
  31. writeln!(f, "Fix({})", &self[*name]),
  32. Stmt::Assn(name, expr) => {
  33. write!(f, "Assn {} ", &self[*name])?;
  34. self.show_expr(&expr, f, 0)
  35. }
  36. Stmt::LitAssn(name, strs) => {
  37. write!(f, "LitAssn({}, [ ", &self[*name])?;
  38. for str in strs.iter() {
  39. write!(f, " {} ", str)?;
  40. }
  41. writeln!(f, "]")
  42. }
  43. }
  44. }
  45. fn indent(&self, f: &mut fmt::Formatter, depth: usize) -> fmt::Result {
  46. for _ in 0..depth {
  47. write!(f, " ")?;
  48. }
  49. Ok(())
  50. }
  51. fn show_expr(&self, expr: &Expr, f: &mut fmt::Formatter, depth: usize) -> fmt::Result {
  52. match expr {
  53. Expr::Var(v) => writeln!(f, "Var({})", &self[*v]),
  54. Expr::Lit(Literal::Atom(n)) => writeln!(f, "Lit(Atom({}))", &self[*n]),
  55. Expr::Lit(lit) => writeln!(f, "{:?}", lit),
  56. Expr::Range(from, to) => {
  57. writeln!(f, "Range(")?;
  58. self.indent(f, depth + 2)?;
  59. self.show_expr(from, f, depth + 2)?;
  60. self.indent(f, depth + 2)?;
  61. self.show_expr(to, f, depth + 2)?;
  62. self.indent(f, depth)?;
  63. writeln!(f, ")")
  64. }
  65. Expr::Ap(func, arg) => {
  66. writeln!(f, "Ap(")?;
  67. self.indent(f, depth + 2)?;
  68. self.show_expr(func, f, depth + 2)?;
  69. self.indent(f, depth + 2)?;
  70. self.show_expr(arg, f, depth + 2)?;
  71. self.indent(f, depth)?;
  72. writeln!(f, ")")
  73. }
  74. Expr::Tup(expr) => {
  75. writeln!(f, "Tup(")?;
  76. for e in expr {
  77. self.indent(f, depth + 2)?;
  78. self.show_expr(e, f, depth + 2)?;
  79. }
  80. self.indent(f, depth)?;
  81. writeln!(f, ")")
  82. }
  83. Expr::Cat(expr) => {
  84. writeln!(f, "Cat(")?;
  85. for e in expr {
  86. self.indent(f, depth + 2)?;
  87. self.show_expr(e, f, depth + 2)?;
  88. }
  89. self.indent(f, depth)?;
  90. writeln!(f, ")")
  91. }
  92. Expr::Chc(expr) => {
  93. writeln!(f, "Chc(")?;
  94. for e in expr {
  95. if let Some(s) = e.weight {
  96. self.indent(f, depth + 2)?;
  97. writeln!(f, "{}:", s)?;
  98. self.indent(f, depth + 4)?;
  99. self.show_expr(&e.value, f, depth + 4)?;
  100. } else {
  101. self.indent(f, depth + 2)?;
  102. self.show_expr(&e.value, f, depth + 2)?;
  103. }
  104. }
  105. self.indent(f, depth)?;
  106. writeln!(f, ")")
  107. }
  108. _ => writeln!(f, "[???]"),
  109. }
  110. }
  111. }
  112. impl std::ops::Index<string_interner::DefaultSymbol> for ASTArena {
  113. type Output = str;
  114. fn index(&self, sf: string_interner::DefaultSymbol) -> &str {
  115. self.strings.resolve(sf).unwrap()
  116. }
  117. }
  118. #[derive(Debug, Clone)]
  119. pub enum Stmt {
  120. Puts(Expr),
  121. Fix(Name),
  122. Assn(Name, Expr),
  123. LitAssn(Name, Vec<String>),
  124. }
  125. impl Stmt {
  126. pub fn show<'a>(&'a self, ast: &'a ASTArena) -> Debuggable<'a, Stmt> {
  127. Debuggable {
  128. arena: ast,
  129. value: self,
  130. }
  131. }
  132. }
  133. #[derive(Debug, Clone)]
  134. pub enum Expr {
  135. Var(Name),
  136. Cat(Vec<Expr>),
  137. Chc(Vec<Choice>),
  138. Rep(i64, Box<Expr>),
  139. Lit(Literal),
  140. Ap(Box<Expr>, Box<Expr>),
  141. Tup(Vec<Expr>),
  142. Let(Name, Box<Expr>, Box<Expr>),
  143. Fun(Vec<Case>),
  144. Case(Box<Expr>, Vec<Case>),
  145. Range(Box<Expr>, Box<Expr>),
  146. }
  147. #[derive(Debug, Clone)]
  148. pub struct Case {
  149. pub pat: Pat,
  150. pub expr: Expr,
  151. }
  152. #[derive(Debug, Clone)]
  153. pub enum Pat {
  154. Var(Name),
  155. Lit(Literal),
  156. Tup(Vec<Pat>),
  157. }
  158. #[derive(Debug, Clone)]
  159. pub struct Choice {
  160. pub weight: Option<i64>,
  161. pub value: Expr,
  162. }
  163. impl Choice {
  164. pub fn weight(&self) -> i64 {
  165. self.weight.unwrap_or(1)
  166. }
  167. }
  168. #[derive(Debug, Clone)]
  169. pub enum Literal {
  170. Str(String),
  171. Atom(Name),
  172. Num(i64),
  173. }