在Haskell中,我经常做这样的事情:
f $ \x -> case x of
A a1 a2 -> ...
B b1 b2 -> ...
C c1 c2 -> ...
Run Code Online (Sandbox Code Playgroud)
但我不想要x,我只想解构它.
在标准ML中,我可以这样做:
f (fn A(a1,a2) => ...
| B(b1,b2) => ...
| C(c1,c2) => ...)
Run Code Online (Sandbox Code Playgroud)
有没有办法在Haskell或任何GHC扩展中执行此操作?
{-# LANGUAGE LambdaCase #-}
我有一堆函数以各种方式编码失败.例如:
f :: A -> BoolFalse失败时返回g :: B -> Maybe B'Nothing失败时返回h :: C -> Either Error C'Left ...失败时返回我想以与Maybemonad 相同的方式链接这些操作,因此链接函数需要知道每个函数在继续下一个函数之前是否失败.为此,我写了这堂课:
class Fail a where
isFail :: a -> Bool
instance Fail () where
isFail () = False
instance Fail Bool where -- a
isFail = not
instance Fail (Maybe a) where -- b
isFail = not . isJust
instance Fail (Either a b) where -- c …Run Code Online (Sandbox Code Playgroud)