Officially we're using the Glasgow Haskell Compiler version 7.8.3. There is a somewhat older version on attu and the CSE undergrad linux machines, namely 7.6.3. Both should work -- we'll try to run all the sample code on both versions. GHC is the de facto standard version of Haskell.
Open a command window and navigate to the directory where you want to keep your Haskell source files. Run Haskell by typing ghci or ghci MyFile.hs.
Alternately, if you're just experimenting and don't have a source file,
you can run Haskell via the "Start" menu. It's here:
All Programs / DEV TOOLS & LANGUAGES / Haskell Plaform 2013.2.0.0 / GHCi
You can also run Haskell on a .hs file by double-clicking on the file name (but this may not work correctly if you are importing another module that you defined, since Haskell will look in the current working directory for this file).
There are also local copies of documentation under
All Programs / DEV TOOLS & LANGUAGES / Haskell Platform 2013.2.0.0 / GHC Documentation
At the command prompt type ghci to start it, or ghci MyFile.hs to start it and load MyFile.hs.
An advantage of running on the lab Linux machines is that we have the emacs Haskell mode package already downloaded -- see the "Using Linux and Emacs in CSE 341" section of Software for CSE 341.
Attu and the linux machines have an older version of Haskell (7.6.3).
Haskell is available for Windows, Mac, and Linux. Here's the download page: http://www.haskell.org/platform/.
We will be using the HUnit unit testing package in 341. This is installed on the lab machines, and came with the standard install for version 7.8.3 on Macintosh. Hopefully students running on a personal machine won't have any trouble with this -- but if it's missing on an install on a personal machine, post a note on the discussion board and we'll try to help.
You can check that it is there by starting Haskell and typing:
import Test.HUnit
A few essential commands:
If you just want to try Haskell without loading any files, just start it up. For anything interesting, though, you'll want to have a file with defintions in it. A simple way to do this is to use your favorite editor to create a file (with the extension .hs) in your home directory or a subdirectory. Save the file but leave the editor open on it. Then start up Haskell in that same directory on that file. Try things out. If you want to edit your file, do so and save it, and then back in Haskell reload the file using :reload.
The above directions may be all you want for 341; and in any case I'd suggest starting out that way. For students comfortable with emacs (or who are willing to learn) running Haskell from emacs is more convenient in the long run. There are directions for installing and running this at Haskell mode for Emacs.
If you are running on the ugrad linux machines, we've got the emacs Haskell mode packages downloaded already. Just add the following lines to the .emacs file in your home directory:
(load "/cse/courses/cse341/common/haskell-mode/haskell-site-file") (add-hook 'haskell-mode-hook 'turn-on-haskell-doc-mode) (add-hook 'haskell-mode-hook 'turn-on-haskell-indent)
Unlike most programming languages, whitespace is significant in Haskell. So that you can see whether things are lining up properly use a fixed-pitch font when editing. Haskell has some rule about how tabs are processed, but I recommend that you avoid tabs in Haskell code and always use spaces instead.
For emacs, if you use the Haskell mode for Emacs, it will avoid using tabs in files. Otherwise, by default, Emacs inserts tabs in place of multiple spaces when it formats a region. Putting the following in your .emacs file turns this off:
(setq-default indent-tabs-mode nil)