Haddock is a free, portable[2] command-line program documentation generator for Haskell.
Developer(s) | Simon Marlow |
---|---|
Initial release | May 1, 2002 |
Stable release | 2.25.0[1]
/ 2 March 2021 |
Repository | |
Written in | Haskell |
Operating system | Cross-platform |
Platform | x86, PowerPC |
Type | Documentation generation |
License | BSD-style license |
Website | http://haskell.org/haddock/ |
Software
editIt is influenced by IDoc,[3] HDoc,[4] and Doxygen.[5] 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.[6] 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.[6] Its lightweight markup is based on IDoc's.[6] Haddock is contained in the Haskell Platform.
It is used by the GHC, Gtk2Hs and HTk projects,[7] as well as xmonad.[citation needed]
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
edit- ^ "Release 2.25.0". 2 March 2021. Retrieved 25 March 2021.
- ^ 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.
- ^ a b c "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.