Haddock (software)
Haddock is a free, portable[1] command-line program documentation generator for Haskell. It is influenced by IDoc,[2] HDoc,[3] and Doxygen.[4] It produces hyperlinked HTML files from annotated Haskell (the documentation is embedded in comments) source files, with additional information extracted from type annotations; it supports only partially generating documentation in SGML.[5] It is often used in conjunction with darcs and Cabal. It is dependent on Glasgow Haskell Compiler (GHC), using a modified form of the HsParser (written in Happy) parser for Haskell included in GHC.[5] Its lightweight markup is based on IDoc's.[5] Haddock is contained in the Haskell Platform.
Developer(s) | Simon Marlow |
---|---|
Initial release | May 1, 2002 |
Stable release | 2.8.0
/ September 2, 2010 |
Repository | |
Written in | Haskell |
Operating system | Cross-platform |
Platform | x86, PowerPC |
Type | Documentation generation |
License | BSD-style license |
Website | http://haskell.org/haddock/ |
It is used by the GHC, Gtk2Hs and HTk projects,[6] as well as XMonad.
Here is an example of Haddock markup:
-- | This is the documentation for 'square', which
-- uses the (*) operator from "Prelude".
-- It multiplies the @x@ argument against itself.
square :: Integer -> Integer
square x = x*x
References
- Haddock runs on POSIX-compliant operating systems and Microsoft Windows.
- "IDoc Manual - Installation". www.cse.unsw.edu.au.
- "Homepage of Armin Größlinger". www.fmi.uni-passau.de.
- "1.3. Contributors". haskell.org.
- "Haddock: A Haskell Documentation Tool" Archived 2006-10-11 at the Wayback Machine -(by Simon Marlow, Proceedings of the ACM SIGPLAN workshop on Haskell, 2002; PDF)
- "Haddock is being used to document the new hierarchical Haskell libraries. The documentation generated for the libraries shipped with the latest release of GHC is here. The Gtk2Hs project is using Haddock to build reference documentation. The HTk project is using Haddock to generate its library documentation." From the Haddock homepage.