From 221f527a4358110815a6f030895468b99a5d709b Mon Sep 17 00:00:00 2001 From: Alessio Ferrarini Date: Fri, 13 Dec 2024 15:49:04 +0100 Subject: [PATCH] Forward allowTC state in lambda body Co-authored-by: Niki Vazou --- .../src/Language/Haskell/Liquid/Transforms/CoreToLogic.hs | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/liquidhaskell-boot/src/Language/Haskell/Liquid/Transforms/CoreToLogic.hs b/liquidhaskell-boot/src/Language/Haskell/Liquid/Transforms/CoreToLogic.hs index 9443e29d8..9e8bfe038 100644 --- a/liquidhaskell-boot/src/Language/Haskell/Liquid/Transforms/CoreToLogic.hs +++ b/liquidhaskell-boot/src/Language/Haskell/Liquid/Transforms/CoreToLogic.hs @@ -289,11 +289,9 @@ coreToLg allowTC (C.Cast e c) = do (s, t) <- coerceToLg c return (ECoerc s t e') -- elaboration reuses coretologic -- TODO: fix this -coreToLg _ (C.Lam x e) = do p <- coreToLg True e - tce <- lsEmb <$> getState - return $ ELam (symbol x, typeSort tce (GM.expandVarType x)) p --- coreToLg _ e@(C.Lam _ _) = throw ("Cannot transform lambda abstraction to Logic:\t" ++ GM.showPpr e ++ --- "\n\n Try using a helper function to remove the lambda.") +coreToLg allowTC (C.Lam x e) = do p <- coreToLg allowTC e + tce <- lsEmb <$> getState + return $ ELam (symbol x, typeSort tce (GM.expandVarType x)) p coreToLg _ e = throw ("Cannot transform to Logic:\t" ++ GM.showPpr e)