]> git.donarmstrong.com Git - lilypond.git/commitdiff
release: 1.2.1 release/1.2.1
authorHan-Wen Nienhuys <hanwen@xs4all.nl>
Mon, 16 Aug 1999 09:42:58 +0000 (11:42 +0200)
committerHan-Wen Nienhuys <hanwen@xs4all.nl>
Mon, 16 Aug 1999 09:42:58 +0000 (11:42 +0200)
40 files changed:
ANNOUNCE-1.2
AUTHORS.txt
ChangeLog [new file with mode: 0644]
Documentation/faq.yo
Documentation/man/out/ly2dvi.1
Documentation/metadoc/GNUmakefile
Documentation/metadoc/feta20.sty [new file with mode: 0644]
Documentation/tex/reference-manual.yo
Documentation/tex/tutorial.yo
INSTALL.txt
NEWS
PATCHES.txt
README.txt
TODO
VERSION
aclocal.m4
buildscripts/lilypond-login.sh
configure
lily/dynamic-engraver.cc
lily/include/bar-align-engraver.hh [deleted file]
lily/include/beam-swallow-trans.hh [deleted file]
lily/include/dynamic-engraver.hh [deleted file]
lily/include/type-swallow-trans.hh [deleted file]
lily/lookup.cc
lily/midi-item.cc
lily/type-swallow-trans.cc [deleted file]
ly/paper.ly
ly/params.ly
make/out/lilypond.lsm
make/out/lilypond.spec
make/toplevel.make.in
mutopia/N.W.Gade/brass.ly
mutopia/N.W.Gade/global.tex
mutopia/N.W.Gade/parts.ly
mutopia/N.W.Gade/score.ly
mutopia/N.W.Gade/wood.ly
scripts/convert-mudela.py
stepmake/make/out/stepmake.lsm
stepmake/make/out/stepmake.spec
tex/titledefs.tex

index 008569d3c3c039998071d609501791adb63584a2..ec9bef6cd25da0b876e08025c958e7e943a4b658 100644 (file)
@@ -1,6 +1,5 @@
 -*- text -*-
 
-[DRAFT]
 
 Keywords: midi notation music typesetting gnu font engraving 
 Subject: GNU LilyPond 1.2 released - The Music Typesetter
@@ -27,8 +26,8 @@ DOWNLOAD
 
 Sources for this project are on
 
-       ftp://ftp.cs.uu.nl/~hanwen/lilypond/ (Europe)
-       ftp://ftp.gnu.org/
+       ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/v1.2/ (Europe)
+       ftp://ftp.gnu.org/pub/lilypond/
 
 Prepackaged i386 and PPC packages for both Debian and RedHat GNU are
 also available.
@@ -48,8 +47,7 @@ WHAT'S NEW?
   signature, more note heads.
 
 * Enhanced input: semi-automatic beaming, (nested) tuplets, (nested)
-  repeats, chordnames, automatic Lyrics
-  durations.
+  repeats, chordnames, automatic Lyrics durations.
   
 * Grace notes, volta brackets, multiple styles for note heads and 
   time signatures, breathing signs, lyric extenders, cross staff 
index 692c32e9d4ae4919893d1319eee6174307210550..a9440caf71ed4647e2c3a8b8d7c96c3618ee0297 100644 (file)
@@ -3,63 +3,63 @@
 
 Contents
 
-This  file  lists  authors  of  GNU  LilyPond, and what they
+This file lists authors of GNU LilyPond, and what they
 wrote.  This list is alphabetically ordered.
 
-o    Tom Cato Amundsen <tomcato@xoommail.com>,  cembalo-par-
+o    Tom Cato Amundsen <tomcato@xoommail.com>, cembalo-par-
      tita in mudela, accordion symbols, some mudela-book.py
 
-o    Mats            Bengtsson            <matsb@s3.kth.se>,
-     http://www.s3.kth.se/~matsb/ lots  of  testing,  fixes,
+o    Mats Bengtsson <matsb@s3.kth.se>,
+     http://www.s3.kth.se/~matsb/ lots of testing, fixes,
      general comments and contributions.
 
 o    Eric Bullinger <eric@aut.ee.ethz.ch>, accidental trans-
      position.
 
