Skip to content

Commit

Permalink
feat: migration to TeXLive 2024.0
Browse files Browse the repository at this point in the history
Signed-off-by: Martin Dünkelmann <[email protected]>
  • Loading branch information
MartinX3 committed Sep 1, 2024
1 parent a161d87 commit f5628e5
Showing 1 changed file with 64 additions and 10 deletions.
74 changes: 64 additions & 10 deletions latexmkrc
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\"" );
#}

0 comments on commit f5628e5

Please sign in to comment.