musiktheorietheorie/musixtex/doc/musixlyr/mxlyrdoc.tex
Josia Pietsch 200080fe9d Tag 6
2022-03-27 12:09:14 +02:00

1876 lines
68 KiB
TeX

%%
%% mxlyrdoc.tex: Manual for the MusiXTeX lyrics package musixlyr
%%
%% Copyright (C) 1996-2003 Rainer Dunker
%%
%% This document is free software; you can redistribute it and/or modify
%% it under the terms of the GNU General Public License as published by
%% the Free Software Foundation; either version 2 of the License, or
%% any later version.
%%
%% This document is distributed in the hope that it will be useful,
%% but WITHOUT ANY WARRANTY; without even the implied warranty of
%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
%% GNU General Public License for more details.
%%
%% You should have received a copy of the GNU General Public License
%% along with this document; if not, write to the Free Software
%% Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
%%
%% Author:
%% Rainer Dunker
%% Wachtelweg 31
%% 85591 Vaterstetten
%% Germany
%%
%% E-mail: rainer.dunker@web.de
%%
\documentclass[twoside]{article}
\usepackage{musixtex,multicol,makeidx}
\input musixlyr
\textwidth210mm \advance\textwidth-2in % These format settings
\textheight297mm \advance\textheight-2in % can be freely changed!
\advance\textheight-\headheight \advance\textheight-\headsep
\footskip0pt \topmargin0pt \evensidemargin0pt \oddsidemargin0pt
\pagestyle{headings}
\parskip0.5ex plus 0.25ex minus 0.25ex
\parindent0pt
\sloppy
\nobarnumbers
\smallmusicsize
%
% command index
%
\makeatletter
\renewenvironment{theindex}
{\let\item\@idxitem
\begin{multicols}{2}
\parskip0pt}
{\end{multicols}}
\def\printcmd#1{{\tt\char92 #1}}
\def\ci#1{\printcmd{#1}\bci{#1}}
\def\bci#1{\index{#1@\printcmd{#1}}} % "blind" command index entry
\makeindex
\let\myqnwidth\qn@width
\makeatother
\def\musixlyr{{\tt musixlyr}}
\def\PMX{{\bf PMX}}
\def\var#1{\hbox{$\langle$#1$\rangle$}}
\def\oneversespace{\par\vspace*{2mm}}
\def\twoversesspace{\par\vspace*{7mm}}
\begin{document}
\title{\musixlyr\ --- a \musixtex\ Extension Package for Lyrics Handling
(Version 2.1c)}
\author{\copyright\ Rainer Dunker 1996--2003\\
{\tt rainer.dunker@web.de}}
\maketitle
\thispagestyle{empty}
{\small\sl (The page layout of this document is tailored to A4 paper
format, but the text width and height can be freely changed in order
to meet other paper sizes; no part of the layout relies on a
particlular size.)\/}
{\parskip0pt\tableofcontents}
\section{Introduction}
\subsection{Basic concepts}
\musixlyr\ is a set of \TeX\ macros to be used with Taupin \musixtex\
(version T.52 or later) for typesetting vocal music. Its purpose is
to compensate two drawbacks of \musixtex's lyrics handling:
\begin{itemize}
\item Typesetting lyrics with the ``native'' \musixtex\ commands
\verb|\zcharnote|, \verb|\zsong| etc.\ tends to be quite
inefficient, particularly if the lyrics have to be changed or
corrected. The idea underlying \musixlyr\ is to separate lyrics
coding from music coding and let \TeX\ weave them together with as
little manual interference as possible. As a result you can enter
and edit lyrics (nearly) as easily as normal text.
\item \musixtex\ has no built-in mechanism for centering hyphens between
syllables and for handling hyphenation at long melismas. This is
implemented in \musixlyr\ following the example of engraved music.
\end{itemize}
\subsection{New since version~2.0}
\musixlyr~2.0 provides the following major enhancements:
\begin{itemize}
\item Support for lyrics on multi-staff instruments
$\longrightarrow$~section~\ref{multi-staff-instruments}
%
\item Melisma declaration as part of the lyrics definition,
i.\,e.~within \ci{setlyrics}
$\longrightarrow$~section~\ref{melismas}
%
\item Improved scheme for vertical lyrics positioning
$\longrightarrow$~section~\ref{vertical-positioning}
%
\item Facility for posting lyrics anywhere on a staff, even where no
notes are present at all
$\longrightarrow$~section~\ref{lyric*-verse-numbers}
\end{itemize}
These new features are especially interesting when \musixlyr\ is used in
conjunction with \PMX:
\begin{itemize}
\item Automatic detection of upper/lower voice context in
a two-voice staff; explicitly addressing lyrics commands to
auxiliary lyrics with \ci{auxlyr} is no longer required
$\longrightarrow$~section~\ref{auxlyr-attachment}
%
\item Context-dependent lyrics settings that do not need to be
adressed to absolute instrument/staff numbers, making lyrics
assignment robust against part extraction
$\longrightarrow$~section~\ref{assignment-by-context}
\end{itemize}
Finally, a few improvements have been made that do not bear explicit
new features but work rather behind the scenes:
\begin{itemize}
\item No more \TeX\ register allocations for each verse name newly
defined by \ci{setlyrics} or \ci{copylyrics}; the use
of those registers has been replaced by macros.
%
\item Due to the abandoned per-verse register allocations, the
\ci{enableauxlyrics} command is obsolete. It is retained for the
sake of backward compatibility, but it has no effect.
%
\item Slightly more robust processing of undefined verses. An error
is raised immediately when an undefined verse is assigned to a
staff/instrument, and the undefined verse name is implicitly
defined as having empty lyrics. This avoids obscure errors in later
stages of \TeX\ processing.
\end{itemize}
The current version~2.1c is mainly a bugfix version of~2.0, with a few
functional additions:
\begin{itemize}
\item Possibility to add additional lyrics to an existing lyrics
definition without discarding the remainder of the current lyrics
line contents; useful if lyrics are defined in several portions
spread over the score (see~\ref{appendlyrics}).
\item The \musixlyr\ version is identified by the predefined macro
\verb|\musixlyrversion|, enabling other \TeX\ code to check for
version compatibility (according to a suggestion by Dirk Laurie).
\end{itemize}
Suggestions for other useful things are welcome.
\subsection{Backward incompatibility issues}
The following properties make \musixlyr\ versions~2.$x$ incompatible
to earlier versions:
\begin{itemize}
\item
It is no longer possible to represent ``empty syllables'' by
empty \TeX\ environments `\verb|{}|' within \ci{setlyrics}; see
also section~\ref{empty-syllable}.
%
\item
Within \ci{setlyrics}, the underscore character has got a
special meaning and thus can no longer be used as usual; see
section~\ref{melismas-by-underscores}.
%
\item
By default, auxiliary lyrics are now placed vertically {\em
above\/} (no longer below) the staff they are assigned to; see
section~\ref{auxlyr-vertical-position-default}.
\end{itemize}
The following bugfix of \musixlyr~2.1b also implies a slight backward
incompatibility:
\begin{itemize}
\item
At the beginning of a music line (system), lyrics have often been
right-shifted because \musixlyr\ has assumed MusiXTeX's horizontal
``zero'' position as the left boundary for lyrics positioning. Now,
lyrics are allowed to extend into the left margin as far as
required for centered placement under/above the note.
Although this is a more ``natural'' behaviour, it may lead to
collisions between lyrics and other stuff (like dynamic marks) that
have not occurred using older \musixlyr\ versions. In such a case,
there are two ways to solve the problem:
%
\begin{itemize}
\item Restore the former \musixlyr\ behaviour globally by saying
\begin{quote}
\ci{oldlyrlinestart}
\end{quote}
near the top of your score source.
%
\item Right-shift the colliding lyrics where necessary using
\ci{lyroffset} (see~\ref{lyroffset}).
\end{itemize}
\end{itemize}
\subsection{Restrictions}
\begin{itemize}
\item \musixlyr\ does not influence the \musixtex/{\tt musixflx}
spacing algorithm in order to make the notes spacing dependent on
the space requirements of the lyrics. See section~\ref{horizpos}
about how spacing problems are handled.
%
\item \musixlyr\ seems to work correctly in my preferred working
environment, but I cannot exclude problems in situations I have
not undergone (especially concerning the use of \musixtex\
preprocessors, the \musixtex\ extension library, and past or
future \musixtex\ releases). Thus it is important that you point out
encountered bugs and incompatibilities to me; there is little
chance that I notice them on my own.
Please do also bother me if you find this manual --- or parts of
it --- incomprehensible or incomplete.
\end{itemize}
\section{Installation}
Put the {\tt musixlyr.tex} file into a directory that is included in
your \verb|TEXINPUTS| search path --- that's all. (Refer to your local \TeX\
documentation for details on this.)
\section{Usage}
Before using \musixlyr\ macros, state
\begin{quote}\verb|\input musixlyr|\end{quote}
near the beginning of your source file but {\bf after} the
\verb|\input musixtex| (\LaTeX: \verb|\usepackage{musixtex}|)
command.
\subsection{Entering lyrics}
\subsubsection{Lyrics as lines of words}
As opposed to the ``vertical'' music construction of
\musixtex, \musixlyr\ treats lyrics ``horizontally'' as {\em lyrics
lines.\/} Each separate ``thread'' of words is a separate lyrics
line; thus, in the following example\footnote{Excerpt from
``Tourdion'' by {\sc Pierre Attaignant} ({\sl ars
musica\/} vol.\,4, M\"oseler Verlag Wolfenb\"uttel/Z\"urich)},
\begin{music}
\setlyrics{soprano}
{Quand je bois du vin clai-ret, a-mi tout}
\setlyrics{alto}{Le bon vin nous}
\setlyrics{tenor}{Bu-vons bien, bu-vons mes a-mis,}
\copylyrics{tenor}{bass}
\assignlyrics4{soprano}
\assignlyrics3{alto}
\assignlyrics2{tenor}
\assignlyrics1{bass}
\setsongraise3{-1.5mm}
\small
\instrumentnumber4
\generalsignature2
\generalmeter{\meterfrac32}
\setclef1\bass
\songtop4
\songbottom1
\sepbarrules
\startextract
\NOtes\wh{`e}\sk\sk\sk\ha e&%
\wh g\sk\sk\sk\ha e&%
\wh b\sk\sk\sk\ha b&%
\qa{efg'a!gf}\en\bar
\NOTesp\wh{`e}&\wh{'b}&\wh e&\hup e\en
\NOtes\sk\ha{`e}&\sk\ha{'b}&\sk\ha e&\qa{fg'a}\en
% force hyphens of incomplete words:
\def\atnextbar{\znotes\lyric{}&\lyric{}\en}%
\endextract
\end{music}
\oneversespace
there are four lyrics lines notwithstanding that two of them consist
of the same words.
Note that the number of lyrics lines does not depend on the number
of staves: Any number of lyrics lines (including none) can be attached
to each staff (more about multiple lyrics lines per staff in
section~\ref{multilyrlines}).
\subsubsection{Setting up a lyrics line}
A lyrics line is set up using the command
\begin{quote}
\ci{setlyrics}\verb|{|\var{name}\verb|}{|\var{words}\/\verb|}|
\end{quote}
where \var{name} is a name\footnote{This name must not contain
backslashes or commas. Most other characters do not cause problems;
however, it is safer to use only letters and digits.} for the lyrics
line (e.\,g.\ the name of the voice singing these lyrics) and
\var{words} is the complete text where multi-syllable words must be
given {\bf hyphenated.} For example, the soprano lyrics of the above
example are set as follows:
\begin{quote}
\bci{setlyrics}
\begin{verbatim}
\setlyrics{soprano}{Quand je bois du vin clai-ret, a-mi tout}\end{verbatim}
\end{quote}
Important notes on using \ci{setlyrics}:
\begin{itemize}
\item
Within the lyrics definition, spaces and hyphens are used to
split the whole text into words or syllables. If you want a space
or hyphen appear {\em within\/} a word/syllable, use the command
\verb|\space| or \ci{lyrhyphenchar}, respectively, instead.
\item
\label{empty-syllable}%
If you want the lyrics attachment to skip over a note,
i.\,e.~a certain note shall not receive a syllable, you may
achieve this by inserting an empty syllable in the \var{words}
text. However, neither a ``really empty'' syllable (i.\,e.~two
consecutive separating spaces) nor an empty environment \verb|{}|
will work, but you may use either \verb|{\empty}| or
\verb|\empty{}| for this.
Normally, the \ci{nolyr} command (discussed later in this
manual) should be used for this purpose, but an empty syllable may
be more handy if it occurs in only one of multiple assigned
verses; see also sections~\ref{melismas-by-underscores}
and~\ref{multilyrlines}.
\item
Note that, since lyrics lines are cut into pieces which are
processed separately, you cannot apply things like temporary font
changes in the usual manner (i.\,e.~using \TeX\
environments). See section~\ref{layoutpar} about how to accomplish
layout changes.
\item
Applying \ci{setlyrics} to an already defined \var{name}
redefines the lyrics line. This may be useful at very long pieces
because setting up and applying lyrics in smaller portions
(e.\,g.\ movement by movement) saves both time and memory.
\item
It is possible to specify melismas --- that shall occur later when
a verse is attached to the music --- already within
\ci{setlyrics}; see section~\ref{melismas-by-underscores} for
details.
\end{itemize}
There are two variants of the \verb|\setlyrics| command available:
\begin{itemize}
\item
If several voices have the same lyrics, you do not have to copy
and paste the lyrics for each further voice; just say
\begin{quote}\ci{copylyrics}\verb|{|\var{from name}%
\verb|}{|\var{to name}\verb|}|\end{quote}
to set up a lyrics line named \var{to name} with the same contents
as \var{from name}.
\item
Applying \ci{setlyrics} to an already defined \var{name}
has the effect of discarding all previous contents of \var{name},
even if part of the lyrics is still pending for being
processed. If you want to {\em append\/} further lyrics to an already
existing lyrics line instead --- without interrupting the
processing of the current lyrics contents ---, use the command
\label{appendlyrics}
\begin{quote}
\ci{appendlyrics}\verb|{|\var{name}\verb|}{|\var{words}\/\verb|}|
\end{quote}
instead of \verb|\setlyrics|.
% A warning about performance loss due to \appendlyrics's material
% accumulation may be added here; it should occur only if \golyr
% jumps to or near to the lyrics beginning are performed.
\end{itemize}
\subsubsection{Assigning lyrics lines to staves}
{\bf Note:} During the following discussion, the term {\em staff\/} is
used wherever \musixtex\ would precisely use the term {\em
instrument\/} instead, assuming that lyrics are posted to single-staff
instruments only. However, everything also applies to the assignment
of lyrics to staves of multi-staff instruments; see
section~\ref{multi-staff-instruments} about how to use lyrics in a
multi-staff instrument context.
To assign a lyrics line to a staff, say
\begin{quote}\ci{assignlyrics}\verb|{|\var i%
\verb|}{|\var{name}\verb|}|\end{quote}
where \var i is the instrument number (counted as usual from bottom to
top) and \var{name} the name of the lyrics line.
The resulting assignment can be redefined everywhere. This is useful
if the arrangement of voices on staves changes within the score; when
a voice is continued on a different staff at the next system, use
\ci{assignlyrics} (preferrably enclosed in \verb|\atnextline{...}|) to
make the respective lyrics line follow this change without
interrupting the flow of words.
If a lyrics line is assigned to instrument \var i and you want it to be
continued on a different instrument while assigning no other lyrics line
to instrument \var i, you must explicitly cancel the former assignment by
saying \ci{assignlyrics}\verb|{|\var i\verb|}{}|.
{\bf Caution:} Never assign a lyrics line to more than one
staff simultaneously; if the same lyrics are needed at
several staves in parallel, use \ci{copylyrics} (see above).
As a summary of this section, here is the complete ``lyrics
definition section'' of the above example:
\begin{quote}
\bci{setlyrics}
\bci{copylyrics}
\bci{assignlyrics}
\begin{verbatim}
\setlyrics {soprano}{Quand je bois du vin clai-ret, a-mi tout}
\setlyrics {alto} {Le bon vin nous}
\setlyrics {tenor} {Bu-vons bien, bu}
\copylyrics{tenor} {bass}
\assignlyrics4{soprano}
\assignlyrics3{alto}
\assignlyrics2{tenor}
\assignlyrics1{bass}\end{verbatim}
\end{quote}
See also section~\ref{assignment-by-context} about an alternative way
to assign lyrics to staves.
\subsection{Managing the attachment of lyrics to notes}
\label{manipulation}
\subsubsection{Automatic lyrics attachment}
\label{auto-attachment}
By default, the syllables of a lyrics line are consecutively attached to
all {\em spacing\/} notes of the assigned staff. Chords thus receive only
one syllable since they usually contain exactly one spacing note.
However, this may be different if you are using auxiliary lyrics;
see section~\ref{auxlyrics} for details.
``Spacing'' in this context means: generated by one of the commands
\verb|\qu|, \verb|\hu|, \verb|\wh|, etc.\ and not by \verb|\zqu|,
\verb|\zhu|, \verb|\zq|, etc. Spacing or not does {\em not\/} depend on
whether the note-generating command is enclosed in \verb|\znotes| or
any other \verb|\notes| command. So if any note seems to have been
left out by the attachment automatism, first make sure that this
note is generated using a command not beginning with \verb|\z|.
If the number of words of a lyrics line gets exhausted before all
notes of the respective staff are processed, ``???'' is posted at all
remaining notes.
\subsubsection{Addressing manipulations to lyrics}
In the ``ideal'' case, the attachment automatism perfectly distributes the
lyrics over the music. In practice, however, situations in which the
automatism must be ``helped'' manually are frequent. Such
manipulations must be posted within the music code. Here are the
basic rules:
\begin{enumerate}
\item All lyrics manipulations must be stated inside
\verb|\notes...\enotes|.
(Exception: melisma specifications within \verb|\setlyrics|, see
section~\ref{melismas-by-underscores}).
\item Lyrics manipulations solely refer to the lyrics line(s)
attached to the current staff (``current'' with respect to the
enclosing `\verb|&|' characters).
\item Similar to many other \musixtex\ commands (e.\,g.\ for beams
and slurs), lyrics manipulations must be issued before the
corresponding note commands.
\end{enumerate}
Examples in the following sections will illustrate the application.
\subsubsection{Melismas}
\label{melismas}
Regarding lyrics and music separately, melismas are no property of
either one; instead, they characterize the relation between both and
play a role only where music and lyrics occur together. Using
\musixlyr, however, lyrics coding and music coding are basically
unrelated, but melismas do have to be specified somewhere. You have to
decide yourself whether you regard melismas as an attribute rather of
the lyrics or rather of the music (this may vary according to the type
of score you are preparing, or may even differ within a score);
\musixlyr\ provides two corresponding styles of melisma specification
which are discussed in the following paragraphs.
\begin{description}
\item[Melismas as a music property.]
Within the music code, a melisma is initiated and terminated by the
command pair
\begin{quote}
\hspace*{\fill}\ci{beginmel}\hfill\ci{endmel}\hspace*{\fill}
\end{quote}
issued before the first and last note, respectively, of the melisma.
This left-justifies the current word/syllable, suspends lyrics until
after the melisma, and sets up a ``word extension
underline''\footnote{I am not sure whether this is the appropriate
term; it is taken from the {\sl Finale\/} reference manual.} unless
the current word is continued afterwards and thus has to be
hyphenated. For example,
\begin{music}
\resetlyrics
\instrumentnumber1
\small\scale{0.6}
\setlyrics{melismatic}{a me-lis-ma}
\assignlyrics1{melismatic}
\startextract
\NOtes\beginmel\qa{def}\endmel\qa e\en\bar
\NOtes\beginmel\qa{def}\endmel\qa g\en\bar
\NOtes\beginmel\qa{'a!gf}\endmel\qa e\en\bar
\NOtes\beginmel\qa{defe}\en\bar
\NOTEs\endmel\wh d\en
\endextract
\end{music}
\oneversespace
has been coded as:
\begin{quote}
\bci{beginmel}
\bci{endmel}
\begin{verbatim}
...
\NOtes\beginmel\qa{def}\endmel\qa e\en\bar
\NOtes\beginmel\qa{def}\endmel\qa g\en\bar
\NOtes\beginmel\qa{'a!gf}\endmel\qa e\en\bar
\NOtes\beginmel\qa{defe}\en\bar
\NOTEs\endmel\wh d\en
...\end{verbatim}
\end{quote}
If a system break occurs within the melisma, hyphenation or underline
is continued at the next system, thus automatic line breaking is
applicable.
\item[Melismas as a lyrics property.]
\label{melismas-by-underscores}
To specify a melisma within a lyrics definition (i.\,e.~within
\ci{setlyrics} or \ci{appendlyrics}), simply append an underscore
character to a syllable to make it span over an additional note,
two underscores to span over two additional notes, and so
on. Alternatively, you may append to a syllable a single underscore
followed by a number which denotes the number of {\em additional\/}
melisma notes: \verb|abc_| is equivalent to \verb|abc_1|,
\verb|abc__| to \verb|abc_2|, and so on.
No matter which of the two underscore appendix styles you use: If a
melismatic syllable is hyphenated to the following one, the melisma
denotation must {\bf precede} the hyphen --- for example:
\verb|abc__-def| ({\bf not:} \verb|abc-__def|).
All melisma properties mentioned above (lyrics suspension, left
justification of syllable, word extension underline, system break
support) also apply to melismas specified this way. For reference,
here is the lyrics definition section of the example above, this time
utilizing the underscore melisma technique (note that, in this case,
all \ci{beginmel} and \ci{endmel} commands must be omitted in the
music section):
\begin{quote}
\ci{setlyrics}\verb|{melismatic}{a___ me_3-lis___-ma_4}|
\end{quote}
\item[Comparing both points of view.]
The music-oriented melisma view (using \ci{beginmel}/\ci{endmel}) is
advantageous for music with a rather loose binding to certain lyrics,
e.\,g.~folk songs that are to be printed with various verse compilations
or in different languages. You may then enter each verse without
taking care of melismas because they are coded just once as part of
the music.
On the other hand, the lyrics-focused melisma style (using
underscores) is best suited to pieces with a fixed lyrics-to-music
binding; it is easier to type and to read, but less flexible as
regards combining the same lyrics with different music. It is
especially advantageous for multiple verses (see
section~\ref{multilyrlines}) with different syllables-to-notes
distribution (see verse~3 of the ``Drunken sailor'' example in
section~\ref{versenumbers}); it is much easier to code each verse's
melismas individually than tracking all melismas in parallel using
the \ci{verses} command (see again section~\ref{multilyrlines}).
\item[Note.]
You may use both styles within the same score but you should avoid
activating both melisma types simultaneously at the same lyrics line;
the result of such an occurrence is undefined.
\end{description}
\subsubsection{Turning automatic lyrics attachment on/off}
If the attachment automatism is unsuitable for some
situation --- e.\,g.\ at complex polyphonic voicings or wherever you
want to place all syllables manually --- you can turn it off using
\begin{quote}\ci{lyricsoff}\end{quote}
after the last note that shall get a syllable. (If your piece begins
with a lyrics-less section, state \ci{lyricsoff} before the first
note of a staff.) To re-enable automatic lyrics attachment, use
\begin{quote}\ci{lyricson}\end{quote}
before the first note that shall get a syllable.
If automatic lyrics attachment shall skip over certain single notes
only, the \ci{nolyr} command is more suitable (see
section~\ref{nolyr-command}).
\subsubsection{Lyrics repetition and skipping}
As in the following example of a polyphonic piece,
\begin{music}
\resetlyrics
\instrumentnumber2
\setclef1\bass
\songtop2
\songbottom1
\small
\setlyrics{amen1}
{\llabel{amenlabel}A-men!} \assignlyrics1{amen1}
\copylyrics{amen1}{amen2} \assignlyrics2{amen2}
\startextract
\NOtes% lower staff:
\itenu0K\beginmel\wh K\sk\sk\sk
\midslur2\tten0\endmel\hlp K&%
% upper staff:
\qa f\lyrnop\lyrpt,\qa g%
\golyr{amenlabel}\lclyr\qa h\lyrnop\lyrpt,\qa{_i}%
\golyr{amenlabel}\lclyr\beginmel\islurd1h\qa{hg}%
\tslur1f\endmel\qa f\en
\NOTEs\wh N&\wh g\en
\endextract
\end{music}
\oneversespace
it often happens that some lyrics phrases are repeated by some but
not all voices, or that each voice has its individual arrangement of
lyrics repetitions. Nevertheless, you do not have to enter
these repetitions directly within \ci{setlyrics}; instead, you
enter the lyrics as if they were performed in an unbroken
sequence. Repetitions and skips are then handled using a ``go to''
technique involving the following steps:
\begin{description}
\item[Labelling ``go to'' targets.] A syllable which has to be jumped at
must be preceded (without spaces in between) by
\begin{quote}\ci{llabel}\verb|{|\var{label name}\verb|}|\end{quote}
within \ci{setlyrics}.
\item[Performing jumps.] Within the music code, say
\begin{quote}\ci{golyr}\verb|{|\var{label name}\verb|}|\end{quote}
before the note at which the jump has to be performed.
{\bf Caution:} If you try to jump to an undefined lyrics label, no
meaningful error message is produced. However, if \TeX\ reports an
error at a \ci{golyr} command, you should check conformity of
defined and used labels.
\end{description}
The following actions must be taken in special cases:
\begin{description}
\item[Adding punctuation marks.] Usually a comma or period is
appended to the word preceding a jump; this is done by the command
\begin{quote}\ci{lyrpt}\var{punctuation char}\end{quote}
where \var{punctuation char} can be any single punctuation
character.
\item[Removing punctuation marks.] Before adding a punctuation mark
to a word as said above, an already existing punctuation mark
should be removed by the command:
\begin{quote}\ci{lyrnop}\end{quote}
\item[Lower case letters.] Words at jump targets often begin with a
capital letter which should appear lower case after a jump;
this can be forced by the command:
\begin{quote}\ci{lclyr}\end{quote}
\end{description}
Here is a code excerpt from the above example, summarizing the use of
all mentioned commands:
\begin{quote}\small
\bci{llabel}
\bci{copylyrics}
\bci{setlyrics}
\bci{lyrnop}
\bci{lyrpt}
\bci{golyr}
\bci{lclyr}
\bci{beginmel}
\bci{endmel}
\begin{verbatim}
\setlyrics{amen1}
{\llabel{amenlabel}A-men!} \assignlyrics1{amen1}
\copylyrics{amen1}{amen2} \assignlyrics2{amen2}
\startextract
\NOtes% lower staff:
\itenu0K\beginmel\wh K\sk\sk\sk
\midslur2\tten0\endmel\hlp K&%
% upper staff:
\qa f\lyrnop\lyrpt,\qa g%
\golyr{amenlabel}\lclyr\qa h\lyrnop\lyrpt,\qa{_i}%
\golyr{amenlabel}\lclyr\beginmel\islurd1h\qa{hg}%
\tslur1f\endmel\qa f\en
\NOTEs\wh N&\wh g\en
\endextract\end{verbatim}
\end{quote}
Note that the ``go to'' technique is recommendable mainly if different
voices perform different repetitions or skips on the same lyrics; if
all voices perform the same sequence of repetitions, however, it is
easier to hard-code them within \ci{setlyrics}.
\subsubsection{Miscellaneous}
\label{miscmanip}
\begin{description}
\item[Excluding single notes.]
\label{nolyr-command}%
In the following situation,
\begin{music}
\resetlyrics
\instrumentnumber1
\setlyrics1{ca-den-za}
\assignlyrics11
\startextract
\NOtes\zqlp{'c}\qu e\en
\Notes\qu{'d}\nolyr\cl b\en
\bar
\NOTes\zhl{'c}\hu c\en
\endextract
\end{music}
\oneversespace
the eighth note must be excluded from receiving a syllable. This
can be accomplished saying
\begin{quote}\ci{nolyr}\end{quote}
before the command generating this note.
\item[Manual lyrics posting.] When automatic lyrics attaching is
switched off, a word or syllable can be placed manually saying
\begin{quote}\ci{lyr}\end{quote}
before the command generating the note that shall get this
word/syllable.
This command also works independently from a following note command;
you can issue it before a rest, a \verb|\sk| or even alone for
itself in order to place a word/syllable wherever you want (no
matter whether the attachment automatism is on or off).
Manipulations to the posted word/syllable have to be placed {\em
before\/} the \ci{lyr} command.
\item[Left justification.] Say
\begin{quote}\ci{llyr}\end{quote}
in order to have the next word/syllable left-justified to the
notehead instead of centered.
If you prefer to have left justification as the default, say
\begin{quote}\ci{leftlyrtrue}\end{quote}
before your piece begins (\ci{leftlyrfalse} to restore centered
lyrics).
\item[Word extension underlines.] The melisma commands (see
\ref{melismas}) automatically manage word extension underlines;
however, they can be set manually: Say
\begin{quote}\ci{lyrrule}\end{quote}
before the respective note command to initiate an underline {\em
after\/} the word, and
\begin{quote}\ci{lyrruleend}\end{quote}
before the note where the underline shall be terminated.
Note that no underline will be drawn if the word is continued
afterwards so that the underline would interfere with the
hyphenation.
\item[Horizontal offset.]\label{lyroffset}%
To shift a word/syllable out of its default
horizontal position, say
\begin{quote}\ci{lyroffset}\verb|{|\var n\verb|}|\end{quote}
which --- similar to \verb|\roffset| --- moves the next word/syllable
\var n quarter note head widths to the right (left if \var n
is negative).
Note that the effect of \ci{lyroffset} may be overridden by
automatic lyrics shifting. If you want to gain complete manual
control over the positioning, you have to disable the shifting
automatism; see section \ref{horizpos} for details.
\item[Extra lyrics.] If, as in the following
example\footnote{Excerpt from ``In the town where I was born''
({\sl Eine kleine Melodie,\/} Strube, M\"unchen 1989)},
\begin{music}
\resetlyrics
\instrumentnumber2
\generalsignature1
\setclef1\bass
\songtop2
\songbottom1
\interinstrument=6mm
\setsongraise2{-0.5mm}
\scale{1.5}
\forcelyrhyphenstrue
\small
\setlyrics{lower}{yel-low sub-ma-rine,} \assignlyrics1{lower}
\copylyrics{lower}{upper} \assignlyrics2{upper}
\startextract
\Notes\ibl0N0\zqbp0N\ibu1N0\qbp1b&%
\ibl2f0\zqbp2d\ibu3g0\qbp3g\en
\notes\tbbl0\tbl0\zqb0N\tbbu1\tbu1\qb1b&%
\tbbl2\tbl2\zqb2d\tbbu3\tbu3\qb3g\en
\Notes\ibl0M0\zqbp0M\ibu1N0\qbp1b&%
\ibl2f0\zqbp2d\ibu3g0\qbp3g\en
\notes\tbbl0\tbl0\zqb0M\tbbu1\tbu1\qb1b&%
\tbbl2\tbl2\zqb2d\tbbu3\tbu3\qb3g\en
\Notes\ibl0L{-1}\zqbp0L\hu b&\zhl d\hu g\en
\notes\tbbl0\tbl0\lyric{ya,}\qb0K\en
\Notes\ibl0L1\lyric{ya,}\qbp0L\en
\notes\tbbl0\tbl0\lyric{ya,}\qb0M\en
\endextract
\end{music}
\oneversespace
a voice has ``extra'' lyrics (such as ``hmm'', ``ah'', ``ya'', etc.)
in addition to the ``main'' lyrics, you need not enter them within
\ci{setlyrics} (which would inhibit using \ci{copylyrics});
instead, you can enter them directly within the music code using
the command
\begin{quote}\ci{lyric}\verb|{|\var{extra syllable}\verb|}|\end{quote}
before the note where they shall appear. (Note that the effect is
different from using \verb|\csong| which would not apply automatic
hyphenation, horizontal positioning control, and \musixlyr's
vertical positioning scheme.) Automatic lyrics attaching --- if
active --- is suspended at that note. All manipulations can be
applied; they must be given before the \ci{lyric} command.
If you want the syllable linked to the following one by a hyphen,
use \ci{lyrich} instead of \ci{lyric}.
It may sometimes be necessary to post lyrics where no note is
present at all, i.\,e.~in the empty space between notes. This is,
however, possible with \verb|\lyric|, but is is unsuitable because
automatic lyrics attachment shall {\em not\/} be suspended at the
next note. In this case one of the commands \ci{lyric*} or --- for
hyphenated syllables --- \ci{lyrich*} should rather be used; they
have no effect on the ``regular'' flow of lyrics.
\label{lyric*-verse-numbers}%
One application for this are vertically aligned verse numbers. For
example,
\begin{quote}
\bci{lyric*}
\bci{verses}
\begin{verbatim}
\setlyrics1{Spring time}
\setlyrics2{Au-tumn}
\assignlyrics1{1,2}
...
\znotes\loffset{2.2}{\verses{\lyric*{1.},\lyric*{2.}}}\en
\hardspace{4mm}%
\NOTes\hu{ee}\en
...\end{verbatim}
\end{quote}
yields:
\begin{music}
\resetlyrics
\setlyrics1{Spring time}
\setlyrics2{Au-tumn}
\assignlyrics1{1,2}
\lyrraise1{b -1.5mm}
\scale{1.2}
\startextract
\znotes\loffset{2.2}{\verses{\lyric*{1.},\lyric*{2.}}}\en
\hardspace{4mm}%
\NOTes\hu{ee}\en
\endextract
\twoversesspace
\end{music}
(See section~\ref{multilyrlines} about attaching multiple verses
to a single staff, a feature that has not been introduced so far.)
You may even obtain verse numbers that are repeated at the
beginning of each system by enclosing the \verb|\znotes...| command
for setting the numbers in \verb|\def\everystaff{...}|.
Another possible application --- combined with empty syllables ---
is coping with unusual lyrics situations at voltas; for example,
\begin{music}
\twoversesspace
\setlyrics1{first pass}
\setlyrics2{se-cond pass}
\assignlyrics1{1,2}
\resetlyrics
\scale{2}
\startextract
\NOTEs\wh g\en
\Setvolta1\def\atnextbar{\znotes\verses{,\lyric{}}\en}\bar
\NOTEs\wh g\en
\znotes\verses{,\lyrich*{}}\en \Setvolta2\setendvoltabox\rightrepeat
\NOTEs\verses\lyricsoff\pause\en\bar
\NOTEs\ha{gg}\en\setendvolta
\endextract
\twoversesspace
\end{music}
is accomplished by:
\begin{quote}
\bci{verses}
\bci{lyric}
\bci{lyrich*}
\begin{verbatim}
\setlyrics1{first pass}
\setlyrics2{se-cond pass}
\assignlyrics1{1,2}
\startextract
\NOTEs\wh g\en
\Setvolta1\def\atnextbar{\znotes\verses{,\lyric{}}\en}\bar
\NOTEs\wh g\en
\znotes\verses{,\lyrich*{}}\en
\Setvolta2\setendvoltabox\rightrepeat
\NOTEs\verses\lyricsoff\pause\en\bar
\NOTEs\ha{gg}\en\setendvolta
\endextract\end{verbatim}
\end{quote}
The trick used here is to inject empty syllables into the second
verse at the barlines around the first volta; they serve as anchors
for the hyphenation suspended under this volta.
Note that the \ci{lyric}, \ci{lyric*}, \ci{lyrich}, and
\ci{lyrich*} commands cannot be used at staves without assigned
lyrics lines.
\end{description}
\subsection{Horizontal positioning}
\label{horizpos}
\musixlyr\ takes care of blank space between words. If a word --- at
its default position --- would come too close to or overlap the
previous word, it is shifted right in order to ensure a minimum of
blank space. This minimal interword space can be set by
\begin{quote}\ci{minlyrspace}\verb|=|\var{any \TeX\ dimension}\end{quote}
and is initially set to~3\,pt.
%The situation is different if two syllables belong to the same
%word. Such syllables are allowed to close up; only overlapping is
%inhibited by shifting. If the space between such syllables is
%narrower than a hyphen, the hyphen is omitted unless you force
%hyphens in every spatial situation saying
%\begin{quote}\verb|\forcelyrhyphenstrue|\end{quote}
%(to restore the default behaviour: \verb|\forcelyrhyphensfalse|). In
%this case, enough room is made for the hyphen by shifting the right
%syllable if necessary.
\leavevmode\label{nicerhyphens}%
The situation is different if two syllables belong to the same
word. Such syllables are allowed to close up; only overlapping is
inhibited by shifting. If the ``natural'' space between such syllables is
narrower than a hyphen, the hyphen is omitted and the two syllables
close up completely (eventually by left-shifting the second syllable
to prevent a small gap). You may though force
hyphens in every spatial situation saying
\begin{quote}\ci{forcelyrhyphenstrue}\end{quote}
(to restore the default behaviour: \ci{forcelyrhyphensfalse}). In
this case, enough room is made for the hyphen by right-shifting the
second syllable if necessary.
If the note spacing is quite narrow, lyrics shifting may get
accumulated within a system. In order to prevent shifting words too
far out of their original position, a wider note spacing should be
considered. The command
\begin{quote}\ci{showlyrshifttrue}\end{quote}
marks each lyric shift with a black rectangle of the respective
width, thus making it easy to detect questionable positionings.
If you prefer to completely disable lyrics shifting, set
\ci{minlyrspace} to a large negative value (e.\,g.~$-10$\,cm).
\subsection{Vertical positioning}
\label{vertical-positioning}
By default, \musixlyr\ places lyrics vertically centered between the
two adjacent staves. Lyrics below the lowest or above the topmost
staff of a system are centered around the system's bottom or top
margin line.%
\footnote{This is not necessarily the most reasonable way, but it is
compatible to \musixtex's \printcmd{csong} behaviour.}
In most scores, you will have to deviate from this standard and
manually adjust the lyrics' vertical position. This can be done per
staff with the command
\begin{quote}
\ci{lyrraise}\verb|{|\var n\verb|}|\verb|{|\var{pos}\var{raise}\verb|}|
\end{quote}
which applies the following setting to the lyrics attached to staff
number~\var n: \var{pos} is one of the letters \verb|a|
and~\verb|b|. \verb|a| sets the lyrics above the staff, \verb|b| below
the staff. \var{raise} is a dimension value by which the lyrics are
lifted above (or lowered under, if it is negative) the default
position as mentioned above. \ci{lyrraise}\verb|{|\var n\verb|}{b0pt}|
is the initial setting for all staves.
It is possible to apply changes to the vertical position at any place
within the score, but in most cases it is most reasonable to do so
within \verb|\atnextline{...}| which ensures consistent, even spacing
within each system.
For the sake of backward compatibility, applying \musixtex's command
\ci{setsongraise}\verb|{|\var n\verb|}{|\var{raise}\verb|}|
implicitly performs a
\ci{lyrraise}\verb|{|\var n\verb|}|\verb|{b|\var{raise}\verb|}|,
but not vice versa --- i.\,e.~\ci{lyrraise} has no effect on lyrics
set with \musixtex's lyrics commands \verb|\csong|,
\verb|\zsong|,~etc. Likewise, the obsolete \musixlyr\ command
\ci{auxsetsongraise} implies \verb|\auxlyr{\lyrraise...{b...}}|, but
not vice versa (see section~\ref{auxlyrics} to learn about the meaning
of \verb|\auxlyr|).
\subsection{Setting lyrics layout parameters}
\label{layoutpar}
\subsubsection{Available parameters}
\begin{description}
\item[Font:] There is no special font command; the current font is
used for lyrics. It can be changed using the usual \TeX/\LaTeX\
commands.
\item[Minimum length of word extension underlines:] A word extension
underline is omitted if it would become too short. The minimum
length can be set by
\begin{quote}\ci{minlyrrulelength}\verb|=|\var{any \TeX\ dimension}
\end{quote}
and is initially set to~2\,mm. If you prefer to completely inhibit
the underlines, set this parameter to an unsurpassably high value
(e.\,g.~the width of your paper).
\item[Minimum inter-syllable distance for multiple hyphens:] If the
space between two hyphenated syllables (or between one of the
syllables and the respective system margin) is wider than this
distance, it is filled with a line of hyphens instead of a single
hyphen. The minimum distance to be filled with more than one
hyphen can be set by
\begin{quote}\ci{minmulthyphens}\verb|=|\var{any \TeX\ dimension}\end{quote}
and is initially set to~15\,mm. If you prefer to completely inhibit
filling with multiple hyphens, set this parameter to an
unsurpassably high value.
\item[Hyphen character:] This can be redefined by:
\begin{quote}\verb|\def|\ci{lyrhyphenchar}\verb|{|\dots\verb|}|\end{quote}
\end{description}
Further layout parameters discussed elsewhere are: vertical
positioning (section \ref{vertical-positioning}), word justification
(section \ref{miscmanip}), minimum interword distance, and forcing
hyphens (section \ref{horizpos}).
{\bf Note:} In order to change the mentioned parameters globally, the
respective commands must be issued {\em outside\/}
\verb|\notes...\enotes|.
\subsubsection{Individual settings per staff}
\label{indivlayout}
All layout parameters can be set either globally (applying to all
lyrics lines) or individually, i.\,e.\ valid for a single specified staff.
An individual change is accomplished by enclosing the proper command
in
\begin{quote}\ci{lyrlayout}\verb|{|\dots\verb|}|\end{quote}
and issuing this within \verb|\notes...\enotes| in the section of the
referred-to staff. For example,
\begin{quote}
\verb|\notes...&|\ci{lyrlayout}\verb|{\it\leftlyrtrue}...&...\en|
\end{quote}
applies italic font and left justification to the lyrics line(s)
assigned to the second staff.
Applying \ci{lyrlayout} to the same staff again overrides
{\em all\/} previous individual settings for this staff;
pay attention to this if you have made several individual settings and
want to reset some but retain others. Saying \ci{lyrlayout}\verb|{}|
restores the global settings for a staff.
The \ci{lyrlayout} command can also be used within
\ci{setlyrics}; this is useful if an individual setting
(especially a font change) should apply to a particular
portion of lyrics rather than to a portion of music. For example,
\begin{quote}
\ci{setlyrics}\verb|{x}{An |\ci{lyrlayout}%
\verb|{\it}em-pha-sized\lyrlayout{} phrase}|
\end{quote}
causes the word ``emphasized'' to appear italic wherever it is posted
within the music. (Be sure to attach \ci{lyrlayout} commands to
the corresponding lyrics portions {\em without\/} blank spaces in
between.)
{\bf As an exception,} the {\bf vertical positioning of lyrics} cannot be
changed within \ci{lyrlayout}; instead, it is handled staff-wise
using the special commands discussed in
section~\ref{vertical-positioning}.
\subsection{Multiple verses per staff}
\label{multilyrlines}
An arbitrary number of verses can be assigned to a staff
straightforwardly by saying
\begin{quote}\ci{assignlyrics}\verb|{|\var n\verb|}{|%
\var{names}\verb|}|\end{quote}
where \var{names} is a {\bf comma-separated list} of the desired
lyrics line names, listed from top to bottom. In the following
example\footnote{Excerpt from: ``Non moriar sed vivam'', motet by
{\sc Martin Luther}},
\begin{music}
\resetlyrics
\generalmeter\allabreve
\generalsignature2
\scale{0.9}
\setlyrics{latin} {Non mo-ri-ar sed}
\setlyrics{german}{Ich wer-de nicht ster-ben, son-dern}
\assignlyrics1{latin,german}
\small
\setsongraise1{-1.5mm}
\startextract
\znotes\verses{,\lyrlayout{\footnotesize\it}}\en
\NOTEs\wh{'a}\en\bar
\NOTes\verses{\beginmel}\ha{'b}\verses{\endmel}\ha a\en\bar
\NOtesp\beginmel\qup{'a}\en
\Notes\ca{'b}\en
\NOtes\verses{,\endmel}\qa{'c}\verses{,\beginmel}\itieu0d\qa d\en\bar
\NOtes\ttie0\qa{'d}\endmel\qa c\en
\NOtes\verses{\beginmel}\ha{'d}\en\bar
\NOTes\verses{\endmel}\ha{'ee}\en
\endextract
\end{music}
\twoversesspace
the lyrics lines have been set up as follows:
\begin{quote}
\bci{assignlyrics}
\begin{verbatim}
\setlyrics{latin} {Non mo-ri-ar sed}
\setlyrics{german}{Ich wer-de nicht ster-ben, son-dern}
\assignlyrics1{latin,german}\end{verbatim}
\end{quote}
\subsubsection{Handling verses individually}
If you code lyrics attachment manipulations the way
described in section~\ref{manipulation}, these manipulations apply
{\em to all lyrics lines\/} of the referred staff {\em
simultaneously.\/} In order to address each lyrics line separately,
use the command
\begin{quote}
\ci{verses}\verb|{|\var{man1}\verb|,|\var{man2}\verb|,|\dots\verb|}|
\end{quote}
where \var{man1} is a sequence of commands to manipulate the upper
lyrics line, \var{man2} to manipulate the second lyrics line from
above, and so on. These command sequences may be empty. Delimiting
commas after the last non-empty list entry can be omitted. For example,
\begin{quote}
\ci{verses}\verb|{,,\beginmel,\golyr{abc}}|
\end{quote}
leaves the upper two lyrics lines unaltered, initiates a melisma at
the third, performs a jump to label {\tt abc} at the fourth, and
leaves all further ones (whatever their number may be) unaltered. As
another example, the font change for the german lyrics of the above
excerpt is accomplished by
\begin{quote}
\verb|\znotes|\ci{verses}\verb|{,\lyrlayout{\footnotesize\it}}\en|
\end{quote}
before the first note is coded.
\subsubsection{Vertical positioning}
\label{multiple-vert-pos}
A block of multiple lyrics lines is vertically centered around the position
which a single lyrics line would have taken; thus you can do things
like
{\small\setlyrstrut
\resetlyrics
\setlyrics{Winter1}{Win-ter a-de\rlap{,} a-ber dein Schei-den macht\rlap{,}}
\setlyrics{Winter2}{schei-den tut weh\rlap,}
\assignlyrics1{Winter1,Winter2}
\generalmeter{\meterfrac34}
\generalsignature2
\setsongraise1{-2mm}
\startextract
\NOtes\qa{ffe}\en\bar
\NOTesp\hup d\en\rightrepeat
\assignlyrics1{Winter1}%
\NOtes\qa{fgh}\en\bar
\NOtes\qa h\en
\Notes\beginmel\Ibu0gf1\qb0g\endmel\tqh0f\en
\NOtes\qa g\en
\endextract}
\twoversesspace
without having to adjust the vertical position within the
piece. (See the source of this manual for the coding of this
example.)
\leavevmode\label{lyrstrut}%
The vertical distance between the baselines of multiple verses is
appropriate for the default 10~points font size of plain \TeX.
However, the size-switching commands \verb|\smalltype|,
\verb|\medtype|~etc.\ do not implicitly adjust the vertical distance
to the chosen font size. Since the vertical distance of lyrics is
controlled by the concept of a {\em lyrics strut\/}\footnote{In
analogy to \TeX's {\tt\char92 strut}; see {\sl The \TeX book\/} by
{\sc D.~E.~Knuth.}}, you should perform this adjustment explicitly with
the command
\begin{quote}\ci{setlyrstrut}\end{quote}
directly after each ``global'' font size change (i.\,e.~after each size
change not issued within \verb|\lyrlayout{...}|;
see~\ref{indivlayout}) unless you do not want the spacing to be
adjusted. (\TeX perts only: If you like to define your own vertical
spacing, you may redefine the \ci{lyrstrutbox} yourself.)
\subsection{Auxiliary lyrics}
\label{auxlyrics}
If you have typeset two voices of a polyphonic arrangement within one
staff, you normally want to give each voice its own lyrics lines.
Usually, the two voices are distinguished by means of the notes' stem
direction; the lyrics of the up-stemmed voice are typeset above,
those of the down-stemmed voice below the staff. \musixlyr\
provides the facility to maintain such two lyrics ``streams'' per
staff; one of them --- which is handled exactly as described so
far --- will be called {\em main lyrics,\/} the second one {\em
auxiliary lyrics.\/}
\subsubsection{Addressing auxiliary lyrics}
Only two rules are to be obeyed for directing commands to auxiliary lyrics:
\begin{enumerate}
\item Enclose everything concerning auxiliary lyrics in:
\begin{quote}\ci{auxlyr}\verb|{...}|\end{quote}
For example, assign lyrics line~{\tt verse1} to staff~2 as
auxiliary lyrics by:
\begin{quote}\ci{auxlyr}\verb|{\assignlyrics{2}{verse1}}|\end{quote}
For example, begin a melisma at the next note of the ``auxiliary'' voice by:
\begin{quote}\ci{auxlyr}\verb|{\beginmel}|\end{quote}
(For \TeX perts: If the argument of \ci{auxlyr} consists of
only one token, the braces can be omitted, so that
\verb|\auxlyr\beginmel| does the same.)
\item There are exactly two exceptions to the first rule. The first
one are the \ci{setlyrics}, \ci{appendlyrics}, and \ci{copylyrics}
commands which need not be enclosed in \ci{auxlyr}\verb|{...}|;
their function is independent of the later use of the defined
lyrics lines as either main or auxiliary lyrics.
The second exception concerns lyrics commands issued as type-1
\TeX\ strings in a \PMX\ source; see below for details.
\end{enumerate}
\label{auxlyr-vertical-position-default}%
Auxiliary lyrics are lifted above the staff by default, i.\,e.~they have
the same vertical position as main lyrics belonging to the staff above
the current staff. If this causes collisions with the main lyrics of
the upper staff, you have to shift the lyrics away from each other
using the vertical spacing commands discussed in
section~\ref{vertical-positioning}.
\subsubsection{Automatic attachment of auxiliary lyrics}
\label{auxlyr-attachment}
While it is easy to attach only one lyrics ``stream'' to a single
voice within a system automatically, the attachment of both main and
auxiliary lyrics involves the task of determining which note belongs
to which voice. Unfortunately, \musixtex\ does not explicitly state a
note's membership of a particular voice; therefore, a heuristic
method has to be used to gather this information. However,
the situation is completely different if you prepare your scores with
the \PMX%
\footnote{If you don't know what \PMX\ is, have a look at:
{\tt http://icking-music-archive.sunsite.dk/musixtex/software/pmx/}}
preprocessor. The following paragraphs explain managing the lyrics
attachment automatism for both cases --- \PMX\ and
non-\PMX\ --- separately.
\paragraph{Using \PMX.}
\label{pmx-autodetection}
(This paragraph requires some \PMX\ knowledge.) For \PMX-prepared
scores (which \musixlyr\ detects automagically\footnote{%
This automatic \PMX\ detection may cause problems for processing
\PMX\ scores prepared with the \PMX-unaware \musixlyr\
version~1.0. See section~\ref{no-pmx-autodetection} about how to
solve this backward-incompatibility issue.
}), the distinction
between the two voices of a staff works fully automatic. This applies
to both the automatic lyrics attachment as well as explicit lyrics
manipulations --- i.\,e.,~you do not have to use \ci{auxlyr}\verb|{...}| for
manipulating auxiliary lyrics. (This only applies to manipulations
that appear in a voice's context, i.\,e.~within a type-1 \TeX\ string.)
For reference, see the following example\footnote{Excerpt from
``Waldesnacht, du wunderk\"uhle'' by {\sc Johannes Brahms} ({\sl Eine
kleine Melodie,\/} Strube, M\"unchen 1989)},
\oneversespace
\begin{music}
\resetlyrics\small
\setlyrics{soprano}{all der ir-ren Qua-len los.}
\auxlyr{\assignlyrics1{soprano}}
\copylyrics{soprano}{alto}
\assignlyrics1{alto}
\auxlyr{\lyrraise1{a -3\internote}}
\staffbotmarg5.5\Interligne
\stafftopmarg5\Interligne
\generalsignature2
\lyrmodealter0
\startextract\addspace\afterruleskip
\scale{1.2}%
\NOtes\zhu{=j}\lower6\internote\qp\lifthpause{-3}\sk\qu h\en
\bar
\NOtes\auxlyr\beginmel\roffset{.8}{\isluru2j}\zhup f\lower8\internote\qp\en
\NOTes\hl{^d}\en
\NOTes\zql e\itieu0e\qu e\en
\bar
\NOtes\beginmel\islurd1c\zql c\ttie0\tslur2h\auxlyr\endmel\qu e%
\roff{\endmel\tsslur1d\zhl d}\qu{=d}%
\auxlyr\beginmel\itieu0d\hu d%
\ql d\en
\bar
\NOTes\zhl d\ttie0\auxlyr\endmel\hu d%
\zhl a\hu c\en
\bar
\NOTes\zhl a\fermataup l\hu d\hpause\en
\setdoubleBAR\endextract
\end{music}
\oneversespace
which can be obtained by the following \PMX\ code (processed with
\PMX\ version~2.3):
\begin{quote}
\bci{auxlyr}
\begin{verbatim}
---
\input musixtex % These commands are necessary
\input pmx % because pmx.tex MUST be \input
\input musixlyr % before musixlyr.tex!
\setlyrics{soprano} % \setlyrics and \copylyrics
{all der ir-ren Qua-len los.} % need not be enclosed in
\copylyrics{soprano}{alto} % \auxlyr{...}.
\assignlyrics1{alto}
\auxlyr{\assignlyrics1{soprano}
\lyrraise1{a 3\Interligne}}
\let\BM\beginmel % For brevity within the subsequent
\let\EM\endmel % music coding recommended.
---
1 1 4 4 0 0 3 2 0 5 20 0
t
./
% 1st and 2nd bar:
r4-6 r2-6 | r4-8 d24s e4 //
c25n a4 | \BM\ f2d s+4 \isu0e{.8}\ e4 /
% 3rd bar:
\BM\ c s \EM\ d2r s d4 //
\ts0e0\EM\ e s+3 dn \BM\ d2 s /
% 4th bar:
d2 a // % Note that \BM and \EM
\EM\ d s c / % apply either to main
% 5th bar: % or to auxiliary lyrics,
a r+0 // % depending on which voice
d of rb / % they appear in.\end{verbatim}
\end{quote}
By default, main lyrics are attached to the lower voice (whose
lines end with \verb|//| in the \PMX\ source), auxiliary lyrics to the
upper voice; due to \PMX\ internals, this ensures that if only one
voice is present, main lyrics are attached to it. However, situations
exist in which it is desirable to have main lyrics attached to the
upper voice, e.\,g.~when you have only main lyrics and want to
synchronize them with the soprano voice instead of the alto voice
(both of them set on the same staff). In this case, you can toggle the
attachment of lyrics to voices with the command
\begin{quote}\ci{lyrmodealter}\verb|{|\var n\verb|}|\end{quote} for
staff number \var n; the command
\begin{quote}\ci{lyrmodenormal}\verb|{|\var n\verb|}|\end{quote}
restores the default behaviour. If $\hbox{\var n}=0$ then the change
affects all staves.
\paragraph{Using ``plain'' \musixtex\ without \PMX.}
In this context, there are two basically different modes for lyrics
attachment:
\begin{enumerate}
\item In {\em normal mode\/} (which is active by default) only main
lyrics are provided automatically as described in
section~\ref{auto-attachment}. All auxiliary lyrics must be issued
manually by saying \ci{auxlyr}\ci{lyr} before the respective note.
This mode is useful when you do not have auxiliary lyrics at all
or when auxiliary lyrics occur only occasionally within the piece.
\item In {\em alternative mode\/}, both main and auxiliary lyrics
are provided automatically. The two voices of a staff are
distinguished by means of their notes' stem direction; the lower
voice gets main lyrics, the upper one auxiliary lyrics. This
implies that the automatism fails at stemless
notes\footnote{Ancient notes, namely breve, longa, and maxima, are
also treated as stemless notes by \musixtex's internals.}, thus you
have to provide lyrics manually by saying \ci{lyr} or
\ci{auxlyr}\ci{lyr}, respectively, before such notes. This mode is
meant for staves which continuously contain two polyphonic voices
with separate lyrics.
\end{enumerate}
The appropriate mode can be chosen staff-wise: The command
\begin{quote}\ci{lyrmodealter}\verb|{|\var n\verb|}|\end{quote}
enables alternative mode for staff number \var n; the command
\begin{quote}\ci{lyrmodenormal}\verb|{|\var n\verb|}|\end{quote}
restores normal mode. As stated above, $\hbox{\var n}=0$ performs the
choice affecting all staves.
For illustration, have a look at the following
example\footnote{Excerpt from ``Audite nova'' by {\sc Orlando di
Lasso} ({\sl ars musica\/} vol.\,4, M\"oseler Verlag
Wolfenb\"uttel/Z\"urich)}:
\oneversespace
\begin{music}
\resetlyrics \small
\lyrmodealter0
\setlyrics{soprano}{bring her die Gans,} \auxlyr{\assignlyrics1{soprano}}
\copylyrics{soprano}{alto} \assignlyrics1{alto}
\generalsignature{-2}
\advance\stafftopmarg3\Interligne
\advance\staffbotmarg2\Interligne
\startextract\addspace\afterruleskip
\NOtes\zqu g\ql e\en
\bar
\Notes\zqu i\beginmel\ibslurd0f\ibl0f{-1}\qb0f\en
\Notes\qb0e\en
\Notes\auxlyr\beginmel\ibsluru1i\zqup i\qb0d\en
\Notes\tqb0e\en
\Notes\endmel\tbslurd0e\ql c\en
\notes\ibbu0h{-1}\qb0h\en
\notes\tqh0g\en
\NOtes\auxlyr\endmel\tbsluru1h\zqu h\ql c\en
\bar
\NOTEs\auxlyr\lyr\zwh i% The lyrics of the whole notes
\lyr\wh b\en % must be given manually.
\endextract
\lyrmodenormal0
\end{music}
\oneversespace
The lyrics were defined as follows:
\begin{quote}
\bci{auxlyr}
\bci{assignlyrics}
\begin{verbatim}
\setlyrics{soprano}{bring her die Gans,}
\copylyrics{soprano}{alto}
\assignlyrics1{alto}
\auxlyr{\assignlyrics1{soprano}}
\lyrmodealter0 % provide main + aux. lyrics automatically\end{verbatim}
\end{quote}
This is the complete notes section:
\begin{quote}
\bci{auxlyr}
\begin{verbatim}
\NOtes\zqu g\ql e\en
\bar
\Notes\zqu i\beginmel\ibslurd0f\ibl0f{-1}\qb0f\en
\Notes\qb0e\en
\Notes\auxlyr\beginmel\ibsluru1i\zqup i\qb0d\en
\Notes\tqb0e\en
\Notes\endmel\tbslurd0e\ql c\en
\notes\ibbu0h{-1}\qb0h\en
\notes\tqh0g\en
\NOtes\auxlyr\endmel\tbsluru1h\zqu h\ql c\en
\bar
\NOTEs\auxlyr\lyr\zwh i% The lyrics of the whole notes
\lyr\wh b\en % must be given manually.\end{verbatim}
\end{quote}
Note that, as opposed to using \PMX, there is no special provision
for attaching main lyrics to the upper voice. If you desire a single
lyrics ``thread'' synchronized with the upper voice, please use
auxiliary lyrics instead and position them below the staff (see
section~\ref{vertical-positioning}).
Alternatively, you may use main lyrics in normal lyrics mode and code
the lower voice completely non-spacing (in the sense explained
in~\ref{auto-attachment}), the upper voice completely spacing; this
should not be too complicated for mainly homophonic pieces.
\subsection{Lyrics at multi-staff instruments}
\label{multi-staff-instruments}
So far in this manual, the term {\em staff\/} has always been used for
what \musixtex\ precisely calls an {\em instrument\/}. This section,
however, correctly adopts the \musixtex\ terminology.
Lyrics can be assigned to staves of a multi-staff instrument. To do
so, use
\begin{quote}
\ci{assignlyricsmulti}\verb|{|\var i\verb|}{|\var s\verb|}{...}|
\end{quote}
instead of \verb|\assignlyrics...|; here, \var s~addresses the desired
staff number (counted from bottom to top) of instrument~\var i.
Nevertheless,
\ci{assignlyrics}\verb|{|\var i\verb|}{...}|
can be used as well if instrument~\var i has multiple staves; in this
case, it is equivalent to
\verb|\assignlyricsmulti{|\var i\verb|}{1}{...}|,
i.\,e.~it affects only the first staff (and not all staves, as may be
presumed).
In the same spirit, the following ``multi'' commands replace the
standard ones within a multi-staff instrument context:
\begin{quote}
\ci{lyrraisemulti}\\
\ci{lyrmodenormalmulti}\\
\ci{lyrmodealtermulti}
\end{quote}
All other \musixlyr\ commands or features can be used the same way as
within a single-staff instrument context.
Using lyrics at multi-staff instruments can be useful, for example,
for typesetting songs with piano accompaniment:%
\footnote{Example taken from songbook {\sl Am Brunnen vor dem Tore\/},
Delphin Verlag M\"unchen/Z\"urich 1981}
\begin{music}
\resetlyrics
\setlyrics{verse}{Gu-ter Mond, du gehst_ so_ stil_-le}
\assignlyricsmulti11{}
\assignlyricsmulti12{verse}
\lyrraisemulti12{b 2\internote}
\setstaffs12
\generalsignature{-1}
\generalmeter\meterC
\setclef1\bass
\interstaff{13}
\scale{1.3}
\startextract
\Notes\qp|\ibl0j{-2}\qb0j\tqb0i\en
\bar\hardspace{1.7\myqnwidth}%
\NOtes\isluru1d\lq c\zq M\ql d|\qa h\en
\NOtes\zq c\zq M\ql e|\qa h\en
\Notes\lq c\zq M\ql d|\islurd0h\ibu0h2\qb0h\tslur0i\tqh0i\en
\Notes\tslur1e\zq c\zq M\ql e|\isluru0j\ibl0j2\qb0j\tslur0k\tqb0k\en
\bar\hardspace\myqnwidth
\Notes\isluru1d\lq c\zq M\ql d|\isluru0j\ibl0j{-2}\qb0j\tslur0i\tqb0i\en
\NOtes\zq c\zq M\ql e|\qa g\en
\NOtes\lq c\zq M\ql d|\qp\en
\znotes\midslur2\tsslur1d\en
\zendextract
\end{music}
The lyrics of this example are defined as follows:
\begin{quote}
\bci{assignlyricsmulti}
\bci{lyrraisemulti}
\begin{verbatim}
\setlyrics{verse}{Gu-ter Mond, du gehst_ so_ stil_-le}
\assignlyricsmulti{1}{2}{verse}
\lyrraisemulti {1}{2}{b \internote}\end{verbatim}
\end{quote}
\subsection{Managing lyrics assignment according to current context}
\label{assignment-by-context}
Managing the properties of lyrics lines assignment to instruments by
absolute instrument numbers --- as it is done with the
\ci{assignlyrics}, \ci{lyrraise}, and \ci{lyrmodealter}
commands --- may cause difficulties whenever the score's number and
order of instruments shall be rearranged; in this case instrument
numbers change, thus the instrument number parameters of the
mentioned lyrics-related commands have to be adjusted.
This is especially unpleasant where such a rearrangement is done
automatically, e.\,g.~by \PMX's part extraction facility {\em
scor2prt\/}; this is intended to work without any manual editing
of the generated part files.
To address this issue, \musixlyr\ provides {\em context-dependent\/}
variants of the commands mentioned above. For example: Instead of
\verb|\assignlyrics{2}{soprano}|, you may say something like:
\begin{quote}
\verb|\notes...&|\ci{assignlyricshere}\verb|{soprano}...\en|
\end{quote}
\ci{assignlyricshere}\verb|{|\var{name(s)}\verb|}| assigns the given verse
\var{name(s)} to the instrument/staff whose context it occurs in within the
\verb|\notes...\en| construct; no absolute instrument/staff number needs to
be specified.
For example, the following two code fragments are equivalent:
\begin{quote}
\footnotesize
\hfill
\def\arraystretch{1}%
\begin{tabular}{l@{\qquad}|@{\qquad}l}
\begin{tabular}[t]{@{}l@{}}
\ci{assignlyrics}\verb| {1} {acct}%|\\
\ci{assignlyricsmulti}\verb|{2}{2}{verse}%|\\
\verb.\NOtes\qa c&\qa e|\qa g\en.
\end{tabular}
&
\begin{tabular}[t]{@{}l@{}}
\verb|\NOtes|\ci{assignlyricshere}\verb|{acct}\qa c%|\\
\verb| &\qa e%|\\
\verb. |.\ci{assignlyricshere}\verb|{verse}\qa g\en|
\end{tabular}
\end{tabular}
\hfill\strut
\end{quote}
Using \PMX, the context-dependent commands must be given as type-1
inline \TeX\ strings. Here is the same example, coded as \PMX input:
\begin{quote}
\footnotesize
\hfill
\def\arraystretch{1}%
\begin{tabular}{l@{\qquad}|@{\qquad}l}
\begin{tabular}[t]{@{}l@{}}
\ci{assignlyrics}\verb| {1} {acct}\|\\
\ci{assignlyricsmulti}\verb|{2}{2}{verse}\|\\
\verb|c44 /|\\
\verb|e44 /|\\
\verb|g44 /|\\
\end{tabular}
&
\begin{tabular}[t]{@{}l@{}}
\hphantom{\tt .NOtes.assignlyricshere.acct..qa cg.en}\\
\\
\ci{assignlyricshere}\verb|{acct}\ c44 /|\\
\verb| e44 /|\\
\ci{assignlyricshere}\verb|{verse}\ g44 /|\\
\end{tabular}
\end{tabular}
\hfill\strut
\end{quote}
The first one (left) results in wrong lyrics assignments in {\em
scor2prt\/} output; the second one (right) is robust against part
extraction.
This is the complete set of ``here'' commands that can be applied the
same way:
\begin{quote}
\ci{assignlyricshere}\\
\ci{lyrraisehere}\\
\ci{lyrmodenormalhere}\\
\ci{lyrmodealterhere}
\end{quote}
All other \musixlyr\ commands are context-driven anyway, i.\,e.~using
the mentioned ``here'' commands you can completely omit any absolute
instrument/staff number assignment.
\subsection{Miscellaneous}
\subsubsection{Avoiding problems after {\tt\char92
endpiece...\char92 startpiece}}
Sometimes, after having suspended the music with \verb|\endpiece| and
restarted it with \verb|\startpiece| (or the respective
\verb|\...extract| commands), the lyrics lines are totally misaligned
because the internal lyrics positioning parameters are not reset
properly. Saying
\begin{quote}\ci{resetlyrics}\end{quote}
before the beginning of the new music section should solve this
problem.
\subsubsection{Improved centering of words with punctuation marks}
Centered words with an attached punctuation mark often seem a bit
left-shifted since the punctuation mark also counts for the
centering. To have a word centered solely with respect to its
letters, enclose the punctuation mark in \verb|\rlap{...}| as it is
done in the example of section~\ref{multiple-vert-pos}. Unfortunately,
this circumvents the lyrics shifting automatism, and is incompatible
with the use of \ci{lyrnop}.
\subsubsection{Verse numbers}
\label{versenumbers}
There is no special command for this topic. See the following example:
\begin{music}
\resetlyrics
\generalmeter{\meterfrac24}
\scale{1.8}
\setlyrics{sailor1}
{\llap{1.} What shall we do with a drun-ken sail-or\rlap{?}}
\setlyrics{sailor2}
{\llap{2.} Take him and shake him and try to\lyrlink a-wake him,}
\setlyrics{sailor3}{\llap{3.} Give him a dose of_ salt and wa-ter,}
\setlyrics{sailor4}{\llap{4.} Give him a dash with a bo-som's rub-ber,}
\assignlyrics1{sailor1,sailor2,sailor3,sailor4}
\small\setlyrstrut
\setsongraise1{-6mm}
\startextract
\znotes\llyr\lyroffset{-2}% make the numbers stand off to the left
\lyr% post the numbers
\en
\Notes\ibu0h0\qb0h\en
\notes\nbbu0\qb0h\tqh0h\en
\Notes\ibu0h0\qb0h\en
\notes\nbbu0\qb0h\tqh0h\en\bar
\Notes\Dqbu hd\Dqbu fh\en
\endextract
\end{music}
\oneversespace
\twoversesspace
To see how this is accomplished, look for the example's coding within
{\tt mxlyrdoc.tex}.
Section~\ref{lyric*-verse-numbers} explains an alternative method for
setting vertically aligned verse numbers.
\subsubsection{``Lyrics slurs''}
If two consecutive syllables of a lyrics line share the same note (as
in the second verse of the above example), you may want to link them
together with a small slur under them \mbox{like\lyrlink this.} To do
this, use the command \ci{lyrlink} instead of the respective blank
space within the \verb|\setlyrics| definition.
If any of the adjacent characters extend under their \TeX\ baseline
(like `g', `j', `p', etc.), use \ci{lowlyrlink} which lowers the
slur accordingly (e.\,g.: \mbox{sing\lowlyrlink gladly}).
\subsubsection{Restoring the \PMX-unaware behaviour of \musixlyr~1.0}
\label{no-pmx-autodetection}
As stated in section~\ref{pmx-autodetection}, \musixlyr\ distinguishes
between main and auxiliary lyrics context in a special way when it
detects that the score has been set up using \PMX. However, this
automatic \PMX\ detection may cause problems for processing \PMX\
scores prepared with the \PMX-unaware \musixlyr\ version~1.0. To solve
this, you can force the old \musixlyr\ behaviour by an explicit macro
redefinition as follows:
Within {\tt musixlyr.tex}, find the code fragment
\begin{quote}\begin{verbatim}
\ifx\nextvoice\undefined
\def\decide@lyrmode{%
\call@lyrmode
...
\fi\fi\fi\fi\fi\fi\fi}
\else\end{verbatim}\end{quote}
(which is about 25 lines long). Copy it, exluding the first and the
last line, to your score source and surround it by the
\verb|\makeatletter...\makeatother| command pair. This
should then look like this:
\begin{quote}\begin{verbatim}
\makeatletter
\def\decide@lyrmode{%
\call@lyrmode
...
\fi\fi\fi\fi\fi\fi\fi}
\makeatother\end{verbatim}\end{quote}
To restore the \PMX-aware \musixlyr\ behaviour of version~1.1 and
newer, copy the {\em second\/} \verb|\decide@lyrmode| definition
from {\tt musixlyr.tex} to the desired place in your score and
surround it with \verb|\makeatletter...\makeatother|.
To do these redefinitions within a \PMX\ input file, it is probably
always best to wrap them in macro definitions within the \PMX\ file
preamble. This way, you can switch between the ``old'' and ``new''
\musixlyr\ behaviour by simply calling these macros in \PMX's
inline-\TeX\ style.
\pagebreak[4]
\section{Command index}
\printindex
\section{Software license}
\musixlyr\ (including this manual) is free software; you can
redistribute it and/or modify it under the terms of the GNU General
Public License as published by the Free Software Foundation; either
version~2 of the License, or any later version.
\musixlyr\ is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with \musixlyr; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
\medskip
Author:
\begin{tabular}[t]{l}
Rainer Dunker\\
Wachtelweg 31\\
85\,591 Vaterstetten\\[0.5ex]
Germany\\[1ex]
E-mail: \tt rainer.dunker@web.de
\end{tabular}
\end{document}