This file contains instructions to upgrade to a new release of Gregorio.
In order to facilitate installation alongside TeX Live, the version number is now appended to the gregorio executable file name. In version 4.2.0, the filename is gregorio-4.2.0. If you run the executable directly, you will need to modify your procedures and/or scripts to use the new name. Alternately, creating a symbolic link, if your system supports it, may work for you.
If you auto-compile or force-compile your GABC files and are not using the Gregorio packaged with TeX Live, you will probably need to use the --shell-escape
option when compiling your .tex
files. Alternately, you can add the new filename to your system's shell_escape_commands
TeX option.
Unfortunately, there appears to be no easier way to let a user-installed Gregorio coexist with the TeX-Live-packaged Gregorio. Please note: in TeX Live 2016, which includes Gregorio 4.1.1, the executable filename does not include the version number, though that will change starting with TeX Live 2017.
As of version 4.2, the orientation of the stemmed oriscus flexus (gOe)
is consistent with the unstemmed oriscus flexus (goe)
in that the oriscus points downwards (since the note which follows is of lower pitch). If you prefer the oriscus to point upwards, you will need to use the 1
modifier (as in (gO1e)
), which will force an upward orientation of the oriscus.
As of version 4.2, when the note after the oriscus is at the same pitch as the oriscus, the oriscus will point downwards by default. If you prefer it to point upwards, append the 1
modifier to force the upward orientation.
As of version 4.2, a podatus followed by a virga of the same or higher pitch as the second note in the podatus (e.g., (eghv)
) will be kept together, disallowing a line break between the two shapes. If you would like to allow a line break between the two shapes, use a /
or some other breakable space between them (e.g., (eg/hv)
).
As of version 4.2, the penalties should be changed by using \grechangecount
rather than the old way of redefining macros. The following tunable values are available (they have the same name as their old macro counterparts, minus the gre
):
brokenpenalty
clubpenalty
endafterbaraltpenalty
endafterbarpenalty
endofelementpenalty
endofsyllablepenalty
endofwordpenalty
finalpenalty
hyphenpenalty
looseness
newlinepenalty
nobreakpenalty
pretolerance
tolerance
widowpenalty
See GregorioRef for descriptions.
Additionally, if you were redefining \greemergencystretch
, you should now be changing the emergencystretch
dimension using the \grechangedim
command.
If the note following a custos has an alteration (flat, natural, or sharp), the custos will now also have that alteration typeset before it. If you prefer the old behavior, use \gresetcustosalteration{invisible}
. This setting may be switched to visible
and invisible
between scores.
As of version 4.2, a different glyph is used for puncta inclinata in an ascent versus puncta inclinata in a descent. However, because the two shapes clash with each other, Gregorio will attempt to use the same shape for all notes within a string of puncta inclinata. This is accomplished by a heuristic algorithm that determines the glyph to use, but tastes differ, so you may override the shape by appending 0
(to force descending) or 1
(to force ascending) after the letter used for the punctum inclinatum.
Two additional distances have been added to handle strings of puncta inclinata which both ascend and descend. descendingpunctuminclinatumascendingshift
will be used between two descending punctum inclinatum glyphs which ascend in pitch, and ascendingpunctuminclinatumdescendingshift
will be used between two ascending punctum inclinatum glyphs which descend in pitch.
From version 4.2, gabc styles persist through syllables so you can now, for instance, style an entire verse differently from the rest of the piece by starting the style at the beginning of the verse and ending it at the end of the verse. This covers italics (<i>
), bold (<b>
), small capitals (<sc>
), underlined text (<ul>
), colored text (<c>
), and "teletype" text (<tt>
).
Prior to version 4.2, Gregorio inconsistenly indicated style errors. Now, errors like ending a style that is not started and starting a style that is already started will be caught more consistently. If you are getting errors to this effect, double-check the styles in your score to make sure that styles are started and ended properly.
To better comply with the TeXLive directory structure, the location of gregoriotex.sty
and gregoriosyms.sty
have changed.
Linux and other users installing from source: install-gtex.sh
should remove the old versions before installing the new one.
Mac users installing via pkg installer: The installer does not attempt to remove the old versions before installing the new ones. Please run Uninstall-Gregorio.pkg before installing 4.2 to ensure that the old versions don't cause any problems.
Windows users: Your installer already should remove old versions of GregorioTeX before installing the new ones.
As always, please file a bug report if you have any problems with the update process.
To avoid conflicts with the LilyPond Parmesan font, the Gregorio Parmesan font is now called Grana Padano. If you were using \gresetgregoriofont{parmesan}
, you should now use \gresetgregoriofont{granapadano}
.
High notes are now taken into account in vertical spacings. If you would like to come back to the old way, use \grechangecount{additionaltopspacethreshold}{6}
. High notes also influence vertical placement of alt text. If you would like to come back to the old way, give a high value to \grechangecount{additionaltopspacealtthreshold}{6}
.
\grelooseness
is now -1
by default. This should prevent orphaned syllable at end of score. If you prefer the old behavior, use \def\grelooseness{\looseness}
befor including your scores.
Initial handling has been simplified. This deprecates the initial-style
gabc header and the biginitial
style.
Rather than using the initial-style
gabc header, set the number of lines the initial should use in Tex with the \gresetinitiallines
command. It currently accepts 0 (for no initial), 1 (for a one-line initial), or 2 (for a two-line initial).
As for the biginitial
style, the intent is that the initial
style be changed within the TeX document whenever the initial style should change, regardless of how many lines the initial requires. For example, before including a score that has a two-line initial, you would probably want to redefine the initial
style to use a larger font. Then, before including a score which requires a one-line initial, you would then redefine the initial
style back to what it was before.
In order to allow a smoother transition to the new behavior, GregorioTeX will behave differently depending on whether or not deprecated usage is allowed (controlled by the [allowdeprecated]
package option). If deprecated usage is allowed, GregorioTeX will use the deprecated biginitial
style for big initials. If not, GregorioTeX will use the initial
style for big initials.
Since the biginitial
style will disappear with Gregorio 5.0, please consider disabling deprecated usage (set [allowdeprecated=false]
when using the gregoriotex
package) and use the initial
style as just described.
When the next syllable starts with an alteration, the minimal space between notes of the current syllable and notes of the current syllable is handled by the new spaces intersyllablespacenotes@alteration
and interwordspacenotes@alteration
. Set them in your custom spacings file if needed.
When a syllable ends with a punctum mora, Gregorio 4.1 doesn't consider the punctum mora completely in horizontal spacing. This can result in next syllable being closer. To balance the output, spacebeforesigns
has been made shorter. If you want to go back to the old behavior, use:
\gresetshiftaftermora{never}
if you want to remove it completely\gresetshiftaftermora{barsonly}
if you want to remove it for non-bar syllables but keep it for bar syllables\grechangedim{spacebeforesigns}{0.05469 cm plus 0.00455 cm minus 0.00455 cm}{scalable}
to go back to the old spacing before punctum mora
The \gresetshiftaftermora
macro can take other arguments for controlling how this should work, see GregorioRef for details.
Prior to version 4.1, Gregorio reserved space between notes at the c
and k
heights and their horizontal episemata for a "ledger line" that might appear between them. However, if the ledger line did not appear, the episema would appear to be too far from the note.
Starting with version 4.1, Gregorio attempts to reduce the space between the note and its episema if it doesn't think there is a "ledger line" there. However, due to the intricacies of distances and measurement in TeX, Gregorio might guess wrong. In this case, you can override the guess by using the [hl:n]
(for a line above the staff) and [ll:n]
(for a line below the staff) notations in gabc. If you put a 0
for n
, Gregorio will assume there is no ledger line, and if you put a 1
for n
, Gregorio will assume there is a ledger line. This notation will have to be placed after every note which should be thus modified.
Note: Using [hl:n]
and [ll:n]
will not add a ledger line if it doesn't exist or remove one if it does. It simply affects whether Gregorio will act as if one is there or not.
If you prefer the old behavior, you may switch this off by issuing \gresetledgerlineheuristic{disable}
in your TeX document. You may switch it back on with \gresetledgerlineheuristic{enable}
.
In the past, Gregorio handled the notes of an <eu>
block like any other, which meant that a custos would appear before the <eu>
block if it happened to start on a new line. However, the '' block is not a continuation of the melody, but rather a reminder of the ending to use for the paired psalm tone. As a result, a custos immediately before an EUOUAE block is now suppressed by default. If you desire the old behaviour, use \greseteolcustosbeforeeuouae{auto}
in your TeX document. To once again suppress the custos, use \greseteolcustosbeforeeuouae{suppressed}
.
A new algorithm has been implemented and is turned on by default. We hope this will be a significant improvement over the previous one. The primary goal of the new algorithm is to place the bar line exactly between the notes which surround it and do the same with the text associated with the bar line. However, it will also keep the text and bar reasonably close together and with sufficent space between the bar syallable and the surrounding syllables (possibly introducing space to meet the competing interests). The new algorithm introduces several new spaces allowing the user to tune the algorithm:
maxbaroffsettextright
maxbaroffsettextleft
maxbaroffsettextright@nobar
maxbaroffsettextleft@nobar
maxbaroffsettextright@eol
maxbaroffsettextleft@eol
bar@*@standalone@text
(where*
is the type of bar)bar@*@standalone@notext
(where*
is the type of bar)interwordspacetext@bars
interwordspacetext@bars@euouae
interwordspacetext@bars@notext
interwordspacetext@bars@notext@euouae
bar@rubber
If you prefer the old bar spacing algorithm, you can revert to that with:
\gresetbarspacing{old}
Another big change in this algorithm is that empty syllables, i.e. ones without any notes, are now treated as a 0-width bar, not as a 0-width note. Thus if you were using this sort of syllable to insert space into your score, chances are the results will be different under the new algorithm and will require you to re-tweak your scores.
The spaces around bars are now:
bar@virgula
bar@minima
(both replacingspacearoundsmallbars
)bar@minor
(replacingspacearoundminor
)bar@maior
(replacingspacearoundmaior
)bar@finalis
(replacingspacearoundfinalis
)bar@finalifinalis
(replaceingspacebeforefinalfinalis
)bar@dominican
(new)
They have variants for the new bar spacing algorithm only:
bar@xxx@standalone@text
(wherexxx
isvirgula
orminima
, etc.) are used when the bar is in a standalone syllable with textbar@xxx@standalone@notext
for bars in a standalone syllable without text
Hyphens should now not go right of staff lines. If you prefer the old behavior, \gresethyphenprotrusion{100}
should restore it.
The oriscus orientation (whether it points up or down) is now dependent on the note the follows, even if the note is not directly connected to the oriscus (as it would be in a salicus or a pressus). Appending a 1
to an unconnected oriscus in gabc will force the oriscus to point upwards and 0
will force the oriscus to point downwards.
Prior to version 4.1, Gregorio automatically oriented the oriscus when it was within a neume, but left the orientation up the user otherwise. If you prefer this behavior, set the oriscus-orientation
header in gabc to legacy
. In legacy mode, the orientation of an unconnected oriscus will (by default) point downwards and may be reversed by appending <
or >
to the oriscus.
The style for the mode number has been bold and small capitals for a long time, but the number was rendered as upper-case Roman numerals, defeating the nuance of small capitals. As of version 4.1, Gregorio will use lower-case Roman numerals (by default) that will then appear as small capitals. This will change how the mode number appears above the initial if you have been using the mode
header to typeset them. If you prefer the earlier appearance, use \gresetmodenumbersystem{roman-majuscule}
in your TeX file for upper-case Roman numerals. The other options available are roman-minuscule
(the new default), for lower-case Roman numerals, and arabic
, for Arabic numerals.
If you were using \scorereference
, \GreScoreReference
, and/or \grescorereference
, stop using them. If you need to capture the manuscript-reference
header, use the new header capture feature (see GregorioRef for details).
Three descending notes that have no other markings (such as liquescentia) will now be rendered as a clivis followed by a punctum. The older, incorrect behavior was to group them as three punctums joined by !
. If you prefer this behavior, explicitly separate the notes with !
.
The music fonts (greciliae, gregorio, and parmesan) have changed with this release. If the neumes do not appear or look strange in the output, you may need to clear your LuaTeX font cache by using luaotfload-tool --cache=erase
.
Changes to the LaTeX kernel have made it so that if you use the fontspec and gregoriotex pacakges, you must load the fontspec package first.
A naming scheme for GregorioTeX commands has been established and so most commands have had their names changed in order to bring them into line with the new scheme. Some have also had their syntax changed. Briefly, user commands all now have a \gre
prefix (to prevent name colisions with other packages) and groups of commands which altered a single setting have been replaced by a single command which takes an argument specifying the value of the setting. The notable exception to this are the two main commands: \gregorioscore
(replaces \includescore
) and \gabcsnippet
. See GregorioRef for the complete list of new command names and their syntax.
Old command names should still work for now, but will raise a deprecation warning which indicates the name of the correct command to use. Exceptions are noted below:
\grescaledim
: This function now takes two arguments. The second should beyes
,true
,on
, orscalable
to acheive the old behavior.
Additionally a new package option has been added. This option, allowdeprecated=false
, is helpful if you wish to ensure that your TeX file is compliant with the new naming system. This option causes all deprecated commands to raise an error, halting TeX, thus allowing you to actively find all deprecated commands and update them in your TeX file.
If you use barred letters and a font other than Linux Libertine in your document, you must adjust the horizontal placement of the bar on the letter. To do so, use the \gresimpledefbarglyph
macro. For example, use \gresimpledefbarredsymbol{A}{0.3em}
in your preamble, tweaking the second argument to have a good result (same for R and V). If using LaTeX, you can alternately use the \grelatexsimpledefbarredsymbol
macro, which allows control over bold and italic versions of the barred letter. See the documentation of \gresimpledefbarredsymbol
and \grelatexsimpledefbarredsymbol
in the PDF documentation for more details.
If you were using \Vbarsmall
, \greletterbar
, and \greletteraltbar
, you must use \gresimpledefbarredsymbol
to redefine your barred letters (see PDF documentation for details).
The gregorio
executable now uses the .gtex
extension by default (instead of .tex
, formerly) for GregorioTeX files that it produces. If you use \includescore{file.tex}
, then you should change this to \includescore{file.gtex}
or use the newer autocompilation feature.
If you are using custom spacings, please update the values of interwordspacetext
, intersyllablespacenotes
and interwordspacenotes
to match their new definitions (in the comments in gsp-default.tex
). Also note that alterationspace
is now fixed and cannot take plus
or minus
values.
You are advised to surround your Euouae blocks by the new <eu>
tag. For instance,
E(i) u(i) o(i) u(h) a(h) e(fe..)
can become
<eu>E(i) u(i) o(i) u(h) a(h) e</eu>(fe..)
This will prevent line breaking, so if you were using so-called no linebreak areas (with {
in gabc) just for Euouae blocks, you can switch to this new tag, which will make things clearer and allow further spacing customization.
Changes to the way the horizontal episema is placed and "bridged" to other notes within the syllable may cause Gregorio to render things differently in the more esoteric (or bug-ridden) cases. If you are depending on the old behavior, you might need to add suffixes to the _
in gabc to get what you want:
- Add
0
to force the episema to appear below the note. - Add
1
to force the episema to appear above the note. - Add
2
to prevent Gregorio from attempting to connect this episema to the next. - Add
3
to use a small episema, aligned to the left of the note. - Add
4
to use a small episema, centered in the middle of the note. - Add
5
to use a small episema, aligned to the right of the note.
Note: 3
, 4
, and 5
encompass a new feature and are listed here only for completeness.
beforechoralsignspace
has been renamed tobeforelowchoralsignspace
.lowchoralsignshift
has been renamed tochoralsigndownshift
.highchoralsignshift
has been renamed tochoralsignupshift
and its sign (direction of shift) inverted.
Changing the styling of text elements of the score (the initial, translations, etc.) formerly required the user to redefine a command which took an argument, while changing the styling of the staff lines had a command specialized to that purpose. All formats can now be changed via the \grechangestyle
command. This command takes two or three arguments. The first argument, required, is the name of the format to be altered. The defined formats are:
initial
: normal initialsbiginitial
: big (2-line) initialstranslation
: translation textabovelinestext
: above lines text (alt
in gabc)normalstafflines
: the full length staff linesadditionalstafflines
: the short lines behind notes above or below the staff. This style defaults to inheriting changes tonormalstafflines
.lowchoralsign
: low choral signshighchoralsign
: high choral signsmodeline
: the mode annotation above the initial if the content of the mode header in gabc is rendered.firstword
: the first word of the score (excluding the score initial)firstsyllable
: the first syllable of the first word of the score (excluding the score initial).firstsyllableinitial
: the first letter of the first word of the score which is not the score initial.
The second argument, also required, is the code necessary to turn on the styling. The third argument, optional and enclosed in square braces ([
and ]
), is the code necessary to turn off the styling (e.g. if the code to turn on the styling contains a \begin{environment}
then the code to turn it off must have the matching \end{environment}
). The third argument is optional because not all styling commands have explicit off switches.
While the old way of changing the styles is still supported, you should switch to this new method to future-proof your scores.
Examples: Let's say you previously had the following in your LaTeX document:
\renewcommand{\greabovelinetextstyle}[1]{{\small\it #1}}
This would have made the text which was wrapped with <alt></alt>
in your gabc file appear small and italicized in your score. To update this to the new system you would replace the above line with the following:
\grechangestyle{abovelinetext}{\small\it}
The gabc centering-scheme
header is now deprecated and will disappear soon. Use the \gresetlyriccentering
command from TeX instead. If you were using centering-scheme: latine;
in gabc, now use \gresetlyriccentering{vowel}
in the TeX file that includes the gabc. If you were using centering-scheme: english;
in gabc, now use \gresetlyriccentering{syllable}
in the TeX file that includes the gabc.
Using the gabc header will, in this release, do that for you, but it will produce a deprecation warning. This header will no longer be available in the next release.
Support for annotations with an arbitrary number of lines has been added. To facilite this, the old functions which added annotations to specific lines (either the first or the second) are consolidated into a single function \greannotation
which builds the annotations line by line. If you used the old functions for adding annotations, then you should switch out those functions for the new one.
The distance associated with the annotations has also been renamed (from aboveinitialseparation
to annotationseparation
) and supplemented by a new distance (annotationraise
). The first still controls the spacing between the lines of the annoation. The second controls the position of the annotation relative to the score, and thus replaces the second argument in the old functions. By default, annotations are positioned so that the baseline of the first line is aligned with the top line of the staff. Positive values of annotationraise
will push the annotation up while negative values will push it down. If you were previously using the second argument to \gresetfirstlineaboveinitial
to adjust the spacing, you will need to convert this to call:
\grechangedim{annotationraise}{0.1cm}{1}
Since the baseline position of annotations is a change from the old behavior, you will need to adjust the value of the distance a bit to achieve the desired positioning.
As is normal, calls to the deprecated command names will raise a warning but still work. However, there is one caveat: the old functions will always add the annotations to the bottom of the annotation list, regardless of the order in which they are called. Previously, you could call \gresetsecondannotation
before \gresetfirstannotation
and still have the first annotation appear on top. Which annotation appears on top is now determined by the order in which the functions are called.
The annotation
header in gabc files now passes its value(s) to GregorioTeX for placement above the inital letter of the score. Up to two annotation
fields are supported, the first for the first line above the initial, and the second field for the second line.
annotation: 1 Ant.;
annotation: VII a;
Full TeX markup is also accepted:
annotation: {\color{red}1 Ant.};
annotation: {\color{red}VII a};
If you define annotation(s) in the main TeX file via \greannotation
, then the annotation
header field in the gabc file will not overwrite that definition.
GregorioTeX is now able to make individual lines of a score taller when the position of the note requires extra space, without affecting the rest of the lines. This is the new default behavior. If you prefer the uniform line heights of earlier versions, use:
\gresetlineheightexpansion{uniform}
Within a TeX document, you can switch back to variable line heights by using:
\gresetlineheightexpansion{variable}
You can freely switch between the two behaviors within a TeX document, but only between scores.
This new behavior requires two passes (two runs of lualatex) in order to do the calculation correctly. On the first pass, lualatex will warn you with the message
Module gregoriotex warning: Line heights or variable brace lengths may have changed. Rerun to fix.
As you edit your document, lualatex will only show this warning if an extra run is required.
Alternately, you can use something like latexmk to automate this activity. Instructions for using latexmk are outside the scope of this document. Please consult the latexmk documentation for more information on using it.
It should also be noted that this new feature, besides requiring two passes, also imposes a small performance penalty on each pass to do the additional computation. This is negligible for small documents, but may have more noticeable impact as documents get larger.
GregorioTeX now uses MetaPost (by default) to render braces. This allows fine-tuning to better maintain optical line weight when braces are stretched. Since the shapes are slightly different, you may prefer the old behavior, which may be restored by using:
\gresetbracerendering{font}
Within a TeX document, you can switch back to MetaPost brace rendering by using:
\gresetbracerendering{metapost}
You can freely switch between the two behaviors within a TeX document.
In order to better match the new command naming conventions, the third argument of \grecreatedim
and \grechangedim
should now be scaling
or fixed
instead of 1
or 0
, respectively.
In order to be more consistent, making a bistropha or tristropha liquescent by adding <
in gabc will now only affect the note thus marked. This means that a tristropha like (gsss<)
will only show the final stropha as liquescent, which is different from the older behavior of making every stropha liquescent. If you prefer the old behavior, mark every note explicitly as liquescent with something like (gs<gs<gs<)
.
Prior to version 4.0, GregorioTeX would put a hyphen below an empty first syllable (which happens when the first syllable consists only of the initial). The spacing algorithm is improved in 4.0, but that eliminates the hyphen if there is not enough space between the note of the first syllable and the next syllable. The \gresetemptyfirstsyllablehyphen
command controls this behavior. It defaults to force
, which restores the pre-4.0 behavior, but may be changed to auto
(i.e., \gresetemptyfirstsyllablehyphen{auto}
) if you prefer the space-based behavior.
The gabc-version header has become meaningless. It is now deprecated. Please remove it from your gabc files if you had been using it.
Because of changes necessary to future-proof the fonts, please upgrade to at least TeX Live 2013 if you are using an older version. If the neumes do not appear or look strange in the output, you may also need to clear your LuaTeX font cache by using luaotfload-tool --cache=erase
.
When migrating to this release, you should start to use the new \includescore
system, as other ways of score inclusion are deprecated and will start disapear soon. See GregorioRef.pdf for details.
In version 2.4.2, an early version of the feature to auto-compile gabc score was added. Because of the confusion this caused with old users upgrading to 2.4.2, the \includescore
command now works in a backwards-compatible way so scores created using this command for versions of Gregorio prior than 2.4.2 should work with no change. However, for users of 2.4.2, the following changes are necessary:
- If you were using
\includescore[f]
, the equivalent command is now\includescore[n]
, but due to this change, you should be able to just use\includescore
without the optional parameter. - If you were using the auto-compile feature, you should use
\autocompilegabc
in your tex file prior to using\includescore
. This is only necessary once and does not need to be used before each use of\includescore
.
If you use custom space definitions (gsp-foo.tex
), the format have changed, and you must rewrite it completely. See the new gsp-default.tex
for an example, and GregorioRef.pdf for documentation.
If you want to change color in gabc, using the <c>
markup is the safest way, and you should migrate to that, as Gregorio introduced mechanisms that may break badly formatted color changes (e.g. \color{red}foo\color{black}
).