On Fri, Dec 5, 2008 at 1:29 AM, Martijn van Steenbergen <martijn@van.steenbergen.nl> wrote:
Dmitri O.Kondratiev wrote:
-- How to define Show [MyType] ?
Define instance Show MyType and implement not only show (for 1 value of MyType) but also showList, which Show provides as well. You can do all the magic in there.
HTH,
Martijn.
Thanks everybody for your help!
I tried to implement showList, but get the same error:
{--
-- from Prelude:
type ShowS = String -> String
showList :: [a] -> ShowS
--}
myShows::ShowS
myShows s = s ++ "\n"
data ShipInfo = Ship {
name :: String,
kind :: String,
canons :: Int
} deriving Show
-- I get this error again:
instance (Show [ShipInfo]) where
showList [] = myShows []
showList (x:xs) = myShows "x" ++ showList xs
Illegal instance declaration for `Show [ShipInfo]'
(The instance type must be of form (T a b c)
where T is not a synonym, and a,b,c are distinct type variables)
In the instance declaration for `Show [ShipInfo]'
Failed, modules loaded: none.
-- What am I doing wrong?
Thanks!