計算機科学のブログ

コンテキストでの型の操作 コンテキストとしてのリスト: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
%