Hi Guys!

I have defined the following type:
data Entry a = EmptyEntry | MakeEntry a a

i have defined show and read as follows:
---------------------------------------------
instance (Show a) => Show (Entry a)
    where showsPrec _ x  = showEntry x

showEntry :: (Show a) => Entry a -> String -> String
showEntry EmptyEntry      = shows "Empty"
showEntry (MakeEntry a b) =  shows a . (':':) . (' ':) . shows b

instance (Read a) => Read (Entry a)
    where readsPrec _ s = readEntry s

readEntry :: (Read a) => ReadS (Entry a)
readEntry s = [(EmptyEntry, x) | ("Empty", x) <- lex s]
              ++
              [(MakeEntry a b, w) | (a, u) <- reads s,
                                    (": ", v) <- lex u,
                                    (b, w) <- reads v]
------------------------------------------------

when I use show or read in any function, i get the following errormessage from hugs:

ERROR "./main.hgs":14 - Cannot justify constraints in explicitly typed binding
*** Expression : getandparse
*** Type : String -> Entry a
*** Given context : ()
*** Constraints : Read a


printing an instance of Entry directly ( print (MakeEntry "Hello" "World") ) works. But using print in a function that takes a string, doesn't work...

Does anybody have an idea how to solve the problem?
thanks
Stephan
_______________________________________________
Haskell mailing list
[EMAIL PROTECTED]
http://www.haskell.org/mailman/listinfo/haskell

Reply via email to