=head1 NAME
INSTALL - installing GNU LilyPond
=head1 DESCRIPTION
This page documents installation and compilation of GNU LilyPond
=head1 ABSTRACT
You do something which looks remotely like
configure
make
make install
tar -C /usr/lib/texmf/fonts/source/ -zxf musixtex-T73.tgz 'mf/*'
The detailed instructions follow here.
=head1 PREREQUISITES
For compilation you need.
=over 5
=item *
A Unix system with GNU tools. GNU LilyPond is known to run on these
unices: Linux, AIX, Digital Unix and Solaris.
If you have the Cygnus WINDOWS32 port of the GNU utils, it will even
work in Windows NT/95, but we don't promise to support it.
=item *
GNU C++ v2.7 or better, with libg++ installed. Version 2.7.2
or better recommended.
=item *
GNU make.
=item *
Flex (2.5.1 or better).
=item *
Bison. (Version 1.25 or better)
=back
=head1 RUNNING
GNU LilyPond does use a lot of resources. For operation you need the following:
=over 5
=item *
TeX
=item *
The MusixTeX fonts (I included those found in MusixTeX T.73). Beware,
the clef symbol seems to have changed its position in some versions,
(notably Egler's, a.k.a. OpusTeX). The MusixTeX fonts are included in
MusixTeX (T73 or better), which can be had from any CTAN site, e.g. at
=over 4
=item ftp://ftp.shsu.edu/tex-archive/macros/musixtex/taupin
=item ftp://ftp.tex.ac.uk/tex-archive/macros/musixtex/taupin
=item ftp://ftp.dante.de/tex-archive/macros/musixtex/taupin
=back
You only need the contents of the F subdirectory of the
package. The primary site of the Taupin version is
ftp://hprib.lps.u-psud.fr/pub/music_zips/musixtex.zip
Andreas Egler's version of MusixTeX, now called OpusTeX, will also
work. Andreas moved some characters around in the fonts, so you have
to edit the definitions in tex/eglerdefs.tex (patch appreciated)
=head1 RECOMMENDED
Although not strictly necessary, these are recommended to have.
=over 5
=item *
Perl. Most scripts are written in Perl. Most documentation was created
with the perl's Plain Old Documentation.
=item *
GNU find
=item *
A fast computer (a full page of music typically takes 1 minute
on my 486/133, using the B<--enable-checking> compile. It's lot slower
than most MusiXTeX preprocessors)
=back
=head1 CONFIGURING and COMPILING
to install GNU LilyPond, simply type:
configure
make install
This will install the following files:
/usr/local/man/man1/mi2mu.1
/usr/local/man/man1/convert-mudela.1
/usr/local/man/man1/mudela-book.1
/usr/local/man/man1/lilypond.1
/usr/local/lib/libflower.{so,a}
/usr/local/bin/lilypond
/usr/local/bin/mi2mu
/usr/local/share/lilypond/*
/usr/lib/texmf/texmf/tex/lilypond/*
The TeX include directory is detected dynamically, but it can be
adjusted with B<--enable-tex-prefix> and B<--enable-tex-dir>. The
above assumes that you are root and have the GNU development tools,
and your make is GNU make. If this is not the case, you can adjust
your environment variables to your taste:
export CPPFLAGS="-I /home/me/my_include -DWEIRD_FOOBAR"
configure
C are the preprocessor flags.
the configure script is Cygnus configure, and it will accept
B<--help>. If you are not root, you will probably have to make it with
configure --prefix=/home/me_myself_and_I/
In this case, you will have to set MFINPUTS, and TEXINPUTS accordingly.
If you want to install GNU LilyPond in F, and your TeX has
no default hooks for local stuff (mine is broken too), you can do:
configure --prefix=/usr/local --enable-tex-prefix=/usr/lib/texmf
Since GNU LilyPond currently is beta, you are advised to also use
--enable-debugging
--enable-checking
other options include:
=over 4
=item --enable-shared
Make a shared library (gnu/linux, solaris (?) only )
=item --enable-printing
Enable debugging print routines (lilypond B<-d> option)
=item --enable-optimise
Set maximum optimisation: compile with B<-O2>
=item --enable-profiling
Compile with support for profiling
=item --enable-tex-prefix
Set the directory where TeX and Metafont live
=item --enable-tex-dir
Set then directory TeX input is in (detected as a subdir of tex-prefix)
=item --enable-mf-dir
Set then directory mf input is in (idem) [obsolete]
=back
All options are documented in the F help
The option B<--enable-optimise> is recommended for Real Life usage.
If you do
make all
everything will be compiled, but nothing will be installed. The
resulting binaries can be found in the subdirectories F (which
contain all files generated during compilation).
=head1 INSTALLING
If you have done a successful C, then a simple
make install
should do the trick.
Install the musixtex fonts in a directory which TeX and MF knows (if
you are root, look for a directory which contains the directories with
AMS and CM source (*.mf) files. Create a subdir lilypond or musixtex
and copy the fonts into that). Do not forget to rehash TeX (if
applicable)
Example: my fonts are in F, and I
have a symlink pointing to that in
F. After I copied the
files, I ran "texhash"
=head1 CAVEATS
=over 5
=item *
The -O2 option to gcc triggers a gcc bug on DEC Alpha in dstream.cc. You
should turn off this flag for this file.
=back
=head1 EXAMPLE
This is what I type in my xterm:
lilypond someinput.ly
tex lelie.tex
xdvi test&
This is what the output looks like over here:
GNU LilyPond 0.0.78 #4/FlowerLib 1.1.24 #0
Parsing ... [/home/hw/share/lilypond/init//
<..etc..>
init//performer.ly]]][input/kortjakje.ly]
Creating elements ...[8][16][24][25]
Preprocessing elements...
Calculating column positions ... [14][25]
Postprocessing elements...
TeX output to lelie.tex ...
Creating MIDI elements ...MIDI output to lelie.midi ...
hw:~/musix/spacer$ xdvi lelie&
[1] 855
Check out the input files, some of them have comments
Please refer to the man page for more information.
=head1 REDHAT LINUX
RedHat Linux users should be able to get a RPM. A spec file is in
F. You should be able to create an rpm as a normal
user. Be sure you have a ~/.rpmrc, and edit the RPM-dir in
F. (If you create the RPM as a normal user the
permissions will not be set correctly, unfortunately)
=head1 WINDOZE
Windows NT:
you need the cygnus windows32 gnu port development stuff; have a look
at http://www.cygnus.com/gnu-win32.
to make GNU LilyPond under, brr, aargh, shudder.. windows32, well,
simply type:
bash configure
make windows32
=head1 AUTHORS
Han-Wen Nienhuys
Jan Nieuwenhuizen
Have fun!