main: ty parser test mode, visually distinct prompt

This commit is contained in:
2025-10-16 01:38:52 -04:00
parent f47de24cfb
commit 95abb81f4a

View File

@@ -1,6 +1,6 @@
//! Tests the lexer
use doughlang::{
ast::{Anno, Pat},
ast::{Anno, Pat, Ty},
parser::PPrec,
};
#[allow(unused_imports)]
@@ -22,7 +22,7 @@ use std::{
fn main() -> Result<(), Box<dyn Error>> {
if stdin().is_terminal() {
read_and("\x1b[32m", " >", "?>", |line| match line.trim_end() {
read_and("\x1b[32m", ".>", " >", |line| match line.trim_end() {
"" => Ok(Response::Continue),
"exit" => Ok(Response::Break),
"clear" => {
@@ -41,16 +41,21 @@ fn main() -> Result<(), Box<dyn Error>> {
pats()?;
Ok(Response::Deny)
}
"ty" => {
tys()?;
Ok(Response::Deny)
}
"macro" => {
if let Err(e) = subst() {
println!("\x1b[31m{e}\x1b[0m");
}
Ok(Response::Deny)
}
_ => {
_ if line.ends_with("\n\n") => {
parse(line);
Ok(Response::Accept)
}
_ => Ok(Response::Continue),
})?;
} else {
let doc = std::io::read_to_string(stdin())?;
@@ -85,23 +90,24 @@ fn lex() -> Result<(), Box<dyn Error>> {
}
fn exprs() -> Result<(), Box<dyn Error>> {
read_and("\x1b[93m", " >", "?>", |line| {
read_and("\x1b[93m", ".>", " >", |line| {
let mut parser = Parser::new(Lexer::new(line));
if line.trim().is_empty() {
return Ok(Response::Break);
}
loop {
for idx in 0.. {
match parser.parse::<Anno<Expr>>(0) {
Err(ParseError::FromLexer(LexError { res: "EOF", .. })) => {
break Ok(Response::Accept);
return Ok(Response::Accept);
}
Err(e) => {
println!("\x1b[31m{e}\x1b[0m");
break Ok(Response::Deny);
return Ok(Response::Deny);
}
Ok(v) => println!("{v}\n{v:?}"),
Ok(v) => println!("{idx}: {v}\n{v:#?}"),
}
}
Ok(Response::Accept)
})?;
Ok(())
}
@@ -128,6 +134,28 @@ fn pats() -> Result<(), Box<dyn Error>> {
Ok(())
}
fn tys() -> Result<(), Box<dyn Error>> {
read_and("\x1b[94m", ".>", " >", |line| {
let mut parser = Parser::new(Lexer::new(line));
if line.trim().is_empty() {
return Ok(Response::Break);
}
loop {
match parser.parse::<Ty>(()) {
Err(ParseError::FromLexer(LexError { res: "EOF", .. })) => {
break Ok(Response::Accept);
}
Err(e) => {
println!("\x1b[31m{e}\x1b[0m");
break Ok(Response::Deny);
}
Ok(v) => println!("{v}\n{v:#?}"),
}
}
})?;
Ok(())
}
fn subst() -> Result<(), Box<dyn Error>> {
let mut rl = repline::Repline::new("\x1b[35mexp", " >", "?>");
let exp = rl.read()?;
@@ -177,7 +205,7 @@ fn subst() -> Result<(), Box<dyn Error>> {
fn parse(document: &str) {
let mut parser = Parser::new(Lexer::new(document));
loop {
for idx in 0.. {
match parser.parse::<Expr>(0) {
Err(ParseError::FromLexer(LexError { res: "EOF", .. })) => break,
Err(e) => {
@@ -185,7 +213,7 @@ fn parse(document: &str) {
break;
}
Ok(v) => {
println!("{v}");
println!("\x1b[{}m{v}", (idx + 5) % 6 + 31);
}
}
}