Вики на www.haskell.org рассказывают нам о Applicative Transformers:
Итак, где аппликативные трансформаторы? Ответ заключается в том, что для аппликативных функторов нам не нужны специальные трансформаторы, поскольку они могут быть объединены общим образом. http://www.haskell.org/haskellwiki/Applicative_functor#Applicative_transfomers
Я попробовал следующее, чтобы попытаться объединить кучу аппликативных функторов. Но все, что у меня было, было кучей ошибок. Вот код:
import Control.Applicative
import System.IO
ex x y = (:) <$> x <*> y
test1 = ex "abc" ["pqr", "xyz"] -- only this works correctly as expected
test2 = ex "abc" [Just "pqr", Just "xyz"]
test3 = ex "abc" (Just "pqr")
test4 = ex (Just 'a') ["pqr", "xyz"]
test5 = ex (return ("abc"):: IO ()) [Just "pqr", Just "xyz"]
Это вызывает множество ошибок типа, которые, хотя я могу частично понять, я не смог их разрешить вообще.
Ошибки приведены в конце.
Итак, как я могу объединить аппликатор Maybe и аппликатор списка, например?
Как я могу объединить пример State Applicative и Application List? Есть ли какие-либо другие примеры, допустим, объединение "Возможно и списка", "Может быть, и состояние" и, наконец, ужас всех заявок на участие в работе ИО и штата?
Спасибо.
Ниже перечислены сообщения об ошибках GHCi.
example.hs:6:19:
Couldn't match expected type `[Char]' with actual type `Maybe a0'
In the return type of a call of `Just'
In the expression: Just "pqr"
In the second argument of `ex', namely `[Just "pqr", Just "xyz"]'
example.hs:7:19:
Couldn't match expected type `[[Char]]' with actual type `Maybe a0'
In the return type of a call of `Just'
In the second argument of `ex', namely `(Just "pqr")'
In the expression: ex "abc" (Just "pqr")
example.hs:8:23:
Couldn't match expected type `Maybe' with actual type `[]'
In the second argument of `ex', namely `["pqr", "xyz"]'
In the expression: ex (Just 'a') ["pqr", "xyz"]
In an equation for `test4': test4 = ex (Just 'a') ["pqr", "xyz"]
example.hs:9:21:
Couldn't match expected type `()' with actual type `[Char]'
In the first argument of `return', namely `("abc")'
In the first argument of `ex', namely `(return ("abc") :: IO ())'
In the expression:
ex (return ("abc") :: IO ()) [Just "pqr", Just "xyz"]
Failed, modules loaded: none.
Prelude>