Skip to content

Latest commit

 

History

History

report

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Haskell Report Sources
~~~~~~~~~~~~~~~~~~~~~~

.verb files
~~~~~~~~~~~

.verb files are converted to .tex by the preprocessor "verbatim" in
../tools.  When generating HTML via tex4ht, we use a slightly
different version of the preprocesor, in ../tools/verb-tex4ht.


make targets
~~~~~~~~~~~~

   all       make both HTML and PDF versions
   html      make the HTML version
   pdf       make the PDF version
   clean     remove generated files
   haddock   re-generate the library documentation using Haddock
             (see Makefile for instructions)


Re-generating the library documentation using Haddock
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The documentation for library modules is generated automatically by
Haddock (http://www.haskell.org/haddock) from the library source code.
You don't need Haddock to build the report though - the generated .tex
files have been checked into the repository.

The library specifications generated for the Haskell 2010 report were
generated using libraries from these repositories:

  base        (http://darcs.haskell.org/packages/base)
  ghc-prim    (http://darcs.haskell.org/packages/ghc-prim)
  integer-gmp (http://darcs.haskell.org/packages/integer-gmp)
  array       (http://darcs.haskell.org/packages/array)
  haskell2010 (http://darcs.haskell.org/packages/haskell2010)

each of the repositories was tagged with

  "Haskell 2010 report generated"

at the point the libray module documentation was generated, so you
should be able to reproduce exactly what is checked into the
repository.

Right now, the only practical way to re-generate the library module
documentation is to have a GHC build.  Fortunately building GHC isn't
that hard these days: go to 

  http://hackage.haskell.org/trac/ghc/wiki/Building

and follow the instructions.  Make sure you don't disable
documentation building, i.e. don't set HADDOCK_DOCS=NO in your
mk/build.mk configuration file.

When you have built GHC

To update the library documentation see the Makefile, in the section
"Haddock-generated library docs".


Roadmap
~~~~~~~

haskell.verb  -- Top level of the report

Sections of the report:
intro.verb
lexemes.verb
exps.verb
decls.verb
modules.verb
basic.verb
io-13.verb
ffi.verb
standard-prelude.verb
syntax-iso.verb
fixity.verb
derived.verb
pragmas.verb
haskell.bib

Library documentation, generated by Haddock:

libs/*.verb       -- documentation for each library module
haddck.sty        -- definitions for macros used by Haddock

Extra .verb files:
iso-chars.verb    -- Some bogus definitions for ISO chars.  Probably not 
                  -- needed since I removed them from the syntax. 
index-extra.verb  -- extra stuff to get indexed (see also's)
index-intro.verb  -- header for index

Haskell source files:

Prelude.hs
PreludeList.hs
PreludeIO.hs
PreludeText.hs

Figures:

classes.ppt       --  The original class figure (Powerpoint)
classes.eps (*)   --  Postscript version of class-fig
classes.gif (*)   --  For html version
cover.cdr         --  A nice looking cover for the report
cover.eps (*)

Html support:

ht/haskell.cfg     -- tex4ht configuration file
ht/haddock.sty     -- customised Haddock style for HTML output

index.html         -- (unused now) Top level of the html report (hand generated)
lambda.gif         -- (unused now) background for title page

Other files:

Makefile         -- Lots of extra cruft no longer used. 

Report any problems to the most recent editor, or failing that, one of
the past editors of the report.


Making figures
~~~~~~~~~~~~~~
The classes.eps files, which contains the classes hierarchy figure,
is made in Powerpoint, from classses.ppt.  To get the .eps file,
do the following:

* Open classes.ppt
* Print..
* Check the print-to-file box, and save as classes.prn
* Edit classes.prn
	Kill the .prn header and footer (before % PS-Adobe), and after %EOF
	Kill the entire setup code (from BeginSetup to EndSetup)
	Kill the showpage near the end
* Save as classes.eps
* Open with Ghostview
* Note the coords of the bottom LH and top RH corner, as reported by
  Ghostview
* Re-edit classes.eps, and put those coords in the
	%BoundingBox line

You also need to do
	Save As.. 
in Powerpoint, and save the thing as classes.gif, for the HTML version