Browse Source

Allow using latexpand instead of latexdiff --flatten

"latexdiff --flatten" is not very robust. It doesn't expand bibliography,
and doesn't seem to work when the \begin{document} is inside an \input-ed
file.

Instead, use latexpand before latexdiff, which should solve these issues.

Works with --latexpand <options>, but has to be last in the series of
options. Shortcut --bbl to include the bibliography with the same name as
the project file.

Commit message improved by: Matthieu Moy <Matthieu.Moy@grenoble-inp.fr>
master
Jörg Weber 12 years ago
committed by Matthieu Moy
parent
commit
ec71dead5d
  1. 48
      git-latexdiff

48
git-latexdiff

@ -64,7 +64,7 @@ Options:
(default if -o is not used) (default if -o is not used)
--pdf-viewer <cmd> use <cmd> to view the PDF file (default: \$PDFVIEWER) --pdf-viewer <cmd> use <cmd> to view the PDF file (default: \$PDFVIEWER)
--no-cleanup don't cleanup temp dir after running --no-cleanup don't cleanup temp dir after running
--no-flatten don't provide latexdiff the --flatten option
--no-flatten don't call latexpand to flatten the document
--cleanup MODE Cleanup temporary files according to MODE: --cleanup MODE Cleanup temporary files according to MODE:
- keeppdf (default): keep only the - keeppdf (default): keep only the
@ -96,6 +96,8 @@ Options:
--whole-tree checkout the whole tree (contrast with --subtree) --whole-tree checkout the whole tree (contrast with --subtree)
--ignore-makefile ignore the Makefile, build as though it doesn't exist --ignore-makefile ignore the Makefile, build as though it doesn't exist
-* other options are passed directly to latexdiff -* other options are passed directly to latexdiff
--bbl shortcut to flatten a bbl file of the same name as the project
--latexpand pass options to lastexpand (should be last option specified)
EOF EOF
} }
@ -147,6 +149,9 @@ latexopt=
ln_untracked=0 ln_untracked=0
quiet=0 quiet=0
latexdiffopt=() latexdiffopt=()
latexpand=()
workingdir=()
bbl=0
while test $# -ne 0; do while test $# -ne 0; do
case "$1" in case "$1" in
@ -224,6 +229,13 @@ while test $# -ne 0; do
"--latexmk") "--latexmk")
uselatexmk=1 uselatexmk=1
;; ;;
"--latexpand")
shift
latexpand=$1
;;
"--bbl")
bbl=1
;;
"--latexopt") "--latexopt")
shift shift
latexopt=$1 latexopt=$1
@ -414,25 +426,39 @@ do
verbose_done verbose_done
done done
if test "$flatten" = 1; then
latexdiffopt+=("--flatten")
mainbase=$(basename "$main" .tex)
maindir=$(dirname "$main")
if test "$bbl" = 1; then
oldbbl=("--expand-bbl old/"$mainbase".bbl")
newbbl=("--expand-bbl new/"$mainbase".bbl")
else
oldbbl=("")
newbbl=("")
fi fi
# Create flattened documents and keep for debugging
if test "$flatten" = 1; then
verbose "Running latexpand"
latexpand old/"$main" > old/"$mainbase"-fl.tex "${latexpand[@]}" $oldbbl
latexpand new/"$main" > new/"$mainbase"-fl.tex "${latexpand[@]}" $newbbl
verbose_done
verbose "Running latexdiff ${latexdiffopt[@]} old/"$mainbase"-fl.tex new/"$mainbase"-fl.tex > ./diff.tex"
latexdiff "${latexdiffopt[@]}" old/"$mainbase"-fl.tex new/"$mainbase"-fl.tex > diff.tex || die "latexdiff failed"
verbose_done
verbose "mv ./diff.tex new/$mainbase-fl.tex"
mv -f new/"$mainbase"-fl.tex new/"$mainbase"-fl.tex.orig
mv -f diff.tex new/"$main"
verbose_done
else
verbose "Running latexdiff ${latexdiffopt[@]} old/$main new/$main > ./diff.tex" verbose "Running latexdiff ${latexdiffopt[@]} old/$main new/$main > ./diff.tex"
latexdiff "${latexdiffopt[@]}" old/"$main" new/"$main" > diff.tex || die "latexdiff failed" latexdiff "${latexdiffopt[@]}" old/"$main" new/"$main" > diff.tex || die "latexdiff failed"
verbose_done verbose_done
verbose "mv ./diff.tex new/$main" verbose "mv ./diff.tex new/$main"
mv -f new/"$main" new/"$main.orig" mv -f new/"$main" new/"$main.orig"
mv -f diff.tex new/"$main" mv -f diff.tex new/"$main"
verbose_done verbose_done
mainbase=$(basename "$main" .tex)
maindir=$(dirname "$main")
fi
verbose "Compiling result" verbose "Compiling result"

Loading…
Cancel
Save