From 5719458b477e05a60b323ba3bb910432b36d30d7 Mon Sep 17 00:00:00 2001 From: Arnaud Bailly Date: Thu, 9 Oct 2025 15:21:49 +0200 Subject: feat: introduce typing of expressions --- lambda-calcul/rust/src/web.rs | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) (limited to 'lambda-calcul/rust/src/web.rs') diff --git a/lambda-calcul/rust/src/web.rs b/lambda-calcul/rust/src/web.rs index 5bc8c3f..27aed21 100644 --- a/lambda-calcul/rust/src/web.rs +++ b/lambda-calcul/rust/src/web.rs @@ -13,7 +13,7 @@ use std::{collections::HashMap, sync::Arc}; use tokio::task::{self, JoinHandle}; use uuid::Uuid; -use lambda::lambda::{eval_all, eval_whnf, generate_expr, generate_exprs, gensym, Environment}; +use lambda::lambda::{Environment, eval_all, eval_whnf, generate_expr, generate_expression_to_type, generate_exprs, gensym, type_of_all}; use lambda::parser::{parse, parse_total}; #[derive(Debug, PartialEq, Serialize, Deserialize, Clone)] @@ -119,7 +119,9 @@ impl Client { } fn generate_expr(&mut self) -> (Vec, Vec) { - if self.grade >= 10 { + if self.grade >= 20 { + self.generate_expression_to_type() + } else if self.grade >= 10 { self.generate_exprs() } else { let input = generate_expr(self.grade.into(), &mut self.runner); @@ -128,6 +130,12 @@ impl Client { } } + fn generate_expression_to_type(&mut self) -> (Vec, Vec) { + let input = generate_expression_to_type(self.grade.into(), &mut self.runner); + let expected = type_of_all(&input).iter().map(|t| Value::Type(t.clone())).collect(); + (input, expected) + } + fn generate_exprs(&mut self) -> (Vec, Vec) { let input = generate_exprs(self.grade.into(), &mut self.runner); let expected = eval_all(&input); @@ -786,6 +794,16 @@ mod app_tests { assert!(!input.is_empty()); } + #[test] + async fn client_generates_typing_expression_at_level_20() { + let mut client = client(); + client.grade = 20; + + let (input, _) = client.generate_expr(); + + assert!(!input.is_empty()); + } + #[test] async fn client_increases_grade_on_successful_test() { let mut client = client(); -- cgit v1.2.3