summaryrefslogtreecommitdiff
path: root/src/Transfer/ErrM.hs
diff options
context:
space:
mode:
Diffstat (limited to 'src/Transfer/ErrM.hs')
-rw-r--r--src/Transfer/ErrM.hs16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/Transfer/ErrM.hs b/src/Transfer/ErrM.hs
new file mode 100644
index 000000000..1f3c566fd
--- /dev/null
+++ b/src/Transfer/ErrM.hs
@@ -0,0 +1,16 @@
+-- BNF Converter: Error Monad
+-- Copyright (C) 2004 Author: Aarne Ranta
+
+-- This file comes with NO WARRANTY and may be used FOR ANY PURPOSE.
+module Transfer.ErrM where
+
+-- the Error monad: like Maybe type with error msgs
+
+data Err a = Ok a | Bad String
+ deriving (Read, Show, Eq)
+
+instance Monad Err where
+ return = Ok
+ fail = Bad
+ Ok a >>= f = f a
+ Bad s >>= f = Bad s