-- |
-- Module : Data.Maybe
-- Copyright : (c) The University of Glasgow 2001
--- License : BSD-style (see the file libraries/core/LICENSE)
+-- License : BSD-style (see the file libraries/base/LICENSE)
--
-- Maintainer : libraries@haskell.org
-- Stability : experimental
-- Portability : portable
--
--- $Id: Maybe.hs,v 1.4 2002/04/24 16:31:39 simonmar Exp $
---
-- The Maybe type, and associated operations.
--
-----------------------------------------------------------------------------
import GHC.Base
#endif
+#ifdef __NHC__
+import Prelude
+import Prelude (Maybe(..), maybe)
+import Maybe
+ ( isJust
+ , isNothing
+ , fromJust
+ , fromMaybe
+ , listToMaybe
+ , maybeToList
+ , catMaybes
+ , mapMaybe
+ )
+#else
+
+#ifndef __HUGS__
-- ---------------------------------------------------------------------------
-- The Maybe type, and instances
-data Maybe a = Nothing | Just a deriving (Eq, Ord)
+-- | The 'Maybe' type encapsulates an optional value. A value of type
+-- @'Maybe' a@ either contains a value of type @a@ (represented as @'Just' a@),
+-- or it is empty (represented as 'Nothing'). Using 'Maybe' is a good way to
+-- deal with errors or exceptional cases without resorting to drastic
+-- measures such as 'error'.
+--
+-- The 'Maybe' type is also a monad. It is a simple kind of error
+-- monad, where all errors are represented by 'Nothing'. A richer
+-- error monad can be built using the 'Data.Either.Either' type.
+
+data Maybe a = Nothing | Just a
+ deriving (Eq, Ord)
instance Functor Maybe where
fmap _ Nothing = Nothing
maybe :: b -> (a -> b) -> Maybe a -> b
maybe n _ Nothing = n
maybe _ f (Just x) = f x
+#endif /* __HUGS__ */
isJust :: Maybe a -> Bool
isJust Nothing = False
Nothing -> rs
Just r -> r:rs
+#endif /* else not __NHC__ */