summaryrefslogtreecommitdiffstats
path: root/buildtools/msys2installdeps.sh
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 11:50:49 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 11:50:49 +0000
commitc853ffb5b2f75f5a889ed2e3ef89b818a736e87a (patch)
tree7d13a0883bb7936b84d6ecdd7bc332b41ed04bee /buildtools/msys2installdeps.sh
parentInitial commit. (diff)
downloadinkscape-c853ffb5b2f75f5a889ed2e3ef89b818a736e87a.tar.xz
inkscape-c853ffb5b2f75f5a889ed2e3ef89b818a736e87a.zip
Adding upstream version 1.3+ds.upstream/1.3+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'buildtools/msys2installdeps.sh')
-rw-r--r--buildtools/msys2installdeps.sh156
1 files changed, 156 insertions, 0 deletions
diff --git a/buildtools/msys2installdeps.sh b/buildtools/msys2installdeps.sh
new file mode 100644
index 0000000..ce47937
--- /dev/null
+++ b/buildtools/msys2installdeps.sh
@@ -0,0 +1,156 @@
+#!/usr/bin/env bash
+# -------------------------------------------------------------------------------
+# This script installs all dependencies required for building Inkscape with MSYS2.
+#
+# See https://wiki.inkscape.org/wiki/Compiling_Inkscape_on_Windows_with_MSYS2 for
+# detailed instructions.
+#
+# The following instructions assume you are building for the standard x86_64 processor architecture,
+# which means that you use the MINGW64 variant of msys2.
+# Else, replace MINGW64 with the appropriate variant for your architecture.
+#
+# To run this script, execute it once on an MINGW64 shell, i.e.
+# - use the "MSYS2 MINGW64" shortcut in the start menu or
+# - run "mingw64.exe" in MSYS2's installation folder
+#
+# MSYS2 and installed libraries can be updated later by executing
+# pacman -Syu
+# in an MSYS shell ("MSYS2 MSYS" shortcut in the start menu or "msys2.exe" in the
+# MSYS2 folder)
+# -------------------------------------------------------------------------------
+
+# select if you want to build 32-bit (i686), 64-bit (x86_64), or both
+case "$MSYSTEM" in
+ MINGW32)
+ ARCH=mingw-w64-i686
+ ;;
+ MINGW64)
+ ARCH=mingw-w64-x86_64
+ ;;
+ UCRT64)
+ ARCH=mingw-w64-ucrt-x86_64
+ ;;
+ CLANGARM64)
+ ARCH=mingw-w64-clang-aarch64
+ ;;
+ *)
+ ARCH={mingw-w64-i686,mingw-w64-x86_64}
+ ;;
+esac
+
+# set default options for invoking pacman (in CI this variable is already set globally)
+if [ -z $CI ]; then
+ PACMAN_OPTIONS="--needed --noconfirm"
+fi
+
+# sync package databases
+pacman -Sy
+
+# install basic development system, compiler toolchain and build tools
+eval pacman -S $PACMAN_OPTIONS \
+git \
+base-devel \
+$ARCH-toolchain \
+$ARCH-autotools \
+$ARCH-cmake \
+$ARCH-meson \
+$ARCH-ninja \
+$ARCH-ccache
+
+# install Inkscape dependencies (required)
+eval pacman -S $PACMAN_OPTIONS \
+$ARCH-double-conversion \
+$ARCH-gc \
+$ARCH-gsl \
+$ARCH-libxslt \
+$ARCH-boost \
+$ARCH-gtk3 \
+$ARCH-gtk-doc \
+$ARCH-gtkmm3 \
+$ARCH-libsoup
+
+# install Inkscape dependencies (optional)
+eval pacman -S $PACMAN_OPTIONS \
+$ARCH-poppler \
+$ARCH-potrace \
+$ARCH-libcdr \
+$ARCH-libvisio \
+$ARCH-libwpg \
+$ARCH-aspell \
+$ARCH-aspell-en \
+$ARCH-gspell \
+$ARCH-gtksourceview4 \
+$ARCH-graphicsmagick \
+$ARCH-libjxl
+
+# install Python and modules used by Inkscape
+eval pacman -S $PACMAN_OPTIONS \
+$ARCH-python \
+$ARCH-python-pip \
+$ARCH-python-lxml \
+$ARCH-python-numpy \
+$ARCH-python-cssselect \
+$ARCH-python-pillow \
+$ARCH-python-six \
+$ARCH-python-gobject \
+$ARCH-python-pyserial \
+$ARCH-python-coverage \
+$ARCH-python-packaging \
+$ARCH-python-zstandard \
+$ARCH-scour
+
+# install modules needed by extensions manager and clipart importer
+eval pacman -S $PACMAN_OPTIONS \
+$ARCH-python-appdirs \
+$ARCH-python-beautifulsoup4 \
+$ARCH-python-filelock \
+$ARCH-python-msgpack \
+$ARCH-python-lockfile \
+$ARCH-python-cachecontrol \
+$ARCH-python-idna \
+$ARCH-python-urllib3 \
+$ARCH-python-chardet \
+$ARCH-python-certifi \
+$ARCH-python-requests
+
+# install Python modules not provided as MSYS2/MinGW packages
+PACKAGES=""
+for arch in $(eval echo $ARCH); do
+ case ${arch} in
+ mingw-w64-i686)
+ #/mingw32/bin/pip3 install --upgrade ${PACKAGES}
+ ;;
+ mingw-w64-x86_64)
+ #/mingw64/bin/pip3 install --upgrade ${PACKAGES}
+ ;;
+ mingw-w64-clang-aarch64)
+ #/clangarm64/bin/pip3 install --upgrade ${PACKAGES}
+ ;;
+ esac
+done
+
+
+# gettext hack - to remove once gettext has the match
+function hack_libintl(){
+f=/$1/include/libintl.h
+sed -i '/^extern int sprintf/a #ifdef __cplusplus\nnamespace std { using ::libintl_sprintf; }\n#endif' $f
+cat $f
+}
+
+case "$MSYSTEM" in
+ MINGW32)
+ hack_libintl mingw32
+ ;;
+ MINGW64)
+ hack_libintl mingw64
+ ;;
+ CLANGARM64)
+ hack_libintl clangarm64
+ ;;
+ *)
+ hack_libintl mingw32
+ hack_libintl mingw64
+ ;;
+esac
+
+echo "Done :-)"