[OT] Teaching Haskell in High School

Arjan van IJzendoorn afie@cs.uu.nl
Tue, 4 Feb 2003 10:22:13 +0100


John Peterson wrote:

> The downside of Haskell is that none of the regular implementations
> (ghc, hugs) are really right for this level of student.  Type
> inference is an especially nasty problem.  There also a number of
> gotcha's lurking in the language that cause problems.

For exactly these reasons we have implemented Helium; not for replacing
Haskell (we're very happy with Haskell), but for *learning* Haskell. There
is no overloading, so types and type errors are easier to understand. The
Helium compiler produces warnings for situations that are probably
incorrect. I've found myself look at a program with a comparable problem as
the one below for fifteen minutes until I saw what was happening (please
look at the program with a non-proportional font like Courier for optimal
confusion):

filterr :: (a -> Bool) -> [a] -> [a]
filterr p [] = []
fi1terr p (x:xs) = if p x then x : filterr p xs else filterr p xs

Hugs, which we used for teaching, doesn't say a word. GHC does give
helpful warnings if you pass the -Wall flag. Helium says:

(2,9): Variable "p" is not used
(3,1): Missing type signature: fi1terr :: (a -> Bool) -> [a] -> [a]
(3,1): Suspicious adjacent functions "fi1terr" and "filterr"

I'm curious what the other "gotcha's" are that John refers to because it
might give
us inspiration for more warnings/language design decisions.

Arjan
http://www.cs.uu.nl/~afie/helium/