-o    Jan  Arne  Fagertun  <Jan.A.Fagertun@energy.sintef.no>,
+o    Jan Arne Fagertun <Jan.A.Fagertun@energy.sintef.no>,
      TeX titling and lytodvi.sh
 
 o    Anthony Fok <foka@debian.org>, debian package: debian/*
 
-o    Bjoern  Jacke  <bjoern.jacke@gmx.de>  german   glossary
+o    Bjoern Jacke <bjoern.jacke@gmx.de> german glossary
      stuff.
 
 o    Neil Jerram <nj104@cus.cam.ac.uk>.  parts of Documenta-
      tion/Vocab*
 
-o    Donald    Ervin    Knuth,     http://www-cs-staff.stan-
-     ford.edu/~knuth/  mf/ital-*.mf  (these  were taken from
+o    Donald Ervin Knuth,  http://www-cs-staff.stan-
+     ford.edu/~knuth/ mf/ital-*.mf (these were taken from
      the CM fonts)
 
-o    Michael  Krause   <m.krause@tu-harburg.de>,   breathing
+o    Michael Krause <m.krause@tu-harburg.de>, breathing
      signs
 
-o    Werner  Lemberg <xlwy01@uxp1.hrz.uni-dortmund.de>, misc
+o    Werner Lemberg <xlwy01@uxp1.hrz.uni-dortmund.de>, misc
      bugfixes, some Beam and Stem code.
 
-o    David R. Linn <drl@vuse.vanderbilt.edu>,  Mailing  list
+o    David R. Linn <drl@vuse.vanderbilt.edu>, Mailing list
      maintenance.
 
-o    Adrian  Mariano  <>  Reference  manual, tutorial fixes,
+o    Adrian Mariano <> Reference manual, tutorial fixes,
      glossary.
 
-o    Han-Wen           Nienhuys           <hanwen@cs.uu.nl>,
-     http://www.cs.uu.nl/~hanwen/   Main  author  (initials:
+o    Han-Wen Nienhuys <hanwen@cs.uu.nl>,
+     http://www.cs.uu.nl/~hanwen/ Main author (initials:
      HWN).
 
-o    Jan          Nieuwenhuizen           <janneke@gnu.org>,
-     http://www.xs4all.nl/~jantien/  Main  author (initials:
+o    Jan Nieuwenhuizen <janneke@gnu.org>,
+     http://www.xs4all.nl/~jantien/ Main author (initials:
      JCN).
 
-o    Alexandre  Oliva  <oliva@dcc.unicamp.br>,   http://sun-
+o    Alexandre Oliva <oliva@dcc.unicamp.br>, http://sun-
      site.unicamp.br/~oliva/ testing
 
-o    Franc,ois  Pinard  <pinard@iro.umontreal.ca>,  parts of
-     Documentation/Vocab*,   started    internationalization
+o    Franc,ois Pinard <pinard@iro.umontreal.ca>, parts of
+     Documentation/Vocab*, started internationalization
 
      stuff
 
-o    Glen  Prideaux  <glenprideaux@iname.com>, minor bug fix
+o    Glen Prideaux <glenprideaux@iname.com>, minor bug fix
      to script used to generate doc++ documentation
 
 o    Jeffrey B. Reed <daboys@austin.rr.com>, Windows-NT sup-
@@ -67,5 +67,5 @@ o    Jeffrey B. Reed <daboys@austin.rr.com>, Windows-NT sup-
 
 o    Shay Rojanski Some mudela source.
 
-Your  name  could  be here! If you want to fix something, do
+Your name could be here! If you want to fix something, do
 it, and send us a patch!
diff --git a/ChangeLog b/ChangeLog
new file mode 100644 (file)
index 0000000..9fb5000
--- /dev/null
+++ b/ChangeLog
@@ -0,0 +1,26 @@
+pl 0.uu1
+       - refman updates by Werner & Mats
+       - now use ChangeLog for changes.
+       
+pl 0.jcn2
+       - po fixes
+
+pl 0.jcn1
+       - gcc-2.95 nitpicks
+       - added pointers to mailing lists in toplevel docs
+
+0.mb2
+       - configure: more robust detection of Guile
+       - Midi_note_off: revert to fixed note-off velocity. Fixes
+         problem with notes that never stop.
+       - Decreased breakable_column_space_strength
+       - Added a few TODO
+       - bf: "harmonic" and "cross" note heads also for half and 
+         whole notes.
+       - linewidth and textheight set independent of the font size.
+       - bf, titledefs.tex: opus and piece are not repeated for 
+         every piece unless they are explicitly set again.
+
+0.mb1
+       - Changed dynamicDir to dynamicDirection.
+       - refman and tutorial corrections.
index 3bc2dfaa38ba1dac3f69a193c74745fe3a890a02..fa758cebfb3002ae09d54efb9579d22197cc20a9 100644 (file)
@@ -510,6 +510,12 @@ sect(Copyright)
 
 question(What is Urtext?  Critical Edition?)
 
+Werner Lemberg:
+
+It may be translated best as `that what the composer intended to tell
+the reader'
+
+
 Peter Chubb <peterc@aurema.com> writes:
 
 An Urtext is a reconstruction of the earliest form of a text,
@@ -540,6 +546,7 @@ signature changes, time compression (original in 4/1, playing edition
 in 4/4, for example, with all semibreves replaced with crotchets)
 Copyright is in the arranger/editor.
 
+
 question(How does copyright for sheet music work? Can I enter and spread my newly bought Bach urtext?) 
 
 Silas S. Brown <ssb22@hermes.cam.ac.uk>:
index c090160395626e429bb51fefc542198ec061beb0..d9e486654a4b5b6ca007b6f31021321fa9e6f506 100644 (file)
@@ -33,9 +33,6 @@ tex file at the end of the headers, last line before \f(CW\ebegin{document}\fP
 .IP "-H,--Heigth=" 
 Set paper heigth (points)\&. Used together with width and LaTeX name of
 papersize in case of papersize unknown to ly2dvi\&.
-.IP "-F,--headers=" 
-Name of additional LaTeX headers file\&. This is included in the
-tex file at the end of the headers, last line before \f(CW\ebegin{document}\fP
 .IP "-K,--keeplilypond" 
 Keep LilyPond output after the run\&.
 .IP "-L,--landscape" 
index 6e8a382f62553dc68ae33750f89030f4f331f294..015002e47f178a555fc51abe4357ae32d3a47ea6 100644 (file)
@@ -31,7 +31,7 @@ include $(depth)/make/stepmake.make
 
 
 
-dvi: $(OUT_BIB_FILES) $(DVI_FILES)
+dvi: $(DVI_FILES)
 
 ps: $(PS_FILES)
 
@@ -52,7 +52,7 @@ $(outdir)/%.tex: %.data $(depth)/VERSION
 
 
 
-local-WWW: $(HTML_FILES) $(OUTTEX_FILES:.tex=.ps.gz) $(OUTYO_FILES:.yo=.latex) $(OUTYO_FILES:.yo=.ps.gz) $(addprefix $(outdir)/, $(BIB_FILES:.bib=.html)) $(datafiles)
+local-WWW: $(HTML_FILES) $(OUTTEX_FILES:.doc=.ps.gz) $(OUTYO_FILES:.yo=.latex) $(OUTYO_FILES:.yo=.ps.gz) $(addprefix $(outdir)/, $(BIB_FILES:.bib=.html)) $(datafiles) ps
        $(PYTHON) $(step-bindir)/ls-latex.py --package=$(topdir) --title 'LaTeX documents about design and implementation of LilyPond' \
          $(YO_FILES) $(OUTYO_FILES:.yo=.latex) $(BIB_FILES) $(DOC_FILES) $(TEX_FILES)\
          | sed "s!$(outdir)/!!g" > $(outdir)/index.html
diff --git a/Documentation/metadoc/feta20.sty b/Documentation/metadoc/feta20.sty
new file mode 100644 (file)
index 0000000..0dbfcf9
--- /dev/null
@@ -0,0 +1,146 @@
+% Creator: mf-to-table.py version 0.7
+% Automatically generated on
+% Do not edit
+% input from out/feta20.log
+% name
+% rests
+\fetdef\wholerest{0}
+\fetdef\halfrest{1}
+\fetdef\outsidewholerest{2}
+\fetdef\outsidehalfrest{3}
+\fetdef\breverest{4}
+\fetdef\longarest{5}
+\fetdef\multirest{6}
+\fetdef\quartrest{7}
+\fetdef\eighthrest{8}
+\fetdef\sixteenthrest{9}
+\fetdef\thirtysecondrest{10}
+\fetdef\sixtyfourthrest{11}
+\fetdef\hundredtwentyeighthrest{12}
+
+% accidentals
+\fetdef\sharp{13}
+\fetdef\natural{14}
+\fetdef\flat{15}
+\fetdef\flatflat{16}
+\fetdef\sharpsharp{17}
+\fetdef\rightparen{18}
+\fetdef\leftparen{19}
+
+% dots
+\fetdef\dot{20}
+\fetdef\repeatcolon{21}
+
+% balls
+\fetdef\brevisball{22}
+\fetdef\brevisledger{23}
+\fetdef\longaball{24}
+\fetdef\longaledger{25}
+\fetdef\wholeball{26}
+\fetdef\wholeledger{27}
+\fetdef\halfball{28}
+\fetdef\halfledger{29}
+\fetdef\quartball{30}
+\fetdef\quartledger{31}
+
+% scripts
+\fetdef\ufermata{32}
+\fetdef\dfermata{33}
+\fetdef\thumb{34}
+\fetdef\sforzatoaccent{35}
+\fetdef\staccato{36}
+\fetdef\ustaccatissimo{37}
+\fetdef\dstaccatissimo{38}
+\fetdef\tenuto{39}
+\fetdef\umarcato{40}
+\fetdef\dmarcato{41}
+\fetdef\ouvert{42}
+\fetdef\plusstop{43}
+\fetdef\upbow{44}
+\fetdef\downbow{45}
+\fetdef\reverseturn{46}
+\fetdef\turn{47}
+\fetdef\trill{48}
+\fetdef\upedalheel{49}
+\fetdef\dpedalheel{50}
+\fetdef\upedaltoe{51}
+\fetdef\dpedaltoe{52}
+\fetdef\flageolet{53}
+\fetdef\trilelement{54}
+\fetdef\prall{55}
+\fetdef\mordent{56}
+\fetdef\prallprall{57}
+\fetdef\prallmordent{58}
+\fetdef\upprall{59}
+\fetdef\downprall{60}
+\fetdef\accDiscant{61}
+\fetdef\accDiscantF{62}
+\fetdef\accDiscantEh{63}
+\fetdef\accDiscantE{64}
+\fetdef\accDiscantFE{65}
+\fetdef\accDiscantFEh{66}
+\fetdef\accDiscantEE{67}
+\fetdef\accDiscantFEE{68}
+\fetdef\accDiscantEEE{69}
+\fetdef\accDiscantFEEE{70}
+\fetdef\accDiscantS{71}
+\fetdef\accDiscantFS{72}
+\fetdef\accDiscantES{73}
+\fetdef\accDiscantEhS{74}
+\fetdef\accDiscantFES{75}
+\fetdef\accDiscantFEhS{76}
+\fetdef\accDiscantEES{77}
+\fetdef\accDiscantFEES{78}
+\fetdef\accDiscantEEES{79}
+\fetdef\accDiscantFEEES{80}
+\fetdef\accDiscantSS{81}
+\fetdef\accDiscantESS{82}
+\fetdef\accDiscantEESS{83}
+\fetdef\accDiscantEEESS{84}
+\fetdef\accFreebass{85}
+\fetdef\accFreebassF{86}
+\fetdef\accFreebassE{87}
+\fetdef\accFreebassFE{88}
+\fetdef\accStdbass{89}
+\fetdef\accStdbassM{90}
+\fetdef\accStdbassBp{91}
+\fetdef\accStdbassT{92}
+\fetdef\accStdbassTp{93}
+\fetdef\accBayanbass{94}
+\fetdef\accBayanbassT{95}
+\fetdef\accBayanbassE{96}
+\fetdef\accBayanbassTE{97}
+\fetdef\accBayanbassEE{98}
+\fetdef\accBayanbassTEE{99}
+\fetdef\accSB{100}
+\fetdef\accBB{101}
+\fetdef\accOldEE{102}
+\fetdef\accOldEES{103}
+
+% flags
+\fetdef\eighthflag{104}
+\fetdef\sixteenthflag{105}
+\fetdef\thirtysecondflag{106}
+\fetdef\sixtyfourthflag{107}
+\fetdef\deighthflag{108}
+\fetdef\dsixteenthflag{109}
+\fetdef\dthirtysecondflag{110}
+\fetdef\dsixtyfourthflag{111}
+
+% clefs
+\fetdef\altoclef{112}
+\fetdef\caltoclef{113}
+\fetdef\bassclef{114}
+\fetdef\cbassclef{115}
+\fetdef\trebleclef{116}
+\fetdef\ctrebleclef{117}
+
+% timesig
+\fetdef\fourfourmeter{118}
+\fetdef\allabreve{119}
+\fetdef\oldfourfourmeter{120}
+\fetdef\oldallabreve{121}
+\fetdef\oldthreetwometer{122}
+\fetdef\oldsixfourmeter{123}
+\fetdef\oldninefourmeter{124}
+
index fa89c365b3539f0f30abc0fcc36122b11b2ad0d5..a07e17480567e07f23cad8035b9f3056044d034f 100644 (file)
@@ -1,9 +1,10 @@
 mailto(gnu-music-discuss@gnu.org)
 COMMENT(-*-text-*-)
 
-redef(var)(1)(whenlatex(latexcommand({\normalfont\scshape )ARG1+latexcommand(}))\
-    whenhtml(sc(ARG1)))
-
+redef(var)(1)(\
+  whenlatex(latexcommand({\normalfont\scshape )ARG1+latexcommand(}))\
+  whenhtml(sc(ARG1))\
+)
 
 def(indexcode)(1)(cindex(ARG1@code(ARG1)))
 def(indexandcode)(1)(code(ARG1)indexcode(ARG1))
@@ -11,49 +12,53 @@ def(keyindex)(1)(cindex(ARG1@code(\ARG1)))
 
 redef(code)(1)(tt(ARG1))
 redef(cindex)(1)(\
-    whenlatex(latexcommand(\index{)ARG1+latexcommand(}))\
-    whentexinfo(XXnl()texinfocommand(@cindex )ARG1XXnl())\
+  whenlatex(latexcommand(\index{)ARG1+latexcommand(}))\
+  whentexinfo(XXnl()texinfocommand(@cindex )ARG1XXnl())\
 )
 
 
 COMMENT(
-
   BUGS:
 
-   restStyle=mensural doesn't seem to work (lots of characters not found
-     for rests.fly)
+    restStyle=mensural doesn't seem to work (lots of characters not found
+    for rests.fly)
 
-TODO:
+  TODO:
   
-   accordion symbols
-   Music expression / music expression
+    accordeon symbols
+    Music expression / music expression
 )
 
 
 COMMENT( 
-This document contains Mudela fragments.  You need at least
-Yodl-1.30.18 to convert this to tex or html.
+  This document contains Mudela fragments.  You need at least
+  Yodl-1.30.18 to convert this to tex or html.
 )
 
 htmlbodyopt(bgcolor)(white)
 htmlcommand(<font color=black>)
 
 latexlayoutcmds(
-\setlength{\topmargin}{-0.25in}
-\setlength{\textheight}{9in}
-\setlength{\textwidth}{5.875in} 
-\setlength{\oddsidemargin}{0.25in}   
-\setlength{\evensidemargin}{0.25in}
-\input mudela-book
-\usepackage{makeidx}
-\makeindex
+  \setlength{\topmargin}{-0.25in}
+  \setlength{\textheight}{9in}
+  \setlength{\textwidth}{5.875in} 
+  \setlength{\oddsidemargin}{0.25in}   
+  \setlength{\evensidemargin}{0.25in}
+  \input mudela-book
+  \usepackage{makeidx}
+  \makeindex
 )
 
 whentexinfo(notableofcontents())
 
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 article(LilyPond 1.2.0 Reference Manual)
-      (Adrian Mariano, Han-Wen Nienhuys and Jan Nieuwenhuizen)
-      (nop()PIPETHROUGH(date "+%B %d, %Y")()()nop())
+       (Adrian Mariano, Han-Wen Nienhuys and Jan Nieuwenhuizen)
+       (nop()PIPETHROUGH(date "+%B %d, %Y")()()nop())
 
 
 latexcommand(\def\interexample{})
@@ -61,92 +66,135 @@ latexcommand(\def\preexample{\par})
 latexcommand(\def\postexample{\par\medskip})
 latexcommand(\def\file#1{{code(#1)}})
 COMMENT(
-latexcommand(\def\texttt#1{\tt #1})
-latexcommand(\def\textbf#1{\bf #1})
+  latexcommand(\def\texttt#1{\tt #1})
+  latexcommand(\def\textbf#1{\bf #1})
 )
 
 COMMENT(urg, texinfo include breaks)
-whenhtml(
-includefile(html-disclaimer.yo-urg)
-)
+whenhtml(includefile(html-disclaimer.yo-urg))
 
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 sect(Overview)
 
+This nop(document)footnote(This document has been revised for
+LilyPond 1.2.) describes the the GNU LilyPond input format, which is
+a language for defining music.  We call this language em(Music
+Definition Language) or em(Mudela), for short.footnote(If anybody
+comes up with a better name, we'd gladly take this.  Gourlay already
+uses a ``Musical Description Language,'' ISO standard 10743 defines a
+``Standard Music Description Language.''  We're not being original
+here.)
 
-This nop(document)footnote(This document was revised for LilyPond
-1.2.)  describes the the GNU LilyPond input format, which is a
-language for defining music.  We call this language Music Definition
-Language or Mudela, for short.footnote(If anybody comes up with a
-better name, we'd gladly take this. Gourlay already uses Musical
-Description Language,  ISO standard
-10743 defines a Standard Music Description Language.  We're not being
-original here.)
+em(Mudela) is a language that allows you to
 
-Mudela is a language that allows you  to
 itemize(
-it() create musical expressions by combining pitches, durations 
-it() output those musical expressions to various formats
-it() give those musical expressions and output definitions names, so
-you can enter them in manageable chunks.
+  it() create musical expressions by combining pitches, durations 
+  it() output those musical expressions to various formats
+  it() give those musical expressions and output definitions names, so
+       you can enter them in manageable chunks.
 )
 
-Mudela aims to define a piece of music completely, both from
+em(Mudela) aims to define a piece of music completely, both from
 typesetting and from a performance point of view.
 
-sect(Top level)cindex(top level)
 
-This section describes what you may  enter at top level.
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+sect(Top level)
+cindex(top level)
+
+This section describes what you may enter at top level.
 
-subsect(Score definitions)cindex(score definition)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Score definitions)
+cindex(score definition)
 
 The output is generated combining a music expression with an output
-definition.  A score block has the following syntax code(\score {)
-var(musicexpr) var(outputdefs) code(}).  var(outputdefs) are zero or
-more output definitons.  If no output definiton is supplied, the
-default code(\paper) block will be added.
+definition.  A score block has the following syntax:
+
+quote(
+  code(\score {) var(musicexpr) var(outputdefs) code(})
+)
+
+var(outputdefs) are zero or more output definitions.  If no output
+definition is supplied, the default code(\paper) block will be added.
 
-subsect(Information header)cindex(header)keyindex(header)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-The syntax is code(\header) code({) var(key1) = var(val1); var(key2) = var(val2); ... code(})
+subsect(Information header)
+cindex(header)
+keyindex(header)
+
+The syntax is
+
+quote(
+  code(\header) code({) var(key1) = var(val1);
+                        var(key2) = var(val2); ellipsis() code(})
+)
 
 A header describes the file's contents.  It can also appear in a
 code(\score) block.  Tools like indexandcode(ly2dvi) can use this
-information for generating titles.  Key values that are used by ly2dvi
-are: title, subtitle, composer, opus, poet, instrument, metre,
-arranger, piece and tagline.
+information for generating titles.  Key values that are used by
+code(ly2dvi) are: title, subtitle, composer, opus, poet, instrument,
+metre, arranger, piece and tagline.
 
 It is customary to put the code(\header) at the top of the file.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 subsect(Setting notenames and chordnames)
 label(notenames)
 
-Note name tables can be specified using code(\notenames)keyindex(notenames) code({)
-var(assignmentlist) code(}).  var(assignmentlist) is a list of definitions of
-the form var(name) = var(pitch).
+Note name tables can be specified using
+
+quote(
+  code(\notenames)keyindex(notenames)
+    code({) var(assignmentlist) code(})
+)
+
+var(assignmentlist) is a list of definitions of the form
+
+quote(
+  var(name) = var(pitch)
+)
 
 Chord modifiers can be set analogously, with
 code(\chordmodifiers)keyindex(chordmodifiers).
 
-
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Output definitions)
 
 A code(\paper) block at top level sets the default paper block.  A
 code(\midi) block at top level works similarly.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(GUILE and Scheme)
 
 LilyPond contains a Scheme interpreter (the GUILE library) for
-internal use.  The following commands access the interpreter directly.
+internal use.  The following commands access the interpreter
+directly.
+
+quote(
+  code(\scm)keyindex(scm) var(scheme) code(;)
+)
 
-code(\scm)keyindex(scm) var(scheme)code(;) evaluates the specified Scheme
-code.  The result is discarded. keyindex(scm)
+Evaluates the specified Scheme code.  The result is discarded.
 
-code(\scmfile)keyindex(scmfile) var(filename)code(;) reads Scheme code from the
-specified file.  The result is discarded. keyindex(scmfile)
+quote(
+  code(\scmfile)keyindex(scmfile) var(filename) code(;)
+)
+
+Reads Scheme code from the specified file.  The result is discarded.
+
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Identifiers)
 
@@ -154,96 +202,175 @@ Identifier assignments may appear at top level.  Semicolons are
 forbidden after top level assignments.
 
 
-sect(Lexical conventions)cindex(Lexical conventions)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Comments)cindex(Comments)
-cindex(%)
+sect(Lexical conventions)
+cindex(lexical conventions)
 
-A one line comment is introduced by a indexandcode(%)
-character.  Block comments are started by code(%{) and ended by
-code(%}).  They cannot be nested.
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
+subsect(Comments)
+cindex(comment)
+indexcode(%)
+whenlatex(cindex(%A@latexcommand(\texttt{\%\textbraceleft})))
+whenlatex(cindex(%B@latexcommand(\texttt{\%\textbraceright})))
+
+A one line comment is introduced by a `code(%)' character. 
+Block comments are started by `code(%{)' and ended by `code(%})'. 
+They cannot be nested.
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Keywords)
 cindex(keyword)
 
 Keywords start with a backslash, followed by a number of lower case
-alphabetic characters.  This are all the keywords.
-
-verb(\accepts \addlyrics \alternative \bar \breathe \cadenza
-\chordmodifiers \chords \clef \cm \consists \consistsend \context
-\duration \font \grace \header \in \key \keysignature \lyrics \mark
-\midi \mm \musicalpitch \name \notenames \notes \paper \partial
-\penalty \property \pt \relative \remove \repeat \repetitions \scm
-\scmfile \score \script \sequential \shape \simultaneous \skip
-\spanrequest \tempo \textscript \time \times \translator \transpose
-\type)
+alphabetic characters.  These are all the keywords.
+
+latexcommand(\begin{raggedright})
+quote(
+  code(\accepts)
+  code(\addlyrics)
+  code(\alternative)
+  code(\bar)
+  code(\breathe)
+  code(\cadenza)
+  code(\chordmodifiers)
+  code(\chords)
+  code(\clef)
+  code(\cm)
+  code(\consists)
+  code(\consistsend)
+  code(\context)
+  code(\duration)
+  code(\font)
+  code(\grace)
+  code(\header)
+  code(\in)
+  code(\key)
+  code(\keysignature)
+  code(\lyrics)
+  code(\mark)
+  code(\midi)
+  code(\mm)
+  code(\musicalpitch)
+  code(\name)
+  code(\notenames)
+  code(\notes)
+  code(\paper)
+  code(\partial)
+  code(\penalty)
+  code(\property)
+  code(\pt)
+  code(\relative)
+  code(\remove)
+  code(\repeat)
+  code(\repetitions)
+  code(\scm)
+  code(\scmfile)
+  code(\score)
+  code(\script)
+  code(\sequential)
+  code(\shape)
+  code(\simultaneous)
+  code(\skip)
+  code(\spanrequest)
+  code(\tempo)
+  code(\textscript)
+  code(\time)
+  code(\times)
+  code(\translator)
+  code(\transpose)
+  code(\type)
+)
+latexcommand(\end{raggedright})
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Integers)cindex(Integers)
+subsect(Integers)
+cindex(integer)
 
 Formed from an optional minus sign followed by digits.  Arithmetic
 operations cannot be done with integers, and integers cannot be mixed
 with reals.
 
-subsect(Reals)cindex(Reals) 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Reals)
+cindex(real) 
+
 Formed from an optional minus sign and a sequence of digits followed
 by a em(required) decimal point and an optional exponent such as
 code(-1.2e3).  Reals can be built up using the usual operations:
-indexandcode(+), indexandcode(-), indexandcode(*), and indexandcode(/), with parentheses for grouping.
-
-A real constant can be followed by one of the dimension keywords:
-cindex(dimension) code(\mm)keyindex(mm), code(\pt)keyindex(pt),
-code(\in)keyindex(in), or code(\cm)keyindex(cm), for millimeters,
-points, inches and centimeters.  This converts the number a real that
+`indexandcode(+)', `indexandcode(-)', `indexandcode(*)', and
+`indexandcode(/)', with parentheses for grouping.
+
+A real constant can be followed by one of the dimension
+keywords:cindex(dimensions) code(\mm)keyindex(mm),
+code(\pt)keyindex(pt), code(\in)keyindex(in), or
+code(\cm)keyindex(cm), for millimeters, points, inches and
+centimeters, respectively.  This converts the number to a real that
 is the internal representation of dimensions.
 
-subsect(String)cindex(String) 
-
-Begins and ends with the code(") character.  To include a code(")
-character in a string write code(\").  Various other backslash
-sequences have special interpretations as in the C language.  A string
-that contains no spaces can be written without the quotes.  See
-Section ref(modes) for details on unquoted strings; their
-interpretation varies depending on the situation.  Strings can be
-concatenated with the code(+) operator.
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
+subsect(String)
+cindex(string) 
 
+Begins and ends with the `code(")' character.  To include a `code(")'
+character in a string write `code(\")'.  Various other backslash
+sequences have special interpretations as in the C language.  A
+string that contains no spaces can be written without the quotes. 
+See bind(section)ref(modes) for details on unquoted strings; their
+interpretation varies depending on the situation.  Strings can be
+concatenated with the `code(+)' operator.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Tokenizer commands)
 
 The tokenizer accepts the following commands.  They can appear
 anywhere.
 
-description(
+quote(
+  code(\maininput)keyindex(maininput)
+)
 
-dit(code(\maininput)) keyindex(maininput) This command is used in init
-files to signal that the user file must be read.  This command cannot
-be used in a user file.
+This command is used in init files to signal that the user file must
+be read. This command cannot be used in a user file.
 
-dit(code(\include) var(file))keyindex(include) Include var(file).  The
-argument var(file) may be a quoted string, (An unquoted string will
-not work here.)  or a string identifier.  The full filename including
-the file(.ly) extension must be given,
+quote(
+  code(\include)keyindex(include) var(file)
+)
 
-dit(code(\version) var(string)code(;))
-keyindex(version)
-Specify the version of LilyPond that a
-file was written for.  The argument is a  version string in quotes, for example
-code("1.2.0").  This is used to detect invalid input, and to aid
-code(convert-mudela), a tool that automatically upgrades input files.
+Include var(file).  The argument var(file) may be a quoted string (an
+unquoted string will not work here!) or a string identifier.  The full
+filename including the file(.ly) extension must be given,
+
+quote(
+  code(\version)keyindex(version) var(string) code(;)
 )
 
-subsect(Pitch Names in Other Languages)cindex(other languages)
+Specify the version of LilyPond that a file was written for.  The
+argument is a version string in quotes, for example code("1.2.0"). 
+This is used to detect invalid input, and to aid
+code(convert-mudela), a tool that automatically upgrades input files.
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Pitch Names in Other Languages)
+cindex(other languages)
 label(notelang)
 
-Note name definitions have been provided in various languages.  
+Note name definitions have been provided in various languages. 
 Simply include the language specific init file.  For example:
-code(\include "english.ly").  The available language files and the names
-they define are:
+`code(\include "english.ly")'.  The available language files and the
+names they define are:
 
+quote(
 verb(                        Note Names               sharp       flat
+
 nederlands.ly  c   d   e   f   g   a   bes b   -is         -es
 english.ly     c   d   e   f   g   a   bf  b   -s/-sharp   -f/-flat
 deutsch.ly     c   d   e   f   g   a   b   h   -is         -es
@@ -251,544 +378,672 @@ norsk.ly       c   d   e   f   g   a   b   h   -iss/-is    -ess/-es
 svenska.ly     c   d   e   f   g   a   b   h   -iss        -ess
 italiano.ly    do  re  mi  fa  sol la  sid si  -d          -b
 catalan.ly     do  re  mi  fa  sol la  sid si  -d/-s       -b)
+)
 
- Pitch names can be redefined using the
-code(\notenames)keyindex(notenames) command, see Subsection
-ref(notenames).
+Pitch names can be redefined using the
+code(\notenames)keyindex(notenames) command, see
+bind(subsection)ref(notenames).
 
-subsect(Lexical modes)cindex(Lexical modes)cindex(modes)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Lexical modes)
+cindex(lexical modes)
+cindex(modes)
 label(modes)
 
-To simplify entering notes, lyrics and chords Mudela has three special
-input modes on top of the default mode.  In each mode, words are
-identified on the input.  If code("word") is encountered, it is
-treated as a string.  If code(\word) is encountered it is treated as a
-keyword or as an identifier.  The behavior of the modes differs in two
-ways: different modes treat unquoted words differently, and different
-modes have different rules for deciding what is a word.
+To simplify entering notes, lyrics, and chords, em(Mudela) has three
+special input modes on top of the default mode.  In each mode, words
+are identified on the input.  If code("word") is encountered, it is
+treated as a string.  If code(\word) is encountered, it is treated as
+a keyword or as an identifier.  The behavior of the modes differs in
+two ways: Different modes treat unquoted words differently, and
+different modes have different rules for deciding what is a word.
 
 description(
-dit(Normal mode)cindex(mode!normal) 
-At the start of parsing, Mudela is in normal mode.
-In normal mode, a word is an alphabetic character followed by
-alphanumeric characters.  If code(word) is encountered on the input it
-is treated as a string. 
-
-dit(Note mode) cindex(mode!note) Note mode is introduced by the keyword
-code(\notes)keyindex(notes).  In Note mode, words can only contain alphabetic
-characters.  If code(word) is encountered, LilyPond first checks for a
-notename of code(word).  If no notename is found, then code(word) is
-treated as a string.
-
-Since combinations of numbers and dots are used for indicating
-durations, it is not possible to enter real numbers in this mode.
-
-dit(Chord mode)cindex(mode!chord) Chord mode is introduced by the keyword
-code(\chords)keyindex(chords).  It is similar to note mode, but words are also looked
-up in a chord modifier table (containg code(maj), code(dim) etc.)
-
-Since combinations of numbers and dots are used for indicating
-durations, you can not enter real numbers in this mode.  Dashes and
-carets are used to indicate chord additions and subtractions, so
-scripts can not be entered in chord mode.
-
-dit(Lyric mode) cindex(mode!lyric) Lyrics mode is introduced by the keyword
-code(\lyrics)keyindex(lyrics).  This mode is has rules that make it easy to include
-punctuation and diacritical marks in words.  A word in Lyrics mode
-begins with: an alphabetic character, code(_), code(?), code(!),
-code(:), code('), the control characters code(^A) through code(^F),
-code(^Q) through code(^W), code(^Y), code(^^), any 8-bit character
-with ASCII code over 127, or a two character combination of a
-backslash followed by one of code(`), code('), code(") or
-code(^).footnote(The purpose of lyrics mode is that you can enter lyrics in
-TeX() format or a standard encoding without needing quotes.  The
-precise definition of this mode indeed is ludicrous.  This will remain
-so until the authors of LilyPond acquire a deeper understanding of
-character encoding, or someone else steps up to fix this.)
-
-Subsequent characters of a word can be any character that is not a
-digit and not white space.  One important consequence of this is that
-a word can end with code(}), which may be confusing if you thought the
-code(}) was going to terminate lyrics mode.footnote(LilyPond will
-issue a warning, though).  Any code(_) characters
-which appear in an unquoted word are converted to spaces.  This
-provides  a
-mechanism for introducing spaces into words without using quotes.  
-Quoted words can also be used in lyrics mode to specify words that
-cannot be specified with the above rules.  Here are some examples.
-Not all of these words are printable by TeX().
+  dit(Normal mode.)cindex(mode!normal) 
+    At the start of parsing, em(Mudela) is in Normal mode.  In Normal
+    mode, a word is an alphabetic character followed by alphanumeric
+    characters.  If code(word) is encountered on the input it is
+    treated as a string.
+
+  dit(Note mode.)cindex(mode!note)
+
+    Note mode is introduced by the keyword
+    code(\notes)keyindex(notes).  In Note mode, words can only
+    contain alphabetic characters.  If code(word) is encountered,
+    LilyPond first checks for a notename of code(word).  If no
+    notename is found, then code(word) is treated as a string.
+
+    Since combinations of numbers and dots are used for indicating
+    durations, it is not possible to enter real numbers in this mode.
+
+  dit(Chord mode.)cindex(mode!chord)
+    Chord mode is introduced by the keyword
+    code(\chords)keyindex(chords).  It is similar to Note mode, but
+    words are also looked up in a chord modifier table (containing
+    code(maj), code(dim), etc).
+
+    Since combinations of numbers and dots are used for indicating
+    durations, you can not enter real numbers in this mode.  Dashes
+    and carets are used to indicate chord additions and subtractions,
+    so scripts can not be entered in Chord mode.
+
+  dit(Lyrics mode.) cindex(mode!lyric)
+
+    Lyrics mode is introduced by the keyword
+    code(\lyrics)keyindex(lyrics).  This mode has rules that make it
+    easy to include punctuation and diacritical marks in words.  A
+    word in Lyrics mode begins with: an alphabetic character,
+    `code(_)', `code(?)', `code(!)', `code(:)', `code(')', the
+    control characters code(^A) through code(^F), code(^Q) through
+    code(^W), code(^Y), code(^^), any 8-bit character with ASCII code
+    over 127, or a two-character combination of a backslash followed
+    by one of `code(`)', `code(')', `code(")', or
+    `code(^)'.footnote(The purpose of Lyrics mode is that you can
+    enter lyrics in TeX() format or a standard encoding without
+    needing quotes.  The precise definition of this mode indeed is
+    ludicrous.  This will remain so until the authors of LilyPond
+    acquire a deeper understanding of character encoding, or someone
+    else steps up to fix this.)
+
+    Subsequent characters of a word can be any character that is not
+    a digit and not white space.  One important consequence of this
+    is that a word can end with `code(})', which may be confusing if
+    you thought the closing brace was going to terminate Lyrics
+    mode.footnote(LilyPond will issue a warning, though.)  Any
+    `code(_)' characters which appear in an unquoted word are
+    converted to spaces.  This provides a mechanism for introducing
+    spaces into words without using quotes.  Quoted words can also be
+    used in Lyrics mode to specify words that cannot be written with
+    the above rules.  Here are some examples.  Not all of these words
+    are printable by TeX().
+
 COMMENT(
 DOEXPAND(muckslash)^etre          % a word
-)verb(Ah!       % a word
-2B_||_!2B       % not a word because it starts with a digit
-``Hello''       % not a word because it starts with `
-_ _ _ _         % 4 words, each one a space
 )
 
+    quote(
+verb(Ah!             % a word
+2B_||_!2B       % not a word because it starts with a digit
+``Hello''       % not a word because it starts with `
+_ _ _ _         % 4 words, each one a space)
+    )
 
-Since combinations of numbers and dots are used for indicating
-durations, you can not enter real numbers in this mode.
-
+    Since combinations of numbers and dots are used for indicating
+    durations, you can not enter real numbers in this mode.
 )
 
 It is possible to create words that break the rules by prefixing them
-with the dollar sign indexandcode($).  Regardless of the context, a word
-beginning with code($) extends until the next white space character.
-Such words can contain numbers (even in Note mode), or other forbidden
-characters.  The dollar sign can be used to create and access
-identifiers that could not otherwise be used.footnote(Use of $ hampers
-readability and portability to future LilyPond versions.  Use of $ is
-discouraged.)
+with the dollar sign `indexandcode($)'.  Regardless of the context, a
+word beginning with `code($)' extends until the next white space
+character.  Such words can contain numbers (even in Note mode), or
+other forbidden characters.  The dollar sign can be used to create
+and access identifiers that could not otherwise be used.footnote(Use
+of `code($)' hampers readability and portability to future LilyPond
+versions, thus the use of the dollar sign is discouraged.)
 
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
+sect(Types)
+cindex(types and identifiers)
 
-sect(Types)cindex(Types and identifiers)
+em(Mudela) has a limited set of types:
 
-Mudela has a limited set of types:
 itemize(
-it() integers,
-it() reals,
-it() strings,
-it() music expressions,
-it() durations of notes and rests (specified with code(\notenames)keyindex(notenames)),
-it() note name tables,
-it() context definitions,  Part of output definitions.  See Section ref(contextdefs) for more
-information,
-it() output definitions (like code(\paper)keyindex(paper) blocks and
-code(\midi)keyindex(midi) blocks),
-it() score definitions. (code(\score)keyindex(score) blocks)
-)
-
-
-Type is a syntactical property: Mudela has no real type system, so
-there is no support for generic expressions, functions or user defined
-types.  For the same reason, it is not possible to mix reals and
-integers in arithmetic expressions, and ``type errors'' cindex(type error) (eg. using a
-string identifier to initialize a code(\paper)keyindex(paper) block)
-will yield ``parse error''.
+  it() integers
+  it() reals
+  it() strings
+  it() music expressions
+  it() durations of notes and rests (specified with
+       code(\notenames)keyindex(notenames))
+  it() note name tables
+  it() context definitions, part of output definitions.  See
+       bind(section)ref(contextdefs) for more information
+  it() output definitions (like code(\paper)keyindex(paper) blocks
+       and code(\midi)keyindex(midi) blocks)
+  it() score definitions (code(\score)keyindex(score) blocks)
+)
+
+Type is a syntactical property: em(Mudela) has no real type system,
+so there is no support for generic expressions, functions, or user
+defined types.  For the same reason, it is not possible to mix reals
+and integers in arithmetic expressions, and ``type
+errors''cindex(type error) (e.g., using a string identifier to
+initialize a code(\paper)keyindex(paper) block) will yield a ``parse
+error''.
 
 Identifiers allow objects to be assigned to names.  To assign an
-identifier you use var(name)=var(value) and to refer to an identifier,
-you preceed its name with a backslash: code(\)var(name).  Identifier
-assignments must appear at top level in the Mudela file.
-Semicolons are forbidden after assignments appearing at top level
-but they are obligatory after assignments appearing elsewhere.
+identifier, you use `var(name)=var(value)' and to refer to an
+identifier, you preceed its name with a backslash:
+`code(\)var(name)'.  Identifier assignments must appear at top level
+in the em(Mudela) file.  Semicolons are forbidden after assignments
+appearing at top level but they are obligatory after assignments
+appearing in the code(\paper) block, see bind(Section)ref(paper).
 
 var(value) is any of the types listed above.
 
 An identifier can be created with any string for its name, but you
 will only be able to refer to identifiers whose names begin with a
-letter and are entirely alphanumeric.  It is impossible to refer to an
+letter, being entirely alphanumeric.  It is impossible to refer to an
 identifier whose name is the same as the name of a keyword.
 
 The right hand side of an identifier assignment is parsed completely
 before the assignment is done, so it is allowed to redefine an
-identifier in terms of its old value: code(foo = \foo * 2.0).
+identifier in terms of its old value, e.g.
 
+quote(
+  code(foo = \foo * 2.0)
+)
 
-When an identifier is referenced, the information that it points to is
+When an identifier is referenced, the information it points to is
 copied.  Therefore it only makes sense to put identifiers for
-translators, output definitions and code(\score)keyindex(score) blocks as the first
-item in a block.  For this reason, if you reference to a code(\foo)
-variable in a code(\foo) block, it must be the first item in the list
-following code(\foo).footnote(code(\paper{\one \two}) does not make
-sense, because the information of code(\two) would overwrite the
-information of code(\one), thereby making the reference to the first
-identifier useless.)
-
-
-
-sect(Music expressions)cindex(Music expressions)
+translators, output definitions, and code(\score)keyindex(score)
+blocks as the first item in a block.  For this reason, if you
+reference a code(\foo) variable in a code(\foo) block, it must be the
+first item in the list following code(\foo).footnote(code(\paper{\one
+\two}) does not make sense, because the information of code(\two)
+would overwrite the information of code(\one), thereby making the
+reference to the first identifier useless.)
+
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+sect(Music expressions)
+cindex(music expressions)
+
+Music in em(Mudela) is entered as a music expression.  Notes, rests,
+lyric syllables are music expressions (the atomic
+expressions)cindex(atomic music expressions), and you can combine
+music expressions to form new ones.  This example forms a compound
+expressions out of the quarter code(c) note and a code(d)
+note:
+
+quote(
+  verb(\sequential { c4 d4 })
+)
 
-Music in mudela is entered as a music expression.  Notes, rests, lyric
-syllables are music expressions (the atomic expressions),
-cindex(atomic music expressions) and you can
-combine music expressions to form new ones.  This example
-forms a compound expressions out of the quarter code(c)   note and a
-code(d) note:COMMENT(
+The meaning of this compound expression is to play the `code(c)'
+first, and then the `code(d)' (as opposed to playing them
+simultaneously, for instance).
 
-)verb(\sequential { c4 d4 })COMMENT(
+Atomic music expression are discussed in
+bind(subsection)ref(atomicmusic).  Compound music expressions are
+discussed in bind(subsection)ref(compoundmusic).
 
-)The meaning of this compound expression is to play the code(c) first,
-and then the code(d) (as opposed to playing them simultaneously, for
-instance).
 
-Atomic music expression are discussed in
-bind(Subsection)ref(atomicmusic).  Compound music expressions are
-discussed in bind(Subsection)ref(compoundmusic).
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 sect(Atomic music expressions)
 label(atomicmusic)
 
-subsect(Pitch and duration)cindex(pitch)cindex(duration) 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Pitch and duration)
+cindex(pitch)
+cindex(duration) 
 
 The syntax for pitch specification is
-code(\musicalpitch)keyindex(musicalpitch) code({) var(octave)
-var(note) var(shift) code(}) The octave is specified by an integer,
-zero for the octave containing middle C.  The note is a number from 0
-to 7, with 0 corresponding to C and 7 corresponding to B.  The shift
-is zero for a natural, negative to add flats, or positive to add
-sharps.
 
-In note and chord mode,  pitches may be designated by names. 
-See Section ref(notelang) for pitch names in different languages.
+quote(
+  code(\musicalpitch)keyindex(musicalpitch)
+    code({) var(octave) var(note) var(shift) code(})
+)
+
+var(octave) is specified by an integer, zero for the octave
+containing middle C.  var(note) is a number from 0 to 7, with 0
+corresponding to C and 7 corresponding to B.  The shift is zero for a
+natural, negative to add flats, or positive to add sharps.
 
-The syntax for duration specification is
-code(\duration)keyindex(duration) code({) var(length) var(dotcount)
-code(}) var(length) is the negative logarithm (base 2) of duration: 1
-is a half note, 2 is a quarter note, 3 is an eighth note, etc.  The
-number of dots after the note is given by var(dotcount).
+In Note and Chord mode, pitches may be designated by names.  See
+bind(section)ref(notelang) for pitch names in different languages.
 
-In note, chord and lyric mode, durations may be designated by numbers
-and dots. See Section ref(notelang) for details.
+The syntax for duration specification is
 
+quote(
+  code(\duration)keyindex(duration)
+    code({) var(length) var(dotcount) code(})
+)
 
+var(length) is the negative logarithm (base 2) of the duration:
+bind(1)is a half note, bind(2)is a quarter note, bind(3)is an eighth
+note, etc.  The number of dots after the note is given by
+var(dotcount).
 
+In Note, Chord, and Lyrics mode, durations may be designated by
+numbers and dots.  See bind(Section)ref(notelang) for details.
 
-subsect(Note specification)label(notedesc)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-cindex(Note Specification)
-cindex(pitches)cindex(entering notes)
+subsect(Note specification)
+label(notedesc)
+cindex(note specification)
+cindex(pitches)
+cindex(entering notes)
 
 A note specification has the form
-var(pitch)[var(octavespec)][code(!)][code(?)][var(duration)].  The
-pitch of the note is specified by the note's name.
 
-subsubsect(Pitches)
+quote(
+  var(pitch)[var(octavespec)][code(!)][code(?)][var(duration)]
+)
 
-The default names are the Dutch note names.  The notes are specified
-by the letters code(c) through code(b), where code(c) is an octave
-below middle C and the letters span the octave above that C.  In
-Dutch,cindex(notenames!Dutch) a sharp is formed by adding code(-is) to
-the end of a pitch name.  A flat is formed by adding code(-es).
-Double sharps and double flats are obtained by adding code(-isis) or
-code(-eses).  code(aes) and code(ees) are contracted to code(as) and
-code(es) in Dutch, but both forms will be accepted.q
+The pitch of the note is specified by the note's name.
 
+subsubsect(Pitches)
 
-LilyPond has predefined sets of notenames for various
-languages.  See Section ref(notelang) for details.
+The default names are the Dutch note names.  The notes are specified
+by the letters `code(c)' through `code(b)', where `code(c)' is an
+octave below middle C and the letters span the octave above that C. 
+In Dutchcindex(notenames!Dutch), a sharp is formed by adding
+`code(-is)' to the end of a pitch name.  A flat is formed by adding
+`code(-es)'. Double sharps and double flats are obtained by adding
+`code(-isis)' or `code(-eses)'.  `code(aes)' and `code(ees)' are
+contracted to `code(as)' and `code(es)' in Dutch, but both forms will
+be accepted.
+
+LilyPond has predefined sets of notenames for various languages.  See
+bind(section)ref(notelang) for details.
 
 subsubsect(Octaves)
 
-The optional octave specification takes the form of a series of single
-quote indexandcode(') characters or a series of comma indexandcode(,)
-characters.  Each code(') raises the pitch by one octave; each code(,)
-lowers the pitch by an octave.
+The optional octave specification takes the form of a series of
+single quote (`indexandcode(')') characters or a series of comma
+(`indexandcode(,)') characters.  Each code(') raises the pitch by one
+octave; each code(,) lowers the pitch by an octave.
 
-mudela(fragment,verbatim,center)(
-c' d' e' f' g' a' b' c''
-)
+mudela(fragment,verbatim,center)(  c' d' e' f' g' a' b' c'')
 
-mudela(fragment,verbatim,center)(
-cis' dis' eis' fis' gis' ais' bis'
-)
+mudela(fragment,verbatim,center)(  cis' dis' eis' fis' gis' ais' bis')
 
-mudela(fragment,verbatim,center)(
-ces' des' es' fes' ges' as' bes'
-)
+mudela(fragment,verbatim,center)(  ces' des' es' fes' ges' as' bes')
 
-mudela(fragment,verbatim,center)(
-cisis' eisis' gisis' aisis' beses'
-)
+mudela(fragment,verbatim,center)(  cisis' eisis' gisis' aisis' beses')
 
-mudela(fragment,verbatim,center)(
-ceses' eses' geses' ases' beses'
-)
+mudela(fragment,verbatim,center)(  ceses' eses' geses' ases' beses')
 
 Whenever a C-sharp is desired,  you must specify a C-sharp.  LilyPond
-will determine what accidentals to  typeset  depending on the  key and
-context.   
-A reminder accidental cindex(reminder accidental) can be forced by
-adding an exclamation mark `code(!)'
-after the pitch.
-A cautionary accidental, cindex(cautionary accidental) i.e., an accidental within parentheses
-can be obtained by adding the question mark `indexandcode(?)' after
-the pitch.COMMENT(
+will determine what accidentals to typeset depending on the key and
+context.  A reminder accidental cindex(reminder accidental) can be
+forced by adding an exclamation mark `code(!)' after the pitch.  A
+cautionary accidental, cindex(cautionary accidental) i.e., an
+accidental within parentheses can be obtained by adding the question
+mark `indexandcode(?)' after the pitch.
 
-)mudela(fragment,verbatim,center)(
-cis' d' e' cis'  c'? d' e' c'!  
-)
+mudela(fragment,verbatim,center)(  cis' d' e' cis'  c'? d' e' c'!)
 
 subsubsect(Duration)
 cindex(duration)
 
-Durations are entered as their reciprocal values. For notes longer
+Durations are entered as their reciprocal values.  For notes longer
 than a whole note, use identifiers.
-verb(
-  c'\longa c'\breve  
-  c'1 c'2 c'4 c'8 c'16 c'32 c'64 c'64 
+
+quote(
+verb(c'\longa c'\breve  
+c'1 c'2 c'4 c'8 c'16 c'32 c'64 c'64)
+)
+
+quote(
+mudela()(\score {
+  \notes \relative c'' {
+    a\longa a\breve  
+    a1 a2 a4 a8 a16 a32 a64 a64 
+  }
+  \paper {
+    loose_column_distance = 2.5 * \interline;
+    linewidth = -1.0;
+    \translator {
+      \type "Score_engraver";
+      \name "Score";
+      \consists "Note_heads_engraver";
+      \consists "Stem_engraver";
+      \consists "Rhythmic_column_engraver";
+    }
+  }
+})
+)
+
+quote(
+verb(r\longa r\breve  
+r1 r2 r4 r8 r16 r32 r64 r64)
+)
+
+quote(
+mudela()(\score {
+  \notes \relative c'' {
+    r\longa r\breve  
+    r1 r2 r4 r8 r16 r32 r64 r64 
+  }
+  \paper {
+    loose_column_distance = 2.5 * \interline;
+    linewidth = -1.0;
+    \translator {
+      \type "Score_engraver";
+      \name "Score";
+      \consists "Rest_engraver";
+      \consists "Stem_engraver";
+      \consists "Rhythmic_column_engraver";
+    }
+  }
+})
 )
-mudela()(
-\score {
-       \notes \relative c'' {
-         a\longa a\breve  
-         a1 a2 a4 a8 a16 a32 a64 a64 
-         }
-         \paper {
-               loose_column_distance = 2.5 * \interline;
-               linewidth = -1.0;
-               \translator { \type "Score_engraver";
-                           \name "Score";
-                           \consists "Note_heads_engraver";
-                           \consists "Stem_engraver";
-                           \consists "Rhythmic_column_engraver";
-         }}})
-verb(
-  r\longa r\breve  
-  r1 r2 r4 r8 r16 r32 r64 r64 
-)mudela()(\score {
-       \notes \relative c'' {
-         r\longa r\breve  
-         r1 r2 r4 r8 r16 r32 r64 r64 
-         }
-         \paper {
-               loose_column_distance = 2.5 * \interline;
-               linewidth = -1.0;
-               \translator { \type "Score_engraver";
-                           \name "Score";
-                           \consists "Rest_engraver";
-                           \consists "Stem_engraver";
-                           \consists "Rhythmic_column_engraver";
-         } }})
 
 If the duration is omitted then it is set equal to the previous
 duration.  If there is no previous duration, a quarter note is
-assumed.  The duration can be followed by a dot indexandcode(.) to
-obtain dotted note lengths.  COMMENT(
+assumed.  The duration can be followed by a dot (`indexandcode(.)')
+to obtain dotted note lengths.
 
-)mudela(fragment,verbatim,center)(
-a'4. b'4.
-)
+mudela(fragment,verbatim,center)(  a'4. b'4.)
 
-You can alter the length of duration by writing code(*)var(fraction)
-after a it.  This will not affect the appearance of note heads or
-rests.
+You can alter the length of duration by writing
+`code(*)var(fraction)' after it.  This will not affect the
+appearance of note heads or rests.
 
 subsubsect(Rests)
 
-Rests are entered like notes, with note name indexandcode(r),
-indexandcode(s) or indexandcode(R).  There is also a note name which
-produces a nonprinting note of the specified duration. code(R) is
-specifically  meant for entering parts: the code(R) rest can expand to
-fill a score with rests, or it can be printed as a single multimeasure rest.
+Rests are entered like notes, with note name `indexandcode(r)',
+or `indexandcode(R)'.  There is also a note name `indexandcode(s)',
+which produces a space of the specified duration. 
+`code(R)' is specifically meant for entering parts: the code(R) rest
+can expand to fill a score with rests, or it can be printed as a
+single multimeasure rest.
+
+subsubsect(Lyrics syllables)
+cindex(lyrics expressions)
+
+Syllables are entered like notes, with pitches replaced by text.  For
+example, `code(Twin-4 kle4 twin-4 kle4)' enters four syllables, each
+with quarter note duration.  Note that the hyphen has no special
+meaning for lyrics, and does not introduce special symbols.  See
+bind(section)ref(modes) for a description of what is interpreted as
+lyrics.
+
+Spaces can be introduced into a lyric either by using quotes
+(`code(")') or by using an underscore without quotes: `code(He_could4
+not4)'.  All unquoted underscores are converted to spaces.  Printing
+lyrics is discussed in bind(section)ref(lyricprint).
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Properties)
+cindex(properties)
 
-subsubsect(Lyrics syllables)cindex(Lyric expressions)
+quote(
+  code(\property)keyindex(property)
+    var(contextname)code(.)var(propname) code(=) var(value)
+)
+
+Sets the var(propname) property of the context var(contextname) to
+the specified var(value).  All three arguments are strings. 
+Depending on the context, it may be necessary to quote the strings or
+to leave space on both sides of the dot.
 
-Syllables are entered like notes, with pitches replaced
-by text.  For example code(Twin-4 kle4 twin-4 kle4) enters four
-syllables, each with quarter note duration.  Note that the hyphen has
-no special meaning for lyrics, and does not introduce special symbols.
-See Section ref(modes) for a description of what is interpreted as a lyric.
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-Spaces can be introduced into a lyric either by using quotes (code("))
-or by using an underscore without quotes: code(He_could4 not4).  All
-unquoted underscores are converted to spaces.  Printing lyrics is
-discussed in Section ref(lyricprint).
+subsect(Translator switches)
+cindex(translator switches)
 
-subsect(Properties)cindex(Properties)
+quote(
+  code(\translator)keyindex(translator)
+    var(contexttype) = var(name)
+)
 
-code(\property)keyindex(property) var(contextname)code(.)var(propname) code(=) var(value)
-Sets the var(propname) property of the context var(contextname) to the
-specified var(value).  All three arguments are strings.  Depending on
-the context it may be necessary to quote the strings or to leave space
-on both sides of the dot. 
+A music expression indicating that the context which is a direct
+child of the a context of type var(contexttype) should be shifted to
+a context of type var(contexttype) and the specified name.
 
-subsect(Translator switches)cindex(Translator switches)
+Usually this is used to switch staffs in Piano music, e.g.
 
-code(\translator)keyindex(translator) var(contexttype) = var(name)
-A music expression that the context which is a direct child of the 
-a  context of type var(contexttype) should be shifted to a context of
-type var(contexttype) and  the specified name.  
+quote(
+  code(\translator Staff = top) var(Music)
+)
 
-Usually this is used to switch staffs in Piano music,
-eg. code(\translator Staff = top )var(Music)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Commands)cindex(Commands)
+subsect(Commands)
+cindex(commands)
 
 Commands are music expressions that have no duration.   
 
 subsubsect(Key signatures)
 
-code(\key)keyindex(key) var(pitch) var(type) code(;) Change the key
-signature.  var(type) should be code(\major)keyindex(major) or code(\minor)keyindex(minor)
-to get var(pitch)-major or var(pitch)-minor, respectively. The second
-argument is optional, the default is major keys.  The var(\context)
+quote(
+  code(\key)keyindex(key) var(pitch) var(type) code(;)
+)
+
+Change the key signature.  var(type) should be
+code(\major)keyindex(major) or code(\minor)keyindex(minor) to get
+var(pitch)-major or var(pitch)-minor, respectively.  The second
+argument is optional; the default is major keys.  The var(\context)
 argument can also be given as an integer, which tells the number of
 semitones that should be added to the pitch given in the subsequent
 code(\key)keyindex(key) commands to get the corresponding major key,
-e.g. code(\minor)keyindex(minor) is defined as 3.  The standard mode names
-code(\ionian)keyindex(ionian), code(\locrian)keyindex(locrian), code(\aeolian)keyindex(aeolian),
-code(\mixolydian)keyindex(mixolydian), code(\lydian)keyindex(lydian), code(\phrygian)keyindex(phrygian), and
-code(\dorian)keyindex(dorian) are also defined.
-
+e.g., code(\minor)keyindex(minor) is defined bind(as)3.  The standard
+mode names code(\ionian)keyindex(ionian),
+code(\locrian)keyindex(locrian), code(\aeolian)keyindex(aeolian),
+code(\mixolydian)keyindex(mixolydian), code(\lydian)keyindex(lydian),
+code(\phrygian)keyindex(phrygian), and code(\dorian)keyindex(dorian)
+are also defined.
+
+quote(
+  code(\keysignature)keyindex(keysignature) var(pitchseq) code(;)
+)
 
-code(\keysignature)keyindex(keysignature) var(pitchseq)code(;)
 Specify an arbitrary key signature.  The pitches from var(pitch) will
-be printed in the key signature in the order that they appear on the list.
-
+be printed in the key signature in the order that they appear on the
+list.
 
 subsubsect(Rehearsal marks)
         
-code(\mark)keyindex(mark) var(unsigned)code(;) or code(\mark)
-var(string)code(;) A music expression.  Prints a mark over or under
-(depending on the indexandcode(markDirection) property) the staff.  You must
-add indexandcode(Mark_engraver) to the either Score or Staff context for this
-to work.
+quote(
+  code(\mark)keyindex(mark) var(unsigned) code(;) nl()
+  code(\mark) var(string) code(;)
+)
 
+Prints a mark over or under (depending on the
+indexandcode(markDirection) property) the staff.  You must add
+indexandcode(Mark_engraver) to either the Score or Staff context for
+this to work.
 
 subsubsect(Bar lines)
+label(barlines)
 
-code(\bar)keyindex(bar) var(bartype)code(;) This is a request to print
-a special bar symbol, or at measure boundaries.  It replaces the
-regular bar symbol with a special symbol.  The argument var(bartype)
-is a string which specifies the kind of bar to print.  Options are
-indexandcode(":|"), indexandcode("|:"), indexandcode(":|:"),
-indexandcode("||"), indexandcode("|."), indexandcode(".|"), or
-indexandcode(".|.").  These produce respectively a right repeat, a
-left repeat, a double repeat, a double bar, a start bar, an end bar,
-or a thick double bar.  If var(bartype) is set to code("empty") then
-nothing is printed, but a line break is allowed at that spot.
+quote(
+  code(\bar)keyindex(bar) var(bartype) code(;)
+)
 
-You are encouraged to use code(\repeat) for repetitions. See Section ref(sec:repeats)
+This is a request to print a special bar symbol. It replaces the 
+regular bar symbol with a special
+symbol.  The argument var(bartype) is a string which specifies the
+kind of bar to print.  Options are code(":|")cindex("|A@code(:|)),
+code("|:")cindex("|B@code(|:)), code(":|:")cindex("|C@code(:|:)),
+code("||")cindex("|D@code(||)), code("|.")cindex("|E@code(|.)),
+code(".|")cindex("|F@code(.|)), and code(".|.")cindex("|G@code(.|.)). 
+These produce, respectively, a right repeat, a left repeat, a double
+repeat, a double bar, a start bar, an end bar, and a thick double
+bar.  If var(bartype) is set to code("empty") then nothing is
+printed, but a line break is allowed at that spot.
+
+You are encouraged to use code(\repeat) for repetitions.
+See bind(section)ref(sec:repeats).
 
 subsubsect(Timing commands) 
 
-code(\cadenza)keyindex(cadenza) var(togglevalue)code(;) Music expression that
-toggles the automatic generation of bar lines.  If var(togglevalue) is
-0, bar line generation is turned off.  If var(togglevalue) is 1,
-a bar is immediately printed and bar generation is turned on.
+quote(
+  code(\cadenza)keyindex(cadenza) var(togglevalue) code(;)
+)
+
+Music expression that toggles the automatic generation of bar lines. 
+If var(togglevalue) bind(is)1, bar line generation is turned off.  If
+var(togglevalue) bind(is)0, a bar line is immediately printed and 
+automatic bar generation is turned on.
+
+quote(
+  code(\time)keyindex(time) var(numerator)code(/)var(denominator) code(;)
+)
+
+Change the time signature.  The default time signature bind(is)4/4. 
+The time signature is used to generate bar lines.
 
-code(\time)keyindex(time) var(numerator)code(/)var(denominator)code(;) Change the time
-signature.  The default time signature is 4/4.  The time signature is
-used to generate bar lines.
+quote(
+  code(\tempo)keyindex(tempo) var(duration) = var(perminute) code(;)
+)
 
-code(\partial )var(duration)code(;) Music expression that makes
-the first measure of the music last for the specified duration.  keyindex(partial)
+Used to specify the tempo.  For example, `code(\tempo 4 = 76;)'
+requests output with bind(76)quarter notes per minute.
 
-code(\tempo)keyindex(tempo) var(duration) = var(perminute)code(;) Used
-to specify the tempo.  For example, `code(\tempo 4 = 76;)' requests
-output with 76 quarter notes per minute.
+quote(
+  code(\partial)keyindex(partial) var(duration) code(;)
+)
+cindex(anacrusis)
+cindex(upstep)
 
-code(\partial)keyindex(partial)var( duration)code(;) This creates an incomplete
-measure at the start of the music, eg.  code(\partial 8*2;) creates a
-starting measure lasting two eighth notes.cindex(anacrusis)cindex(upstep)
+This creates an incomplete measure (anacrusis, upbeat) at the start of 
+the music, e.g., `code(\partial 8*2;)' creates a starting measure 
+lasting two eighth notes.
 
-code(|)cindex(|)cindex(barcheck)
+quote(
+  code(|)indexcode(|)cindex(bar check)
+)
+cindex(shorten measures)
+cindex(upstep)
 
-code(|) is a barcheck.  Whenever a barcheck is encountered during
+`code(|)' is a barcheck.  Whenever a barcheck is encountered during
 interpretation, a warning message is issued if it doesn't fall at a
-measure boundary.  This can help you finding errors in the input. The
-beginning of the measure will also be relocated, so this can also be
-used to shorten measures.cindex(shorten measures)cindex(upstep)
+measure boundary.  This can help you finding errors in the input. 
+The beginning of the measure will be relocated, so this can also
+be used to shorten measures.
 
 subsubsect(Other commands)
 
-code(\penalty)keyindex(penalty) var(int)code(;) 
-Discourage or encourage line breaks.  See identifiers code(\break)keyindex(break) and
-code(\nobreak)keyindex(nobreak) in Section ref(ident). 
-
-code(\clef)keyindex(clef) var(clefname)code(;) Music expression that
-sets the current clef.  The argument is
-a string which specifies the name of the clef.  Several clef names are
-supported.  If code(_8) or code(^8) is added to the end of a clef
-name then the clef lowered or raised an octave will be generated.  
-Here are the supported clef names with middle C shown in each clef:
-mudela(center)(
-\score{
-  \notes{ \cadenza 1;
-   %\property Voice.textStyle = typewriter
-   \clef subbass; c'4-"\kern-10mm subbass" 
-           \clef bass;    c'4^"\kern -8mm bass"
-           \clef baritone; c'4_"\kern -10mm baritone"
-           \clef varbaritone; c'4^"\kern -10mm varbaritone"
-           \clef tenor;     c'4_"\kern -10mm tenor"
-           \clef "G_8";   c'4^"\kern -6mm G\_8" 
-   }  
-   \paper{ linewidth= 4.5 \in; }
-}
+quote(
+  code(\penalty)keyindex(penalty) var(int) code(;)
 )
-mudela(center)(
-\score{
-  \notes{\cadenza 1; \clef alto;    c'4_"\kern -10mm alto"
-           \clef mezzosoprano; c'4^"\kern -10mm mezzosoprano"
-           \clef soprano;  c'4_"\kern -10mm soprano"
-           \clef treble;  c'4^"\kern -6mm treble"
-           \clef french;  c'4_"\kern -10mm french" }  
-  \paper{ linewidth= 4.5 \in; }
-}
+
+Discourage or encourage line breaks.  See identifiers
+code(\break)keyindex(break) and code(\nobreak)keyindex(nobreak) in
+bind(section)ref(ident).
+
+quote(
+  code(\clef)keyindex(clef) var(clefname) code(;)
 )
-The treble  clef  can also  be obtained using  the  names code(G) or
-code(violin).  The bass clef is also available by code(\clef  F). 
 
-code(\skip)keyindex(skip) var(duration)code(;) Skips the amount of time
-specified by var(duration).  If no other music is played, a gap will
-be left for the skipped time with no notes printed.  It works in Note
-Mode or Lyrics Mode.  In note mode, this has the same effect as the
-space rest code(s).
+Music expression that sets the current clef.  The argument is a
+string which specifies the name of the clef.  Several clef names are
+supported.  If `code(_8)' or `code(^8)' is added to the end of a clef
+name, then the clef lowered or raised an octave will be generated. 
+Here are the supported clef names with bind(middle)C shown in each
+clef:
+
+quote(
+mudela()(\score {
+  \notes {
+    \cadenza 1;
+    %\property Voice.textStyle = typewriter
+    \clef subbass;     c'4-"\kern -5mm subbass" 
+    \clef bass;        c'4^"\kern -2mm bass"
+    \clef baritone;    c'4_"\kern -5mm baritone"
+    \clef varbaritone; c'4^"\kern -6mm varbaritone"
+    \clef tenor;       c'4_"\kern -3mm tenor"
+    \clef "G_8";       c'4^"\kern -2mm G\\texttt{\\_}8" 
+  }  
+  \paper {
+    linewidth = 4.5 \in;
+  }
+})
+)
+
+quote(
+mudela()(\score {
+  \notes {
+    \cadenza 1;
+    \clef alto;         c'4_"\kern -2mm alto"
+    \clef mezzosoprano; c'4^"\kern -9mm mezzosoprano"
+    \clef soprano;      c'4_"\kern -6mm soprano"
+    \clef treble;       c'4^"\kern -4mm treble"
+    \clef french;       c'4_"\kern -4mm french"
+  }
+  \paper {
+    linewidth = 4.5 \in;
+  }
+})
+)
+
+The three clef symbols can also be obtained using the names `code(G)', 
+`code(C)' or `code(F)', optionally followed by an integer which 
+indicates at which note line the clef is located. An as example, the 
+code(mezzosoprano) clef can also be given as `code(C2)'.
 
+quote(
+  code(\skip)keyindex(skip) var(duration) code(;)
+)
+
+Skips the amount of time specified by var(duration).  If no other
+music is played, a gap will be left for the skipped time with no
+notes printed.  It works in Note Mode or Lyrics Mode.  In Note mode,
+this has the same effect as the space rest `code(s)'.
 
-subsubsect(Beams)cindex(beams)
+subsubsect(Beams)
+cindex(beams)
 label(manualbeam)
 
 A beam is specified by surrounding the beamed notes with brackets
-indexandcode([) and indexandcode(]).  
-mudela(fragment,verbatim,center)(
-[a'8 a'] [a'16 a' a' a'] 
-)
+`indexandcode([)' and `indexandcode(])'.  
+
+mudela(fragment,verbatim,center)(  [a'8 a'] [a'16 a' a' a'])
+
 Some more elaborate constructions:
-mudela(fragment,verbatim,center)(
-[a'16 <a' c''> c'' <a' c''>]
-\times 2/3 { [e'8 f' g'] }
-)
 
-Beaming can be generated automatically see Section ref(autobeam).
+mudela(fragment,verbatim,center)(  [a'16 <a' c''> c'' <a' c''>]
+  \times 2/3 { [e'8 f' g'] })
 
-cindex(Tremolo beams)
+Beaming can be generated automatically; see bind(section)ref(autobeam).
 
-To place tremolo marks in between two notes, begin with
-code([:)var(length) and end with code(]).  The tremolo marks will
-appear instead of beams.  Putting more than two notes in such a
-construction will produce odd effects.
+To place tremolo marks cindex(tremolo beams) between two notes, begin
+with `code([:)var(length)' and end with `code(])'.  Tremolo marks
+will appear instead of beams.  Putting more than two notes in such a
+construction will produce odd effects.  To create tremolo beams on a
+single note, simply attach `code(:)var(length)' to the note itself
+(see also bind(section)ref(tremolo)).
   
-mudela(fragment,verbatim,center)(
-  [:16 e'1 g'] [:8 e'4 f']
-)
+mudela(fragment,verbatim,center)(  [:16 e'1 g'] [:8 e'4 f'])
   
-mudela(fragment,verbatim,center)(
-  c'4:32 [:16 c'8 d'8]
-)
-
-COMMENT(ref to normal tremolos?)
+mudela(fragment,verbatim,center)(  c'4:32 [:16 c'8 d'8])
 
 subsubsect(Lyric helpers)
-cindex(--)cindex(__)cindex(extender)cindex(hyphen)
-
-The syntax for an extender mark is code(__).  This syntax can only be
-used within lyrics mode.  The syntax for a spanning hyphen (a hyphen
-that will be printed between two lyric syllables) is code(-)code(-)
+cindex(--@code(-)code(-))
+indexcode(__)
+cindex(extender)
+cindex(hyphen)
 
+The syntax for an extender mark is `code(__)'.  This syntax can only
+be used within lyrics mode.  The syntax for a spanning hyphen (i.e.,
+a hyphen that will be printed between two lyric syllables) is
+`code(-)code(-)'.
 
-
-subsubsect(Tie)cindex(tie)
+subsubsect(Ties)
+cindex(ties)
 
 A tie connects two adjacent note heads of the same pitch.  When used
 with chords, it connects all of the note heads whose pitches match.
-Ties are indicated using the tilde symbol indexandcode(~).
+Ties are indicated using the tilde symbol `indexandcode(~)'.
 If you try to tie together chords which have no common pitches, a
-warning message will appear. No ties will be created.  COMMENT(
+warning message will appear and no ties will be created.
 
-)mudela(fragment,verbatim,center)(
-e' ~ e' <c' e' g'> ~ <c' e' g'>
-)
+mudela(fragment,verbatim,center)(  e' ~ e' <c' e' g'> ~ <c' e' g'>)
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Atomic music expressions: add-ons)
 
 [TODO: explain Requests]
 
-
-subsubsect(Articulations)cindex(articulations)cindex(scripts)cindex(ornaments)
+subsubsect(Articulations)
+cindex(articulations)
+cindex(scripts)
+cindex(ornaments)
 
 A variety of symbols can appear above and below notes to indicate
 different characteristics of the performance.  These symbols can be
@@ -796,85 +1051,109 @@ added to a note with `var(note)code(-\)var(name)'.  Numerous symbols
 are defined in file(script.ly) and file(script.scm).  Symbols can be
 forced to appear above or below the note by writing
 `var(note)code(^\)var(name)' and `var(note)code(_\)var(name)'
-respectively. Here is a chart showing symbols above notes, with the
+respectively.  Here is a chart showing symbols above notes, with the
 name of the corresponding symbol appearing underneath.
 
 mudela()(
-\score{
- < \notes{ c''-\accent c''-\marcato c''-\staccatissimo f'-\fermata 
-          c''-\stopped c''-\staccato c''-\tenuto c''-\upbow c''-\downbow
-          c''-\lheel c''-\rheel  c''-\ltoe  c''-\rtoe  c''-\turn
-          c''-\open  c''-\flageolet  c''-\reverseturn 
-          c''-\trill
-          c''-\prall c''-\mordent c''-\prallprall  c''-\prallmordent
-          c''-\upprall c''-\downprall c''-\thumb c''-\segno c''-\coda}
-  \context Lyrics \lyrics{  
-        accent__ marcato__ staccatissimo__ fermata stopped__
-        staccato__ tenuto__ upbow downbow__ lheel__ rheel__ ltoe
-        rtoe__ turn__ open__ flageolet reverseturn__ trill__ prall__
-        mordent prallprall__ prallmordent__ uprall__ downprall thumb 
-       segno coda }
-  >
-  \paper{ linewidth = 5.875\in;          
-          indent = 0.0;        }
- }
+  \score {
+    < \notes {
+        c''-\accent      c''-\marcato      c''-\staccatissimo c''-\fermata 
+        c''-\stopped     c''-\staccato     c''-\tenuto        c''-\upbow
+        c''-\downbow     c''^\lheel        c''-\rheel         c''^\ltoe
+        c''-\rtoe        c''-\turn         c''-\open          c''-\flageolet
+        c''-\reverseturn c''-\trill        c''-\prall         c''-\mordent
+        c''-\prallprall  c''-\prallmordent c''-\upprall       c''-\downprall
+        c''-\thumb       c''-\segno        c''-\coda
+      }
+      \context Lyrics \lyrics {  
+        accent__      marcato__      staccatissimo__ fermata
+        stopped__     staccato__     tenuto__        upbow
+        downbow__     lheel__        rheel__         ltoe
+        rtoe__        turn__         open__          flageolet
+        reverseturn__ trill__        prall__         mordent
+        prallprall__  prallmordent__ uprall__        downprall
+        thumb__       segno__        coda
+      }
+    >
+    \paper {
+      linewidth = 5.875\in;          
+      indent    = 0.0;
+    }
+  }
 )
 
 In addition, it is possible to place arbitrary strings of text or
-TeX() above or below notes by using a string instead of an identifier:
-`code(c^"text")'.  Fingerings cindex(fingering) can be placed by
-simply using digits.  All of these note ornaments appear in the
-printed output but have no effect on the MIDI rendering of the music.
+TeX() above or below notes by using a string instead of an
+identifier: `code(c^"text")'.  Fingerings cindex(fingering) can be
+placed by simply using digits.  All of these note ornaments appear in
+the printed output but have no effect on the MIDI rendering of the
+music.
 
-To save typing, fingering instructions (digits 0 to 9 are supported)
-and single characters shorthands exist also for a few common symbols
-COMMENT(
+To save typing, fingering instructions (digits 0 bind(to)9 are
+supported) and single characters shorthands exist for a few
+common symbols
 
-)mudela()(
-\score{ \notes {
-        \property Voice.textStyle = typewriter
-        c''4-._"c-." s4
-        c''4--_"c-{}-"  s4
-        c''4-+_"c-+" s4
-        c''4-|_"c-|" s4
-        c''4->_"c->"  s4
-        c''4-^_"c-\\^{ }"  s4
-       c''4-1_"c-1" s4
-       c''4-2_"c-2" s4
-       c''4-3_"c-3" s4
-       c''4-4_"c-4" s4
-       }
-%        \paper { linewidth = 12.\cm; }
-})
+mudela()(
+  \score {
+    \notes {
+      \property Voice.textStyle = typewriter
+      c''4-._"c-."      s4
+      c''4--_"c-{}-"    s4
+      c''4-+_"c-+"      s4
+      c''4-|_"c-|"      s4
+      c''4->_"c->"      s4
+      c''4-^_"c-\\^{ }" s4
+      c''4-1_"c-1"      s4
+      c''4-2_"c-2"      s4
+      c''4-3_"c-3"      s4
+      c''4-4_"c-4"      s4
+    }
+    \paper {
+      linewidth = 5.875 \in;
+      indent    = 0.0;
+    }
+  }
+)
 
 Dynamic marks are specified by using an identifier after a note:
-code(c4-\ff).  The available dynamic marks are: keyindex(pppp),
-code(\ppp)keyindex(ppp), code(\pp)keyindex(pp), code(\p)keyindex(p),
-code(\mp)keyindex(mp), code(\mf)keyindex(mf), code(\f)keyindex(f),
-code(\ff)keyindex(ff), code(\fff)keyindex(fff),
-code(\ffff)keyindex(ffff), code(\fp)keyindex(fp),
-code(\sf)keyindex(sf), code(\sff)keyindex(sff), code(\sp)keyindex(sp),
-code(\spp)keyindex(spp), code(\sfz)keyindex(sfz) and
+`code(c4-\ff)' (the dash is optional for dynamics: `code(c4 \ff))'.  
+The available dynamic marks are:
+code(\ppp)keyindex(ppp),
+code(\pp)keyindex(pp), code(\p)keyindex(p), code(\mp)keyindex(mp),
+code(\mf)keyindex(mf), code(\f)keyindex(f), code(\ff)keyindex(ff),
+code(\fff)keyindex(fff), code(\fff)keyindex(ffff),
+code(\fp)keyindex(fp), code(\sf)keyindex(sf),
+code(\sff)keyindex(sff), code(\sp)keyindex(sp),
+code(\spp)keyindex(spp), code(\sfz)keyindex(sfz), and
 code(\rfz)keyindex(rfz).
 
 subsubsect(General text scripts)
 
-code(\textscript)keyindex(textscript) var(text) var(style).  Defines a text to be
-printed over or under a note.  var(style) is a string that may be one
-of code(finger), code(roman), code(italic), code(dynamic), code(Large)
-or code(large).  
+quote(
+  code(\textscript)keyindex(textscript) var(text) var(style)
+)
+
+Defines a text to be printed over or under a note.  var(style) is a
+string that may be one of code(roman), code(italic), code(typewriter), 
+code(bold), code(Large), code(large), code(dynamic) or code(finger).
+
+You can attach a general textscript request using this syntax:
 
-You can attach a general textscript request using this syntax
+quote(
 verb(c4-\textscript "6" "finger"
-c4-\textscript "foo" "normal"
+c4-\textscript "foo" "normal")
 )
-This is equivalent with code(c4-6 c4-"foo").  
 
-subsubsect(General scripts)cindex(scripts)
+This is equivalent to `code(c4-6 c4-"foo")'.  
 
-Syntax: code(\script)keyindex(script) var(alias).
+subsubsect(General scripts)
+cindex(scripts)
 
- Prints a symbol above or below a note.  The argument is a string
+quote(
+  code(\script)keyindex(script) var(alias)
+)
+
+Prints a symbol above or below a note.  The argument is a string
 which points into the script-alias table defined in file(script.scm).
 The scheme definitions specify whether the symbol follows notes into
 the staff, dependence of symbol placement on staff direction, and a
@@ -882,1642 +1161,2182 @@ priority for placing several symbols over one note.  Usually the
 code(\script)keyindex(script) keyword is not used directly.  Various
 helpful identifier definitions appear in file(script.ly).
 
-
-subsubsect(Slur)cindex(Slur)
+subsubsect(Slurs)
+cindex(slur)
 
 Slurs connects chords and try to avoid crossing stems.  A slur is
-started with code(CHAR(40)) and stopped with code(CHAR(41)).  The
-starting code(CHAR(40)) appears to the right of the first note in the
-slur.  The terminal code(CHAR(41)) apppears to the left of the first
-note in the slur.  This makes it possible to put a note in slurs from
-both sides: COMMENT(
-
-)mudela(fragment,verbatim,center)(
-f'()g'()a' [a'8 b'(] a'4 g'2 )f'
-)
+started with `code(CHAR(40))' and stopped with `code(CHAR(41))'.  The
+starting `code(CHAR(40))' appears to the right of the first note in
+the slur.  The terminal `code(CHAR(41))' appears to the left of the
+first note in the slur.  This makes it possible to put a note in
+slurs from both sides:
+
+mudela(fragment,verbatim,center)(  f'()g'()a' [a'8 b'(] a'4 g'2 )f'4)
+
+subsubsect(Crescendo)
+cindex(crescendo)
+
+A crescendo mark is started with code(\cr)keyindex(cr) and terminated
+with code(\rc)keyindex(rc).  A decrescendo mark is started with
+code(\decr)keyindex(decr) and terminated with
+code(\rced)keyindex(rced).  There are also shorthands for these
+marks.  A crescendo can be started with code(\<)keyindex(<) and a
+decrescendo can be started with code(\>)keyindex(>).  Either one can
+be terminated with code(\!)keyindex("!).  Note that code(\!)
+must go before the last note of the dynamic mark whereas code(\rc)
+and code(\rced) go after the last note.  Because these marks are
+bound to notes, if you want to get several marks during one note, you
+must use spacer notes.
+
+mudela(fragment,verbatim,center)(  c'' \< \! c''   d'' \decr e'' \rced 
+  < f''1 { s4 \< \! s2 \> \! s4 } >)
 
+subsubsect(General spanners)
 
-subsubsect(Crescendo)cindex(Crescendo)
+quote(
+  code(\spanrequest)keyindex(spanrequest) var(startstop) var(type)
+)
 
-A crescendo mark is started with code(\cr)keyindex(cr) and terminated with
-code(\rc)keyindex(rc).  A decrescendo mark is started with code(\decr)keyindex(decr) and
-terminated with code(\rced)keyindex(rced).  There are also shorthands for these
-marks.  A crescendo can be started with code(\<)keyindex(<) and a decrescendo can
-be started with code(\>)keyindex(>).  Either one can be terminated with code(\!)keyindex(!).
-Note that code(\!) must go before the last note of the dynamic mark whereas
-code(\rc) and code(\rced) go after the last note.  Because these marks are
-bound to notes, if you want to get several marks during one note, you must use
-spacer notes. COMMENT(
+Define a spanning request. The var(startstop) parameter is bind(either)-1
+(code(\start)keyindex(start)) bind(or)1 (code(\stop)keyindex(stop)) and
+var(type) is a string that describes what should be started.
+Supported types are code(crescendo), code(decrescendo),
+code(beam), code(slur).  This is an internal command.  Users should
+use the shorthands which are defined in the initialization file
+file(spanners.ly).
 
-)mudela(fragment,verbatim,center)(
-c'' \< \! c''   d'' \decr e'' \rced 
-< f''1 {s4 \< \! s2 \> \! s2 } >)
+You can attach a (general) span request to a note using
 
+mudela(fragment,verbatim,center)(  c'4-\spanrequest \start "slur"
+  c'4-\spanrequest \stop "slur")
 
+The slur syntax with parentheses is a shorthand for this.
 
-subsubsect(General spanners)
+COMMENT(came till here with indexifying)
 
-code(\spanrequest)keyindex(spanrequest) var(startstop) var(type).
-Define a spanning request var(startstop) is either -1
-(code(\start)keyindex(start)) or 1 (code(\stop)keyindex(stop)). The
-var(type) parameter is a string that describes what should be started.
-Supported types are code(crescendo), code(decrescendo), code(beam),
-code(slur).  This is an internal command.  Users should use the
-shorthands which are defined in the initialization file
-file(spanners.ly).
+subsubsect(Tremolo marks)
+cindex(tremolo marks)
+label(tremolo)
 
-You can attach a (general) span request to a note using
-mudela(fragment,center)(
-c4-\spanrequest \start "slur"
-c4-\spanrequest \stop "slur"
-)
-The slur syntax with parentheses is a shorthand for this.
+Tremolo marks can be printed on a single note by adding
+`code(:)[var(length)]' after the note.  The length must be at
+bind(least)8.  A var(length) value bind(of)8 gives one line across
+the note stem.  If the length is omitted, then the last value is
+used, or the value of the indexandcode(abbrev) property if there was
+no last value.
 
-COMMENT(came till here with indexifying)
+mudela(verbatim,fragment,center)(  c'2:8 c':32)
 
-subsubsect(Tremolo marks)cindex(Tremolo marks)
 
-Tremolo marks can be printed on a single note by adding code(:)[var(length)]
-after the note.  The length must be at least 8.  A var(length) value
-of 8 gives one line across the note stem.  
-If the length is omitted,
-then the last value is used, or the value of the code(abbrev)
-property if there was no last value.
-mudela(verbatim,fragment,center)(c'2:8 c':32
-)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-sect(Compound music expressions)cindex(Compound music expressions)
+sect(Compound music expressions)
+cindex(compound music expressions)
 label(compoundmusic)
 
-
 Music expressions are compound data structures.  You can nest music
 expressions any way you like.  This simple example shows how three
-chords can be expressed in two different ways: COMMENT(
+chords can be expressed in two different ways:
 
-)mudela(fragment,verbatim,center)(
-\notes\context Staff{
-  <a c'> <b  d' > <c' e' >
-  <{a b  c'}{c' d' e'}>
-})
+mudela(fragment,verbatim,center)(  \notes \context Staff {
+    \cadenza 1;
+    <a c'> <b  d' > <c' e' >
+    <{a b  c'}{c' d' e'}>
+  })
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Context selection)cindex(Context selection)
+subsect(Context selection)
+cindex(context selection)
 
-code(\context)keyindex(context) var(contexttype) [code(=) var(contextname)]
-var(musicexpr)
+quote(
+  code(\context)keyindex(context)
+    var(contexttype) [code(=) var(contextname)] var(musicexpr)
+)
 
-Interpret var(musicexpr) within a context of type var(contexttype).
+Interpret var(musicexpr) within a context of type var(contexttype). 
 If the context does not exist, it will be created.  The new context
-can optionally be given a name.  See Section ref(contextselection) and
-ref(contextdefs) for more
+can optionally be given a name.  See
+bind(section)ref(contextselection) bind(and)ref(contextdefs) for more
 information on interpretation contexts.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 subsect(Music entry modes)
 cindex(input modes)
 cindex(mode switch)
 
-Mode switching keywords form compound music
-expressions:keyindex(notes)keyindex(chords)keyindex(lyrics)
-code(\notes )var(musicexpr), code(\chords )var( musicexpr), and
-code(\lyrics )var(musicexpr).  These expressions do not add anything
-to the meaning of their arguments.  They are just a way to indicate
-that the arguments should be parsed in indicated mode. See Section
-ref(modes) for more information on modes.
-
+Mode switching keywords form compound music expressions: code(\notes)
+keyindex(notes) var(musicexpr), code(\chords) keyindex(chords)
+var(musicexpr), and code(\lyrics) keyindex(lyrics) var(musicexpr). 
+These expressions do not add anything to the meaning of their
+arguments.  They are just a way to indicate that the arguments should
+be parsed in indicated mode.  See bind(section)ref(modes) for more
+information on modes.
+
+More information on context selection can be found in
+bind(section)ref(contextselection).
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Sequential music)
+cindex(sequential music)
+COMMENT(It's not possible to index `{' and `}' directly, thus we
+        must construct it.)
+whenlatex(cindex(?A@latexcommand(\texttt{\textbraceleft})))
+whenlatex(cindex(?B@latexcommand(\texttt{\textbraceright})))
+
+quote(
+  code(\sequential)keyindex(sequential)
+    code({) var(musicexprlist) code(})
+)
 
-More information on context selection can be found in Section ref(contextselection)
+This means that list should be played or written in sequence, i.e.,
+the second after the first, the third after the second.  The duration
+of sequential music is the the sum of the durations of the elements. 
+There is a shorthand, which leaves out the keyword:
 
+quote(
+  code({) var(musicexprlist) code(})
+)
 
-subsect(Sequential music)cindex(Sequential music)
-keyindex(sequential)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-The syntax is code(\sequential)code( {)var(musicexprlist)code( }).  This means that list should be played or
-written in sequence, i.e., the second after the first, the third after
-the second.  The duration of sequential music is the the sum of the
-durations of the elements.  There is a shorthand, which leaves
-out the keyword: code({ )var(musicexprlist )code( }).
+subsect(Simultaneous music)
+cindex(simultaneous music)
+indexcode(<)
+indexcode(>)
 
+quote(
+  code(\simultaneous)keyindex(simultaneous)
+    code({) var(musicexprlist) code(})
+)
 
-subsect(Simultaneous music)cindex(Simultaneous music)
+It constructs a music expression where all of its arguments start at
+the same moment.  The duration is the maximum of the durations of the
+elements.  The following shorthand is a common idiom:
 
-The syntax is code(\simultaneous)keyindex(simultaneous)code({)var(
-musicexprlist )code(}).  It constructs a music expression where all of
-its arguments start at the same moment.  The duration is the maximum
-of the durations of the elements.  The shorthand, code(<)
-var(musicexprlist) code(>) is common idiom.
+quote(
+  code(<) var(musicexprlist) code(>)
+)
 
-If you try to use a chord as the first thing in your score, you
-might get multiple staffs in stead of a chord.COMMENT(
+If you try to use a chord as the first thing in your score, you might
+get multiple staffs instead of a chord.
 
-)mudela(verbatim)(\score { \notes <c''4 e''>
-       \paper { linewidth = -1.; }
-})COMMENT(
+mudela(verbatim,center)(  \score {
+    \notes <c''4 e''>
+    \paper {
+      linewidth = -1.;
+    }
+  })
 
-This happens because the chord is interpreted by a score context.
+This happens because the chord is interpreted by a score context.
 Each time a note is encountered a default Voice context (along with a
-Staff context) is created. The solution is to explicitly instantiate a
-Voice context:
-mudela(verbatim,center)(\score { \notes\context Voice <c''4 e''>
-  \paper { linewidth = -1.; }
-})
+Staff context) is created.  The solution is to explicitly instantiate
+a Voice context:
+
+mudela(verbatim,center)(  \score {
+    \notes\context Voice <c''4 e''>
+    \paper {
+      linewidth = -1.;
+    }
+  })
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Relative Pitch Specification)cindex(Relative Pitch Specification)
+subsect(Relative Pitch Specification)
+cindex(relative pitch specification)
 label(relative)
 
 It is easy to get confused by octave changing marks and accidentally
-put a pitch in the wrong octave.  A much better way of entering a
+putting a pitch in the wrong octave.  A much better way of entering a
 note's octave is `the relative octave' mode.
 
-The syntax for relative mode is code(\relative)keyindex(relative)
-var(startpitch) var(musicexpr).
+quote(
+  code(\relative)keyindex(relative) var(startpitch) var(musicexpr)
+)
 
 The octave of notes that appear in var(musicexpr) are calculated as
-follows: when no octave changing marks are used, the basic interval
+follows: If no octave changing marks are used, the basic interval
 between this and the last note is always taken to be a fourth or
-less.footnote(The interval is determined without regard accidentals.
-A code(fisis) following a code(ceses) will be put above the
-code(ceses)) The octave changing marks code(') and code(,) can then be
-added to raise or lower the pitch by an extra octave.  Upon entering
-relative mode, an absolute starting pitch must be specified that will
-act as the predecessor of the first note of var(musicexpr).
+less.footnote(The interval is determined without regarding
+accidentals.  A code(fisis) following a code(ceses) will be put above
+the code(ceses).)  The octave changing marks `code(')' and `code(,)'
+can then be added to raise or lower the pitch by an extra octave. 
+Upon entering relative mode, an absolute starting pitch must be
+specified that will act as the predecessor of the first note of
+var(musicexpr).
 
 Entering scales is straightforward in relative mode.
 
-mudela(fragment,verbatim,center)(
-\relative c' { c d e f g a b c c, }
-)
+mudela(fragment,verbatim,center)(  \relative c' {
+    c d e f g a b c c,
+  })
 
-and octave changing marks are used for intervals greater than a fourth.
+And octave changing marks are used for intervals greater than a fourth.
 
-mudela(fragment,verbatim,center)(
-\relative c'' { c g c f, c' a,, e''' }
-)
+mudela(fragment,verbatim,center)(  \relative c'' {
+    c g c f, c' a, e'' })
 
-When the preceding item is a chord, the first note of the chord is used to
-determine the first note of the next chord.  But other notes within the second
-chord are determined by looking at the immediately preceding note.  
+If the preceding item is a chord, the first note of the chord is used
+to determine the first note of the next chord.  But other notes
+within the second chord are determined by looking at the immediately
+preceding note.
 
-mudela(fragment,verbatim,center)(
-\relative c' { c <c e g> 
-    <c' e g> <c, e' g> }
-) 
+mudela(fragment,verbatim,center)(  \relative c' {
+    c <c e g> 
+    <c' e g>
+    <c, e' g>
+  }) 
 
-The pitch after the code(\relative) contains a notename. To parse the
-pitch as a notename, you have to be in note mode, so there must be a
-surrounding code(\notes)keyindex(notes) keyword (which is not shown here).
+The pitch after the code(\relative) contains a notename.  To parse
+the pitch as a notename, you have to be in note mode, so there must
+be a surrounding code(\notes)keyindex(notes) keyword (which is not
+shown here).
 
 The relative conversion will not affect code(\transpose) or
-code(\relative) sections in its argument.  If you want to use relative
-within transposed music, you must place an additional code(\relative)
-inside the code(\transpose).
-
-You are strongly recommended to use relative pitch mode: it is less
-work, less error-prone and more readable.
+code(\relative) sections in its argument.  If you want to use
+relative within transposed music, you must place an additional
+code(\relative) inside the code(\transpose).
 
+It is strongly recommended to use relative pitch mode: less work,
+less error-prone, and more readable.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Chord names)
 
 Chord names are a way to generate simultaneous music expressions that
-correspond with traditional chord names. It can only be used in chord
-mode (See Section ref(modes)).  The syntax is
-var(tonic)[var(duration)][code(-)var(modifiers)][code(^)var(subtractions)][code(/)var(inversion)].
-var(tonic) should be the tonic note of the chord, and the var(duration) is
-the chord duration in the usual notation.  There are two kinds of modifiers.
-One type is chord additions, which are obtained by listing intervals separated
-by dots.  An interval is written by its number with an optional code(+) or
-code(-) to indicate raising or lowering by half a step.  A chord additions has
-two effects:  it adds the specified interval and all lower odd numbered
-intervals to the chord, and it may lower or raise the specified interval.
-Intervals must be separated by a dot (code(.)).
-COMMENT(
+correspond with traditional chord names.  It can only be used in
+Chord mode (see bind(section)ref(modes)).
 
-)mudela(fragment,verbatim)(
-\transpose c''{ 
-\chords{
-  c1 c-3- c-7 c-8 c-9  
-  c-9-.5+.7+ c-3-.5- c-4.6.8
-}})COMMENT(
-
-)The second type of modifier that may appear after the code(-) is 
-a named modifier. 
-Named modifiers are listed in the file file(chord-modifiers.ly).  The
-available modifiers are code(m) and code(min) which lower
-the 3rd half a step, indexandcode(aug) which raises the 5th, indexandcode(dim) which lowers
-the 5th, indexandcode(maj) which adds a raised 7th, and indexandcode(sus) which replaces the
-5th with a 4th.  
-mudela(fragment,verbatim,center)(
-\transpose c''{ 
-\chords{
-  c1-m c-min7 c-maj c-aug c-dim c-sus
-}}) 
-
-Chord subtractions are used to eliminate notes from a chord.  The notes to be
-subtracted are listed after a code(^) character, separated by dots.  
-mudela(fragment,verbatim,center)(
-\transpose c''{ 
-\chords{
-  c1^3 c-7^5.3 c-8^7
-}}) 
-
-Chord inversions can be specified by appending indexandcode(/) and the name of a
-single note to a chord.  This has the effect of lowering the specified note by
-an octave so it becomes the lowest note in the chord.  If the
-specified note is not in the chord, a warning will be printed.  
-mudela(fragment,verbatim,center)(
-\transpose c'''{ 
-  \chords { c1 c/e c/g c-7/e }
-}) 
-Throughout these examples, chords have been shifted around the staff
-using code(\transpose).
+quote(
+  var(tonic)[var(duration)][code(-)var(modifiers)]\
+                           [code(^)var(subtractions)]\
+                           [code(/)var(inversion)].
+)
+
+var(tonic) should be the tonic note of the chord, and var(duration)
+is the chord duration in the usual notation.  There are two kinds of
+modifiers.  One type is em(chord additions), which are obtained by
+listing intervals separated by dots.  An interval is written by its
+number with an optional `code(+)' or `code(-)' to indicate raising or
+lowering by half a step.  Chord additions has two effects: It adds
+the specified interval and all lower odd numbered intervals to the
+chord, and it may lower or raise the specified interval.  Intervals
+must be separated by a dot (`code(.)').
+
+quote(
+mudela(fragment,verbatim)(\transpose c'' {
+  \chords {
+    c1  c-3-       c-7     c-8
+    c-9 c-9-.5+.7+ c-3-.5- c-4.6.8
+  }
+}
+)
+)
+
+The second type of modifier that may appear after the `code(-)' is a
+named modifier.  Named modifiers are listed in the file
+file(chord-modifiers.ly).  The available modifiers are `code(m)' and
+`code(min)' which lower the 3rd half a step, `indexandcode(aug)' which
+raises the 5th, `indexandcode(dim)' which lowers the 5th,
+`indexandcode(maj)' which adds a raised 7th, and `indexandcode(sus)'
+which replaces the 5th with a 4th.
+
+quote(
+mudela(fragment,verbatim)(\transpose c'' {
+  \chords {
+    c1-m c-min7 c-maj c-aug c-dim c-sus
+  }
+}
+)
+) 
 
-You should  not combine code(\relative)  with named chords. 
+Chord subtractions are used to eliminate notes from a chord.  The
+notes to be subtracted are listed after a `code(^)' character,
+separated by dots.
+
+mudela(fragment,verbatim,center)(  \transpose c'' {
+    \chords {
+      c1^3 c-7^5.3 c-8^7
+    }
+  }) 
+
+Chord inversions can be specified by appending `indexandcode(/)' and
+the name of a single note to a chord.  This has the effect of
+lowering the specified note by an octave so it becomes the lowest
+note in the chord.  If the specified note is not in the chord, a
+warning will be printed.
+
+mudela(fragment,verbatim,center)(  \transpose c''' {
+    \chords {
+      c1 c/e c/g c-7/e
+    }
+  }
+) 
 
+Throughout these examples, chords have been shifted around the staff
+using code(\transpose).
 
+You should not combine code(\relative) with named chords. 
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Tuplets)cindex(Tuplets)
+subsect(Tuplets)
+cindex(tuplets)
 
 Tuplets are made out of a music expression by multiplying their
-duration with a fraction.  The syntax is code(\times)keyindex(times) var(fraction)
-var(musicexpr).
+duration with a fraction.
+
+quote(
+  code(\times)keyindex(times) var(fraction) var(musicexpr)
+)
 
-The duration of var(musicexpr) will be multiplied by the fraction.
+The duration of var(musicexpr) will be multiplied by the fraction. 
 In print, the fraction's denominator will be printed over the notes,
-optionally with a bracket.  The most
-common tuplet is the triplet in which 3 notes have the length of 2, so
-the notes are 2/3 their written length:
-COMMENT(
+optionally with a bracket.  The most common tuplet is the triplet in
+which bind(3)notes have the length bind(of)2, so the notes are 2/3 of
+their written length:
+
+mudela(fragment,verbatim,center)(  g'4 \times 2/3 {c'4 c' c'} d'4 d'4)
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-)mudela(fragment,verbatim,center)( b'4 \times 2/3 {c'4 c' c'} d'4 d'4 )
+subsect(Grace notes)
+cindex(grace notes)
 
-subsect(Grace notes)cindex(Grace notes)
+quote(
+  code(\grace)keyindex(grace) var(musicexpr)
+)
 
-Grace notes are specified as code(\grace )keyindex(grace )var(musicexpr).  A grace
-note expression has duration 0; the next real note is assumed to the
-main note.
+A grace note expression has bind(duration)0; the next real note is
+assumed to be the main note.
 
-You cannot have the grace note after the main note, terms of duration
-and main notes, but you can typeset the grace notes to the right of
-the main note using the property indexandcode(graceAlignPosition).
+You cannot have the grace note after the main note, in terms of
+duration, and main notes, but you can typeset the grace notes to the
+right of the main note using the property
+indexandcode(graceAlignPosition).
 
 When grace music is interpreted, a score-within-a-score is set up:
 var(musicexpr) has its own time bookkeeping, and you could (for
-example) have a separate time signature within grace notes.  Within
-this score-within-a-score you can create notes, beams, slurs,
-etc. Unbeamed eighth notes and shorter by default have a slash through
-the stem.  This behavior can be controlled with the
+example) have a separate time signature within grace notes.  While in
+this score-within-a-score, you can create notes, beams, slurs, etc.
+Unbeamed eighth notes and shorter by default have a slash through the
+stem.  This behavior can be controlled with the
 indexandcode(stemStyle) property.
 
-mudela(fragment)(
-  \relative c'' { \grace c8 c4 \grace { [c16 c16] } c4
-    \grace { \property Grace.stemStyle = "" c16 } c4 }
+quote(
+mudela(fragment,verbatim)(\relative c'' {
+  \grace c8 c4 \grace { [c16 c16] } c4
+  \grace { \property Grace.stemStyle = "" c16 } c4
+}
+)
 )
 
-At present nesting code(\grace)keyindex(grace) notes, eg. code(\grace { \grace
-c32 c16} c4) may result in run-time errors of LilyPond.  Since the
-meaning of such a construct is unclear, we don't consider this a loss.
-Similarly, juxtaposing two code(\grace) sections syntactically valid,
-but makes no sense and may cause runtime errors.
+At present, nesting code(\grace)keyindex(grace) notes, e.g.
 
-Ending a staff or score with grace notes may generate a run-time
+quote(
+  code(\grace { \grace c32 c16 } c4)
+)
+
+may result in run-time errors of LilyPond.  Since the meaning of such
+a construct is unclear, we don't consider this a loss.  Similarly,
+juxtaposing two code(\grace) sections is syntactically valid, but
+makes no sense and may cause runtime errors.
+
+Ending a staff or score with grace notes may also generate a run-time
 error, since there will be no main note to attach the grace notes to.
 
-subsect(Repeats)cindex(Repeats)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Repeats)
+cindex(repeats)
 label(sec:repeats)
 
-In order to specify repeats, use the code(\repeat)keyindex(repeat) keyword.  Since
-repeats look and sound differently when played or printed, there are a few
-different variants of repeats.
+In order to specify repeats, use the code(\repeat)keyindex(repeat)
+keyword.  Since repeats look and sound differently when played or
+printed, there are a few different variants of repeats.
 
 description(
-dit(unfolded) repeated music is fully written (played) out.  Useful
-for  MIDI output.
-dit(volta)  This is the normal notation: repeats are not
-written out, but alternative endings (voltas), are printed, left to right.
-dit(folded) alternative endings are written stacked, which is useful
-for lyrics.
+  dit(unfolded) nl()
+    Repeated music is fully written (played) out.  Useful for MIDI
+    output.
+
+  dit(volta) nl()
+    This is the normal notation: Repeats are not written out, but
+    alternative endings (voltas) are printed, left to right.
+
+  dit(folded) nl()
+    Alternative endings are written stacked, which is useful for
+    lyrics.
 )  
 
-The syntax for repeats is code(\repeat) var(variant) var(repeatcount)
-var(repeatbody).  If you have alternative endings, you may add
-code(\alternative)keyindex(alternative)code( { )var(alternative1)
-var(alternative2) var(alternative3) .. code( }), where each
-var(alternative) is a  Music expression.
+The syntax for repeats is
 
-Normal notation repeats are used like this:
-mudela(fragment,verbatim,center)(
-c'1
-\repeat volta 2 { c'4 d' e' f' }
-\repeat volta 2 { f' e' d' c' })
+quote(
+  code(\repeat) var(variant) var(repeatcount) var(repeatbody)
+)
 
-With alternative endings:
-mudela(fragment,verbatim,center)(
-c'1
-\repeat volta 2 {c'4 d' e' f'} 
-\alternative { {d'2 d'} {f' f} })
+If you have alternative endings, you may add
 
-Folded repeats look like this:footnote(Folded repeats offer little
-more over simultaneous music.  However, it is to be expected that more
-functionality --especially for the MIDI backend-- will be implemented) 
+quote(
+  code(\alternative)keyindex(alternative)
+    code({) var(alternative1)
+            var(alternative2)
+            var(alternative3) ellipsis() code(})
+)
 
+where each var(alternative) is a Music expression.
 
-mudela(fragment,verbatim,center)(
-c'1
-\repeat fold 2 {c'4 d' e' f'} 
-\alternative { {d'2 d'} {f' f} })
+Normal notation repeats are used like this:
 
-mudela(fragment,verbatim)(
-\context Staff { \relative c'{
-  \partial 4; \repeat volta 2 {  e | c2 d2 | e2 f2 | }
-  \alternative { { g4 g g } {  a a a a  b1 } }
-}})
+quote(
+mudela(fragment,verbatim)(  c'1
+  \repeat volta 2 { c'4 d' e' f' }
+  \repeat volta 2 { f' e' d' c' }
+)
+)
 
-If you don't give enough alternatives for all of the repeats, then the
-first alternative is assumed to be repeated often enough to equal the
-specified number of repeats.  
-mudela(fragment,verbatim)(
-\context Staff { \relative c'{
-  \repeat volta 3 { \partial 4; e | c2 d2 | e2 f2 | }
-  \alternative { { g4 g g } {\partial 1; e4 e e } 
-                 {\partial 1; a a a a | b1 } }
-}})
+With alternative endings:
 
+quote(
+mudela(fragment,verbatim)(  c'1
+  \repeat volta 2 {c'4 d' e' f'} 
+  \alternative { {d'2 d'} {f' f} }
+)
+)
 
+Folded repeats look like this:footnote(Folded repeats offer little
+more over simultaneous music.  However, it is to be expected that
+more functionality -- especially for the MIDI backend -- will be
+implemented.)
+
+quote(
+mudela(fragment,verbatim)(  c'1
+  \repeat fold 2 {c'4 d' e' f'} 
+  \alternative { {d'2 d'} {f' f} }
+)
+)
 
-It is possible to nest code(\repeat).  This is not entirely supported:
-the notes will come be in the right places, but the repeat bars will
-not.
+quote(
+mudela(fragment,verbatim)(\context Staff {
+  \relative c' {
+    \partial 4;
+    \repeat volta 2 { e | c2 d2 | e2 f2 | }
+    \alternative { { g4 g g } { a | a a a a | b1 } }
+  }
+}
+)
+)
 
+If you don't give enough alternatives for all of the repeats, then
+the first alternative is assumed to be repeated often enough to equal
+the specified number of repeats.
+
+quote(
+mudela(fragment,verbatim)(\context Staff {
+  \relative c' {
+    \repeat volta 3 { \partial 4; e | c2 d2 | e2 f2 | }
+    \alternative { { g4 g g }
+                   {\partial 1; e4 e e } 
+                   {\partial 1; a a a a | b1 } }
+  }
+}
+)
+)
 
+It is possible to nest code(\repeat).  This is not entirely
+supported: the notes will come be in the right places, but the repeat
+bars will not.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Tranposition of Pitches)cindex(Tranposition of Pitches)
+subsect(Transposition of Pitches)
+cindex(transposition of pitches)
 label(transpose)
 
-A music expression can be transposed with code(\transpose)keyindex(transpose).
-The syntax is code(\transpose) var(pitch) var(musicexpr)
-This means that middle C in var(musicexpr) is tranposed to var(pitch). 
+A music expression can be transposed with
+code(\transpose)keyindex(transpose).  The syntax is
+
+quote(
+  code(\transpose) var(pitch) var(musicexpr)
+)
+
+This means that middle C in var(musicexpr) is transposed to
+var(pitch).
 
 code(\transpose) distinguishes between enharmonic pitches: both
 code(\transpose cis') or code(\transpose des') will transpose up half
 a tone.  The first version will print sharps and the second version
-will print flats.    COMMENT(
+will print flats.
 
-)mudela(fragment,verbatim)(
-\context Staff {
-  \clef "F"; { \key e; c d e f } \clef "G";
+quote(
+mudela(fragment,verbatim)(\context Staff {
+  \clef "F";
+  { \key e; c d e f }
+  \clef "G";
   \transpose des'' { \key e; c d e f }
-  \transpose cis'' { \key e; c d e f } }
+  \transpose cis'' { \key e; c d e f }
+}
+)
 )
 
+If you want to use both code(\transpose) and code(\relative), then
+you must use code(\transpose) first.  code(\relative) will have no
+effect music that appears inside a code(\transpose).
 
-If you want to use both code(\transpose) and code(\relative), then you
-must use code(\transpose) first.  code(\relative) will have no effect
-music that appears inside a code(\transpose).
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Automatic lyric durations)cindex(Automatic lyric durations)
+subsect(Automatic lyric durations)
+cindex(automatic lyric durations)
 
-If you have lyrics that are set to a melody, you can import the rhythm
-of that melody into the lyrics using code(\addlyrics).
-keyindex(addlyrics) The syntax for this is code(\addlyrics)
-var(musicexpr1 musicexpr2).  This means that both var(musicexpr1) and
-var(musicexpr2) are interpreted, but that every non-command atomic
-music expression (``every syllable'') in var(musicexpr2) is
-interpreted using timing of var(musicexpr1).
+If you have lyrics that are set to a melody, you can import the
+rhythm of that melody into the lyrics using code(\addlyrics).
+keyindex(addlyrics) The syntax for this is
 
-If the property code(automaticMelismata) is set in the context of
-var(musicexpr1), then no lyrics will be put on slurred or tied notes.
+quote(
+  code(\addlyrics) var(musicexpr1 musicexpr2)
+)
 
-Example
-COMMENT(
+This means that both var(musicexpr1) and var(musicexpr2) are
+interpreted, but that every non-command atomic music expression
+(``every syllable'') in var(musicexpr2) is interpreted using timing
+of var(musicexpr1).
 
-)mudela(verbatim,fragment)(
-       \addlyrics
-               \transpose c'' {
-                       \property Voice.automaticMelismata = "1"
-                       c8 () cis d8. e16 f2 }
-               \context Lyrics \lyrics { do4 re mi fa }
-)COMMENT(
+If the property indexandcode(automaticMelismata) is set in the
+context of var(musicexpr1), no lyrics will be put on slurred or tied
+notes.
+
+quote(
+mudela(verbatim,fragment)(\addlyrics
+\transpose c'' {
+  \property Voice.automaticMelismata = "1"
+  c8 () cis d8. e16 f2
+}
+\context Lyrics \lyrics {
+ do4 re mi fa }
+)
+)
 
-)You should use a single rhythm melody, and single rhythm lyrics (a
+You should use a single rhythm melody, and single rhythm lyrics (a
 constant duration is the obvious choice).  If you do not, you will get
-undesired effects when using multiple stanzas: COMMENT(
+undesired effects when using multiple stanzas:
 
-)mudela(verbatim,fragment)(
-       \addlyrics
-               \transpose c'' { c8 () cis d8. e16 f2 }
-               \context Lyrics \lyrics < { do4 re mi fa }
-                                         { do8 re mi fa } >
+quote(
+mudela(verbatim,fragment)(\addlyrics
+\transpose c'' {
+  c8 () cis d8. e16 f2
+}
+\context Lyrics \lyrics
+< { do4 re mi fa }
+  { do8 re mi fa } >
+)
 )
 
-It is valid (but probably not very useful) to use notes in stead of  lyrics
-for var(musicexpr2). COMMENT(
+It is valid (but probably not very useful) to use notes instead of
+lyrics for var(musicexpr2).
 
-mudela(verbatim,fragment)(
-       \context Voice \addlyrics
-               { s4 s8 s16 s32 }
-               { [c16 c c c] }))
+COMMENT(
+  mudela(verbatim,fragment)(
+    \context Voice \addlyrics
+      { s4 s8 s16 s32 }
+      { [c16 c c c] }
+  )
+)
 
-       
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-sect(Ambiguities)cindex(ambiguities)
+sect(Ambiguities)
+cindex(ambiguities)
 
-The grammar contains a number of ambiguities.footnote(The authors hope
-to resolve them at a later time.)
+The grammar contains a number of ambiguities.footnote(The authors
+hope to resolve them at a later time.)
 
 itemize(
-it()
-The assignment
-verb(
-foo = bar)
-COMMENT(
+  it() The assignment
+
+       quote(
+         verb(foo = bar)
+       )
+
+       can be interpreted as making a string identifier code(\foo)
+       containing code("bar"), or a music identifier code(\foo)
+       containing the syllable `bar'.
+
+  it() The assignment
 
-)Can be interpreted as making a string identifier code(\foo)
-containing code("bar"), or a music identifier code(\foo) containing
-the syllable `bar'.
+       quote(
+         verb(foo = -6)
+       )
 
-it()The assignment
-verb( foo = -6
-)Can be interpreted as making a integer identifier containing -6, or a
-Request identifier containing the fingering `6' (with neutral direction).
+       can be interpreted as making an integer identifier
+       bind(containing)-6, or a Request identifier containing the
+       bind(fingering)`6' (with neutral direction).
 
-it()
-If you do a nested repeat,
-verb(
+  it() If you do a nested repeat like
+
+       quote(
+verb(\repeat ...
 \repeat ...
-  \repeat ..
-  \alternative
-  ) then it is ambiguous to which code(\repeat) the code(\alternative)
-  belongs. This is the classic if-then-else dilemma.  It may be solved
-  by using braces.
+\alternative)
+       )
+
+       then it is ambiguous to which code(\repeat) the
+       code(\alternative) belongs.  This is the classic if-then-else
+       dilemma.  It may be solved by using braces.
 
-it()
-(an as yet unidentified ambiguity)
+  it() (an as yet unidentified ambiguity :-)
 )
 
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 sect(Notation conversion specifics)
 
-subsect(Automatic Beam Generation)cindex(Automatic Beam Generation)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Automatic Beam Generation)
+cindex(automatic beam generation)
 label(autobeam)
 
 By default, LilyPond will generate beams automatically.  This feature
 can be disabled by setting the indexandcode(Voice.noAutoBeaming)
-property to 1.  It can be overridden for specific cases by specifying
-explicit beams as described in Section ref(manualbeam).
+property bind(to)1.  It can be overridden for specific cases by
+specifying explicit beams as described in
+bind(section)ref(manualbeam).
 
 A large number of Voice properties are used to decide how to generate
 beams.  Their default values appear in file(auto-beam-settings.ly).
 In general, beams can begin anywhere, but their ending location is
 significant.  Beams can end on a beat, or at durations specified by
 the indexandcode(Voice.beamAutoEnd) property.  To end beams every
-quarter note, for example, you could use set
-indexandcode(Voice.beamAutoEnd) equal to code("1/4").  To end beams at
-every three eighth notes you would set it to code("3/8").  The same
-syntax can be used to specify beam starting points using
+quarter note, for example, you could set
+indexandcode(Voice.beamAutoEnd) equal to `code("1/4")'.  To end beams
+at every three eighth notes you would set it to `code("3/8")'.  The
+same syntax can be used to specify beam starting points using
 indexandcode(Voice.beamAutoBegin).
 
 To allow different settings for different time signatures, these
-property names can start with code(time)var(N)code(_)var(M) to
-restrict the definition to var(N)code(/)code(M) time.  For example,
-to specify beams ending only for 6/8 time you would use the property
-code(Voice.time6_8beamAutoEnd).  To allow different endings for notes
-of different durations, the duration can be tacked onto the end of the
-property.  To specify beam endings for beams that contain 32nd notes,
-you would use code(Voice.beamAutoEnd_32).
-
-subsect(Printing chord names)cindex(chord names)cindex(chords)cindex(printing!chord names)
-
-For displaying printed chord names, use the indexandcode(ChordNames) context.  
-The chords may be entered either using the notation described above,
-or directly using simultaneous music. 
-mudela(fragment,verbatim)(
-<
-  \context ChordNames { \chords{ a b c} \notes{ < d f g >  < e g b > } }
-  \context Staff \notes{ a b c' d' e' }
+property names can start with `code(time)var(N)code(_)var(M)' to
+restrict the definition to `var(N)code(/)var(M)' time.  For example,
+to specify beams ending only for bind(6/8)time you would use the
+property code(Voice.time6_8beamAutoEnd).  To allow different endings
+for notes of different durations, the duration can be tacked onto the
+end of the property.  To specify beam endings for beams that contain
+bind(32nd)notes, you would use code(Voice.beamAutoEnd_32).
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Printing chord names)
+cindex(chord names)
+cindex(chords)
+cindex(printing!chord names)
+
+For displaying printed chord names, use the indexandcode(ChordNames)
+and indexandcode(ChordNameVoice) contexts.  The chords may be entered
+either using the notation described above, or directly using
+simultaneous music.
+
+quote(
+mudela(fragment,verbatim)(<
+  \context ChordNames {
+    \chords{a b c} \notes{<d f g>  <e g b>}
+  }
+  \context Staff \notes {
+    a b c' d' e'
+  }
 >
 )
-LilyPond examines chords specified as lists of notes to determine a
-name to give the chord.  By default, LilyPond will not try to identify
-chord inversions:
-mudela(fragment,verbatim,center)(
-<
-  \context ChordNameVoice { 
-     \notes{ < e'1 g' c'' > } }
-  \context Thread \notes{ < e'1 g' c'' > }
->)
-If you want inversions to be recognized, you must set the property
-indexandcode(ChordNames.chordInversion): 
-mudela(fragment,verbatim,center)(
-<
-  \property Score.chordInversion = 1
-  \context ChordNameVoice { 
-       \notes{ < e'1 g' c'' > } }
-  \context Thread \notes{ < e'1 g' c'' > }
->)
-
+)
 
+LilyPond examines chords specified as lists of notes to determine a
+name to give the chord.  By default, LilyPond will not try to
+identify chord inversions:
+
+mudela(fragment,verbatim,center)(  <
+    \context ChordNameVoice \notes {
+      <e'1 g' c''>
+    }
+    \context Thread \notes {
+      <e'1 g' c''>
+    }
+  >)
 
-subsect(Printing lyrics)cindex(Lyrics)cindex(printing!lyrics)
+If you want inversions to be recognized, you must set the property
+indexandcode(ChordNames.chordInversion):
+
+mudela(fragment,verbatim,center)(  <
+    \property Score.chordInversion = 1
+    \context ChordNameVoice \notes {
+      <e'1 g' c''>
+    }
+    \context Thread \notes {
+      <e'1 g' c''>
+    }
+  >)
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Printing lyrics)
+cindex(lyrics)
+cindex(printing!lyrics)
 label(lyricprint)
 
 Lyric syllables must be interpreted within a code(Lyrics) context
 cindex(context!Lyrics) for printing them.
 
 Here is a full example: 
-mudela(verbatim)(\score{
-  <  \notes \transpose c'' {c d e c | c d e c | e f g2 | 
-                              e4 f g2 \bar "|."; }
-     \context Lyrics \lyrics { 
-              Va-4 der Ja- cob Va- der Ja- cob
-              Slaapt gij nog?2 Slaapt4 gij nog?2  }
-  >
-})
-
 
- You may 
-want a  continuous line after the syllables to show melismata.   To achieve
-this effect, add a code(__) lyric as a separate word 
-after the lyric to be extended.  
-This will create
-an extender, a line  that extends over the entire duration of 
-the lyric.  This line will run all the way to the start of the next
-lyric, so you may want to shorten it by using a blank lyric.  
-COMMENT(
-
-)mudela(verbatim)(\score{
-< \notes \relative c''{ 
-     a4()b()c()d c()d()b()a c()d()b()a }
-   \context Lyrics \lyrics {
-     foo1 __  bar2. __ _4 baz1 __ }
-> })COMMENT(
+quote(
+mudela(verbatim)(\score {
+  <
+    \notes \transpose c'' {
+      c d e c | c d e c |
+      e f g2 | e4 f g2 \bar "|.";
+    }
+    \context Lyrics \lyrics { 
+      Va-4 der Ja- cob Va- der Ja- cob
+      Slaapt gij nog?2 Slaapt4 gij nog?2
+    }
+  >
+}
+)
+)
 
+You may want a continuous line after the syllables to show melismata. 
+To achieve this effect, add a `code(__)' lyric as a separate word
+after the lyric to be extended.  This will create an extender, a line
+that extends over the entire duration of the lyric.  This line will
+run all the way to the start of the next lyric, so you may want to
+shorten it by using a blank lyric (using `code(_)').
+
+quote(
+mudela(verbatim)(\score {
+  <
+    \notes \relative c'' {
+      a4 () b () c () d | c () d () b () a | c () d () b () a
+    }
+    \context Lyrics \lyrics {
+      foo1 __ | bar2. __ _4 | baz1 __
+    }
+  >
+}
+)
 )
      
-If you want to have hyphens centered between syllables (rather than attached
-to the end of the first syllable) you can use the special code(-)code(-) lyric as
-separate word between syllables. This will result in a hyphen whose length
-varies depending on the space between syllables, and centered between the
-syllables. For example: 
-mudela(verbatim)(\score{
-  <  \notes \transpose c'' {c d e c | c d e c | e f g2 | 
-                              e4 f g2 \bar "|."; }
-     \context Lyrics \lyrics { 
-              Va4  -- der Ja -- cob Va -- der Ja -- cob
-              Slaapt gij nog?2 Slaapt4 gij nog?2  }
+If you want to have hyphens centered between syllables (rather than
+attached to the end of the first syllable) you can use the special
+`code(-)code(-)' lyric as a separate word between syllables.  This
+will result in a hyphen which length varies depending on the space
+between syllables, and which will be centered between the syllables. 
+For example:
+
+quote(
+mudela(verbatim)(\score {
+  <
+    \notes \transpose c'' {
+      c d e c | c d e c |
+      e f g2 | e4 f g2 \bar "|.";
+    }
+    \context Lyrics \lyrics {
+      Va4 -- der Ja -- cob | Va -- der Ja -- cob |
+      Slaapt gij nog?2 | Slaapt4 gij nog?2
+    }
   >
-})
-
+}
+)
+)
 
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-sect(Notation Contexts)cindex(Notation Contexts)
+sect(Notation Contexts)
+cindex(notation contexts)
 
 Notation contexts are objects that only exist during a run of
 LilyPond.  During the interpretation phase of LilyPond, the Music
 expression contained in a code(\score) block is interpreted in time
-order.  This is the order in which humans read, play and write music.
+order.  This is the order in which humans read, play, and write
+music.
+
+A context is an object that holds the reading state of the
+expression; it contains information like
 
-A  context is an object that holds the reading state of the expression:
-it contains information like
 itemize(
-it() What notes are playing at this point?
-it() What symbols will be printed at this point?
-it() In what style will they printed?
-it() What is the current key signature, time signature, point within
-the measure, etc.
+  it() What notes are playing at this point?
+  it() What symbols will be printed at this point?
+  it() In what style will they printed?
+  it() What is the current key signature, time signature, point within
+       the measure, etc.?
 )
 
-Contexts are grouped hierarchically: a code(Voice) context is
+Contexts are grouped hierarchically: A code(Voice) context is
 contained in a code(Staff) context (because a staff can contain
-multiple voices at any point), a code(Staff) context is contained in a
-code(Score), code(StaffGroup) or code(ChoirStaff) context (because these
-can all contain multiple staffs.)
-
-Contexts associated with sheet music output are called notation
-contexts, those for sound output are called playing contexts.
-
-Contexts are created either  manually or automatically.
-Initially, the top level music expression is interpreted by the top level
-context (the code(Score) context). 
-When a atomic music expression (a note, a rest, a code(\bar),
-code(\time) command), a nested set of contexts is created that can process these
-atomic expressions, so in this example,COMMENT(
+multiple voices at any point), a code(Staff) context is contained in
+a code(Score), code(StaffGroup), or code(ChoirStaff) context (because
+these can all contain multiple staffs).
+
+Contexts associated with sheet music output are called em(notation
+contexts), those for sound output are called playing contexts.
+
+Contexts are created either manually or automatically.  Initially,
+the top level music expression is interpreted by the top level
+context (the code(Score) context).  When a atomic music expression
+(i.e. a note, a rest, code(\bar), or code(\time) commands), a nested
+set of contexts is created that can process these atomic expressions,
+as in this example:
+
+quote(
+  verb(\score { \notes < c4 > })
+)
 
-)verb(\score { \notes < c4 > })COMMENT(
+The sequential music, `code({ c4 })' is interpreted by code(Score)
+context. When the note `code(c4)' itself is interpreted, a set of
+contexts is needed that will accept notes.  The default for this is a
+code(Voice) context, contained in a code(Staff) context.  Creation of
+these contexts results in the staff being printed.
 
-)the sequential music, code({ c4 }) is interpreted by code(Score) context.
-When the note code(c4) itself is interpreted, a set of contexts is needed
-that will accept notes. The default for this is a code(Voice) context,
-contained in a code(Staff) context.  Creation of  these contexts
-results in the staff being printed.
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 subsect(Context selection)
 label(contextselection)
+cindex(context)
 
 You can also create contexts manually, and you probably have to do so
-if you want to typeset complicated multiple part
-material.  If a code(\context )var(name musicexpr) expression is
-encountered during the interpretation phase, the var(musicexpr)
-argument will be interpreted with a context of type var(name).  If you
-specify a name, the specific context with that name is searched.
+if you want to typeset complicated multiple part material.  If a
+`code(\context) var(name) var(musicexpr)' expression is encountered
+during the interpretation phase, the var(musicexpr) argument will be
+interpreted with a context of type var(name).  If you specify a name,
+the specific context with that name is searched.
 
 If a context of the specified type and name can not be found, a new
 one is created.  For example,
-COMMENT(
 
-)mudela(verbatim)(\score {
+quote(
+mudela(verbatim)(\score {
   \notes \relative c'' {
-    c4 <d4 \context Staff = "another" e4> f } })COMMENT(
-
-) in this example, the code(c) and code(d) are
-printed on the default staff.  For the code(e), a context Staff called
-code(another) is specified; since that does not exist, a new context is
-created.  Within code(another) a (default) Voice context is created
-for the code(e4).   When all music referring to a context is finished, the
-context is ended as well.  So after the third quarter, the
-code(another) is removed.
-
-Almost all music expressions inherit their interpretation context from
-their parent. In other words, suppose that the syntax for a music
-expression is code(\keyword) var(musicexpr1) var(musicexpr2) ellipsis().
-When the interpretation of this music expression starts, the context
-for var(musicexpr1), var(musicexpr2), etc. that of the total
-expression.
-
-Lastly, you may wonder, why doesn't this:
-verb(\score { \notes \relative c'' { c4 d4 e4 }})
-result in this?
-mudela()(\score { \notes \relative c'' { <c4> <d4> <e4> }})
-
-For the code(c4) a default code(Staff) (with contained code(Voice)) context is
-created.  After the code(c4), ends no music refers to this default
-staff, so it would be ended, with the result shown.  To prevent this
-inconvenient behavior, the context to which the sequential music
-refers is adjusted during the interpretation.  So after the code(c4)
-ends, the context of the sequential music is also the default code(Voice)
-context.  The code(d4) gets interpreted in the same context as code(c4)
-
-
-subsect(Predefined contexts)
-
-These are the contexts are supplied with the package.  They are
-defined in init file(ly/engraver.ly).
-
-description(
-
-dit(code(Grace))indexcode(Grace) The context for handling grace notes, it is
-  instantiated automatically when you use code(\grace).  It is a
-  `embedded' miniature of the Score context.  Since this context needs
-  special interaction with the rest of LilyPond, you should not
-  explicitly instantiate it.
-
-dit(code(LyricVoice))indexcode(LyricVoice) Corresponds to a voice with lyrics.  Handles the printing
-of a single line of lyrics.  
-
-dit(code(Thread))indexcode(Thread) Handles note heads, and is contained in the Voice
-  context.  You have to instantiate these explicitly if you want to
-  adjust the style of individual note heads.
+    c4 <d4 \context Staff = "another" e4> f
+  }
+}
+)
+)
 
-dit(code(Voice))indexcode(Voice) Corresponds to a voice on a staff.  This context
-  handles the conversion of dynamic signs, stems, beams, super- and
-  subscripts, slurs, ties and rests.
+In this example, the code(c) bind(and)code(d) are printed on the
+default staff.  For bind(the)code(e), a context Staff called
+`code(another)' is specified; since that does not exist, a new
+context is created.  Within code(another), a (default) Voice context
+is created for bind(the)code(e4).  When all music referring to a
+context is finished, the context is ended as well.  So after the
+third quarter, code(another) is removed.
 
-  You have to instantiate these explicitly if you want to have
-  multiple voices on the same staff.
+Almost all music expressions inherit their interpretation context
+from their parent.  In other words, suppose that the syntax for a
+music expression is
 
-dit(code(ChordNamesVoice))indexcode(ChordNamesVoice) A voice with chord names.  Handles printing
-of a line of chord names.  
+quote(
+  code(\keyword) var(musicexpr1) var(musicexpr2) ellipsis()
+)
 
-dit(code(ChordNames))indexcode(ChordNames)  Typesets chord names.  Can contain
-code(ChordNamesVoice) contexts.  
+When the interpretation of this music expression starts, the context
+for var(musicexpr1), var(musicexpr2), etc. is that of the total
+expression.
 
-dit(code(Lyrics))indexcode(Lyrics) Typesets lyrics.  It can contain code(LyricVoice) contexts.
+Lastly, you may wonder, why this:
 
-dit(code(Staff))indexcode(Staff) Handles clefs, bar lines, keys,
-  accidentals.  It can contain code(Voice) contexts.
+quote(
+verb(\score {
+  \notes \relative c'' {
+    c4 d4 e4
+  }
+})
+)
 
-dit(code(RhythmicStaff))indexcode(RhythmicStaff) A context like code(Staff) but for printing
-rhythms.  Pitches are ignored; the notes are printed on one line.  
-It can contain code(Voice) contexts. 
+doesn't result in this:
 
-dit(code(GrandStaff))indexcode(GrandStaff) Contains code(Staff) or code(RhythmicStaff)
-contexts.  It adds a brace on the left side grouping the staffs
-together. The bar lines of the contained staffs are connected vertically.
-It can contain code(Staff) contexts.
+mudela()(
+  \score {
+    \notes \relative c'' {
+      <c4> <d4> <e4>
+    }
+  }
+)
 
-dit(code(PianoStaff))indexcode(PianoStaff) Just like code(GrandStaff) but with
-code(minVerticalAlign) set equal to code(maxVerticalAlign) so that
-interstaff beaming and slurring can be used.  
+For bind(the)code(c4), a default code(Staff) (with a contained
+code(Voice)) context is created.  After bind(the)code(c4) ends, no
+music refers to this default staff, so it would be ended, with the
+result shown.  To prevent this inconvenient behavior, the context to
+which the sequential music refers is adjusted during the
+interpretation.  So after bind(the)code(c4) ends, the context of the
+sequential music is also the default code(Voice) context. 
+bind(The)code(d4) gets interpreted in the same context
+bind(as)code(c4).
 
-dit(code(StaffGroup))indexcode(StaffGroup) Contains code(Staff) or code(RhythmicStaff)
-contexsts.  Adds a bracket on the left side, grouping the staffs
-together.  The bar lines of the contained staffs are connected vertically.
-It can contain code(Staff), code(RhythmicStaff), code(GrandStaff) or code(Lyrics) contexts.  
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-dit(code(ChoirStaff))indexcode(ChoirStaff) Identical to code(StaffGroup) except that the
-contained staffs are not connected vertically.  
+subsect(Predefined contexts)
 
-dit(code(Score))indexcode(Score) This is the top level notation context.    No
-other context can contain a code(Score) context.  This context handles
-the administration of time signatures.  It also makes sure that items
-such as clefs, time signatures, and key-signatures are aligned across
-staffs.  It can contain code(Lyrics), code(Staff),
-code(RhythmicStaff), code(GrandStaff), code(StaffGroup), and
-code(ChoirStaff) contexts.
+These are the contexts supplied with the package.  They are defined
+in the initialization file file(ly/engraver.ly).
 
-You can not explicitly instantiate a Score context (since it is not
-contained in any other context.).  It is instantiated automatically
-when an output definition (a code(\score) or code(\paper) block) is
-processed.
+description(
+  dit(code(Grace))indexcode(Grace) nl()
+    The context for handling grace notes.  It is instantiated
+    automatically when you use code(\grace).  Basically, it is an
+    `embedded' miniature of the Score context.  Since this context
+    needs special interaction with the rest of LilyPond, you should
+    not explicitly instantiate it.
+
+  dit(code(LyricVoice))indexcode(LyricVoice) nl()
+    Corresponds to a voice with lyrics.  Handles the printing of a
+    single line of lyrics.
+
+  dit(code(Thread))indexcode(Thread) nl()
+    Handles note heads, and is contained in the Voice context.  You
+    have to instantiate this explicitly if you want to adjust the
+    style of individual note heads.
+
+  dit(code(Voice))indexcode(Voice) nl()
+    Corresponds to a voice on a staff.  This context handles the
+    conversion of dynamic signs, stems, beams, super- and subscripts,
+    slurs, ties, and rests.
+
+    You have to instantiate this explicitly if you want to have
+    multiple voices on the same staff.
+
+  dit(code(ChordNamesVoice))indexcode(ChordNamesVoice) nl()
+    A voice with chord names.  Handles printing of a line of chord
+    names.
+
+  dit(code(ChordNames))indexcode(ChordNames) nl()
+    Typesets chord names.  Can contain code(ChordNamesVoice)
+    contexts.
+
+  dit(code(Lyrics))indexcode(Lyrics) nl()
+    Typesets lyrics.  It can contain code(LyricVoice) contexts.
+
+  dit(code(Staff))indexcode(Staff) nl()
+    Handles clefs, bar lines, keys, accidentals.  It can contain
+    code(Voice) contexts.
+
+  dit(code(RhythmicStaff))indexcode(RhythmicStaff) nl()
+    A context like code(Staff) but for printing rhythms.  Pitches are
+    ignored; the notes are printed on one line.  It can contain
+    code(Voice) contexts.
+
+  dit(code(GrandStaff))indexcode(GrandStaff) nl()
+    Contains code(Staff) or code(RhythmicStaff) contexts.  It adds a
+    brace on the left side, grouping the staffs together.  The bar
+    lines of the contained staffs are connected vertically.  It can
+    contain code(Staff) contexts.
+
+  dit(code(PianoStaff))indexcode(PianoStaff) nl()
+    Just like code(GrandStaff) but with code(minVerticalAlign) set
+    equal to code(maxVerticalAlign) so that interstaff beaming and
+    slurring can be used.
+
+  dit(code(StaffGroup))indexcode(StaffGroup) nl()
+    Contains code(Staff) or code(RhythmicStaff) contexts.  Adds a
+    bracket on the left side, grouping the staffs together.  The bar
+    lines of the contained staffs are connected vertically.  It can
+    contain code(Staff), code(RhythmicStaff), code(GrandStaff), or
+    code(Lyrics) contexts.
+
+  dit(code(ChoirStaff))indexcode(ChoirStaff) nl()
+    Identical to code(StaffGroup) except that the contained staffs
+    are not connected vertically.
+
+  dit(code(Score))indexcode(Score) nl()
+    This is the top level notation context.  No other context can
+    contain a code(Score) context.  This context handles the
+    administration of time signatures.  It also makes sure that items
+    such as clefs, time signatures, and key-signatures are aligned
+    across staffs.  It can contain code(Lyrics), code(Staff),
+    code(RhythmicStaff), code(GrandStaff), code(StaffGroup), and
+    code(ChoirStaff) contexts.
+
+    You cannot explicitly instantiate a Score context (since it is
+    not contained in any other context).  It is instantiated
+    automatically when an output definition (a code(\score) or
+    code(\paper) block) is processed.
 )
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 subsect(Context properties)
 
 Properties that are set in one context are inherited by all of the
-contained contexts.  This means that a property valid for the Voice
-context can be set in the Score context (for example) and thus take
-effect in all Voice contexts.
+contained contexts.  This means that a property valid for the
+code(Voice) context can be set in the code(Score) context (for
+example) and thus take effect in all code(Voice) contexts.
 
 Properties can be preset within the code(\translator) block
-corresponding to the appropriate context.  In this case, the syntax is
-`var(propname) code(=) var(value)'.  This assignment happens before
-interpretation starts, so a code(\property) expression will override
-any pre defined settings.
+corresponding to the appropriate context.  In this case, the syntax
+is
+
+quote(
+  var(propname) code(=) var(value)
+)
+
+This assignment happens before interpretation starts, so a
+code(\property) expression will override any predefined settings.
 
 The code(\property) expression will create any property you specify.
-There is no guarantee that a property will be used.  So if you spell a
-property name wrong, there will be no error message.
+There is no guarantee that a property will be used.  So if you spell
+property name wrong, there will be no error message.
 
-The property settings are used during the interpretation phase. They
+The property settings are used during the interpretation phase.  They
 are read by the LilyPond modules where interpretation contexts are
-built of.  These modules are called em(translators). Translators for
-notation are called em(engravers) and translators for sound are called
-em(performers).
+built of.  These modules are called em(translators).  Translators for
+notation are called em(engravers), and translators for sound are
+called em(performers).
 
 The precise result of a property is determined by the implementation
 of the translator that reads them.  Therefore, the result of a
 property can vary, since it is implementation and configuration
 dependent.
 
-In order to fully find out what properties are used, you must search
-the source code for calls to code(get_property).  The rest of the
-section is devoted to an (incomplete) overview of available properties.
+In order to fully find out what properties are used, you must
+currently search the source code for calls to code(get_property). 
+The rest of the section is devoted to an (incomplete) overview of
+available properties.
 
-subsubsubsect(Lyrics properties)cindex(properties!Lyrics)
+subsubsect(Lyrics properties)
+cindex(properties!Lyrics)
 
 description(
-
-dit(code(textStyle))indexcode(textStyle) Set the font for lyrics.  The available font
-choices are code(roman), code(italic), code(bold), code(large),
-code(Large), code(typewriter), and code(finger).  The code(finger)
-font can only display numbers.  Note also that you must be careful
-when using code(\property) in Lyrics mode,  because of the way strings
-are parsed.   Either put quotes around the arguments to code(\property)
-or be sure to leave a space on both sides of the dot.
-
-
+  dit(code(textStyle))indexcode(textStyle) nl()
+    Set the font for lyrics.  The available font choices are
+    code(roman), code(italic), code(bold), code(large), code(Large),
+    code(typewriter), and code(finger).  The code(finger) font can
+    only display numbers.  Note also that you must be careful when
+    using code(\property) in Lyrics mode, because of the way strings
+    are parsed.  Either put quotes around the arguments to
+    code(\property) or be sure to leave a space on both sides of the
+    dot.
 )
 
-subsubsubsect(Thread properties)cindex(properties!Thread)
+subsubsect(Thread properties)
+cindex(properties!Thread)
 
 description(
-dit(code(noteheadStyle))indexcode(noteheadStyle) Selects type of note head.  Choices are
-code(cross), code(diamond), code(harmonic), code(transparent), and
-code("").  They are shown in that order below.  
-mudela(center)(
-\score{
-  \notes{ 
-     \property Staff.barNonAuto = 1
-     \property Voice.noteHeadStyle = cross 
-     a'
-     \property Voice.noteHeadStyle = diamond
-     a'
-     \property Voice.noteHeadStyle = harmonic
-     a'
-     \property Voice.noteHeadStyle = transparent
-     a' 
-     \property Voice.noteHeadStyle = ""
-     a'
-  }
- \paper{ linewidth = -1.;}
-}
-)
+  dit(code(noteheadStyle))indexcode(noteheadStyle) nl()
+    Selects type of note head.  Choices are code(cross),
+    code(diamond), code(harmonic), code(transparent), and code(""). 
+    They are shown in that order below.
+
+    mudela(center)(
+      \score {
+        \notes { 
+          \property Staff.barNonAuto = 1
+          \property Voice.noteHeadStyle = cross 
+          a'
+          \property Voice.noteHeadStyle = diamond
+          a'
+          \property Voice.noteHeadStyle = harmonic
+          a'
+          \property Voice.noteHeadStyle = transparent
+          a' 
+          \property Voice.noteHeadStyle = ""
+          a'
+        }
+        \paper {
+          linewidth = -1.;
+        }
+      }
+    )
 )
 
-
-subsubsubsect(Voice properties)cindex(properties!Voice)
-
+subsubsubsect(Grace properties)
+cindex(properties!Grace)
 description(  
+  dit(indexandcode(stemStyle)) nl()
+    By default set to code("grace") meaning that all unbeamed 
+    notes with flags are typeset with a slash through the flag. 
+    Setting to code("") gives standard flags.
+)
 
-dit(code(stemLength))indexcode(stemLength) Set length of stems.  Unit is 
-code(interline)/2, so code(stemLength) defaults to 7.
-
-dit(code(stemLeftBeamCount))indexcode(stemLeftBeamCount) Specify the number of beams to draw on
-the left side of the next note.   Overrides automatic beaming.  The
-value is only used once, and then it is erased.
-
-dit(code(stemRightBeamCount))indexcode(stemRightBeamCount) Specify the number of beams to draw on
-the right side of the next note.   Overrides automatic beaming.  The
-value is only used once, and then it is erased.
-
-dit(code(noAutoBeaming))indexcode(beamAuto) If set to 1 then beams are
-not generated automatically.
-
-dit(code(beamAutoEnd))indexcode(beamAutoEnd) Specifies when automatically generated beams
-can end.  See Section ref(autobeam).
-
-dit(code(beamAutoBegin))indexcode(beamAutoBegin) Specifies when automatically generated beams
-can start.  See Section ref(autobeam). 
-
-dit(code(textEmptyDimension))indexcode(textEmptyDimension) If set to 1 then text placed above or
-below the staff is assumed to have zero width.  
-
-dit(code(beamquantisation))indexcode(beamquantisation) Set to
-code(\none) for no quantization.  Set to code(\normal) to quantize
-position and slope.  Set to code(\traditional) to avoid wedges.  These
-three settings are available via code(\beamposfree),
-code(\beamposnormal), and code(\beampostraditional).
-
-dit(code(beamslopedamping))indexcode(beamslopedamping) Set to code(\none) for undamped beams.
-Set to code(\normal) for damped beams.  Set to code(\infinity) for
-beams with zero slope.  The identifiers code(\beamslopeproportional),
-code(\beamslopedamped), and code(\beamslopezero) each set the
-corresponding value.
-
-dit(code(restStyle))indexcode(restStyle) Change the layout of rests shorter than quarter notes. 
-Currently, the standard layout code(restStyle="") and mensural notation
-code(restStyle="mensural") are available.
+subsubsect(Voice properties)
+cindex(properties!Voice)
 
-dit(code(midiInstrument))indexcode(midiInstrument) Sets the instrument for MIDI output.    If
-this property is not set then LilyPond will use the code(instrument)
-property.  This must be set to one of the strings on the list of MIDI
-instruments that appears in Section ref(midilist).  If you use a
-string which is not listed, LilyPond will silently substitute piano. 
+description(  
+  dit(code(stemLength))indexcode(stemLength) nl()
+    Set length of stems.  Unit is `code(interline)/2', so
+    code(stemLength) defaults bind(to)7.
+
+  dit(code(stemLeftBeamCount))indexcode(stemLeftBeamCount) nl()
+    Specify the number of beams to draw on the left side of the next
+    note.  Overrides automatic beaming.  The value is only used once,
+    and then it is erased.
+
+  dit(code(stemRightBeamCount))indexcode(stemRightBeamCount) nl()
+    Specify the number of beams to draw on the right side of the next
+    note.  Overrides automatic beaming.  The value is only used once,
+    and then it is erased.
+
+  dit(code(noAutoBeaming))indexcode(beamAuto) nl()
+    If set bind(to)1 then beams are not generated automatically.
+
+  dit(code(beamAutoEnd))indexcode(beamAutoEnd) nl()
+    Specifies when automatically generated beams can end.  See
+    bind(section)ref(autobeam).
+
+  dit(code(beamAutoBegin))indexcode(beamAutoBegin) nl()
+    Specifies when automatically generated beams can start.  See
+    bind(section)ref(autobeam).
+
+  dit(code(textEmptyDimension))indexcode(textEmptyDimension) nl()
+    If set bind(to)1 then text placed above or below the staff is
+    assumed to have zero width.
+
+  dit(code(beamquantisation))indexcode(beamquantisation) nl()
+    Set to code(\none) for no quantization.  Set to code(\normal) to
+    quantize position and slope.  Set to code(\traditional) to avoid
+    wedges.  These three settings are available via
+    code(\beamposfree)keyindex(beamposfree),
+    code(\beamposnormal)keyindex(beamposnormal), and
+    code(\beampostraditional)keyindex(beampostraditional).
+
+  dit(code(beamslopedamping))indexcode(beamslopedamping) nl()
+    Set to code(\none) for undamped beams.  Set to code(\normal) for
+    damped beams.  Set to code(\infinity) for beams with zero slope. 
+    The identifiers
+    code(\beamslopeproportional)keyindex(beamslopeproportional),
+    code(\beamslopedamped)keyindex(beamslopedamped), and
+    code(\beamslopezero)keyindex(beamslopezero) each set the
+    corresponding value.
+
+  dit(code(restStyle))indexcode(restStyle) nl()
+    Change the layout of rests shorter than quarter notes. 
+    Currently, the standard layout code("") and mensural notation
+    code("mensural") are available. Mensural rests of duration
+    32 or shorter are not available.
+
+  dit(code(midiInstrument))indexcode(midiInstrument) nl()
+    Sets the instrument for MIDI output.  If this property is not set
+    then LilyPond will use the code(instrument) property.  This must
+    be set to one of the strings on the list of MIDI instruments that
+    appears in bind(section)ref(midilist).  If you use a string which
+    is not listed, LilyPond will silently substitute piano.
+
+  dit(code(transposing))indexcode(transposing) nl()
+    Transpose the MIDI output.  Set this property to the number of
+    half-steps to transpose by.
+
+  dit(code(oldTieBehavior))indexcode(oldTieBehavior) nl()
+    Set bind(to)1 in order to get old tie behavior where ties would
+    connect unequal pitches.  This property is deprecated, and its
+    use is not recommended.
+
+  dit(code(verticalDirection))indexcode(verticalDirection) nl()
+    Determines the direction of stems, subscripts, beams, slurs, and
+    ties.  Set to code(\down) to force them down, code(\up) to force
+    them up, or code(\free) to let LilyPond decide.  This can be used
+    to distinguish between voices on the same staff.  The
+    code(\stemdown)keyindex(stemdown), code(\stemup)keyindex(stemup),
+    and code(\stemboth)keyindex(stemboth) identifiers set this
+    property.
+
+  dit(code(slurVerticalDirection))indexcode(slurVerticalDirection) nl()
+    Set to code(\free) for free choice of slur direction, set to
+    code(\up) to force slurs up, set to code(\down) to force slurs
+    down.  The shorthands code(\slurup)keyindex(slurup),
+    code(\slurdown)keyindex(slurdown), and
+    code(\slurboth)keyindex(slurboth) are available.
+
+  dit(code(tieVerticalDirection))indexcode(tieVerticalDirection) nl()
+    Set to code(\free) for free choice of tie direction, set to
+    code(\up) to force ties up, set to code(\down) to force ties
+    down.
+
+  dit(code(slurDash))indexcode(slurDash) nl()
+    Set bind(to)0 for normal slurs, bind(1)for dotted slurs, and a
+    larger value for dashed slurs.  Identifiers
+    code(\slurnormal)keyindex(slurnormal) and
+    code(\slurdotted)keyindex(slurdotted) are predefined to set the
+    first two settings.
+
+  dit(code(horizontalNoteShift))indexcode(horizontalNoteShift) nl()
+    Enable LilyPond to shift notes horizontally if they collide with
+    other notes.  This is useful when typesetting many voices on one
+    staff.  The identifier code(\shift)keyindex(shift) is defined to
+    enable this.  Traditionally, the outer chords (the upmost and
+    downmost voices), should have no code(horizontalNoteShift).
+
+   dit(code(forceHorizontalShift))indexcode(forceHorizontalShift) nl()
+    Force horizontal shift for collision resolution.  It overrides
+    automatic collision resolution.  The value is the shift amount
+    expressed in code(note_width), as set in the paper section.
+
+  dit(code(dynamicDirection))indexcode(dynamicDirection) nl()
+    Determines location of dynamic marks.  Set to code(\up) to print
+    marks above the staff; set to code(\down) to print marks below
+    the staff.
+
+  dit(code(dynamicStyle))indexcode(dynamicStyle) nl()
+    Set the text style for dynamics.  
+
+  dit(code(textStyle))indexcode(textStyle) nl()
+    Set the text style for superscripts and subscripts.  See above
+    for list of text styles.
+
+  dit(code(textScriptPadding))indexcode(textScriptPadding) nl()
+    Determines the extra space added between superscripted resp.
+    subscripted text and the closest staff line or note.
+
+  dit(code(fontSize))indexcode(fontSize) nl()
+    Can be used to select smaller font sizes for music.  The normal
+    font size bind(is)0, and the two smaller sizes are -1
+    bind(and)-2.
+
+  dit(code(abbrev))indexcode(abbrev) nl()
+    Set length for tremolo to be used if no length is explicitly
+    specified.
+
+  dit(code(tupletDirection))indexcode(tupletDirection) nl()
+    Determines the direction of triplets and other tuplets.  Set to
+    code(\down) to force them below the staff, code(\up) to force
+    them above, or code(\free) to let LilyPond decide.
+
+  dit(code(tupletVisibility))indexcode(tupletVisibility) nl()
+    Determines whether tuplets of notes are labelled.  Setting
+    bind(to)0 shows nothing; setting bind(to)1 shows a number;
+    setting bind(to)2 shows a number and a bracket if there is no
+    beam; setting bind(to)3 shows a number, and if there is no beam
+    it adds a bracket; setting bind(to)4 shows both a number and a
+    bracket unconditionally.
+
+  dit(code(markScriptPadding))indexcode(markScriptPadding) nl()
+    Determines the extra space added between the mark and the closest
+    staff line or note.
+
+  dit(code(markDirection))indexcode(markDirection) nl()
+    Determines if marks should be printed above or below the staff.
+    Set to code(\up) to print marks above the staff; set to
+    code(\down) to print marks below the staff.
+
+  dit(code(articulationScriptPadding))indexcode(articulationScriptPadding)
+    nl()
+    Determines the extra space added between articulation marks, such
+    as staccato, tenuto, trill, up/down bow or fermata, and the
+    closest staff line or note.
+
+  dit(code(articulationScriptVerticalDirection))
+    indexcode(articulationScriptVerticalDirection) nl()
+    Determines the location of articulation marks.  Set to code(\up)
+    to print marks above the staff; set to code(\down) to print marks
+    below the staff.  This property does not override explicit
+    directions marked with `code(^)' or `code(_)' in the mudela file.
+)
 
-dit(code(transposing))indexcode(transposing) Tranpose the MIDI output.  Set this property to
-the number of half-steps to transpose by.
+subsubsubsect(Staff properties)
+cindex(properties!Staff)
 
-dit(code(oldTieBehavior))indexcode(oldTieBehavior) Set to 1 in order to get old tie behavior
-where ties would connect unequal pitches.  This property is
-deprecated, and use is not recommended.
+description(
+  dit(code(createInitdefaultClef))indexcode(createInitdefaultClef) nl()
+    Specify whether clefs are created on default?  (Doesn't seem to
+    do anything.)
+
+  dit(code(barNumberDirection))indexcode(barNumberDirection) nl()
+    Set to code(\up) or code(\down) to put bar numbers above or below
+    the staff.
+
+  dit(code(barNumberHangOnClef))indexcode(barNumberHangOnClef) nl()
+    Set bind(to)1 to cause bar numbers to appear above or below the
+    clef instead of on the bar line.  This property is deprecated. 
+    Do not use.
+
+  dit(code(barNumberScriptPadding))indexcode(barNumberScriptPadding) nl()
+    Sets extra space between the bar number and the bar it labels.
+
+  dit(code(barSize))indexcode(barSize) nl()
+    Specify the height of the bar lines if it should be different
+    than the staff height.
+
+  dit(code(markHangOnClef))indexcode(markHangOnClef) nl()
+    Set bind(to)1 to cause marks to appear by clefs instead of by bar
+    lines.  Deprecated, use is not recommended.
+
+  dit(code(marginDirection))indexcode(marginDirection) nl()
+    Set to code(\left) or code(\right) to specify location of
+    marginal scripts.
+
+  dit(code(marginScriptPadding))indexcode(marginScriptPadding) nl()
+    Specify extra space for marginal scripts.
+
+  dit(code(forgetAccidentals))indexcode(forgetAccidentals) nl()
+    Causes accidentals to be printed at every note instead of
+    remembered for the duration of a measure.
+
+  dit(code(noResetKey))indexcode(noResetKey) nl()
+    Do not reset the key at the start of a measure.  Accidentals will
+    be printed only once and are in effect until overridden, possibly
+    many measures later.
+
+  dit(code(staffLineLeading))indexcode(staffLineLeading) nl()
+    Specifies the distance (in points) between lines of the staff.
+
+  dit(code(numberOfStaffLines))indexcode(numberOfStaffLines) nl()
+    Specifies the number of staff lines.  The default bind(is)5.
+
+  dit(code(postBreakPadding))indexcode(postBreakPadding) nl()
+    Extra space in points to be added after the clef, time signature
+    and key signature on the staff.  Deprecated, do not use.
+
+  dit(code(barAtLineStart))indexcode(barAtLineStart) nl()
+    Set bind(to)1 to produce a bar line after the clef at the start
+    of each line (but not at the beginning of the music).
+
+  dit(code(noVoltaBraces))indexcode(noVoltaBraces) nl()
+    Set to true to suppress the printing of brackets over alternate
+    endings specified by the command code(\alternative).
+
+  dit(code(voltaSpannerDuration))indexcode(voltaSpannerDuration) nl()
+    Set to an integer to control the size of the brackets printed by
+    code(\alternative).  The integer specifies the number of whole
+    notes duration to use for the brackets.  It is rounded to the
+    nearest measure.  This can be used to shrink the length of
+    brackets in the situation where one alternative is very large. 
+    It may have odd effects if the specified duration is longer than
+    the music given in an code(\alternative).
+
+  dit(code(barNonAuto))indexcode(barNonAuto) nl()
+    If set bind(to)1 then bar lines will not be printed
+    automatically; they must be explicitly created with code(\bar)
+    keywords.  Unlike with the code(\cadenza) keyword, measures are
+    still counted.  Bar generation will resume according to that
+    count if this property is set to zero.
+
+  dit(code(defaultClef))indexcode(defaultClef) nl()
+    Determines the default clef.  See code(\clef) keyword.
+
+  dit(code(numberOfStaffLines))indexcode(numberOfStaffLines) nl()
+    Sets the number of lines that the staff has.
+  dit(code(barAlways))indexcode(barAlways) nl()
+    If set bind(to)1 a bar line is drawn after each note.
+
+  dit(code(defaultBarType))indexcode(defaultBarType) nl()
+    Sets the default type of bar line. See bind(Section)ref(barlines) 
+    for a list of available bar types.
+
+  dit(code(keyOctaviation))indexcode(keyOctaviation) nl()
+    If set bind(to)1, then keys are the same in all octaves.  If set
+    bind(to)0 then the key signature for different octaves can be
+    different and is specified independently:
+
+    quote(
+      code(\keysignature bes fis')
+    )
+
+    The default value bind(is)1.  Can be set to zero with
+    code(\specialkey) or reset bind(to)1 with code(\normalkey).
+
+  dit(code(instrument), code(instr))
+    indexcode(instrument)indexcode(instr) nl()
+    If code(Staff_margin_engraver)cindex(Staff_margin_engraver) is
+    added to the Staff translator, then the code(instrument) property
+    is used to label the first line of the staff and the code(instr)
+    property is used to label subsequent lines.  If the
+    code(midiInstrument) property is not set, then code(instrument)
+    is used to determine the instrument for MIDI output.
+
+  dit(code(createKeyOnClefChange))indexcode(createKeyOnClefChange) nl()
+    Set to a nonempty string if you want key signatures to be printed
+    when the clef changes.  Set to the empty string if you do not
+    want key signatures printed.
+
+  dit(code(timeSignatureStyle))indexcode(timeSignatureStyle) nl()
+    Changes the default two-digit layout for time signatures.  The
+    following values are recognized:
+
+    description(
+      dit(code(C))indexcode(C) nl()
+        4/4 and 2/2 are typeset as C and struck C, respectively.  All
+        other time signatures are written with two digits.
+
+      dit(code(old))indexcode(old) nl()
+        2/2, 3/2, 2/4, 3/4, 4/4, 6/4, 9/4, 4/8, 6/8 and 9/8 are
+        typeset with old-style mensuration marks.  All other time
+        signatures are written with two digits.
+
+      dit(code(1))indexcode(1) nl()
+        All time signatures are typeset with a single
+        digit, e.g. 3/2 is written bind(as)3.
+
+      dit(indexcode(CM/N)code(C)var(M)code(/)var(N), 
+      indexcode(oldM/N)code(old)var(M)code(/)var(N) or
+      indexandcode(old6/8alt)) nl()
+        Tells LilyPond to use a specific symbol as time signature.
+    )
+
+    The different time signature characters are shown below with its
+    names:
+
+    mudela(center)(
+      \score {
+        \notes\relative c'' {
+          \property Voice.textStyle = typewriter
+          \property Staff.timeSignatureStyle = "C2/2"
+          \time 2/2; a2^"C2/2" a2 
+          \property Staff.timeSignatureStyle = "C4/4"
+          \time 2/2; a2^"C4/4" a2 
+          \property Staff.timeSignatureStyle = "old2/2"
+          \time 2/2; a2^"old2/2" a2 
+          \property Staff.timeSignatureStyle = "old3/2"
+          \time 2/2; a2^"old3/2" a2 
+          \property Staff.timeSignatureStyle = "old2/4"
+          \time 2/2; a2^"old2/4" a2 
+          \property Staff.timeSignatureStyle = "old4/4"
+          \time 2/2; a2^"old4/4" a2 
+          \property Staff.timeSignatureStyle = "old6/4"
+          \time 2/2; a2^"old6/4" a2 
+          \property Staff.timeSignatureStyle = "old9/4"
+          \time 2/2; a2^"old9/4" a2 
+          \property Staff.timeSignatureStyle = "old4/8"
+          \time 2/2; a2^"old4/8" a2 
+          \property Staff.timeSignatureStyle = "old6/8"
+          \time 2/2; a2^"old6/8" a2 
+          \property Staff.timeSignatureStyle = "old6/8alt"
+          \time 2/2; a2^"old6/8alt" a2 
+          \property Staff.timeSignatureStyle = "old9/8"
+          \time 2/2; a2^"old9/8" a2 
+        }
+        \paper {
+          linewidth = 4.5 \in;
+        }
+      }
+    )
+
+  dit(code(clefStyle))indexcode(clefStyle) nl()
+    Determines how clefs are typeset.  If set to code(transparent),
+    the clefs are not printed at all, if set to
+    code(fullSizeChanges), clef changes in the middle of a line are
+    typeset with a full size clef.  By default, clef changes are
+    typeset in smaller size.
+)
+   
+subsubsect(GrandStaff properties)
+cindex(properties!GrandStaff)
 
-dit(code(verticalDirection))indexcode(verticalDirection) Determines the direction of stems, subscripts,
-beams, slurs, and ties.  Set to code(\down) to force them down,
-code(\up) to force them up, or code(\free) to let LilyPond decide.
-This can be used to distinguish between voices on the same staff.  The
-code(\stemdown), code(\stemup), and code(\stemboth) identifiers set
-this property.
+description( 
+  dit(code(alignmentReference))indexcode(alignmentReference) nl()
+    Set to code(\center) for vertical alignment reference point to be
+    in the center of the vertical group.  Set to code(\up) to put the
+    reference point at the top of the group.
 
-dit(code(slurVerticalDirection))indexcode(slurVerticalDirection) Set to code(\free) for free choice of slur
-direction, set to code(\up) to force slurs up, set to code(\down) to
-force slurs down.  The shorthands code(\slurup), code(\slurdown), and
-code(\slurboth) are available.
+  dit(code(maxVerticalAlign))indexcode(maxVerticalAlign) nl()
+    Set the maximum vertical distance between staffs.
 
-dit(code(tieVerticalDirection))indexcode(tieVerticalDirection) Set to code(\free) for free choice of tie
-direction, set to code(\up) to force ties up, set to code(\down) to
-force ties down.  
+  dit(code(minVerticalAlign))indexcode(minVerticalAlign) nl()
+    Set the minimum vertical distance between staffs.  
+)
 
-dit(code(slurDash))indexcode(slurDash) Set to 0 for normal slurs, 1 for dotted slurs, and
-a larger value for dashed slurs.  Identifiers code(\slurnormal) and
-code(\slurdotted) are predefined to set the first two settings.
+subsubsect(Score properties)
+cindex(properties!Score)
 
-dit(code(horizontalNoteShift))indexcode(horizontalNoteShift) Enable LilyPond to shift notes
-horizontally if they collide with other notes.  This is useful when
-typesetting many voices on one staff.  The identifier code(\shift) is
-defined to enable this.  Traditionally, the outer chords (the upmost
-and downmost voices), should have no code(horizontalNoteShift). 
+description(
+  dit(code(skipBars))indexcode(skipBars) nl()
+    Set bind(to)1 to skip the empty bars that are produced by
+    multimeasure notes and rests.  These bars will not appear on the
+    printed output.  Set to zero (the default) to expand multimeasure
+    notes and rests into their full length, printing the appropriate
+    number of empty bars so that synchronization with other voices is
+    preserved.
+
+    quote(
+mudela(fragment,verbatim,center)\
+  (r1 r1*3 R1*3\property Score.skipBars=1 r1*3 R1*3
+)
+    )
+)
 
+subsubsect(ChordNamesVoice properties)
+cindex(properties!ChordNamesVoice)
 
-dit(code(forceHorizontalShift))indexcode(forceHorizontalShift) Force
-horizontal shift for collision resolution.  It overrides automatic
-collision resolution.  The value is the shift amount expressed in
-code(note_width), as set in the paper section.
+description(
+  dit(code(chordInversion))indexcode(chordInversion) nl()
+    Determines whether LilyPond should look for chord inversions when
+    translating from notes to chord names.  Set bind(to)1 to find
+    inversions.  The default bind(is)0 which does not look for
+    inversions.
+)
 
-dit(code(dynamicDir))indexcode(dynamicDir) Determines location of dynamic marks.  Set to
-code(\up) to print marks above the staff; set to code(\down) to print
-marks below the staff.
 
-dit(code(dynamicStyle))indexcode(dynamicStyle) Set the text style for dynamics.  
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-dit(code(textStyle))indexcode(textStyle) Set the text style for superscripts and
-subscripts.  See above for list of text styles.
+sect(Notation output definitions)
+cindex(output)
+cindex(notation output)
+cindex(output definition)
+label(output)
+label(paper)
 
-dit(code(textScriptPadding))indexcode(textScriptPadding) Determines the extra space added between
-super-/subscripted text and the closest staff line or note.
+The most important output definition is the code(\paper) block, for
+music notation.  The syntax is
 
-dit(code(fontSize))indexcode(fontSize) Can be used to select smaller font sizes for
-music.  The normal font size is 0, and the two smaller sizes are -1
-and -2.
+quote(
+  code(\paper {) [var(paperidentifier)] var(items) code(})
+)
 
-dit(code(abbrev))indexcode(abbrev) Set length for tremolo to be used if no length is
-explicitly specified.
+where each of the items is one of
 
-dit(code(tupletDirection))indexcode(tupletDirection) Determines the direction of triplets and 
-other tuplets.  Set to code(\down) to force them below the staff,
-code(\up) to force them above, or code(\free) to let LilyPond decide.
+itemize(
+  it() An assignment.  The assignment must be terminated by a
+       semicolon.  See bind(section)ref(papervars) for information on
+       paper variables.
 
-dit(code(tupletVisibility))indexcode(tupletVisibility) Determines whether tuplets of notes are
-labelled.  Setting to 0 shows nothing; setting to 1 shows a number;
-setting to 2 shows a number and a bracket if there is no beam; setting
-to 3 shows a number, and if there is no beam it adds a bracket;
-setting to 4 shows both a number and a bracket unconditionally.
+  it() A context definition.  See bind(section)ref(contextdefs) for
+       more information on context definitions.
 
+  it() A margin shape declaration.  The syntax is
 
-dit(code(markScriptPadding))indexcode(markScriptPadding) Determines the extra space added between
-the mark and the closest staff line or note.
+       quote(
+         code(\shape) var(indent1)code(,) var(width1)code(,)
+                      var(indent2)code(,) var(width2) ellipsis() code(;)
+       )
+       keyindex(shape)
 
-dit(code(markDirection))indexcode(markDirection) Determines if marks should be printed above
-or below the staff. Set to code(\up) to print marks above the staff;
-set to code(\down) to print marks below the staff.
+       Each pair of var(indent) and var(width) values is a dimension
+       specifying how far to indent and how wide to make the line. 
+       The indentation and width of successive lines are specified by
+       the successive pairs of dimensions.  The last pair of
+       dimensions will define the characeristics of all lines beyond
+       those explicitly specified.
 
-dit(code(articulationScriptPadding))indexcode(articulationScriptPadding) Determines the extra space added 
-between articulation marks, such as staccato, tenuto, trill, up/down 
-bow or fermata, and the closest staff line or note.
+  it() A font declaration.  Its syntax is
 
+       quote(
+         var(fontsize) code(=) code(\font)keyindex(font) var(fontname)
+       )
 
-dit(code(articulationScriptVerticalDirection))indexcode(articulationScriptVerticalDirection) Determines the location
-of articulation marks. Set to code(\up) to print marks above the
-staff; set to code(\down) to print marks below the staff. This
-property does not override explicit directions marked with code(^) or
-code(_) in the mudela file.
+       var(fontsize) is an integer describing the font to be used. 
+       bind(0)is the default font.  var(fontname) is the basename of
+       a font (usually a member of the Feta family).
 )
 
-subsubsubsect(Staff properties)cindex(properties!Staff)
-
-description(
-
-dit(code(createInitdefaultClef))indexcode(createInitdefaultClef) Specify whether clefs are created on
-default?  (Doesn't seem to do anything.)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-dit(code(barNumberDirection))indexcode(barNumberDirection) Set to code(\up) or code(\down) to put
-bar numbers above or below the staff.  
+subsect(Changing Font Size and Paper Size)
+cindex(changing font size and paper size)
 
-dit(code(barNumberHangOnClef))indexcode(barNumberHangOnClef) Set to 1
-to cause bar numbers to appear above or below the clef instead of on
-the bar line. This property is deprecated.  Do not use.
-
-dit(code(barNumberScriptPadding))indexcode(barNumberScriptPadding) Sets extra space between the bar
-number and the bar it labels.
+The Feta font provides musical symbols at six different sizes.  These
+fonts are bind(11)point, bind(13)point, bind(16)point, bind(20)point,
+bind(23)point, and bind(26)point.  The point size of a font is the
+height of the five lines in a staff when displayed in the font.
 
-dit(code(barSize))indexcode(barSize) Specify the height of the bar lines if it should be
-different than the staff height.
+Definitions for these sizes are the files file(paperSZ.ly), where
+code(SZ) is one of 11, 13, 16, 20, 23 bind(and)26.  If you include
+any of these files, the identifiers code(paper_eleven),
+code(paper_thirteen), code(paper_sixteen), code(paper_twenty),
+code(paper_twentythree), and code(paper_twentysix) are defined
+respectively.  The default code(\paper) block is also set.
+
+To change the paper size, you must first set the
+indexandcode(papersize) variable at top level.  Set it to the strings
+code(a4), code(letter), or code(legal).  After this specification,
+you must set the font as described above.  If you want the default
+font, then use the bind(20)point font.  The new paper size will not
+take effect if the font is not loaded and selected afterwards.  Paper
+size selection works by loading a file named after the paper size you
+select.
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+subsect(Paper variables)
+cindex(paper variables)
+label(papervars)
 
-dit(code(markHangOnClef))indexcode(markHangOnClef) Set to 1 to cause marks to appear by clefs
-instead of by bar lines.  Deprecated, use is not recommended.
+There is a large number of paper variables that are used to control
+details of the layout.  These variables control the defaults for the
+entire score.  Usually, they do not have to be changed; they are by
+default set to values that depend on the font size in use.  The
+values are used by the graphic objects while formatting the score;
+they are therefore implementation dependent.  Most variables are
+accompanied by documentation in the initalization file
+file(params.ly) or file(paperSZ.ly), where code(SZ) is the staff
+height in points.
 
-dit(code(marginDirection))indexcode(marginDirection) Set to code(\left) or code(\right) to
-specify location of marginal scripts.  
+Nevertheless, here are some variables you may want to use or change:
 
-dit(code(marginScriptPadding))indexcode(marginScriptPadding) Specify extra space for marginal scripts.
+description(
+  dit(code(indent))indexcode(indent) nl()
+    The indentation of the first line of music.
 
-dit(code(forgetAccidentals))indexcode(forgetAccidentals) Causes accidentals to be printed at every
-note instead of remembered for the duration of a measure.  
+  dit(code(interline))indexcode(interline) nl()
+    The distance between two staff lines, calculated from the center
+    of the lines.  You should use either this or code(rulethickness)
+    as a unit for distances you modify.
+  
+  dit(code(linewidth))indexcode(linewidth) nl()
+    Sets the width of the lines.  If set bind(to)-1.0, a single
+    unjustified line is produced.
+
+  dit(code(output))indexcode(output) nl()
+    Specifies an alternate name for the the output file(s).
+    A file(.tex), file(.midi) or file(.ps) extension will be 
+    added to the string you specify.
+
+  dit(code(rulethickness))indexcode(rulethickness) nl()
+    Determines the thickness of staff and bar lines. 
+
+  dit(code(castingalgorithm))indexcode(castingalgorithm) nl()
+    The algorithm to use for breaking lines.  Choices are
+    code(\Gourlay)keyindex(Gourlay) for a TeX()-like dynamic
+    programming algorithm, and code(\Wordwrap)keyindex(Wordwrap) for
+    a simple algorithm.  Gourlay breaking looks much better, but
+    takes a lot more resources.  Wordwrap leaves loosely spaced lines
+    at the end.
+)
 
-dit(code(noResetKey))indexcode(noResetKey) Do not reset the key at the start of a measure.
-Accidentals will be printed only once and are in effect until
-overridden, possibly many measures later. 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-dit(code(staffLineLeading))indexcode(staffLineLeading) Specifies the distance (in points) between lines
-of the staff.  
+subsect(Context definitions)
+label(contextdefs)
+cindex(context definition)
 
-dit(code(numberOfStaffLines))indexcode(numberOfStaffLines) Specifies the number of staff lines. The
-default is 5. 
+A notation contexts is defined by the following information
 
-dit(code(postBreakPadding))indexcode(postBreakPadding) Extra space in points to be added after
-the clef, time signature and key signature on the staff. Deprecated,
-do not use.
+enumerate(
+  it() A name.
 
-dit(code(barAtLineStart))indexcode(barAtLineStart) Set to 1 to produce a bar line after the
-clef at the start of each line (but not at the beginning of the
-music).  
+  it() The LilyPond modules that do the actual conversion of music to
+       notation.  Each module is a so-called
+       em(engraver)cindex(engraver).
 
-dit(code(noVoltaBraces))indexcode(noVoltaBraces) Set to true to suppress the printing
-of brackets over alternate endings specified by code(\alternative).
+  it() How these modules should cooperate, i.e. which ``cooperation
+       module'' should be used.  This cooperation module is a special
+       type of engraver.
 
-dit(code(voltaSpannerDuration))indexcode(voltaSpannerDuration) Set to an integer to control the size
-of the brackets printed by code(\alternative).  The integer specifies
-the number of whole notes duration to use for the brackets.  It seems
-to be rounded to the nearest measure.  This can be used to shrink the
-length of brackets in the situation where one alternative is very
-large.  It may have odd effects if the specified duration is longer
-than the music given in an code(\alternative).   [FIXME: This was
-broken in 1.1.53]
+  it() What other contexts the context can contain,
 
-dit(code(barNonAuto))indexcode(barNonAuto) If set to 1 then bar lines will not be printed
-automatically; they must be explicitly created with code(\bar) keywords.
-Unlike with the code(\cadenza) keyword, measures are still counted.  Bar
-generation will resume according to that count if this property is set to
-zero.  
+  it() What properties are defined.
+)
 
-dit(code(defaultClef))indexcode(defaultClef) Determines the default clef.  See code(\clef)
-keyword.
+A context definition has this syntax:
 
-dit(code(numberOfStaffLines))indexcode(numberOfStaffLines) Sets the number of lines that the staff has.
-dit(code(barAlways))indexcode(barAlways) If set to 1 a bar line is drawn after each note.
-
-dit(code(defaultBarType))indexcode(defaultBarType) Sets the default type of bar line.  See
-code(\bar) keyword.
-
-dit(code(keyOctaviation))indexcode(keyOctaviation) If set to 1, then keys are the same in all
-octaves.  If set to 0 then the key signature for different octaves can
-be different and is specified independently: code(\keysignature bes
-fis').  The default value is 1.  Can be set to zero with
-code(\specialkey) or reset to 1 with code(\normalkey).
-
-dit(code(instrument)) and code(instr) If code(Staff_margin_engraver)
-cindex(instrument)cindex(instr)cindex(Staff_margin_engraver)
-is added to the Staff translator, then the code(instrument) property
-is used to label the first line of the staff and the code(instr)
-property is used to label subsequent lines.  If the
-code(midiInstrument) property is not set then code(instrument) is
-used to determine the instrument for MIDI output.
-
-dit(code(createKeyOnClefChange))indexcode(createKeyOnClefChange) Set
-to a nonempty string if you want key signatures to be printed when the
-clef changes.  Set to the empty string if you do not want key
-signatures printed.
-
-dit(code(timeSignatureStyle))indexcode(timeSignatureStyle) Changes the default two-digit layout
-   for time signatures. The following values are recognized:
-   description(
-      dit(code(C))indexcode(C) 4/4 and 2/2 are typeset as C and struck C,
-      respectively. All other time signatures are written with two digits.
-      dit(code(old))indexcode(old) 2/2, 3/2, 2/4, 3/4, 4/4, 6/4, 9/4, 4/8, 6/8 and
-      9/8 are typeset with old-style mensuration marks. All other time
-      signatures are written with two digits.
-      dit(code(1))indexcode(1) All time signatures are typeset with a single
-      digit, e.g. 3/2 is written as 3.
-      dit(indexandcode(C2/2), code(C4/4), code(old2/2), code(old3/2),
-      code(old2/4), code(old3/4), code(old4/4), code(old6/4), 
-      code(old9/4), code(old4/8), code(old6/8), code(old6/8alt)
-      or code(old9/8))Tells LilyPond to use a specific symbol as 
-      time signature.
-   )
-The different time signature characters are shown below with
-their names:
-mudela(center)(
-\score{
-  \notes\relative c'' {
-\property Voice.textStyle = typewriter
-\property Staff.timeSignatureStyle = "C2/2"
-\time 2/2; a2^"C2/2" a2 
-\property Staff.timeSignatureStyle = "C4/4"
-\time 2/2; a2^"C4/4" a2 
-\property Staff.timeSignatureStyle = "old2/2"
-\time 2/2; a2^"old2/2" a2 
-\property Staff.timeSignatureStyle = "old3/2"
-\time 2/2; a2^"old3/2" a2 
-\property Staff.timeSignatureStyle = "old2/4"
-\time 2/2; a2^"old2/4" a2 
-\property Staff.timeSignatureStyle = "old4/4"
-\time 2/2; a2^"old4/4" a2 
-\property Staff.timeSignatureStyle = "old6/4"
-\time 2/2; a2^"old6/4" a2 
-\property Staff.timeSignatureStyle = "old9/4"
-\time 2/2; a2^"old9/4" a2 
-\property Staff.timeSignatureStyle = "old4/8"
-\time 2/2; a2^"old4/8" a2 
-\property Staff.timeSignatureStyle = "old6/8"
-\time 2/2; a2^"old6/8" a2 
-\property Staff.timeSignatureStyle = "old6/8alt"
-\time 2/2; a2^"old6/8alt" a2 
-\property Staff.timeSignatureStyle = "old9/8"
-\time 2/2; a2^"old9/8" a2 
-}
-   \paper{ linewidth= 4.5 \in; }
-}
+quote(
+  code(\translator) code({)
+                      var(translatorinit) var(translatormodifierlist)
+                    code(})
 )
 
-dit(code(clefStyle))indexcode(clefStyle) Determines how clefs are typeset. When set to
-code(transparent), the clefs are not printed at all, when set to
-code(fullSizeChanges), clef changes in the middle of a line are
-typeset with a full size clef. By default, clef changes are typeset in
-smaller size.
+var(translatorinit) can be an identifier or of the form
 
+quote(
+  code(\type) var(typename) code(;)
 )
-   
-subsubsubsect(GrandStaff properties)cindex(properties!GrandStaff)
 
-description( 
+var(typename) is one of
 
-dit(code(alignmentReference))indexcode(alignmentReference) Set to code(\center) for vertical
-alignment reference point to be in the center of the vertical group.
-Set to code(\up) to put the reference point at the top of the group. 
+description(
+  dit(code(Engraver_group_engraver))indexcode(Engraver_group_engraver) nl()
+    The standard cooperation engraver.
 
-dit(code(maxVerticalAlign))indexcode(maxVerticalAlign) Set the maximum vertical distance between
-staffs.
+  dit(code(Score_engraver))indexcode(Score_engraver) nl()
+    This is cooperation module that should be in the top level context.
 
-dit(code(minVerticalAlign))indexcode(minVerticalAlign) Set the minimum vertical distance between
-staffs.  
+  dit(code(Grace_engraver_group))indexcode(Grace_engraver_group) nl()
+    This is a special cooperation module (resembling
+    code(Score_engraver)) that is used to created an embedded
+    `miniscore'.
+) 
 
-)
+var(translatormodifierlist) is a list of items where each item is
+one of
 
-subsubsubsect(Score properties)cindex(properties!Score)
+itemize(
+  it() code(\consists) var(engravername) code(;) nl()
+    Add var(engravername) to the list of modules in this context. 
+    bind(Section)ref(engravers) contains an overview of the engravers
+    available.  The order of engravers added with code(\consists) is
+    significant.
+  
+  it() code(\consistsend) var(engravername) code(;) nl()
+    Analogous to code(\consists), but makes sure that
+    var(engravername) is always added to the end of the list of
+    engravers.
 
-description(
+    Some engraver types need to be at the end of the list; this
+    insures they are put there, and stay there, if a user adds or
+    removes engravers.  This command is usually not needed for
+    end-users.
+    
+  it() code(\accepts) var(contextname) code(;) nl()
+    Add var(contextname) to the list of  context this context can
+    contain.  The first listed context the context to create by
+    default.
+  
+  it() code(\remove) var(engravername) code(;) nl()
+    Remove a previously added (with code(\consists)) engraver.
+  
+  it() code(\name) var(contextname) code(;) nl()
+    This sets name of the context, e.g. code(Staff), code(Voice).  If
+    the name is not specified, the translator won't do anything.
 
-dit(code(skipBars))indexcode(skipBars) Set to 1 to skip the empty bars that are produced
-by multimeasure notes and rests.  These bars will not appear on the
-printed output.  Set to zero (the default) to expand multimeasure
-notes and rests into their full length, printing the appropriate
-number of empty bars so that synchronization with other voices is
-preserved.
-mudela(fragment,verbatim,center)(
-r1 r1*3 R1*3\property Score.skipBars=1 r1*3 R1*3
+  it() var(propname) code(=) var(value) code(;) nl()
+    A property assignment.  It is allowed to use reals for
+    var(value).
 )
 
+In the code(\paper) block, it is also possible to define translator
+identifiers.  Like other block identifiers, the identifier can only
+be used as the very first item of a translator.  In order to define
+such an identifier outside of code(\score), you must do
+
+quote(
+verb(\paper {
+  foo = \translator { ... }
+}
+\score {
+  \notes {
+    ...
+  }
+  \paper {
+    \translator { \foo ... }
+  }
+})
 )
 
-subsubsubsect(ChordNamesVoice properties)cindex(properties!ChordNamesVoice)
+subsubsect(Paper Types, Engravers, and Pre-defined Translators)
+cindex(paper types, engravers, and pre-defined translators)
 
-description(
-dit(code(chordInversion))indexcode(chordInversion) Determines whether LilyPond should look for
-chord inversions when translating from notes to chord names.  Set to 1
-to find inversions.  The default is 0 which does not look for inversions.
-)
+Some pre-defined identifiers can simplify modification of
+translators.  The pre-defined identifiers are:
 
+description(
+  dit(code(StaffContext))indexcode(StaffContext) nl()
+    Default Staff context. 
 
-sect(Notation output definitions)cindex(Output)cindex(Notation output)
-cindex(output definition)
-label(output)
-label(paper)
+  dit(code(RhythmicStaffContext))indexcode(RhythmicStaffContext) nl()
+    Default RhythmicStaff context. 
 
-The most important output definition is the code(\paper) block, for
-music notation.  The syntax is
-code(\paper {) [var(paperidentifier)] var(items) code(}),
-where each of the items is one of
+  dit(code(VoiceContext))indexcode(VoiceContext) nl()
+    Default Voice context.  
 
-itemize(
+  dit(code(ScoreContext))indexcode(ScoreContext) nl()
+    Default Score context. 
 
-it() An assignment.  The assignment must be terminated by a semicolon.
-See Section ref(papervars) for information on paper variables.
+  dit(code(ScoreWithNumbers))indexcode(ScoreWithNumbers) nl()
+    Score context with numbering at the Score level.
 
-it() A context definition, see Section ref(contextdefs) for more
-information on context definitions.
+  dit(code(BarNumberingStaffContext))indexcode(BarNumberingStaffContext) nl()
+    Staff context with numbering at the Staff level.
 
-it() A margin shape declaration. The syntax is code(\shape)
-var(indent1)code(,) var(width1)code(,) var(indent2)code(,) var(width2)
-ellipsis() code(;)
-indexcode(\shape)
-Each pair of var(indent) and var(width) values is a
-dimension specifying how far to indent and how wide to make the line.
-The indentation and width of successive lines are specified by the
-successive pairs of dimensions.  The last pair of dimensions will
-define the characeristics of all lines beyond those explicitly
-specified.
+  dit(code(HaraKiriStaffContext))indexcode(HaraKiriStaffContext) nl()
+    Staff context that does not print if it only contains rests. 
+    Useful for orchestral scores.footnote(Harakiri, also called
+    Seppuku, is the ritual suicide of the Samourai.)
 
-it() A font declaration.  Its syntax is var(fontsize) code(=)
-code(\font)keyindex(font) var(fontname).  var(fontsize) is an integer
-describing the font to be used.  0 is the default font. var(fontname)
-is the basename of a font (usually a member of the Feta family).
+  dit(code(OrchestralPartStaffContext))indexcode(OrchestralPartStaffContext)
 
+  dit(code(OrchestralScoreContext))indexcode(OrchestralScoreContext)
 )
 
+Using these pre-defined values, you can remove or add items to the
+translator:
 
+quote(
+verb(\paper {
+  \translator {
+    \StaffContext
+    \remove Some_engraver;
+    \consists Different_engraver;
+  }
+})
+)
+      
+subsubsect(Engravers)
+label(engravers)
 
+The engravers for paper output are:
 
-subsect(Changing Font Size and Paper Size)cindex(Changing Font Size and Paper Size)
+[incomplete, FIXME]
 
-The Feta font provides musical symbols at six different sizes.  These
-fonts are 11 point, 13 point, 16 point, 20 point, 23 point, and 26
-point.  The point size of a font is the height of the five line staff
-when displayed in the font.
+description(
+  dit(code(Bar_engraver))indexcode(Bar_engraver) nl()
+    Engraves bar lines.  Normally in code(Staff) and
+    code(RhythmicStaff).
 
-Definitions for these sizes are the files file(paperSZ.ly), where
-code(SZ) is one of 11, 13, 16, 20, 23 and 26.  If you include any of
-these files, the identifiers code(paper_eleven), code(paper_thirteen),
-code(paper_sixteen), code(paper_twenty), code(paper_twentythree), and
-code(paper_twentysix) are defined respectively.  The default
-code(\paper) block is also set.
+  dit(code(Bar_number_engraver))indexcode(Bar_number_engraver) nl()
+    Engrave bar numbers.  These numbers appear at the start of each
+    line.  Not normally in any translator.  Can be added to
+    code(Score) for score-wide numbering or to code(Staff) for
+    numbering on each staff.
 
-To change the paper size, you must first set the code(papersize)
-variable at top level.  Set it to the strings code(a4),
-code(letter), or code(legal).  After this specification, you must set
-the font as described above.  If you want the default font, then use
-the 20 point font.  The new paper size will not take effect if the
-font is not loaded and selected afterwards.  Paper size selection
-works by loading a file named after the paper size you select.
+  dit(code(Beam_engraver))indexcode(Beam_engraver) nl()
+    Handles beam requests by engraving beams.  Normally appears in
+    the code(Voice) translator.  If omitted, then notes will be
+    printed with flags instead of beams.
 
+  dit(code(Beam_req_swallow_translator))
+    indexcode(Beam_req_swallow_translator) nl()
+    Swallows beam requests.  In code(LyricVoice).  
 
+  dit(code(Chord_name_engraver))indexcode(Chord_name_engraver) nl()
+    Engraves chord names.  Normally in code(ChordNameVoice) .
 
-subsect(Paper variables)cindex(Paper variables)
-label(papervars)
+  dit(code(Chord_tremolo_engraver))indexcode(Chord_tremolo_engraver)
 
-There are a large number of paper variables that are used to control
-details of the layout. These variables control the defaults for the
-entire score.  Usually, they do not have to be changed; they are 
-by default set to values that depend on the font size in use.  The values
-are used by the graphic objects while formatting the score; they are
-therefore implementation dependent.  Most variables are accompanied by
-documentation in the initalization file file(params.ly) or
-file(paperSZ.ly), where code(SZ) is the staff height in points.
+  dit(code(Clef_engraver))indexcode(Clef_engraver) nl()
+    Engraves the clef symbol.  Normally in code(Staff).
 
-Nevertheless, here are some variables  you may want to use or change:
+  dit(code(Collision_engraver))indexcode(Collision_engraver)
 
-description(
-dit(code(indent))indexcode(indent) The indentation of the first line of music.
+  dit(code(Dot_column_engraver))indexcode(Dot_column_engraver) nl()
+    Engraves dots on dotted notes shifted to the right of the note. 
+    Normally in code(Voice).  If omitted, then dots appear on top of
+    the notes.
 
-dit(code(interline))indexcode(interline) The distance between two
-staff lines, calculated from the center of the lines.  You should use
-either this or code(rulethickness) as a unit for distances you modify.
-  
-dit(code(linewidth))indexcode(linewidth) Sets the width of the
-lines.  If  set to -1.0, a single unjustified line is
-produced.
+  dit(code(Dynamic_engraver))indexcode(Dynamic_engraver) nl()
+    Engraves dynamics symbols.  Normally in code(Voice).
 
-dit(code(output))indexcode(output) Specifies an alternate name for
-the TeX() output.  A file(.tex) extension will be added to the string
-you specify.
+  dit(code(Font_size_engraver))indexcode(Font_size_engraver)
 
-dit(code(rulethickness))indexcode(rulethickness) Determines thickness of staff lines and bars. 
+  dit(code(Key_engraver))indexcode(Key_engraver) nl()
+    Engraves the key signature.  Normally in code(Staff).
 
-code(castingalgorithm)indexcode(castingalgorithm) The algorithm to use
-for breaking lines.  Choices are code(\Gourlay)keyindex(Gourlay) for a
-TeX() like dynamic programming algorithm, and
-code(\Wordwrap)keyindex(Wordwrap) for a simple algorithm.  Gourlay
-breaking looks much better, but takes a lot more resources.  Wordwrap
-leaves loosely spaced lines at the end
+  dit(code(Local_key_engraver))indexcode(Local_key_engraver)
 
-)
+  dit(code(Lyric_engraver))indexcode(Lyric_engraver) nl()
+    Engraves lyrics.  Normally in code(LyricVoice).
 
+  dit(code(Multi_measure_rest_engraver))
+    indexcode(Multi_measure_rest_engraver) nl()
+    Engraves multi-measure rests that are produced with code(R). 
+    Normally in code(Voice).
 
+  dit(code(Piano_bar_engraver))indexcode(Piano_bar_engraver)
 
-subsect(Context definitions)
-label(contextdefs)cindex(context definition)
+  dit(code(Pitch_squash_engraver))indexcode(Pitch_squash_engraver) nl()
+    Treat all pitches as middle C.  Used in code(RhythmicStaff). 
+    Note that the notes move, but the locations of accidentals stay
+    the same.
 
-A notation contexts is defined by the following information
+  dit(code(Priority_horizontal_align_engraver))
+    indexcode(Priority_horizontal_align_engraver)
 
-enumerate(
-it() a name
-it() The LilyPond modules that do the actual conversion of music to
-notation.   Each module is a so-called code(Engraver)cindex(Engraver).
-it() How these modules should cooperate, i.e. which ``cooperation
-module'' should be used.   This cooperation module is a special type
-of engraver. 
-it() what other contexts the context can contain,
-it() what properties are defined
-)
+  dit(code(Repeat_engraver))indexcode(Repeat_engraver) nl()
+    Handles repeats?  In code(Staff) and code(RhythmicStaff).
 
+  dit(code(Rest_collision_engraver))indexcode(Rest_collision_engraver) nl()
+    Handles collisions of rests.  In code(Staff).
 
-A context definition has this syntax: code(\translator
-{ )var(translatorinit) var(translatormodifierlist) code(}).
+  dit(code(Rest_engraver))indexcode(Rest_engraver) nl()
+    Engraves rests.  Normally in code(Voice).
 
-var(translatorinit) can be  an identifier, or code(\type
-)var(typename)code(;).   var(typename) is one of
-itemize(
-it() indexandcode(Engraver_group_engraver) the standard cooperation engraver.
-it() indexandcode(Score_engraver) this is cooperation module that should be
-  in the top level context.
-it() indexandcode(Grace_engraver_group) 
-  This is  a special cooperation module (resembling Score_engraver),
-  that is used to created an embedded `miniscore'
-) 
+  dit(code(Rhythmic_column_engraver))indexcode(Rhythmic_column_engraver)
 
-var(translatormodifierlist) is a list of items, where each item is one
-of
+  dit(code(Score_priority_engraver))indexcode(Score_priority_engraver)
 
-itemize(
-it() code(\consists) var(engravername)code(;)
-  Add var(engravername)  to the list of modules in  this
-  context. Section ref(engravers) contains an overview of the
-  engravers available.  The order of engravers added   with
-  code(\consists) is significant.
-  
-it() code(\consistsend) var(engravername)code(;)
-  Analogous to code(\consists), but makes sure that var(engravername)
-  is always added to the end of the list of engravers. 
+  dit(code(Script_engraver))indexcode(Script_engraver) nl()
+    Handles note ornaments generated by code(\script).  Normally in
+    code(Voice).
 
-    Some engraver types need to be at the end of the list; this
-    insures they are put there, and stay there, if a user adds or
-    removes engravers.  This command is usually not needed for
-    end-users.
+  dit(code(Separating_line_group_engraver))
+    indexcode(Separating_line_group_engraver)
 
+  dit(code(Skip_req_swallow_translator))
+    indexcode(Skip_req_swallow_translator)
 
-    
-it() code(\accepts) var(contextname)code(;)
-  Add var(contextname) to the list of  context this context can
-  contain.  The first listed context the context to create  by
-  default.
-  
-it() code(\remove) var(engravername)code(;) 
-  Remove a previously added (with code(\consists)) engraver
-  
-it() code(\name) var(contextname)code(;) This sets name of the
-  context, eg. code(Staff), code(Voice).  If the name is not
-  specified, the translator won't do anything.
+  dit(code(Slur_engraver))indexcode(Slur_engraver) nl()
+    Engraves slurs.  Normally in code(Voice).
 
-it()
-  var(propname)code(=)var(value)code(;) A property assignment.  It is
-  allowed to use reals for var(value)
+  dit(code(Span_bar_engraver))indexcode(Span_bar_engraver) nl()
+    Engraves lines across multiple staffs.  Normally in
+    code(Staffgroup) and code(GrandStaff).  Removing this from
+    code(StaffGroup) gives the definition of code(ChoirStaff).
 
-)
+  dit(code(Span_score_bar_engraver))indexcode(Span_score_bar_engraver)
 
+  dit(code(Staff_group_bar_engraver))indexcode(Staff_group_bar_engraver)
 
-In the code(\paper) block, it is also possible to define translator
-identifiers.  Like other block identifiers, the identifier can only
-be used as the very first item of a translator.  In order to define
-such an identifier outside of code(\score), you must do
-verb(
-\paper{ foo=\translator{ ... } }
-\score{
-  \notes{ ... }
-  \paper{ \translator{ \foo ... } }
-})
+  dit(code(Staff_margin_engraver))indexcode(Staff_margin_engraver) nl()
+    Prints the name of the instrument (specified by
+    code(Staff.instrument) and code(Staff.instr)) at the left of the
+    staff.
 
-subsubsect(Paper Types and Engravers and Pre-defined Translators)cindex(Paper Types and Engravers and Pre-defined Translators)
+  dit(code(Staff_sym_engraver))indexcode(Staff_sym_engraver)
 
-Some pre-defined identifiers can simplify modification of translators.
-The pre-defined identifiers are:  
-description(
-dit(code(StaffContext))indexcode(StaffContext)
-Default Staff  context. 
-dit(code(RhythmicStaffContext))indexcode(RhythmicStaffContext)
-Default RhythmicStaff  context. 
-dit(code(VoiceContext))indexcode(VoiceContext)
-  Default Voice  context.  
-dit(code(ScoreContext))indexcode(ScoreContext)
-  Default  Score context. 
-dit(code(ScoreWithNumbers))indexcode(ScoreWithNumbers)
-  Score context with numbering at the Score level.   
-
-dit(code(BarNumberingStaffContext))indexcode(BarNumberingStaffContext)
-  Staff context with numbering at the Staff level.
-
-dit(code(HaraKiriStaffContext))indexcode(HaraKiriStaffContext)
-  Staff context that does not print if it only contains rests.  Useful for
-  orchestral scores.footnote(Hara kiri is the ritual suicide of the Samourai)
-dit(code(OrchestralPartStaffContext))indexcode(OrchestralPartStaffContext)
-dit(code(OrchestralScoreContext))indexcode(OrchestralScoreContext)
-)
-
-Using these pre-defined values, you can remove  or add items to the
-translator verb(\paper{ \translator{ \StaffContext
-                     \remove Some_engraver;
-                     \consists Different_engraver;  }})
-      
+  dit(code(Stem_engraver))indexcode(Stem_engraver) nl()
+    Engraves stems.  Normally in code(Voice).
 
-subsubsect(Engravers)
-label(engravers)
+  dit(code(Ties_engraver))indexcode(Ties_engraver) nl()
+    Engraves ties.  Normally in code(Voice).
 
+  dit(code(Time_signature_engraver))indexcode(Time_signature_engraver) nl()
+    Engraves the time signature.  Normally in code(Staff) and
+    code(RhythmicStaff).
 
-The engravers for paper output are:
+  dit(code(Timing_engraver))indexcode(Timing_engraver) nl()
+    Responsible for synchronizing timing information from staffs. 
+    Normally in code(Score).  In order to create polyrhythmic music,
+    this engraver should be removed from code(Score) and placed in
+    code(Staff).
 
-[incomplete, FIXME]
+  dit(code(Tuplet_engraver))indexcode(Tuplet_engraver) nl()
+    Engraves tuplet brackets?  In code(Staff).
 
-description(
-dit(code(Bar_engraver))indexcode(Bar_engraver) Engraves bar lines.  Normally in code(Staff) and
-code(RhythmicStaff).  
-dit(code(Bar_number_engraver))indexcode(Bar_number_engraver) Engrave bar numbers.  These numbers
-appear at the start of each line.  Not normally in any translator.  Can
-be added to code(Score) for Score-wide numbering or to code(Staff) for
-numbering on each staff.  
-
-dit(code(Beam_engraver))indexcode(Beam_engraver) Handles beam requests by engraving beams.  Normally
-appears in the code(Voice) translator.  If omitted, then notes will be printed
-with flags instead of beams.
-
-dit(code(Beam_req_swallow_translator))indexcode(Beam_req_swallow_translator) Swallows beam requests.  In
-code(LyricVoice).  
-dit(code(Chord_name_engraver))indexcode(Chord_name_engraver) Engraves chord names.  Normally in
-code(ChordNameVoice) 
-dit(code(Chord_tremolo_engraver))indexcode(Chord_tremolo_engraver)
-dit(code(Clef_engraver))indexcode(Clef_engraver) Engraves the clef symbol.  Normally in code(Staff).
-dit(code(Collision_engraver))indexcode(Collision_engraver)
-dit(code(Dot_column_engraver))indexcode(Dot_column_engraver) Engraves dots on dotted notes shifted to the
-right of the note.  Normally in code(Voice).  If omitted, then dots appear on
-top of the notes.  
-dit(code(Dynamic_engraver))indexcode(Dynamic_engraver) Engraves dynamics symbols.  Normally in code(Voice).
-dit(code(Font_size_engraver))indexcode(Font_size_engraver)
-dit(code(Key_engraver))indexcode(Key_engraver) Engraves the key signature.  Normally in code(Staff).
-dit(code(Local_key_engraver))indexcode(Local_key_engraver)
-dit(code(Lyric_engraver))indexcode(Lyric_engraver) Engraves lyrics.  Normally in code(LyricVoice).
-dit(code(Multi_measure_rest_engraver))indexcode(Multi_measure_rest_engraver) Engraves multi-measure rests that are
-produced with code(R).  Normally in code(Voice).
-dit(code(Piano_bar_engraver))indexcode(Piano_bar_engraver)
-dit(code(Pitch_squash_engraver))indexcode(Pitch_squash_engraver) Treat all pitches as middle C.  Used in
-code(RhythmicStaff).  Note that the notes move, but the locations of
-accidentals stay the same. 
-dit(code(Priority_horizontal_align_engraver))indexcode(Priority_horizontal_align_engraver)
-dit(code(Repeat_engraver))indexcode(Repeat_engraver) Handles repeats? In code(Staff) and 
-   code(RhythmicStaff).
-dit(code(Rest_collision_engraver))indexcode(Rest_collision_engraver) Handles collisions of rests. In code(Staff).
-dit(code(Rest_engraver))indexcode(Rest_engraver) Engraves rests.  Normally in code(Voice).
-dit(code(Rhythmic_column_engraver))indexcode(Rhythmic_column_engraver)
-dit(code(Score_priority_engraver))indexcode(Score_priority_engraver)
-dit(code(Script_engraver))indexcode(Script_engraver) Handles note ornaments generated by code(\script).
-Normally in code(Voice).  
-dit(code(Separating_line_group_engraver))indexcode(Separating_line_group_engraver)
-dit(code(Skip_req_swallow_translator))indexcode(Skip_req_swallow_translator)
-dit(code(Slur_engraver))indexcode(Slur_engraver) Engraves slurs.  Normally in code(Voice).
-dit(code(Span_bar_engraver))indexcode(Span_bar_engraver) Engraves lines across multiple staffs.  Normally
-in code(Staffgroup) and code(GrandStaff).  Removing this from code(StaffGroup)
-gives the definition of code(ChoirStaff).  
-dit(code(Span_score_bar_engraver))indexcode(Span_score_bar_engraver)
-dit(code(Staff_group_bar_engraver))indexcode(Staff_group_bar_engraver)
-dit(code(Staff_margin_engraver))indexcode(Staff_margin_engraver) Prints the name of the instrument
-(specified by code(Staff.instrument) and code(Staff.instr)) at the
-left of the staff.  
-dit(code(Staff_sym_engraver))indexcode(Staff_sym_engraver)
-dit(code(Stem_engraver))indexcode(Stem_engraver) Engraves stems.  Normally in code(Voice).
-dit(code(Ties_engraver))indexcode(Ties_engraver) Engraves ties.  Normally in code(Voice).
-dit(code(Time_signature_engraver))indexcode(Time_signature_engraver) Engraves the time signature.  Normally in
-code(Staff) and code(RhythmicStaff).
-dit(code(Timing_engraver))indexcode(Timing_engraver) Responsible for synchronizing timing information
-from staffs.  Normally in code(Score).  In order to create polyrhythmic music,
-this engraver should be removed from code(Score) and placed in code(Staff).
-dit(code(Tuplet_engraver))indexcode(Tuplet_engraver) Engraves tuplet brackets?  In code(Staff).
-dit(code(Vertical_align_engraver))indexcode(Vertical_align_engraver) 
+  dit(code(Vertical_align_engraver))indexcode(Vertical_align_engraver) 
 )
 
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
 sect(Sound output)
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
 subsect(output definition)
 
 The MIDI block is analogous to the paper block, but it is simpler.
 The code(\midi) block can contain:cindex(MIDI block)
 
 itemize(
-it() a  code(\tempo) definition.
-it() context definitions
+  it() a code(\tempo) definition
+  it() context definitions
 )
 
 Assignments in the code(\midi) block are not allowed.
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(Context definitions) cindex(context definitions)
+subsect(Context definitions)
+cindex(context definition)
 
-Context definitions follow the precisely the same syntax as within the
+Context definitions follow precisely the same syntax as within the
 \paper block.  Translation modules for sound are called performers.
 The contexts for MIDI output are defined in file(ly/performer.ly).
 
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
 
-subsect(MIDI Instrument Names)cindex(MIDI Instrument Names)
+subsect(MIDI Instrument Names)
+cindex(MIDI instrument names)
 label(midilist)
 
-The MIDI instrument name is set by the indexandcode(Staff.midiInstrument)
-property or, if that property is not set, the indexandcode(Staff.instrument)
-property.  The instrument name should be chosen from this list.  If
-string does not exactly match one from this list then LilyPond uses
-the default piano.
+The MIDI instrument name is set by the
+indexandcode(Staff.midiInstrument) property or, if that property is
+not set, the indexandcode(Staff.instrument) property.  The instrument
+name should be chosen from the following list.  If the selected
+string does not exactly match, then LilyPond uses the default piano.
 
 COMMENT( acordina = accordion, tango accordian = concertina
          distortion guitar = distorted guitar
          orchestral strings = harp 
          pan flute = wood flute? )
 
-verb("acoustic grand"               "contrabass"             "lead 7 (fifths)"
-"bright acoustic"              "tremolo strings"        "lead 8 (bass+lead)"
-"electric grand"               "pizzicato strings"      "pad 1 (new age)"
-"honky-tonk"                   "orchestral strings"     "pad 2 (warm)"
-"electric piano 1"             "timpani"                "pad 3 (polysynth)"
-"electric piano 2"             "string ensemble 1"      "pad 4 (choir)"
-"harpsichord"                  "string ensemble 2"      "pad 5 (bowed)"
-"clav"                         "synthstrings 1"         "pad 6 (metallic)"
-"celesta"                      "synthstrings 2"         "pad 7 (halo)"
-"glockenspiel"                 "choir aahs"             "pad 8 (sweep)"
-"music box"                    "voice oohs"             "fx 1 (rain)"
-"vibraphone"                   "synth voice"            "fx 2 (soundtrack)"
-"marimba"                      "orchestra hit"          "fx 3 (crystal)"
-"xylophone"                    "trumpet"                "fx 4 (atmosphere)"
-"tubular bells"                "trombone"               "fx 5 (brightness)"
-"dulcimer"                     "tuba"                   "fx 6 (goblins)"
-"drawbar organ"                "muted trumpet"          "fx 7 (echoes)"
-"percussive organ"             "french horn"            "fx 8 (sci-fi)"
-"rock organ"                   "brass section"          "sitar"
-"church organ"                 "synthbrass 1"           "banjo"
-"reed organ"                   "synthbrass 2"           "shamisen"
-"accordion"                    "soprano sax"            "koto"
-"harmonica"                    "alto sax"               "kalimba"
-"concertina"                   "tenor sax"              "bagpipe"
-"acoustic guitar (nylon)"      "baritone sax"           "fiddle"
-"acoustic guitar (steel)"      "oboe"                   "shanai"
-"electric guitar (jazz)"       "english horn"           "tinkle bell"
-"electric guitar (clean)"      "bassoon"                "agogo"
-"electric guitar (muted)"      "clarinet"               "steel drums"
-"overdriven guitar"            "piccolo"                "woodblock"
-"distorted guitar"             "flute"                  "taiko drum"
-"guitar harmonics"             "recorder"               "melodic tom"
-"acoustic bass"                "pan flute"              "synth drum"
-"electric bass (finger)"       "blown bottle"           "reverse cymbal"
-"electric bass (pick)"         "skakuhachi"             "guitar fret noise"
-"fretless bass"                "whistle"                "breath noise"
-"slap bass 1"                  "ocarina"                "seashore"
-"slap bass 2"                  "lead 1 (square)"        "bird tweet"
-"synth bass 1"                 "lead 2 (sawtooth)"      "telephone ring"
-"synth bass 2"                 "lead 3 (calliope)"      "helicopter"
-"violin"                       "lead 4 (chiff)"         "applause"
-"viola"                        "lead 5 (charang)"       "gunshot"
-"cello"                        "lead 6 (voice)")
-
-
-subsubsect(MIDI Types and Performers)cindex(MIDI Types and Performers)
+quote(
+verb("acoustic grand"            "contrabass"           "lead 7 (fifths)"
+"bright acoustic"           "tremolo strings"      "lead 8 (bass+lead)"
+"electric grand"            "pizzicato strings"    "pad 1 (new age)"
+"honky-tonk"                "orchestral strings"   "pad 2 (warm)"
+"electric piano 1"          "timpani"              "pad 3 (polysynth)"
+"electric piano 2"          "string ensemble 1"    "pad 4 (choir)"
+"harpsichord"               "string ensemble 2"    "pad 5 (bowed)"
+"clav"                      "synthstrings 1"       "pad 6 (metallic)"
+"celesta"                   "synthstrings 2"       "pad 7 (halo)"
+"glockenspiel"              "choir aahs"           "pad 8 (sweep)"
+"music box"                 "voice oohs"           "fx 1 (rain)"
+"vibraphone"                "synth voice"          "fx 2 (soundtrack)"
+"marimba"                   "orchestra hit"        "fx 3 (crystal)"
+"xylophone"                 "trumpet"              "fx 4 (atmosphere)"
+"tubular bells"             "trombone"             "fx 5 (brightness)"
+"dulcimer"                  "tuba"                 "fx 6 (goblins)"
+"drawbar organ"             "muted trumpet"        "fx 7 (echoes)"
+"percussive organ"          "french horn"          "fx 8 (sci-fi)"
+"rock organ"                "brass section"        "sitar"
+"church organ"              "synthbrass 1"         "banjo"
+"reed organ"                "synthbrass 2"         "shamisen"
+"accordion"                 "soprano sax"          "koto"
+"harmonica"                 "alto sax"             "kalimba"
+"concertina"                "tenor sax"            "bagpipe"
+"acoustic guitar (nylon)"   "baritone sax"         "fiddle"
+"acoustic guitar (steel)"   "oboe"                 "shanai"
+"electric guitar (jazz)"    "english horn"         "tinkle bell"
+"electric guitar (clean)"   "bassoon"              "agogo"
+"electric guitar (muted)"   "clarinet"             "steel drums"
+"overdriven guitar"         "piccolo"              "woodblock"
+"distorted guitar"          "flute"                "taiko drum"
+"guitar harmonics"          "recorder"             "melodic tom"
+"acoustic bass"             "pan flute"            "synth drum"
+"electric bass (finger)"    "blown bottle"         "reverse cymbal"
+"electric bass (pick)"      "skakuhachi"           "guitar fret noise"
+"fretless bass"             "whistle"              "breath noise"
+"slap bass 1"               "ocarina"              "seashore"
+"slap bass 2"               "lead 1 (square)"      "bird tweet"
+"synth bass 1"              "lead 2 (sawtooth)"    "telephone ring"
+"synth bass 2"              "lead 3 (calliope)"    "helicopter"
+"violin"                    "lead 4 (chiff)"       "applause"
+"viola"                     "lead 5 (charang)"     "gunshot"
+"cello"                     "lead 6 (voice)")
+)
+
+subsubsect(MIDI Types and Performers)
+cindex(MIDI types and performers)
 
 The types available for  MIDI translators are:
+
 description(
-dit(code(Performer_group_performer))indexcode(Performer_group_performer)
-dit(code(Score_performer))indexcode(Score_performer)
-dit(code(Staff_performer))indexcode(Staff_performer)
+  dit(code(Performer_group_performer))indexcode(Performer_group_performer)
+  dit(code(Score_performer))indexcode(Score_performer)
+  dit(code(Staff_performer))indexcode(Staff_performer)
 )
 
 The performers for MIDI translators are:
+
 description(
-dit(code(Key_performer))indexcode(Key_performer)
-dit(code(Time_signature_performer))indexcode(Time_signature_performer)
-dit(code(Note_performer))indexcode(Note_performer)
-dit(code(Lyric_performer))indexcode(Lyric_performer)
-dit(code(Swallow_performer))indexcode(Swallow_performer)
+  dit(code(Key_performer))indexcode(Key_performer)
+  dit(code(Time_signature_performer))indexcode(Time_signature_performer)
+  dit(code(Note_performer))indexcode(Note_performer)
+  dit(code(Lyric_performer))indexcode(Lyric_performer)
+  dit(code(Swallow_performer))indexcode(Swallow_performer)
 )
 
 
-sect(Pre-defined Identifiers)cindex(Pre-defined Identifiers)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+sect(Pre-defined Identifiers)
+cindex(pre-defined identifiers)
 label(ident)
 
 Various identifiers are defined in the initialization files to
-provide shorthands for some settings.  Most of them are in file(ly/declarations.ly).
+provide shorthands for some settings.  Most of them are in
+file(ly/declarations.ly).
 
 description(
-dit(code(\break))keyindex(break) Force a line break in music by using a large
-argument for the keyword code(\penalty). 
-dit(code(\center))keyindex(center) Used for setting direction  properties.  Equals 0.
-dit(code(\down))keyindex(down) Used for setting direction setting properties.  Is
-equal to -1.  
-dit(code(\free))keyindex(free) Used for setting direction setting properties.  Is
-equal to 0.  
-dit(code(\left))keyindex(left) Used for setting textalignment property.  Is equal to -1.
-dit(code(\nobreak))keyindex(nobreak) Prevent a line break in music by using a large
-negative argument for the keyword code(\penalty). 
-dit(code(\none))keyindex(none) Used for setting code(Score.beamslopedamping) and
-code(Score.beamquantisation) properties.  Is equal to 0.
-dit(code(\normal))keyindex(normal) Used for setting code(Score.beamslopedamping) and
-code(Score.beamquantisation) properties.  Is equal to 1.
-dit(code(\normalkey))keyindex(normalkey) Select normal key signatures where each octave
-has the same key signature.  This sets the code(Staff.keyoctaviation) property.
-dit(code(\right))keyindex(right) Used for setting textalignment property.  Is set to 1.
-dit(code(\shiftoff))keyindex(shiftoff) Disable horizontal shifting of note heads that collide.  
-Sets the code(Voice.horizontalNoteShift) property.
-dit(code(\shifton))keyindex(shifton) Enable note heads that collide with other note heads
-to be shifted horiztonally.  Sets the code(Voice.horizontalNoteShift) property.
-dit(code(\slurboth))keyindex(slurboth) Allow slurs to be above or below notes.  This
-sets the code(Voice.slurVerticalDirection) property. 
-dit(code(\slurdown))keyindex(slurdown) Force slurs to be below notes. This sets the
-code(Voice.slurVerticalDirection) property. 
-dit(code(\slurup))keyindex(slurup) Force slurs to be above notes.  This sets the
-code(Voice.slurVerticalDirection) property.  
-dit(code(\specialkey))keyindex(specialkey) Allow keys signatures do differ in different
-octaves.  This sets the code(Staff.keyoctaviation) property.  
-dit(code(\stemboth))keyindex(stemboth) Allow stems, beams, and slurs to point either
-direction.  This sets the code(Voice.verticalDirection) property. 
-dit(code(\stemdown))keyindex(stemdown) Force stems, beams, and slurs to point down.
-This sets the code(Voice.verticalDirection) property. 
-dit(code(\stemup))keyindex(stemup) Force stems, beams and slurs to point up.  This
-sets the code(Voice.verticalDirection) property. 
-dit(code(\traditional))keyindex(traditional) Used for setting the 
-code(Score.beamquantisation) property.  Is equal to 2.  
-dit(code(\up))keyindex(up) Used for setting various direction properties.  Is
-equal to 1. 
-)
-
-
-
-sect(Running LilyPond)cindex(Running LilyPond)
+  dit(code(\break))keyindex(break) nl()
+    Force a line break in music by using a large argument for the
+    keyword code(\penalty).
+
+  dit(code(\center))keyindex(center) nl()
+    Used for setting direction  properties.  bind(Equals)0.
+
+  dit(code(\down))keyindex(down) nl()
+    Used for setting direction setting properties.  Is equal
+    bind(to)-1.
+
+  dit(code(\free))keyindex(free) nl()
+    Used for setting direction setting properties.  Is equal
+    bind(to)0.
+
+  dit(code(\left))keyindex(left) nl()
+    Used for setting text alignment property.  Is equal bind(to)-1.
+
+  dit(code(\nobreak))keyindex(nobreak) nl()
+    Prevent a line break in music by using a large negative argument
+    for the keyword code(\penalty).
+
+  dit(code(\none))keyindex(none) nl()
+    Used for setting code(Score.beamslopedamping) and
+    code(Score.beamquantisation) properties.  Is equal bind(to)0.
+
+  dit(code(\normal))keyindex(normal) nl()
+    Used for setting code(Score.beamslopedamping) and
+    code(Score.beamquantisation) properties.  Is equal bind(to)1.
+
+  dit(code(\normalkey))keyindex(normalkey) nl()
+    Select normal key signatures where each octave has the same key
+    signature.  This sets the code(Staff.keyoctaviation) property.
+
+  dit(code(\right))keyindex(right) nl()
+    Used for setting text alignment property.  Is set bind(to)1.
+
+  dit(code(\shiftoff))keyindex(shiftoff) nl()
+    Disable horizontal shifting of note heads that collide.  Sets the
+    code(Voice.horizontalNoteShift) property.
+
+  dit(code(\shifton))keyindex(shifton) nl()
+    Enable note heads that collide with other note heads to be
+    shifted horiztonally.  Sets the code(Voice.horizontalNoteShift)
+    property.
+
+  dit(code(\slurboth))keyindex(slurboth) nl()
+    Allow slurs to be above or below notes.  This sets the
+    code(Voice.slurVerticalDirection) property.
+
+  dit(code(\slurdown))keyindex(slurdown) nl()
+    Force slurs to be below notes.  This sets the
+    code(Voice.slurVerticalDirection) property.
+
+  dit(code(\slurup))keyindex(slurup) nl()
+    Force slurs to be above notes.  This sets the
+    code(Voice.slurVerticalDirection) property.
+
+  dit(code(\specialkey))keyindex(specialkey) nl()
+    Allow key signatures do differ in different octaves.  This sets
+    the code(Staff.keyoctaviation) property.
+
+  dit(code(\stemboth))keyindex(stemboth) nl()
+    Allow stems, beams, and slurs to point either upwards or
+    downwards, decided automatically by LilyPond.  This sets the
+    code(Voice.verticalDirection) property.
+
+  dit(code(\stemdown))keyindex(stemdown) nl()
+    Force stems, beams, and slurs to point down.  This sets the
+    code(Voice.verticalDirection) property.
+
+  dit(code(\stemup))keyindex(stemup) nl()
+    Force stems, beams and slurs to point up.  This sets the
+    code(Voice.verticalDirection) property.
+
+  dit(code(\traditional))keyindex(traditional) nl()
+    Used for setting the code(Score.beamquantisation) property.  Is
+    equal bind(to)2.
+
+  dit(code(\up))keyindex(up) nl()
+    Used for setting various direction properties.  Is equal
+    bind(to)1.
+)
+
+
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+COMMENT(%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%)
+
+sect(Running LilyPond)
+cindex(running LilyPond)
 
 
 When invoked with a filename that has no extension, LilyPond will try
-adding a file(.ly) extension first, then a file(.sly) and then a
-file(.ly) extension second.  If the filename ends with file(.fly),
-LilyPond processes the file as music using file(init.fly).  In this
-case, LilyPond does something like: COMMENT(
+adding `file(.ly)' as an extension first, then `file(.fly)' and
+finally `file(.sly)' extension.  If the filename ends with
+`file(.fly)', LilyPond processes the file as music using
+`file(init.fly)'.  In this case, LilyPond does something like:
 
-)verb(\score {
+quote(
+verb(\score {
   \notes\relative c {
     \input "yourfile.fly"
   }
   \paper{}
   \midi{}
 })
-If you invoke LilyPond with a file file(foo.)var(ext) that doesn't
-have the file(.ly) extension then LilyPond will look for a file called
-file(init.)var(ext) and process this file.  The file
-file(init.)var(ext) must contain the code(\maininput) keyword or LilyPond
-will not read the user specified file.
+)
+The result of `file(.sly)' is similar except that a single unjustified
+line is produced.
+
+If you invoke LilyPond with a file `file(foo.)var(ext)' that doesn't
+have the `file(.ly)' extension, then LilyPond will look for a file
+called `file(init.)var(ext)' and process this file.  The file
+`file(init.)var(ext)' must contain the code(\maininput) keyword or
+LilyPond will not read the user specified file.
 
 When LilyPond processes file(filename.ly) it will produce
 file(filename.tex) as output.  If file(filename.ly) contains a second
 code(\paper) keyword, then LilyPond will produce file(filename-1.tex)
-as well.  Subsequent code(\paper) keywords will produces sequentially
+as well.  Subsequent code(\paper) keywords will produce sequentially
 numbered file names.  Several files can be specified; they will each
-be processed independently.footnote(Not entirely true: the status of
-GUILE is kept).
+be processed independently.footnote(Not entirely true: The status of
+GUILE is kept.)
 
+whenlatex(latexcommand(\printindex))
 
-whenlatex(
-latexcommand(\printindex)
-)
+COMMENT(End of reference-manual.yo)
index 4f0d662ec9f6fda424cd4a00c79da8e0b8a25813..5d5c11bac0b6f4ca73851447613418ae8e3fac38 100644 (file)
@@ -102,9 +102,9 @@ mudela(verbatim)(% lines preceded by a percent are comments.
 \include "paper16.ly"
 \score {
     \notes                        
-    \relative c'' {                
-            \key g;
+    \relative c'' \sequential{                
             \time 3/4;                
+            \key g;
 
         \repeat "volta" 2 {
             d4 g,8 a b c d4 g, g |
@@ -245,7 +245,7 @@ note is code(d'').  The code(4) designates the duration of the note
         a b
 )COMMENT(
 
-)These are notes with pitch code(a') and code(b').  Because their
+)These are notes with pitch code(a) and code(b).  Because their
 duration is the same as the code(g), there is no need to enter the
 duration (You may enter it anyway, eg. code(a4 b4)) COMMENT(
 
@@ -256,13 +256,8 @@ duration (You may enter it anyway, eg. code(a4 b4)) COMMENT(
 ) Three more notes.  The `code(|)' character is a `barcheck'.  When
 processing the music, LilyPond will verify that barchecks are found at
 the start of a measure.  This can help you track down errors.
-COMMENT(
-
-)verb(
-        e'4 
-) COMMENT(
 
-) So far, no notes were chromatically altered.  Here is the first one
+ So far, no notes were chromatically altered.  Here is the first one
 that is: code(fis). Mudela by default uses Dutch note names, and
 ``Fis'' is the Dutch note name for ``F sharp''.  However, there is no
 sharp sign in the output. The program keeps track of key signatures,
@@ -511,14 +506,14 @@ assignment is finished with a semicolon.COMMENT(
 
 )The structure of the file will be the same as the previous one, a
 code(\score) block with music in it.  To keep things readable, we will
-give the different parts of music names, and use names to construct
-music within the score block.
+give names to the different parts of music, and use the names to
+construct the music within the score block.
 
 verb(
         \partial 8;
 )
 
-The piece starts an anacrusis of one eighth.  COMMENT(
+The piece starts with an anacrusis of one eighth.  COMMENT(
 
 )verb(
         c4 c8 d [es () d] c4 | f4 f8 g [es() d] c g |
@@ -824,7 +819,7 @@ chord.  code(\f) places a forte symbol  under the chord.COMMENT(
 controls the directions of stems, articulations marks and other
 symbols.
   If code(verticalDirection) is set to code(\down)
-(identifier for the integer -1) the stems go down
+(identifier for the integer -1) the stems go down,
 code(\up) (identifier for the integer 1) makes the stems go up.COMMENT(
 
 )verb(        g'8. b,16)COMMENT(
@@ -837,7 +832,7 @@ note of the previous chord (the central C).
 verb(s1 s2. r4)COMMENT(
 
 )code(s) is a `spacer' rest.  It does not print anything,  but it does
-have duration of a rest.   COMMENT(
+have the duration of a rest.   COMMENT(
 
 )verb(oboes = \notes \relative c'' \context Voice = oboe {)COMMENT(
 
index f1ae153a05385db23f500a604527d9075a51c648..59eace9b6fd93a79f8dbe9a2ad6f052f481d8701 100644 (file)
@@ -1,5 +1,5 @@
 
-      INSTALL - compiling and installing GNU LilyPond
+       NSTALL - compiling and installing GNU LilyPond
 
                          HWN & JCN
 
@@ -16,24 +16,25 @@ Contents
 9: REDHAT LINUX
 10: DEBIAN GNU/LINUX
 11: WINDOWS NT/95
-12: AUTHORS
+12: BUGS
+13: AUTHORS
 
 1: ABSTRACT
 
-This  document  explains  what you need to install LilyPond,
-and what you should do.  If you are  going  to  compile  and
-install  LilyPond  often,  e.g.  when doing development, you
+This document explains what you need to install LilyPond,
+and what you should do.  If you are going to compile and
+install LilyPond often, e.g. when doing development, you
 might want to check out the buildscripts/set-lily.sh script.
 It sets some environment variables and symlinks, which comes
 in handly when you have to compile LilyPond more often.
 
 2: OBTAINING
 
-You  can   get   the   latest   version   of   LilyPond   at
-ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/.   Refer  to  the links
+You can get the latest version of LilyPond at
+ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/.  Refer to the links
 document for mirror sites.
 
-If you upgrade by patching do  remember  to  rerun  autoconf
+If you upgrade by patching do remember to rerun autoconf
 after applying the patch.
 
 3: PREREQUISITES
@@ -41,12 +42,12 @@ after applying the patch.
 For compilation you need:
 
 o    A GNU system: GNU LilyPond is known to run on these GNU
-     systems: Linux (PPC, intel),  FreeBSD,  AIX,  NeXTStep,
+     systems: Linux (PPC, intel), FreeBSD, AIX, NeXTStep,
      IRIX, Digital Unix and Solaris.
 
-o    Lots  of  disk space: LilyPond takes between 30 and 100
+o    Lots of disk space: LilyPond takes between 30 and 100
      mb to compile if you use debugging information.  If you
-     are  short  on disk-space run configure with --disable-
+     are short on disk-space run configure with --disable-
      debugging.
 
      Although we recommend to use Unix, LilyPond is known to
@@ -54,88 +55,102 @@ o    Lots  of  disk space: LilyPond takes between 30 and 100
 
 o    EGCS 1.1 or newer.
 
-o    Python   1.5,   Check   out   ftp://ftp.python.org   or
+o    Python 1.5, Check out ftp://ftp.python.org or
      ftp://ftp.cwi.nl/pub/python.
 
-o    GUILE   1.3,    check   out    http://www.gnu.org/soft-
+o    GUILE 1.3,  check out http://www.gnu.org/soft-
      ware/guile/guile.html.
 
 o    GNU make.  Check out ftp://ftp.gnu.org.
 
-o    Flex    (version    2.5.4   or   newer).    Check   out
+o    Flex (version 2.5.4 or newer).  Check out
      ftp://ftp.gnu.org.
 
-o    Bison   (version   1.25   or   newer).     Check    out
+o    Bison (version 1.25 or newer).  Check out
      ftp://ftp.gnu.org.
 
-o    Yodl.   All  documentation  will  be in Yodl. (1.30.17)
-     ftp://ftp.lilypond.org/pub/yodl
+o    Yodl.  All documentation will be in Yodl. (1.31.15)
+     ftp://ftp.lilypond.org/pub/yodl. You need the latest
+     version of YODL, because the tutorial will trigger a
+     bug in earlier versions.
 
 o    The geometry package for LaTeX is needed to use ly2dvi.
-     Available           at          ftp://ftp.ctan.org/tex-
-     archive/macros/latex/contrib/supported/geometry  or  at
+     Available at ftp://ftp.ctan.org/tex-
+     archive/macros/latex/contrib/supported/geometry or at
      mirror site ftp://ftp.dante.de
 
-o    MetaPost,  if you want to use direct PostScript output.
-     Please note  that  tetex-0.4pl8 (included  with  Redhat
-     5.x)  does not include mfplain.mp, which is needed  for
+o    MetaPost, if you want to use direct PostScript output.
+     Please note  that  tetex-0.4pl8 (included with Redhat
+     5.x) does not include mfplain.mp, which is needed  for
      producing the scaleable font files.
 
 4: RUNNING
 
-GNU LilyPond does use a lot of resources. For operation  you
+GNU LilyPond does use a lot of resources. For operation you
 need the following software
 
 o    TeX
 
-o    A   PostScript   printer   and/or   viewer   (such   as
-     Ghostscript) is strongly recommended.  Xdvi  will  show
-     all  embedded  PostScript  too  if you have Ghostscript
+o    A PostScript printer and/or viewer (such as
+     Ghostscript) is strongly recommended.  Xdvi will show
+     all embedded PostScript too if you have Ghostscript
      installed.
 
-o    GUILE   1.3,    check    out    http://www.gnu.org/pro-
+o    GUILE 1.3, check out http://www.gnu.org/pro-
      grams/guile.html
 
-For  running  LilyPond successfully you have to help TeX and
-MetaFont find various files.  The recommended way  of  doing
-so  is  adjusting  the environment variables in the start-up
-scripts of your shell.  An example is  given  here  for  the
+For running LilyPond successfully you have to help TeX and
+MetaFont find various files.  The recommended way of doing
+so is adjusting the environment variables in the start-up
+scripts of your shell.  An example is given here for the
 Bourne shell:
 
      export MFINPUTS="/usr/local/share/lilypond/mf:"
      export TEXINPUTS="/usr/local/share/lilypond/tex:/usr/local/share/lilypond/ps:"
 
-The  empty path component represents  and MetaFont's default
-search paths.  Scripts with the proper paths for the  bourne
-and   C-shell   respectively   are   generated   in   build-
-scripts/out/lilypond-profile and  buildscripts/out/lilypond-
+The empty path component represents  and MetaFont's default
+search paths.  Scripts with the proper paths for the bourne
+and C-shell respectively are generated in build-
+scripts/out/lilypond-profile and buildscripts/out/lilypond-
 login during compilation.
 
-LilyPond  is  a hiddeously big, slow and bloated program.  A
-fast CPU and plenty of RAM is  recommended  for  comfortable
+LilyPond is a hiddeously big, slow and bloated program.  A
+fast CPU and plenty of RAM is recommended for comfortable
 use.
 
 5: WEBSITE
 
-If  you  want  to  auto-generate Lily's website, you'll need
+The website is the most convenient form to use for reading
+the documentation on-line documentation. It is made by
+entering
+
+       make website
+
+This does require a fully functioning
+
+If you want to auto-generate Lily's website, you'll need
 some additional conversion tools.
 
+o    YODL 1.31.15 or later.
+
 o    xpmtoppm (from the Portable Bitmap Utilities) (For Red-
-     Hat  Linux  users:  it  is  included within the package
-     libgr-progs).  the original is at  ftp://ftp.x.org/con-
+     Hat Linux users: it is included within the package
+     libgr-progs).  the original is at ftp://ftp.x.org/con-
      trib/utilities/netpbm-1mar1994.p1.tar.gz
 
-o    pnmtopng,  which is also in libgr-progs for RedHat. The
-     original                     is                      at
+o    pnmtopng, which is also in libgr-progs for RedHat. The
+     original is at
      ftp://swrinde.nde.swri.edu/pub/png/applications/pnm-
      topng-2.37.2.tar.gz.i
 
      The version of pnmtopng that is distributed with RedHat
-     5.1  and  5.2  contains  a bug: pnmtopng is dynamically
-     linked to the wrong version of  libpng.   Recompile  it
-     from  source, and make sure that the pnmtopng binary is
-     linked statically to the libpng  that  is  included  in
-     libgr.  RedHat 6.0 does not have this problem.
+     5.1 and 5.2 contains a bug: pnmtopng is dynamically
+     linked to the wrong version of libpng, which results in
+
+     cropped images.  Recompile it from source, and make
+     sure that the pnmtopng binary is linked statically to
+     the libpng that is included in libgr.  RedHat 6.0 does
+     not have this problem.
 
            tar xzf libgr-2.0.13.tar.gz
                 make
@@ -143,19 +158,21 @@ o    pnmtopng,  which is also in libgr-progs for RedHat. The
                 rm libpng.so*
                 make pnmtopng
 
-     You   can   then   install   the   new   pnmtopng  into
+     You can then install the new pnmtopng into
      /usr/local/bin/
 
 o    Bib2html http://pertsserver.cs.uiuc.edu/~hull/bib2html.
      Which, in turn depends on man2html for proper installa-
-     tion.   man2html  can  be   had   from   http://askdon-
+     tion.  man2html can be had from http://askdon-
      ald.ask.uni-karlsruhe.de/hppd/hpux/Network-
      ing/WWW/Man2html-1.05.
 
-     The website will build without this  utility,  but  you
+     The website will build without this utility, but you
      will not see our hypertextified bibliography.
 
-You  also  have  to install buildscripts/out/ps-to-gifs in a
+o    Doc++ (optional) to read the source code.
+
+You also have to install buildscripts/out/ps-to-gifs in a
 directory that is in the path.
 
 6: CONFIGURING and COMPILING
@@ -179,9 +196,9 @@ This will install a number of files, something close to:
           /usr/local/share/lilypond/*
           /usr/local/share/locale/{it,nl}/LC_MESSAGES/lilypond.mo
 
-The above assumes that you are root and have the GNU  devel-
+The above assumes that you are root and have the GNU devel-
 opment tools, and your make is GNU make.  If this is not the
-case, you can adjust  your  environment  variables  to  your
+case, you can adjust your environment variables to your
 taste:
 
           export CPPFLAGS="-I /home/me/my_include -DWEIRD_FOOBAR"
@@ -190,16 +207,16 @@ taste:
 CPPFLAGS are the preprocessor flags.
 
 The configure script is Cygnus configure, and it will accept
---help. If you are not root, you will probably have to  make
+--help. If you are not root, you will probably have to make
 it with a different --prefix option.  Our favourite location
 is
 
           ./configure --prefix=$HOME/usr
 
-In this case, you will have to set up MFINPUTS,  and  TEXIN-
+In this case, you will have to set up MFINPUTS, and TEXIN-
 PUTS accordingly.
 
-Since  GNU  LilyPond  currently  is beta, you are advised to
+Since GNU LilyPond currently is beta, you are advised to
 also use
 
           --enable-debugging
@@ -211,33 +228,33 @@ Options to configure include:
      Enable debugging print routines (lilypond -D option)
 
 --enable-optimise
-     Set maximum optimisation: compile with -O2.   This  can
-     be  unreliable  on  some compiler/platform combinations
+     Set maximum optimisation: compile with -O2.  This can
+     be unreliable on some compiler/platform combinations
      (eg, DEC Alpha and PPC)
 
 --enable-profiling
      Compile with support for profiling.
 
 --enable-config
-     Output to a different configuration file.   Needed  for
+     Output to a different configuration file.  Needed for
      multi-platform builds
 
-All  options are documented in the configure help The option
+All options are documented in the configure help The option
 --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
+everything will be compiled, but nothing will be installed.
+The resulting binaries can be found in the subdirectories
 out/ (which contain all files generated during compilation).
 
 7: CONFIGURING FOR MULTIPLE PLATFORMS
 
 If you want to compile LilyPond with different configuration
-settings, then, you  can  use  the  --enable-config  option.
-Example:  suppose I want to build with and   without profil-
+settings, then, you can use the --enable-config option.
+Example: suppose I want to build with and   without profil-
 ing.  Then I'd use the following for the normal build,
 
            ./configure --prefix=~ --disable-optimise --enable-checking
@@ -260,22 +277,21 @@ If you have done a successful make, then a simple
 should do the trick.
 
 If you are doing an upgrade, please remember to remove obso-
-lete .pk and .tfm files of the fonts.   A  script  has  been
+lete .pk and .tfm files of the fonts.  A script has been
 provided to do the work for you, see bin/clean-fonts.sh.
 
 CAVEATS
 
-o    The  -O2  option   triggers   bugs on various platforms
-     (PowerPC, Alpha).   If  you  experience  problems,  you
-
+o    The -O2 option  triggers  bugs on various platforms
+     (PowerPC, Alpha).  If you experience problems, you
      should first try  turning off this.
 
 o    On PPC you need at least EGCS-1.1.2f.
 
 9: REDHAT LINUX
 
-RedHat  Linux  users  can  compile an RPM. A spec file is in
-make/out/lilypond.spec, it is  distributed  along  with  the
+RedHat Linux users can compile an RPM. A spec file is in
+make/out/lilypond.spec, it is distributed along with the
 sources.
 
 You can make the rpm by issuing
@@ -284,12 +300,14 @@ You can make the rpm by issuing
           rpm -i /usr/src/redhat/RPMS/i386/lilypond-x.y.z
 
 Precompiled i386 RedHat RPMS are available from ftp://fresh-
-meat.net/pub/rpms/lilypond/.
+meat.net/pub/rpms/lilypond/ and http://linux.umbc.edu/soft-
+ware/lilypond/rpms/.
 
 10: DEBIAN GNU/LINUX
 
-A Debian package is  also  available;  contact  Anthony  Fok
-foka@debian.org.   The build scripts are in the subdirectory
+A Debian package is also available; contact Anthony Fok
+foka@debian.org.  The build scripts are in the subdirectory
+
 debian/.
 
 11: WINDOWS NT/95
@@ -297,7 +315,14 @@ debian/.
 Separate instructions on building for W32 are avaible in the
 file README-W32.yo.
 
-12: AUTHORS
+12: BUGS
+
+Send bug reports to bug-gnu-music@gnu.org.  For help and
+questions use help-gnu-music@gnu.org and gnu-music-dis-
+cuss@gnu.org.  Please consult the faq before mailing your
+problems.
+
+13: AUTHORS
 
 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 
diff --git a/NEWS b/NEWS
index fe760ecb1068017494ae421ea2c9d7ba4358d6e3..cb3928f8f9266ccf203d6afd9759dad143f60b4a 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -1,6 +1,29 @@
-pl 0.jcn2
-       - po fixes
 
-pl 0.jcn1
-       - gcc-2.95 nitpicks
-       - added pointers to mailing lists in toplevel docs
+
+WHAT'S NEW?
+
+* Large cleanups, enhanced design and GUILE integration for smaller
+  memory footprint and more flexible code.
+
+* Direct output to PostScript (optional), PDFTeX or as GUILE script
+  (default output still to plain TeX).
+
+* Convertors for ABC and MUP formats.
+
+* Font: now available as scalable PostScript.  New glyphs: time
+  signature, more note heads.
+
+* Enhanced input: semi-automatic beaming, (nested) tuplets, (nested)
+  repeats, chordnames, automatic Lyrics durations.
+  
+* Grace notes, volta brackets, multiple styles for note heads and 
+  time signatures, breathing signs, lyric extenders, cross staff 
+  beaming and slurring.
+  
+* --safe option for the paranoid.
+
+* More elegant spacing.  Text is spaced exactly.
+
+* Lots of bugfixes.
+
+
index 55e1a71ea74b41882defb681f37b3a9d5e60feb6..f0601c00d782b8088e8d9e1b761955501fafaa93 100644 (file)
@@ -5,23 +5,23 @@ NAME
 
 DESCRIPTION
 
-     This  page  documents how to distribute your changes to
+     This page documents how to distribute your changes to
 GNU lilypond
 
 ABSTRACT
 
-     We would like to have unified context diffs  with  full
-pathnames.   A  script  automating supplied with Lily.  Dis-
+     We would like to have unified context diffs with full
+pathnames.  A script automating supplied with Lily.  Dis-
 tributing a change normally goes like this:
 
 o    make your fix/add your code
 
-o    Add changes to NEWS, and  add  yourself  to  Documenta-
+o    Add changes to NEWS, and add yourself to Documenta-
      tion/AUTHORS.yo
 
 o    generate a patch,
 
-o    e-mail  your  patch  to  one  of the mailing lists gnu-
+o    e-mail your patch to one of the mailing lists gnu-
      music-discuss@gnu.org or bug-gnu-music@gnu.org
 
 GENERATING A PATCH
@@ -43,9 +43,9 @@ Then, from the top of Lily's source tree, type
          make dist
          make diff
 
-which rolls the  tarball  ../releases/lilypond-0.1.73.tar.gz
-and leaves your patch as  ./lilypond-0.1.73.jcn1.diff.   [1]
-We  assume that there is a tarball lilypond-0.1.73.tar.gz in
+which rolls the tarball ../releases/lilypond-0.1.73.tar.gz
+and leaves your patch as ./lilypond-0.1.73.jcn1.diff.  [1]
+We assume that there is a tarball lilypond-0.1.73.tar.gz in
 the directory ../releases.
 
 If you didn't configure Lily using --srcdir, you can do:
@@ -60,12 +60,12 @@ PREREQUISITES
 
 For creating a patch you need
 
-o    All items mentioned in INSTALL.  You're  not  going  to
+o    All items mentioned in INSTALL.  You're not going to
      send a patch that you haven't even built, right?
 
 o    GNU diff
 
-o    Python  (version 1.5 or newer).  You can of course make
+o    Python (version 1.5 or newer).  You can of course make
      a patch by hand, which would go something like:
 
 -----------
@@ -76,8 +76,8 @@ balls.  For more info type 'make diff help=='.
               cd ..
               diff -urN lilypond-0.1.73 lilypond-0.1.73.jcn1 > lilypond-0.1.73.jcn1
 
-     but there  are  handy  python  scripts  available.   If
-     you're  doing development, you'll need Python for other
+     but there are handy python scripts available.  If
+     you're doing development, you'll need Python for other
      LilyPond scripts anyway.
 
 o    The Lily directory structure, which looks like:
@@ -96,16 +96,16 @@ o    The Lily directory structure, which looks like:
               yodl -> yodl-1.30.17
               yodl-1.30.17
 
-     with prefix $HOME/usr/src and (for building rpms  only)
+     with prefix $HOME/usr/src and (for building rpms only)
      in $HOME/.rpmrc:
 
               topdir: /home/fred/usr/src/RedHat
 
 APPLYING PATCHES
 
-If  you're  following  LilyPond  development  regularly, you
+If you're following LilyPond development regularly, you
 probably want to download just the patch for each subsequent
-release.   After  downloading  the  patch  (into the patches
+release.  After downloading the patch (into the patches
 directory, of course), simply apply it:
 
          gzip -dc ../patches/lilypond-0.1.74.diff.gz | patch -p1 -E
@@ -119,11 +119,11 @@ and don't forget to make automatically generated files:
 
 SYNCHRONISE
 
-If you're not very quick with sending your patch, there's  a
+If you're not very quick with sending your patch, there's a
 good chance that an new release of LilyPond comes available.
 In such a case, the maintainer will probably ask you to make
 a new patch against the latest release.  Your best bet is to
-download the latest release, and apply  your  patch  against
+download the latest release, and apply your patch against
 this new source tree:
 
          cd lilypond-0.1.74
index 996a5c59ee02a599167ea476226baa419b87b64d..d5dd11f03764980172df6ab79802fc3b1b773564 100644 (file)
           This is the toplevel README to LilyPond
 
 LilyPond is a music typesetter.  It produces beautiful sheet
-music using a high level description file as  input.   Lily-
+music using a high level description file as input.  Lily-
 Pond is part of the GNU Project.
 
 1: VERSIONING
 
-LilyPond  uses a versioning scheme similar to the Linux ker-
-nel.  In a  version  "x.y.z",  an  even  second  number  'y'
-denotes  a  stable version.  For development versions 'y' is
+LilyPond uses a versioning scheme similar to the Linux ker-
+nel.  In a version "x.y.z", an even second number 'y'
+denotes a stable version.  For development versions 'y' is
 odd.  For using straightforward score production, please use
-the  latest  stable  version.   Development versions may not
+the latest stable version.  Development versions may not
 produce good or nice scores.
 
 2: REQUIREMENTS
 
-For the compilation and running of LilyPond  you  need  some
-additional  packages.   Please  refer  to  the  installation
+For the compilation and running of LilyPond you need some
+additional packages.  Please refer to the installation
 instructions.
 
-NOTE: If you downloaded a binary  (.rpm  or  a  W95/NT  .zip
+NOTE: If you downloaded a binary (.rpm or a W95/NT .zip
 file), then you don't have to compile LilyPond.
 
 3: INSTALLATION
 
-For  your  convenience,  a  formatted  copy  of  the INSTALL
+For your convenience, a formatted copy of the INSTALL
 instructions are in the toplevel directory, as INSTALL.txt
 
-The process is fairly straightforward, but chances are  that
-you  have  to specify directories for  to configure: this is
+The process is fairly straightforward, but chances are that
+you have to specify directories for  to configure: this is
 done with the options --enable-tex-dir and --enable-mf-dir
 
 4: DOCUMENTATION
 
 The real documentation is the directory Documentation/
 
-To generate the pretty-printed docs, you have to run config-
-ure first, and then do this:
+If you want to read the documentation online, these are
+options:
 
-make doc
+o    use .html. Refer to INSTALL.txt for info on how to make
+     the .html documentation.
 
-You  can  also  simply read the .yo sources.  They are ASCII
-text.  The complete documentation is accessible in formatted
-form  at the website http://www.cs.uu.nl/people/hanwen/lily-
-pond/index.html
+o    use .html. Point your browser to
+     http://www.cs.uu.nl/~hanwen/lilypond/index.html.
+
+o     use .dvi,  for the tutorial and reference manual. Do
+
+            make -C Documentation/tex/ dvi
+
+o    use ASCII. Do using
+
+               make -C Documentation/
+
+     The tutorial and the reference manual  can not be made
+     in ASCII, as they contain graphics.
 
 5: COMMENTS
 
-LilyPond is a long way from finished and  polished.   We  do
+LilyPond is a long way from finished and polished.  We do
 appreciate criticism, comments, bugreports, patches, etc.
 
              Please send your e-mail to one of the MAILING LISTS
 
-and  not  to  us personally.  See Documentation/links.yo for
+and not to us personally.  See Documentation/links.yo for
 more info.
 
 6: WINDOWS 32
 
-If you have received this file as  part  of  a  DOS/Window32
-distribution  (LilyPond-*.zip), then it is advisable to also
-download the source package, since  it  might  contain  more
+If you have received this file as part of a DOS/Window32
+distribution (LilyPond-*.zip), then it is advisable to also
+download the source package, since it might contain more
 documentation ftp://ftp.cs.uu.nl/pub/GNU/LilyPond/
 
 If you decide to build LilyPond from source, please read the
-INSTALL.txt document first,  especially  the  Windows  NT/95
+INSTALL.txt document first, especially the Windows NT/95
 section.
 
 7: CAVEATS
 
 * Please read the file BUGS for some ugly bugs.
 
-*  If  you  have  installed  a  previous version, be sure to
+* If you have installed a previous version, be sure to
 remove old font files, eg
 
      rm `find /var/lib/texmf/fonts -name 'feta*'`
 
-a script to  do  this  for  you  is  in  buildscripts/clean-
+a script to do this for you is in buildscripts/clean-
 fonts.sh
 
-8: CDROM DISTRIBUTIONS
+8: BUGS
+
+Send bug reports to bug-gnu-music@gnu.org.  For help and
+questions use help-gnu-music@gnu.org and gnu-music-dis-
+cuss@gnu.org.  Please consult the faq before mailing your
+problems.
+
+9: CDROM DISTRIBUTIONS
 
-If  you  have received LilyPond on a cdrom, chances are that
-development has moved a some patchlevels up.   Please  check
+If you have received LilyPond on a cdrom, chances are that
+development has moved a some patchlevels up.  Please check
 the latest version of LilyPond before reporting bugs.
diff --git a/TODO b/TODO
index e38eaaabe96f8fbdbe65b0ac039a5ebaaf9cb8d8..673acaf3eb4d0fbca4db07f73c4916b748e54f07 100644 (file)
--- a/TODO
+++ b/TODO
@@ -4,12 +4,17 @@
 Features you cannot find in the documentation as working, should be
 mentioned here.  This is an assorted collection of stuff that will be
 done, might be done, or is an idea that we want to think about.
-
+m
 Most of the items are marked in the code as well
 Grep -i for TODO, FIXME and ugh/ugr/urg.  
 
 .* TODO after 1.2
 . * Break_req handling is silly (break_forbid () + \break fucks up.)
+. * HaraKiriStaffContext removes bar lines and doesn't remove
+    staff margin text on removed staff lines.
+. * make all Feta (including dynamics) available to the user in
+    textual scripts. Examples: "D.S. al \coda", "\mf espress.".
 . * ?  -Q, --find-old-relative show all changes in relative syntax
 What's old about absolute to relative conversion?  Could maybe use for
 abc2ly, midi2ly?
@@ -37,14 +42,62 @@ abc2ly, midi2ly?
 .* BUGS
 . * [c8. c16 c16 c16] in 6/8 timesig. 
 . * staffside spanner (crescendo!) along with staffswitch.
+. * --- 1, sometimes broken slurs start too early in the next line:
+
+\score {
+  \context Staff {
+    \clef "bass";
+    \notes \relative c' {
+      \time 4/4; \key g;
+      a4 g8 fis a d c d ~ \break | d e d b a b a fis \break
+    }
+  }
+}
+
+--- 2, margin notes don't work correctly for the pianostaff (in the
+following example, i expect the "piano" string to be centered
+vertically between the two staves):
+
+\score {
+  \notes \context PianoStaff <
+    \property PianoStaff.instrument = "Piano"
+    \context Staff = treble {
+       a b c
+    }
+    \context Staff = bass {
+       \clef bass;
+       a, b, c,
+    }
+  >
+  \paper {
+    \translator { \StaffContext \consists "Staff_margin_engraver"; }
+    \translator { \PianoStaffContext \consists "Staff_margin_engraver"; }
+  }
+}
 . * 
 > \context Staff <
 >   {\voiceone''4. r8}
 >  \voicetwo c,4 r4}
 > >
+. * sort out breve shapes.
+. * \time forces keysig?
 
 .* STUFF
 . * We need feta-din*.mf files for more sizes than 10.
+. *
+- It's clumsy to have to set Staff.instr = " " to get instrument name
+  on only the first line.
+
+- The syntax for chords looks clumsy with two different meanings of 
+  '-' and different syntax for separating modifiers from the tonic
+  and from other modifiers. Why not use for example ':' between
+  tonic and modifier and between the different modifiers?
+
+- Rests and beams don't work too well together. Example:
+   [ r8 g''16 des'] [r8 c16 a] 
+
+- The stemLength property should affect also beamed stems.
+
 . * align left edge of broken (de)cresc/slur/tie/tuplet/volta
 . * fix dynamics decently, ie. use kerning & ligatures.
 . * key restorations & repeats
diff --git a/VERSION b/VERSION
index 11c9f17feeed91a772704c2e10711f40d851acb5..9b18ae90d88febe785f407d82b935d8d6ebde474 100644 (file)
--- a/VERSION
+++ b/VERSION
@@ -1,8 +1,8 @@
 PACKAGE_NAME=LilyPond
 MAJOR_VERSION=1
 MINOR_VERSION=2
-PATCH_LEVEL=0
-MY_PATCH_LEVEL=jcn2
+PATCH_LEVEL=1
+MY_PATCH_LEVEL=
 
 # use the above to send patches: MY_PATCH_LEVEL is always empty for a
 # released version.
index caee78ed689c2ec3ef1c521d12b1712ad6bc8c1c..5d6b023d4004ffcf68c2a3974569daa5856ae11c 100644 (file)
@@ -175,7 +175,14 @@ AC_DEFUN(AC_STEPMAKE_GUILE, [
       AC_DEFINE(HAVE_LIBGUILE)], , $GUILE_LDFLAGS dnl
     )
     if test "$ac_cv_lib_guile_gh_scm2doubles" != yes ; then
-       AC_STEPMAKE_WARN(You should install guile 1.3 or newer)
+      GUILE_LDFLAGS="`echo $GUILE_LDFLAGS | sed -e 's/-lreadline//g'`"
+      AC_CHECK_LIB(guile, gh_doubles2scm,
+        [LIBS="`echo $GUILE_LDFLAGS | sed -e 's/-L[[/-_a-zA-Z0-9]]\+ //g'` $LIBS"
+       AC_DEFINE(HAVE_LIBGUILE)], , $GUILE_LDFLAGS dnl
+      )
+      if test "$ac_cv_lib_guile_gh_doubles2scm" != yes ; then
+       AC_STEPMAKE_WARN(You should install guile 1.3 or newer)
+      fi
     fi
 ])
 
index feb3dfc8bda91a808a8b8f49428b1d2edfb7e4b4..d7e8e972d8d7a4284cf328ec13bf195f96025b90 100644 (file)
@@ -9,6 +9,20 @@ setenv GS_FONTPATH "@datadir@/afm"
 setenv LILYPONDPREFIX "@datadir@"
 
 # include an empty path component for the system wide includes.
-setenv MFINPUTS "@datadir@/mf:$MFINPUTS::"
-setenv TEXINPUTS "@datadir@/tex:$TEXINPUTS::"
-setenv GUILE_LOAD_PATH "@datadir@/scm:$GUILE_LOAD_PATH"
+if ($?MFINPUTS) then
+        setenv MFINPUTS "/usr/share/lilypond/mf:${MFINPUTS}::"
+else
+        setenv MFINPUTS "/usr/share/lilypond/mf::"
+endif
+if ($?TEXINPUTS) then
+        setenv TEXINPUTS "/usr/share/lilypond/tex:${TEXINPUTS}::"
+else
+        setenv TEXINPUTS "/usr/share/lilypond/tex::"
+endif
+if ($?GUILE_LOAD_PATH) then
+        setenv GUILE_LOAD_PATH "/usr/share/lilypond/scm:${GUILE_LOAD_PATH}"
+else
+        setenv GUILE_LOAD_PATH "/usr/share/lilypond/scm"
+endif
+
+
index 506ffcfa7f8cadafe2d57b7a3d145450187a95aa..9681a2a71bf4d737ff6e6bb113f830873a99d1f0 100755 (executable)
--- a/configure
+++ b/configure
@@ -2997,16 +2997,66 @@ else
 fi
 
     if test "$ac_cv_lib_guile_gh_scm2doubles" != yes ; then
-       
+      GUILE_LDFLAGS="`echo $GUILE_LDFLAGS | sed -e 's/-lreadline//g'`"
+      echo $ac_n "checking for gh_doubles2scm in -lguile""... $ac_c" 1>&6
+echo "configure:3003: checking for gh_doubles2scm in -lguile" >&5
+ac_lib_var=`echo guile'_'gh_doubles2scm | sed 'y%./+-%__p_%'`
+if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then
+  echo $ac_n "(cached) $ac_c" 1>&6
+else
+  ac_save_LIBS="$LIBS"
+LIBS="-lguile $GUILE_LDFLAGS        $LIBS"
+cat > conftest.$ac_ext <<EOF
+#line 3011 "configure"
+#include "confdefs.h"
+/* Override any gcc2 internal prototype to avoid an error.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+/* We use char because int might match the return type of a gcc2
+    builtin and then its argument prototype would still apply.  */
+char gh_doubles2scm();
+
+int main() {
+gh_doubles2scm()
+; return 0; }
+EOF
+if { (eval echo configure:3025: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
+  rm -rf conftest*
+  eval "ac_cv_lib_$ac_lib_var=yes"
+else
+  echo "configure: failed program was:" >&5
+  cat conftest.$ac_ext >&5
+  rm -rf conftest*
+  eval "ac_cv_lib_$ac_lib_var=no"
+fi
+rm -f conftest*
+LIBS="$ac_save_LIBS"
+
+fi
+if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then
+  echo "$ac_t""yes" 1>&6
+  LIBS="`echo $GUILE_LDFLAGS | sed -e 's/-L[/-_a-zA-Z0-9]\+ //g'` $LIBS"
+       cat >> confdefs.h <<\EOF
+#define HAVE_LIBGUILE 1
+EOF
+
+else
+  echo "$ac_t""no" 1>&6
+fi
+
+      if test "$ac_cv_lib_guile_gh_doubles2scm" != yes ; then
+       
     echo "configure: warning: You should install guile 1.3 or newer" 1>&2
     warn_b=yes
 
+      fi
     fi
 
 
 
 echo $ac_n "checking for 8-bit clean memcmp""... $ac_c" 1>&6
-echo "configure:3010: checking for 8-bit clean memcmp" >&5
+echo "configure:3060: checking for 8-bit clean memcmp" >&5
 if eval "test \"`echo '$''{'ac_cv_func_memcmp_clean'+set}'`\" = set"; then
   echo $ac_n "(cached) $ac_c" 1>&6
 else
@@ -3014,7 +3064,7 @@ else
   ac_cv_func_memcmp_clean=no
 else
   cat > conftest.$ac_ext <<EOF
-#line 3018 "configure"
+#line 3068 "configure"
 #include "confdefs.h"
 #ifdef __cplusplus
 extern "C" void exit(int);
@@ -3027,7 +3077,7 @@ main()
 }
 
 EOF
-if { (eval echo configure:3031: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null
+if { (eval echo configure:3081: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null
 then
   ac_cv_func_memcmp_clean=yes
 else
@@ -3045,12 +3095,12 @@ echo "$ac_t""$ac_cv_func_memcmp_clean" 1>&6
 test $ac_cv_func_memcmp_clean = no && LIBOBJS="$LIBOBJS memcmp.${ac_objext}"
 
 echo $ac_n "checking for vprintf""... $ac_c" 1>&6
-echo "configure:3049: checking for vprintf" >&5
+echo "configure:3099: checking for vprintf" >&5
 if eval "test \"`echo '$''{'ac_cv_func_vprintf'+set}'`\" = set"; then
   echo $ac_n "(cached) $ac_c" 1>&6
 else
   cat > conftest.$ac_ext <<EOF
-#line 3054 "configure"
+#line 3104 "configure"
 #include "confdefs.h"
 /* System header to define __stub macros and hopefully few prototypes,
     which can conflict with char vprintf(); below.  */
@@ -3076,7 +3126,7 @@ vprintf();
 
 ; return 0; }
 EOF
-if { (eval echo configure:3080: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
+if { (eval echo configure:3130: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
   rm -rf conftest*
   eval "ac_cv_func_vprintf=yes"
 else
@@ -3100,12 +3150,12 @@ fi
 
 if test "$ac_cv_func_vprintf" != yes; then
 echo $ac_n "checking for _doprnt""... $ac_c" 1>&6
-echo "configure:3104: checking for _doprnt" >&5
+echo "configure:3154: checking for _doprnt" >&5
 if eval "test \"`echo '$''{'ac_cv_func__doprnt'+set}'`\" = set"; then
   echo $ac_n "(cached) $ac_c" 1>&6
 else
   cat > conftest.$ac_ext <<EOF
-#line 3109 "configure"
+#line 3159 "configure"
 #include "confdefs.h"
 /* System header to define __stub macros and hopefully few prototypes,
     which can conflict with char _doprnt(); below.  */
@@ -3131,7 +3181,7 @@ _doprnt();
 
 ; return 0; }
 EOF
-if { (eval echo configure:3135: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
+if { (eval echo configure:3185: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
   rm -rf conftest*
   eval "ac_cv_func__doprnt=yes"
 else
@@ -3158,12 +3208,12 @@ fi
 for ac_func in memmem snprintf vsnprintf gettext
 do
 echo $ac_n "checking for $ac_func""... $ac_c" 1>&6
-echo "configure:3162: checking for $ac_func" >&5
+echo "configure:3212: checking for $ac_func" >&5
 if eval "test \"`echo '$''{'ac_cv_func_$ac_func'+set}'`\" = set"; then
   echo $ac_n "(cached) $ac_c" 1>&6
 else
   cat > conftest.$ac_ext <<EOF
-#line 3167 "configure"
+#line 3217 "configure"
 #include "confdefs.h"
 /* System header to define __stub macros and hopefully few prototypes,
     which can conflict with char $ac_func(); below.  */
@@ -3189,7 +3239,7 @@ $ac_func();
 
 ; return 0; }
 EOF
-if { (eval echo configure:3193: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
+if { (eval echo configure:3243: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then
   rm -rf conftest*
   eval "ac_cv_func_$ac_func=yes"
 else
@@ -3228,7 +3278,7 @@ do
 # Extract the first word of "$ac_prog", so it can be a program name with args.
 set dummy $ac_prog; ac_word=$2
 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6
-echo "configure:3232: checking for $ac_word" >&5
+echo "configure:3282: checking for $ac_word" >&5
 if eval "test \"`echo '$''{'ac_cv_prog_MAKEINFO'+set}'`\" = set"; then
   echo $ac_n "(cached) $ac_c" 1>&6
 else
index 0e3f29135304af912deeb44d87cb352dc86bc4d9..9a4996c6fd29a9afb8e65550d3531885ee0f9223 100644 (file)
@@ -133,7 +133,7 @@ Dynamic_engraver::do_process_requests()
              staff_side_p_->dir_ = Direction (int (prop));
            }
 
-         prop = get_property ("dynamicDir", 0);
+         prop = get_property ("dynamicDirection", 0);
          if (prop.isnum_b ())
            {
              staff_side_p_->dir_ = (Direction) (int) prop;
@@ -178,7 +178,7 @@ Dynamic_engraver::do_process_requests()
                    {
                      to_end_ss_span_p_->dir_ = Direction (int (prop));
                    }
-                 prop = get_property ("dynamicDir", 0);
+                 prop = get_property ("dynamicDirection", 0);
                  if (prop.isdir_b ())
                    {
                      to_end_ss_span_p_->dir_ = (Direction) (int) prop;
diff --git a/lily/include/bar-align-engraver.hh b/lily/include/bar-align-engraver.hh
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/lily/include/beam-swallow-trans.hh b/lily/include/beam-swallow-trans.hh
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/lily/include/dynamic-engraver.hh b/lily/include/dynamic-engraver.hh
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/lily/include/type-swallow-trans.hh b/lily/include/type-swallow-trans.hh
deleted file mode 100644 (file)
index e69de29..0000000
index 3c05d65b28192947fd20dd9567befab9e16d41fb..e2b81bfa6c70e2741d7cea31fc6e7700071306fe 100644 (file)
@@ -132,6 +132,8 @@ Lookup::notehead (int j, String type) const
 {
   if (j > 2)
     j = 2;
+  if (type == "harmonic" || type == "cross")
+    j = 2;
 
   return afm_find (String ("noteheads-") + to_str (j) + type);
 }
index 703a66ff21f0a624b610a1b8cac92a44286cfcd8..39883f8328e138f2b9065dbf32a4f2d5d3c8f5ce 100644 (file)
@@ -437,13 +437,10 @@ Midi_note_off::Midi_note_off (Midi_note* n)
   channel_i_ = n->channel_i_;
 
   // Anybody who hears any difference, or knows how this works?
-  
-  // 0x64 is supposed to be neutral, but let's try
-  //aftertouch_byte_ = 0x64;
+  //  0 should definitely be avoided, notes stick on some sound cards.
+  // 64 is supposed to be neutral
+  aftertouch_byte_ = 64;
 
-  static int i = 0;
-  aftertouch_byte_ = i;
-  i += 0x10;
 }
 
 String
diff --git a/lily/type-swallow-trans.cc b/lily/type-swallow-trans.cc
deleted file mode 100644 (file)
index e69de29..0000000
index 794a69b345287165210aad359b94f209deb80db0..145d1e050502aa91386835dbc93970ffabf54895 100644 (file)
@@ -1,9 +1,13 @@
 % paper.ly
 
-linewidth20 = \hsize - 2.5 * \staffheight;
-textheight20 = \vsize - 5.0 * \staffheight;
-linewidth = \staffheight/20.0 * \linewidth20;
-textheight = \staffheight/20.0 * \textheight20;
+%% Why som complicated?  /MB
+%linewidth20 = \hsize - 2.5 * \staffheight;
+%textheight20 = \vsize - 5.0 * \staffheight;
+%linewidth = \staffheight/20.0 * \linewidth20;
+%textheight = \staffheight/20.0 * \textheight20;
+
+linewidth = \hsize - 2.\cm;
+textheight = \vsize - 4.\cm;
 
 indent = \linewidth / 14.0;
 
index 12f1c34a3f14920f5eeca0df0702d2bd7d27d6b3..203169f394078ff9cbcbcfa206afbf2045862fcb 100644 (file)
@@ -232,7 +232,7 @@ hyphen_height = 0.2*\font_normal;
 hyphen_minimum_length = 0.25*\font_normal;
 
 % Multi-measure rests
-mmrest_x_minimum = 2.0*\staffheight;
+mmrest_x_minimum = 1.4*\staffheight;
 
 
 % chop off this much when next to pp / ff sign.
@@ -253,7 +253,7 @@ stemSpacingCorrection = 0.5*\interline;
 %{
  relative strength of space following breakable columns (eg. prefatory matter)
  %}
-breakable_column_space_strength = 8.0; 
+breakable_column_space_strength = 2.0; 
 
 % space after inline clefs and such get this much stretched
 decrease_nonmus_spacing_factor = 1.0 ;
index 8f750dbc22653070136503283ea27bd3d718a893..9e6b7df97a4580a70cae2b0020114ad041996fb1 100644 (file)
@@ -1,7 +1,7 @@
 Begin3
 Title: LilyPond
-Version: 1.2.0
-Entered-date: 28JUL99
+Version: 1.2.1
+Entered-date: 16AUG99
 Description: 
 LilyPond is a music typesetter.  It produces beautiful sheet music
 using a high level description file as input.  LilyPond is part of 
@@ -13,8 +13,8 @@ Author: hanwen@cs.uu.nl (Han-Wen Nienhuys)
        janneke@gnu.org (Jan Nieuwenhuizen)
 Maintained-by: hanwen@stack.nl (Han-Wen Nienhuys)
 Primary-site: sunsite.unc.edu /pub/Linux/apps/sound/convert
-       1000k lilypond-1.2.0.tar.gz 
+       1000k lilypond-1.2.1.tar.gz 
 Original-site: ftp.cs.uu.nl /pub/GNU/LilyPond/development/
-       1000k lilypond-1.2.0.tar.gz 
+       1000k lilypond-1.2.1.tar.gz 
 Copying-policy: GPL
 End
index 7c9cd762b2d41ff450d8dc3a77f8e3f68d28a36c..f53dfcc6a7facf49702d0477e36979601c5ae022 100644 (file)
@@ -1,9 +1,9 @@
 Name: lilypond
-Version: 1.2.0
+Version: 1.2.1
 Release: 1
 Copyright: GPL
 Group: Applications/Publishing
-Source0: ftp.cs.uu.nl:/pub/GNU/LilyPond/development/lilypond-1.2.0.tar.gz
+Source0: ftp.cs.uu.nl:/pub/GNU/LilyPond/development/lilypond-1.2.1.tar.gz
 Summary: A program for printing sheet music.
 URL: http://www.cs.uu.nl/~hanwen/lilypond
 Packager: Han-Wen Nienhuys <hanwen@cs.uu.nl>
index f8b069a0271f7a2899c4108d3b18a1a7395a6a17..288eeed2f6b32d8d5fedaf2ad9eb8512a54fb4dc 100644 (file)
@@ -15,7 +15,7 @@ SUBDIRS = scripts buildscripts  flower lib lily mf midi2ly po debian \
 
 SCRIPTS = configure aclocal.m4
 README_FILES = BUGS DEDICATION ANNOUNCE-0.1 ANNOUNCE-1.0 ANNOUNCE-1.2 \
- COPYING NEWS-0.1 NEWS-1.0 NEWS-0.0 NEWS-1.1  NEWS  TODO AIMS
+ COPYING NEWS-0.1 NEWS-1.0 NEWS-0.0 NEWS-1.1  NEWS TODO AIMS  ChangeLog
 README_TXT_FILES = README.txt AUTHORS.txt INSTALL.txt PATCHES.txt
 IN_FILES := $(wildcard *.in)
 EXTRA_DIST_FILES = dstreamrc mudela-mode.el vimrc VERSION $(README_FILES)  $(SCRIPTS) $(IN_FILES) TASKS
index 61f61b0b1f0177bc2c54440156ffeabfee9e8e4b..9094208b4ad2f7bae732391356902087e0ad04a6 100644 (file)
@@ -548,7 +548,9 @@ r4^"Flauto" r8 [c'16 ( d] |
 trpIIhelp=\notes\relative c'' {
 \tiny
 
-s2.*32 |
+[c8.^"Oboe" ( d16] ) c2 |
+[c8. ( d16] ) c2 |
+s2.*30 |
 s2*9 |
 r4^"Clar. I" r8 c-. |
 [bes-. a-. g-. f-. ] |
index 81d102135fa93e01ed290471c89ad489bc6d61e4..003def855ac551c82e5546105ce16a9c9bcba7b4 100644 (file)
@@ -1,8 +1,8 @@
-\def\fetdef#1#2{%
-  \def#1{\hbox{\fetchar{#2}}}}
-\font\fetasixteen = feta16
-\def\fetchar#1{{\fetasixteen\char#1}}
-\input{feta20}         %%% Add lilypond-xxx/mf/out/ to TEXINPUTS
+%\def\fetdef#1#2{%
+%  \def#1{\hbox{\fetchar{#2}}}}
+%\font\fetasixteen = feta16
+%\def\fetchar#1{{\fetasixteen\char#1}}
+%\input{feta20}         %%% Add lilypond-xxx/mf/out/ to TEXINPUTS
 
 \newcommand{\okt}{$8^{va}$}
 
@@ -18,7 +18,7 @@
 \advance\topmargin-5mm
 \advance\headsep-4mm
 \addtolength{\textheight}{17mm}
-\advance\footskip-3mm
+\advance\footskip-5mm
 
 \usepackage{fancyheadings}
 \lhead{\textbf{\large\theinstrument}}
@@ -52,7 +52,7 @@
         \end{flushright}%
   \end{minipage}\par
   \parskip\saveparskip
-  {\flushleft{\Large\textbf\thepiece}\par}%
+  {\flushleft{\Large\textbf\thepiece}\\}%
 %  \leavevmode%
-  \enlargethispage*{5mm}%
+%  \enlargethispage*{7mm}%
 }
index 31846c0113f8b93438d33ee6fcf3b943db172919..f9326fc15559819b2913f577cc3153847202b1a4 100644 (file)
@@ -19,15 +19,15 @@ copyright = "Mats Bengtsson, 1999. Free circulation permitted and " +
 \include "strings.ly"
 
 my_paper = \paper {
-  textheight = 275.0 \mm;
+  textheight = 265.0 \mm;
   \translator {
     \OrchestralPartStaffContext
   }
   \translator { 
     \ScoreContext
     skipBars = 1;
-    markScriptPadding = "6.0";
-    barNumberScriptPadding = "11.0";
+    barNumberScriptPadding = "12.0";
+    markScriptPadding = "20.0";
     dynamicPadding = 3.0;
     textScriptPadding = 5.0;
     textStyle = "italic";
@@ -85,7 +85,7 @@ my_paper = \paper {
     \clarI
   >
   \header{
-    instrument = "Clarinetto I in B\\flat";
+    instrument = "Clarinetto I in B\\textflat";
   }
   \paper{
     \my_paper
@@ -103,7 +103,7 @@ my_paper = \paper {
     \clarII
   >
   \header{
-    instrument = "Clarinetto II in B\\flat";
+    instrument = "Clarinetto II in B\\textflat";
   }
   \paper{
     \my_paper
@@ -184,7 +184,7 @@ my_paper = \paper {
     \context Voice = help \trpIhelp
   >
   \header{
-    instrument = "Tromba I in B\\flat";
+    instrument = "Tromba I in B\\textflat";
   }
   \paper{
     \my_paper
@@ -205,7 +205,7 @@ my_paper = \paper {
     \context Voice = help \trpIIhelp
   >
   \header{
-    instrument = "Tromba II in B\\flat";
+    instrument = "Tromba II in B\\textflat";
   }
   \paper{
     \my_paper
index be35e29f73b286df7550f20afaf9cf0f916e1251..67ace5a781e7265c597e07b9a85dbeb2e4ee1fe0 100644 (file)
@@ -14,8 +14,7 @@ copyright =   "Mats Bengtsson, 1999. Free circulation permitted and " +
 \include "wood.ly"
 \include "brass.ly"
 \include "strings.ly"
-\include "paper16.ly";
-
+\include "paper16.ly"
 
 \score{ <
   \context StaffGroup = wood <
@@ -33,13 +32,13 @@ copyright = "Mats Bengtsson, 1999. Free circulation permitted and " +
       \oboe
     >
     \context Voice = clarI <
-      \property Staff.instrument = "Clar. I in B\\flat  "
+      \property Staff.instrument = "Clar. I in B\\textflat  "
       \property Staff.instr = "Cl. I"
       \globalNoKey
       \clarI
     >
     \context Voice = clarII <
-      \property Staff.instrument = "Clar. II  in B\\flat  "
+      \property Staff.instrument = "Clar. II  in B\\textflat  "
       \property Staff.instr = "Cl. II"
       \globalNoKey
       \clarII
@@ -68,7 +67,7 @@ copyright =   "Mats Bengtsson, 1999. Free circulation permitted and " +
       }
     >
     \context Staff = trp <
-      \property Staff.instrument = "2 Trp. in B\\flat  "
+      \property Staff.instrument = "2 Trp. in B\\textflat  "
       \property Staff.instr = "Trp."
       \context Voice = trpI <
        \globalNoKey
@@ -85,7 +84,7 @@ copyright =   "Mats Bengtsson, 1999. Free circulation permitted and " +
   >
     \context StaffGroup = percussion <\context Voice = timpani <
       \property Staff.instrument = "Timp. \& Triang."
-      \property Staff.instr = "Tmp\&{}Trg"
+      \property Staff.instr = "\qquad Tmp\& Trg"
       \global
       \timpani
     >
@@ -135,7 +134,9 @@ copyright = "Mats Bengtsson, 1999. Free circulation permitted and " +
         barNumberScriptPadding = "12.0";
         markScriptPadding = "20.0";
     }
-    \translator { \StaffContext
+    \translator { 
+%        \HaraKiriStaffContext % Gives lost bar lines and misplaced marks!!
+        \StaffContext
        \consists "Staff_margin_engraver";
         marginScriptPadding = "15.0";
         dynamicPadding = 3.0;
index bc6b44c6bcbedbdbbd28fe98cbab78d8334e7688..0221e01cc5a21a1676b23fd7d45af27e41920af6 100644 (file)
@@ -649,8 +649,8 @@ b r b r |
 b r b r |
 a r r4 |
 R2 |
-g!4 \p \< ( a |
-\! b!2 ~ |
+g4 \p \< ( a |
+\! b2 ~ |
 b4 \> a ~ |
 a \! ) fis8 r |
 g4 \p \< ( a |
index 7395958a0ff980ffd89db12b2e405447d7553e71..09bc18962e6426a7f4be3ec96ec539272afab550 100644 (file)
@@ -419,6 +419,16 @@ if 1:
        conversions.append ((1,2,0), conv,
                            'automaticMelismas -> automaticMelismata')
 
+if 1:
+       def conv(lines):
+               newlines =[]
+               for x in lines:
+                       x =  re.sub ('dynamicDir', 'dynamicDirection', x)
+                       newlines.append (x)
+               return newlines
+
+       conversions.append ((1,2,1), conv,
+                           'dynamicDir -> dynamicDirection')
 
 ############################
        
index c6f31cea881e8689f0547f3267a22d24f50c66fd..85b101eb0559f3374eb43ea55ff0db134ac036e4 100644 (file)
@@ -1,15 +1,15 @@
 Begin3
 Title: StepMake
-Version: 0.1.79
-Entered-date: 21JUL99
+Version: 0.1.80
+Entered-date: 16AUG99
 Description: 
 Keywords: music notation typesetting midi fonts engraving
 Author: janneke@gnu.org (Jan Nieuwenhuizen)
        hanwen@cs.ruu.nl (Han-Wen Nienhuys)
 Maintained-by: janneke@gnu.org (Jan Nieuwenhuizen)
 Primary-site: sunsite.unc.edu /pub/Linux/apps/sound/convert
-       40k stepmake-0.1.79.tar.gz 
+       40k stepmake-0.1.80.tar.gz 
 Original-site: pcnov095.win.tue.nl /pub/lilypond/development/
-       40k stepmake-0.1.79.tar.gz 
+       40k stepmake-0.1.80.tar.gz 
 Copying-policy: GPL
 End
index ff5cbd6ca1f0b49344e3d234a010c14d3466c088..d29fe4024a42ec224d3ff15d31e871a49ff56174 100644 (file)
@@ -1,9 +1,9 @@
 Name: stepmake
-Version: 0.1.79
+Version: 0.1.80
 Release: 1
 Copyright: GPL
 Group: Development
-Source0: pcnov095.win.tue.nl:/pub/lilypond/development/stepmake-0.1.79.tar.gz
+Source0: pcnov095.win.tue.nl:/pub/lilypond/development/stepmake-0.1.80.tar.gz
 Summary: generic make package
 Packager: janneke@gnu.org (Jan Nieuwenhuizen)
 Buildroot: /tmp/stepmake-install
index fd18c5b60615e103ea3fea90b6720402dc8d835e..876dff52139b82896293b82a6144872a22e83d7c 100644 (file)
   {\center{\large\theinstrument}\par}
   {\flushleft{\large\normalfont\scshape\thepiece}}
 %  \leavevmode
+  \global\let\theopus\relax%
+  \global\let\thepiece\relax%
 }
 \def\makelilypiecetitle
 {
   \bigskip
   {\flushright{\theopus}\par}
   {\flushleft{\large\normalfont\scshape\thepiece}}
+  \global\let\theopus\relax%
+  \global\let\thepiece\relax%
 }
 \endinput