コンテキストでの型の操作 コンテキストとしてのリスト:Applicative型クラスをさらに掘り下げる Applecativeによるfmapの実装
入門Haskellプログラミング (Will Kurt(著)、株式会社クイープ(監修、翻訳)、翔泳社)のUNIT5(コンテキストでの型の操作)、LESSON 29(コンテキストとしてのリスト:Applicative型クラスをさらに掘り下げる)、29.5(練習問題)Q29-1の解答を求めてみる。
コード
lesson/app/Main.hs
module Main (main) where
import Lib (allFmap)
main :: IO ()
main = do
print $ allFmap (+ 1) [1, 2, 3]
print $ allFmap (+ 1) (Just 5)
print $ allFmap (+ 1) Nothing
lesson/src/Lib.hs
module Lib
( allFmap,
)
where
allFmap :: Applicative f => (a -> b) -> f a -> f b
allFmap f x = (pure f) <*> x
入出力結果(Terminal, Zsh)
% stack exec lesson-exe
[2,3,4]
Just 6
Nothing
%