Wrapper around convert to avoid Inkscape use

See comments in the script
This commit is contained in:
Bill Kendrick 2023-06-17 11:42:39 -07:00
parent c7f1e0a257
commit 8e9b33b22e
2 changed files with 52 additions and 14 deletions

View file

@ -4,7 +4,7 @@
# Various contributors (see AUTHORS.txt)
# https://tuxpaint.org/
# June 14, 2002 - June 13, 2023
# June 14, 2002 - June 17, 2023
# The version number, for release:
@ -329,6 +329,7 @@ OLDSVGFLAG:=$(if $(filter -lsvg-cairo,$(SVG_LIB)),-DOLD_SVG,)
PNG_CFLAGS:=$(shell $(PKG_CONFIG) libpng --cflags)
CONVERT:=./convert-wrapper.sh
ifeq ($(hack),1)
hack:
@ -380,7 +381,7 @@ MOUSE_CFLAGS:=-Isrc/$(MOUSEDIR) -D$(CURSOR_SHAPES)_CURSOR_SHAPES
# are 132x80. On larger screens, they will be bigger (since the New dialog
# is always 4x4 thumbnails); therefore, generating larger thumbs, which can
# be still be scaled down fairly quickly (esp. complicated SVG ones).
CONVERT_OPTS:=-alpha Background -alpha Off +depth -resize !264x160 -background white -interlace none
CONVERT_OPTS:=-alpha Background -alpha Off +depth -resize "!264x160" -background white -interlace none
.SUFFIXES:
@ -745,7 +746,6 @@ clean:
@-rm -f dlllist a.exe
@-rm -f win32/Preprocessed.iss win32/tuxpaint-*.zip win32/tuxpaint-*.exe
@-rm -f test-png
@-rm -f ./inkscape
@echo
# "make uninstall" should remove the various parts from their
@ -870,10 +870,10 @@ $(THUMB_STARTERS):
@if [ "x" != "x"$(STARTER_BACK_NAME) ] ; \
then \
composite $(STARTER_NAME) $(STARTER_BACK_NAME) obj/tmp_$(notdir $(STARTER_NAME)).png ; \
convert $(CONVERT_OPTS) obj/tmp_$(notdir $(STARTER_NAME)).png $@ 2> /dev/null ; \
$(CONVERT) $(CONVERT_OPTS) obj/tmp_$(notdir $(STARTER_NAME)).png $@ 2> /dev/null ; \
rm obj/tmp_$(notdir $(STARTER_NAME)).png ; \
else \
convert $(CONVERT_OPTS) $(STARTER_NAME) $@ 2> /dev/null || ( echo "($@ failed)" ; rm -f $@ ) ; \
$(CONVERT) $(CONVERT_OPTS) $(STARTER_NAME) $@ 2> /dev/null || ( echo "($@ failed)" ; rm -f $@ ) ; \
fi
$(INSTALLED_THUMB_STARTERS): $(DATA_PREFIX)/%: % install-example-starters-dirs
@ -883,10 +883,6 @@ $(INSTALLED_THUMB_STARTERS): $(DATA_PREFIX)/%: % install-example-starters-dirs
echo-thumb-starters:
@echo
@echo "...Generating thumbnails for starters..."
@echo "# Don't let ImageMagick use Inkscape; use rsvgconvert instead" > ./inkscape
@echo "exit 1" >> ./inkscape
@chmod 755 ./inkscape
@(eval export PATH="$(shell pwd)":"$(PATH)")
# Create thumbnails for starters
.PHONY: thumb-starters
@ -932,7 +928,7 @@ TEMPLATE_NAME=$(or $(wildcard $(subst templates/.thumbs,templates,$(@:-t.png=.sv
$(THUMB_TEMPLATES):
@printf "."
@mkdir -p templates/.thumbs
@convert $(CONVERT_OPTS) $(TEMPLATE_NAME) $@ 2> /dev/null || ( echo "($@ failed)" ; rm -f $@ ) ; \
@$(CONVERT) $(CONVERT_OPTS) $(TEMPLATE_NAME) $@ 2> /dev/null || ( echo "($@ failed)" ; rm -f $@ ) ; \
$(INSTALLED_THUMB_TEMPLATES): $(DATA_PREFIX)/%: %
@install -D -m 644 $< $@ || ( echo "NO THUMB $<" )
@ -941,10 +937,6 @@ $(INSTALLED_THUMB_TEMPLATES): $(DATA_PREFIX)/%: %
echo-thumb-templates:
@echo
@echo "...Generating thumbnails for templates..."
@echo "# Don't let ImageMagick use Inkscape; use rsvgconvert instead" > ./inkscape
@echo "exit 1" >> ./inkscape
@chmod 755 ./inkscape
@(eval export PATH="$(shell pwd)":"$(PATH)")
# Create thumbnails for templates
.PHONY: thumb-templates

46
convert-wrapper.sh Executable file
View file

@ -0,0 +1,46 @@
#!/bin/sh
# A wrapper around ImageMagick's `convert` so we can
# prevent it from using Inkscape to convert SVG files
# (which can pollute one's local filesystem with a fontcache;
# as reported by Tim Dickson, who helps maintain the
# Slackware version of the 'tuxpaint' package).
#
# Bill Kendrick <bill@newbreedsoftware.com>
# with input from Mark Kim, TOYAMA Shin-ichi, and Tim Dickson.
#
# Last modified: 2023-06-17
INPUT=`{
shift \`expr $# - 2\`
echo $1
}`
FILEEXT=`echo "$INPUT" | awk -F"." '{printf $NF}'`
if [ x$FILEEXT = "xsvg" ]; then
# An SVG!
# Create a dummy 'inkscape' that exits in such a way
# that Imagemagick's `convert` will fallback to another
# SVG converter, thus avoiding invoking the real Inkscape.
echo "exit 1" > ./inkscape
# Add the local directory to the beginning of this script's
# $PATH so `convert` finds the dummy script we just made.
export PATH="`pwd`":"${PATH}"
# Now run `convert` in the usual way (and grab its exit status,
# so we don't catch `rm`'s)
convert $@
EXIT=$?
# Clean up
rm ./inkscape
else
# Not an SVG (so, a PNG or JPEG); just run `convert` as usual.
convert $@
EXIT=$?
fi
exit $EXIT