-
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Martin Dünkelmann <[email protected]>
- Loading branch information
Showing
1 changed file
with
64 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,64 @@ | ||
add_cus_dep( 'acn', 'acr', 0, 'makeglossaries' ); | ||
add_cus_dep( 'glo', 'gls', 0, 'makeglossaries' ); | ||
$clean_ext .= " acr acn alg glo gls glg"; | ||
sub makeglossaries { | ||
my ($base_name, $path) = fileparse( $_[0] ); | ||
pushd $path; | ||
my $return = system "makeglossaries", $base_name; | ||
popd; | ||
return $return; | ||
} | ||
# https://mirrors.ctan.org/support/latexmk/example_rcfiles/glossaries_latexmkrc | ||
|
||
# This shows how to use the glossaries package | ||
# (http://www.ctan.org/pkg/glossaries) and the glossaries-extra package | ||
# (http://www.ctan.org/pkg/glossaries-extra) with latexmk. | ||
|
||
# N.B. There is also the OBSOLETE glossary package | ||
# (http://www.ctan.org/pkg/glossary), which has some differences. See item 3. | ||
|
||
# 1. If you use the glossaries or the glossaries-extra package, then you can use: | ||
|
||
add_cus_dep( 'acn', 'acr', 0, 'makeglossaries' ); | ||
add_cus_dep( 'glo', 'gls', 0, 'makeglossaries' ); | ||
$clean_ext .= " acr acn alg glo gls glg"; | ||
|
||
sub makeglossaries { | ||
my ($base_name, $path) = fileparse( $_[0] ); | ||
my @args = ( "-q", "-d", $path, $base_name ); | ||
if ($silent) { unshift @args, "-q"; } | ||
return system "makeglossaries", "-d", $path, $base_name; | ||
} | ||
|
||
# 2. The above will tend to run makeglossaries more often than needed, since | ||
# each out of date file will trigger the use of makeglossaries, even | ||
# though makeglossaries makes all the glossaries. The following solution | ||
# solves this, but at the expense of not having the convenience that | ||
# makeglossaries can change how it makes the glossaries depending on the | ||
# settings of the glossaries package. | ||
# A better solution will need more advanced work. | ||
# | ||
# add_cus_dep( 'acn', 'acr', 0, 'makeglossaries' ); | ||
# add_cus_dep( 'glo', 'gls', 0, 'makeglossaries' ); | ||
# $clean_ext .= " acr acn alg glo gls glg"; | ||
# | ||
# sub makeglossaries { | ||
# my @args = ( "-s", "$_[0].ist", "-t", "$$Psource.ilg", | ||
# "-o", $$Pdest, $$Psource ); | ||
# if ($silent) { unshift @args, "-q"; } | ||
# return system "makeindex", @args; | ||
# } | ||
|
||
# 3. If you use the OBSOLETE glossary package, then you can do the following: | ||
# (Note that the code lines are commented out to avoid trouble when this | ||
# file is simply copied into a latexmkrc or this file is arranged to be | ||
# read by latexmk, and one of the modern packages glossaries and | ||
# glossaries-extra is used.) | ||
|
||
## For the main glossary: | ||
#add_cus_dep( 'glo', 'gls', 0, 'makeglo2gls' ); | ||
#sub makeglo2gls { | ||
# system("makeindex -s \"$_[0].ist\" -t \"$_[0].glg\" -o \"$_[0].gls\" \"$_[0].glo\"" ); | ||
#} | ||
|
||
## For acronyms: | ||
## | ||
## ===> WARNING: The code below is ONLY FOR PACKAGE glossary, NOT FOR | ||
## glossaries and glossaries-extra. In the current glossaries and | ||
## glossaries-extra packages the roles of the .acr and .acn files are | ||
## exchanged compared with the old glossary package. Hence the the | ||
## code below will fail with the more modern packages. | ||
#add_cus_dep( 'acr', 'acn', 0, 'makeacr2acn' ); | ||
#sub makeacr2acn { | ||
# system( "makeindex -s \"$_[0].ist\" -t \"$_[0].alg\" -o \"$_[0].acn\" \"$_[0].acr\"" ); | ||
#} |