計算機科学のブログ

型によるプログラミング パラメータ化された型 引数をとる型

入門Haskellプログラミング (Will Kurt(著)、株式会社クイープ(監修、翻訳)、翔泳社)のUNIT3(型によるプログラミング)、LESSON 18(パラメータ化された型)、18.1(引数をとる型)、クイックチェック 18-1の解答を求めてみる。

Box (Box Char)型。

実際に確認。

コード

lesson/app/Main.hs

module Main where

import Lib

main :: IO ()
main = return ()

lesson/src/Lib.hs

module Lib
  (
  )
where

data Box a = Box a deriving (Show)

wrap :: a -> Box a
wrap = Box

unwrap :: Box a -> a
unwrap (Box x) = x

入出力結果(Terminal, Zsh)

% stack ghci
Using main module: 1. Package `lesson' component lesson:exe:lesson-exe with main-is file: /Users/…/lesson/app/Main.hs
lesson> initial-build-steps (lib + exe)
The following GHC options are incompatible with GHCi and have not been passed to it: -threaded
Configuring GHCi with the following packages: lesson

* * * * * * * *

Warning: Multiple files use the same module name:
         * Paths_lesson found at the following paths
           * /Users/…/lesson/.stack-work/dist/x86_64-osx/Cabal-3.4.1.0/build/autogen/Paths_lesson.hs (lesson:lib)
           * /Users/…/lesson/.stack-work/dist/x86_64-osx/Cabal-3.4.1.0/build/lesson-exe/autogen/Paths_lesson.hs (lesson:exe:lesson-exe)
* * * * * * * *

GHCi, version 9.0.2: https://www.haskell.org/ghc/  :? for help
macro 'doc' overwrites builtin command.  Use ':def!' to overwrite.
(0.00 secs, 0 bytes)
(0.00 secs, 0 bytes)
Loaded GHCi configuration from /Users/…/.ghc/ghci.conf
[1 of 3] Compiling Lib              ( /Users/…/lesson/src/Lib.hs, interpreted )
[2 of 3] Compiling Main             ( /Users/…/lesson/app/Main.hs, interpreted )
[3 of 3] Compiling Paths_lesson     ( /Users/…/lesson/.stack-work/dist/x86_64-osx/Cabal-3.4.1.0/build/autogen/Paths_lesson.hs, interpreted )
Ok, three modules loaded.
Loaded GHCi configuration from /private/var/folders/wj/52wjq8dn0fj1qltsnx3xxpnh0000gn/T/haskell-stack-ghci/ac09a814/ghci-script
*Main Lib Paths_lesson
λ> :load Lib
[1 of 1] Compiling Lib              ( /Users/…/lesson/src/Lib.hs, interpreted )
Ok, one module loaded.
(0.01 secs,)
*Lib
λ> wrap $ Box 'a'
Box (Box 'a')
it :: Box (Box Char)
(0.01 secs, 512,432 bytes)
*Lib
λ> :t wrap $ Box 'a'
wrap $ Box 'a' :: Box (Box Char)
*Lib
λ> :quit 
Leaving GHCi.
%