blob: fa202f7edd490a40f53cdb2288ba43c6cc1aacf8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
{-# LANGUAGE Safe #-}
{-# LANGUAGE CPP #-}
-- This module deliberately declares orphan instances:
{-# OPTIONS_GHC -fno-warn-orphans #-}
-----------------------------------------------------------------------------
-- |
-- Module : Text.Show.Functions
-- Copyright : (c) The University of Glasgow 2001
-- License : BSD-style (see the file libraries/base/LICENSE)
--
-- Maintainer : libraries@haskell.org
-- Stability : provisional
-- Portability : portable
--
-- Optional instance of 'Text.Show.Show' for functions:
--
-- > instance Show (a -> b) where
-- > showsPrec _ _ = showString \"\<function\>\"
--
-----------------------------------------------------------------------------
module Text.Show.Functions () where
import Prelude
#ifndef __NHC__
instance Show (a -> b) where
showsPrec _ _ = showString "<function>"
#else
instance (Show a,Show b) => Show (a->b) where
showsPrec d a = showString "<<function>>"
showsType a = showChar '(' . showsType value . showString " -> " .
showsType result . showChar ')'
where (value,result) = getTypes undefined
getTypes x = (x,a x)
#endif
|