From 487fc58ba66f0d404c465fa0f0f110c4b9671065 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Czajka?= <62751+lukaszcz@users.noreply.github.com> Date: Thu, 14 Sep 2023 18:50:38 +0200 Subject: [PATCH] Fix bug in isTrait (#2368) * Closes #2367 --- .../FromInternal/Analysis/TypeChecking/Traits/Resolver.hs | 4 ++-- tests/Compilation/positive/out/test061.out | 1 + tests/Compilation/positive/test061.juvix | 3 +++ 3 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/Juvix/Compiler/Internal/Translation/FromInternal/Analysis/TypeChecking/Traits/Resolver.hs b/src/Juvix/Compiler/Internal/Translation/FromInternal/Analysis/TypeChecking/Traits/Resolver.hs index 43e69022c8..9355b019c9 100644 --- a/src/Juvix/Compiler/Internal/Translation/FromInternal/Analysis/TypeChecking/Traits/Resolver.hs +++ b/src/Juvix/Compiler/Internal/Translation/FromInternal/Analysis/TypeChecking/Traits/Resolver.hs @@ -15,8 +15,8 @@ type SubsI = HashMap VarName InstanceParam subsIToE :: SubsI -> SubsE subsIToE = fmap paramToExpression -isTrait :: InfoTable -> InductiveName -> Bool -isTrait tab name = fromJust (HashMap.lookup name (tab ^. infoInductives)) ^. inductiveInfoDef . inductiveTrait +isTrait :: InfoTable -> Name -> Bool +isTrait tab name = maybe False (^. inductiveInfoDef . inductiveTrait) (HashMap.lookup name (tab ^. infoInductives)) resolveTraitInstance :: (Members '[Error TypeCheckerError, NameIdGen, Inference, Reader LocalVars, Reader InfoTable] r) => diff --git a/tests/Compilation/positive/out/test061.out b/tests/Compilation/positive/out/test061.out index fdabe647f3..01961e4c34 100644 --- a/tests/Compilation/positive/out/test061.out +++ b/tests/Compilation/positive/out/test061.out @@ -10,4 +10,5 @@ just (true) :: nothing :: just (false) :: nil just (1 :: nil) :: nothing :: just (2 :: 3 :: nil) :: nil abba abba! +abba3 a :: b :: c :: d :: nil diff --git a/tests/Compilation/positive/test061.juvix b/tests/Compilation/positive/test061.juvix index 9ef1f0e79f..84e37d3b5c 100644 --- a/tests/Compilation/positive/test061.juvix +++ b/tests/Compilation/positive/test061.juvix @@ -47,6 +47,8 @@ f'3 {A} {{M : Show A}} : A → String := Show.show {{M}}; f'4 {A} {{_ : Show A}} : A → String := Show.show; +f5 {A} {{Show A}} (n : String) (a : A) : String := n ++str Show.show a; + main : IO := printStringLn (Show.show true) >> printStringLn (f false) >> @@ -60,4 +62,5 @@ main : IO := printStringLn (f'4 [just [1]; nothing; just [2; 3]]) >> printStringLn (f'3 "abba") >> printStringLn (f'3 {{M := mkShow (λ{x := x ++str "!"})}} "abba") >> + printStringLn (f5 "abba" 3) >> printStringLn (Show.show ["a"; "b"; "c"; "d"]);