我之前问了一个类似的问题,并解决了最初的问题。我遇到了另一个错误隐藏的附加问题。我能够使诸如“if”语句之类的语句正常工作,但不能使“while”语句正常工作。当评估“stmt”时,必须更新环境。这适用于我的“if”语句,如下所示:
exec :: Env -> Stmt -> Env
exec env (If c t e) =
exec env ( if eval env c == BoolLit True then t else e )
评估看起来像这样:
eval :: Env -> Expr -> Expr
eval _ (IntLit i) = IntLit i
eval _ (BoolLit b) = BoolLit b
eval env (Var n) = lookupVar env n
eval env (BinOp op a b) = primEval op (eval env a) (eval env b)
正在解析的文件如下所示:
x = 1; c = 0;
if (x < 2) c = c + 1; else ;
我尝试让 while 语句工作是这样的:
exec env (While c t) = exec env ( if eval env c == BoolLit True then t)
但这会在“)”上产生解析错误。正在解析的文件中的 while 语句的预期格式:
x = 1; c = 1;
while (x < 10)
{
c = c * x;
x = x + 1;
}
c
我试图了解如何根据这种预期格式返回正确的环境。如果 Haskell 中的 while 语句已经有类似的结构,那就很简单了,但我知道没有这样的结构存在。