我正在关注Liquid Haskell 的官方教程,并偶然发现了其中似乎是一个“错误”。
以下代码出现在教程中, Liquid Haskell 应该检查它是否安全。
{-@ type TRUE = {v:Bool | v } @-}
{-@ type FALSE = {v:Bool | not v} @-}
{-@ (==>) :: p:Bool -> q:Bool -> {v:Bool | v <=> (p ==> q)} @-}
False ==> False = True
False ==> True = True
True ==> True = True
True ==> False = False
{-@ measure f :: Int -> Int @-}
{-@ congruence :: (Int -> Int) -> Int -> Int -> TRUE @-}
congruence :: (Int -> Int) -> Int -> Int -> Bool
congruence f x y = (x == y) ==> (f x == f y)
但是,在检查文件时,我得到:
**** RESULT: UNSAFE ************************************************************
/tmp/liquid.hs:14:1-44: Error: Liquid Type Mismatch
14 | congruence f x y = (x == y) ==> (f x == f y)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Inferred type
VV : {v : GHC.Types.Bool | v <=> (x == y => ?d == ?c)}
not a subtype of Required type
VV : {VV : GHC.Types.Bool | VV}
In Context
?c : GHC.Types.Int
x : GHC.Types.Int
?d : GHC.Types.Int
y : GHC.Types.Int
我怎样才能检查这个属性?