From ef38c6b7b77f7ff1d37ae9fe50d997c421aa0311 Mon Sep 17 00:00:00 2001 From: Maxim Biro Date: Thu, 4 Jun 2020 02:05:16 -0400 Subject: [PATCH] feat(windows): Link all Windows deps dynamically --- windows/cross-compile/build.sh | 179 ++++++++++++++++++++++++++++----- 1 file changed, 156 insertions(+), 23 deletions(-) diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index 415bdecdc..fd87f234c 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -408,10 +408,11 @@ then ./configure --host="$ARCH-w64-mingw32" \ --prefix="$SQLCIPHER_PREFIX_DIR" \ - --disable-shared \ + --enable-shared \ + --disable-static \ --enable-tempstore=yes \ CFLAGS="-O2 -g0 -DSQLITE_HAS_CODEC -I$OPENSSL_PREFIX_DIR/include/" \ - LDFLAGS="$OPENSSL_PREFIX_DIR/lib/libcrypto.a -lcrypto -lgdi32 -L$OPENSSL_PREFIX_DIR/lib/" \ + LDFLAGS="-lcrypto -lgdi32 -L$OPENSSL_PREFIX_DIR/lib/" \ LIBS="-lgdi32 -lws2_32" sed -i s/"TEXE = $"/"TEXE = .exe"/ Makefile @@ -454,15 +455,14 @@ then ./configure $CONFIGURE_OPTIONS \ --enable-gpl \ + --enable-shared \ + --disable-static \ --prefix="$FFMPEG_PREFIX_DIR" \ --target-os="mingw32" \ --cross-prefix="$ARCH-w64-mingw32-" \ --pkg-config="pkg-config" \ - --extra-cflags="-static -O2 -g0" \ - --extra-ldflags="-lm -static" \ - --pkg-config-flags="--static" \ + --extra-cflags="-O2 -g0" \ --disable-debug \ - --disable-shared \ --disable-programs \ --disable-protocols \ --disable-doc \ @@ -612,8 +612,8 @@ then CFLAGS="-O2 -g0" ./configure --host="$ARCH-w64-mingw32" \ --prefix="$QRENCODE_PREFIX_DIR" \ - --disable-shared \ - --enable-static \ + --enable-shared \ + --disable-static \ --disable-sdltest \ --without-tools \ --without-debug @@ -647,8 +647,8 @@ then CFLAGS="-O2 -g0" ./configure --host="$ARCH-w64-mingw32" \ --prefix="$EXIF_PREFIX_DIR" \ - --disable-shared \ - --enable-static \ + --enable-shared \ + --disable-static \ --disable-docs \ --disable-nls make @@ -682,8 +682,8 @@ then CFLAGS="-O2 -g0" ./configure --host="$ARCH-w64-mingw32" \ --prefix="$OPUS_PREFIX_DIR" \ - --disable-shared \ - --enable-static \ + --enable-shared \ + --disable-static \ --disable-extra-programs \ --disable-doc make @@ -716,9 +716,8 @@ then ./configure --host="$ARCH-w64-mingw32" \ --prefix="$SODIUM_PREFIX_DIR" \ - --disable-shared \ - --enable-static \ - --with-pic + --enable-shared \ + --disable-static make make install echo -n $SODIUM_VERSION > $SODIUM_PREFIX_DIR/done @@ -760,17 +759,153 @@ then VPX_CFLAGS="" fi + cd .. + +# Fix VPX not supporting creation of dll +# Modified version of https://aur.archlinux.org/cgit/aur.git/tree/configure.patch?h=mingw-w64-libvpx&id=6d658aa0f4d8409fcbd0f20be2c0adcf1e81a297 +> configure.patch cat << "EOF" +diff -ruN libvpx/build/make/configure.sh patched/build/make/configure.sh +--- libvpx/build/make/configure.sh 2019-02-13 16:56:48.972857636 +0100 ++++ patched/build/make/configure.sh 2019-02-13 16:50:37.995967583 +0100 +@@ -1426,11 +1426,13 @@ + win32) + add_asflags -f win32 + enabled debug && add_asflags -g cv8 ++ add_ldflags "-Wl,-no-undefined" + EXE_SFX=.exe + ;; + win64) + add_asflags -f win64 + enabled debug && add_asflags -g cv8 ++ add_ldflags "-Wl,-no-undefined" + EXE_SFX=.exe + ;; + linux*|solaris*|android*) +diff -ruN libvpx/build/make/Makefile patched/build/make/Makefile +--- libvpx/build/make/Makefile 2019-02-13 16:56:48.972857636 +0100 ++++ patched/build/make/Makefile 2019-02-13 16:50:37.995967583 +0100 +@@ -304,6 +304,7 @@ + $(if $(quiet),@echo " [LD] $$@") + $(qexec)$$(LD) -shared $$(LDFLAGS) \ + -Wl,--no-undefined -Wl,-soname,$$(SONAME) \ ++ -Wl,-out-implib,libvpx.dll.a \ + -Wl,--version-script,$$(EXPORTS_FILE) -o $$@ \ + $$(filter %.o,$$^) $$(extralibs) + endef +@@ -388,7 +389,7 @@ + .libs: $(LIBS) + @touch $@ + $(foreach lib,$(filter %_g.a,$(LIBS)),$(eval $(call archive_template,$(lib)))) +-$(foreach lib,$(filter %so.$(SO_VERSION_MAJOR).$(SO_VERSION_MINOR).$(SO_VERSION_PATCH),$(LIBS)),$(eval $(call so_template,$(lib)))) ++$(foreach lib,$(filter %dll,$(LIBS)),$(eval $(call so_template,$(lib)))) + $(foreach lib,$(filter %$(SO_VERSION_MAJOR).dylib,$(LIBS)),$(eval $(call dl_template,$(lib)))) + $(foreach lib,$(filter %$(SO_VERSION_MAJOR).dll,$(LIBS)),$(eval $(call dll_template,$(lib)))) + +diff -ruN libvpx/configure patched/configure +--- libvpx/configure 2019-02-13 16:56:49.162860897 +0100 ++++ patched/configure 2019-02-13 16:53:03.328719607 +0100 +@@ -513,23 +513,23 @@ + } + + process_detect() { +- if enabled shared; then ++ #if enabled shared; then + # Can only build shared libs on a subset of platforms. Doing this check + # here rather than at option parse time because the target auto-detect + # magic happens after the command line has been parsed. +- case "${tgt_os}" in +- linux|os2|solaris|darwin*|iphonesimulator*) ++ # case "${tgt_os}" in ++ # linux|os2|solaris|darwin*|iphonesimulator*) + # Supported platforms +- ;; +- *) +- if enabled gnu; then +- echo "--enable-shared is only supported on ELF; assuming this is OK" +- else +- die "--enable-shared only supported on ELF, OS/2, and Darwin for now" +- fi +- ;; +- esac +- fi ++ # ;; ++ # *) ++ # if enabled gnu; then ++ # echo "--enable-shared is only supported on ELF; assuming this is OK" ++ # else ++ # die "--enable-shared only supported on ELF, OS/2, and Darwin for now" ++ # fi ++ # ;; ++ # esac ++ #fi + if [ -z "$CC" ] || enabled external_build; then + echo "Bypassing toolchain for environment detection." + enable_feature external_build +diff -ruN libvpx/examples.mk patched/examples.mk +--- libvpx/examples.mk 2019-02-13 16:56:49.162860897 +0100 ++++ patched/examples.mk 2019-02-13 16:50:37.995967583 +0100 +@@ -315,7 +315,7 @@ + ifneq ($(filter os2%,$(TGT_OS)),) + SHARED_LIB_SUF=_dll.a + else +-SHARED_LIB_SUF=.so ++SHARED_LIB_SUF=.dll.a + endif + endif + CODEC_LIB_SUF=$(if $(CONFIG_SHARED),$(SHARED_LIB_SUF),.a) +diff -ruN libvpx/libs.mk patched/libs.mk +--- libvpx/libs.mk 2019-02-13 16:56:48.972857636 +0100 ++++ patched/libs.mk 2019-02-13 16:50:37.995967583 +0100 +@@ -256,12 +256,12 @@ + LIBVPX_SO_SYMLINKS := + LIBVPX_SO_IMPLIB := libvpx_dll.a + else +-LIBVPX_SO := libvpx.so.$(SO_VERSION_MAJOR).$(SO_VERSION_MINOR).$(SO_VERSION_PATCH) +-SHARED_LIB_SUF := .so ++LIBVPX_SO := libvpx.dll ++SHARED_LIB_SUF := .dll + EXPORT_FILE := libvpx.ver +-LIBVPX_SO_SYMLINKS := $(addprefix $(LIBSUBDIR)/, \ +- libvpx.so libvpx.so.$(SO_VERSION_MAJOR) \ +- libvpx.so.$(SO_VERSION_MAJOR).$(SO_VERSION_MINOR)) ++LIBVPX_SO_SYMLINKS := ++ ++ + endif + endif + endif +@@ -271,7 +271,7 @@ + $(if $(LIBVPX_SO_IMPLIB), $(BUILD_PFX)$(LIBVPX_SO_IMPLIB)) + $(BUILD_PFX)$(LIBVPX_SO): $(LIBVPX_OBJS) $(EXPORT_FILE) + $(BUILD_PFX)$(LIBVPX_SO): extralibs += -lm +-$(BUILD_PFX)$(LIBVPX_SO): SONAME = libvpx.so.$(SO_VERSION_MAJOR) ++$(BUILD_PFX)$(LIBVPX_SO): SONAME = libvpx.dll + $(BUILD_PFX)$(LIBVPX_SO): EXPORTS_FILE = $(EXPORT_FILE) + + libvpx.def: $(call enabled,CODEC_EXPORTS) +EOF + + cd - + patch -Np1 < ../configure.patch + rm ../configure.patch + CFLAGS="$VPX_CFLAGS" \ CROSS="$ARCH-w64-mingw32-" ./configure --target="$VPX_TARGET" \ --prefix="$VPX_PREFIX_DIR" \ - --disable-shared \ - --enable-static \ + --enable-shared \ + --disable-static \ + --enable-runtime-cpu-detect \ --disable-examples \ --disable-tools \ --disable-docs \ --disable-unit-tests make make install + + mkdir -p "$VPX_PREFIX_DIR/bin" + mv "$VPX_PREFIX_DIR/lib/"*.dll "$VPX_PREFIX_DIR/bin/" + mv ./libvpx*.dll.a "$VPX_PREFIX_DIR/lib/" + echo -n $VPX_VERSION > $VPX_PREFIX_DIR/done cd .. @@ -816,8 +951,8 @@ then cmake -DCMAKE_INSTALL_PREFIX=$TOXCORE_PREFIX_DIR \ -DBOOTSTRAP_DAEMON=OFF \ -DCMAKE_BUILD_TYPE=Release \ - -DENABLE_STATIC=ON \ - -DENABLE_SHARED=OFF \ + -DENABLE_STATIC=OFF \ + -DENABLE_SHARED=ON \ -DCMAKE_TOOLCHAIN_FILE=toolchain.cmake \ .. @@ -985,10 +1120,8 @@ cp -r $QT_PREFIX_DIR/plugins/imageformats \ $QT_PREFIX_DIR/plugins/platforms \ $QT_PREFIX_DIR/plugins/iconengines \ $QTOX_PREFIX_DIR -cp $OPENAL_PREFIX_DIR/bin/OpenAL32.dll $QTOX_PREFIX_DIR -cp $OPENSSL_PREFIX_DIR/bin/libssl-*.dll \ - $OPENSSL_PREFIX_DIR/bin/libcrypto-*.dll \ - $QTOX_PREFIX_DIR +cp {$OPENSSL_PREFIX_DIR,$SQLCIPHER_PREFIX_DIR,$FFMPEG_PREFIX_DIR,$OPENAL_PREFIX_DIR,$QRENCODE_PREFIX_DIR,$EXIF_PREFIX_DIR,$OPUS_PREFIX_DIR,$SODIUM_PREFIX_DIR,$VPX_PREFIX_DIR,$TOXCORE_PREFIX_DIR}/bin/*.dll $QTOX_PREFIX_DIR + cp /usr/lib/gcc/$ARCH-w64-mingw32/*-posix/libgcc_s_*.dll $QTOX_PREFIX_DIR cp /usr/lib/gcc/$ARCH-w64-mingw32/*-posix/libstdc++-6.dll $QTOX_PREFIX_DIR cp /usr/$ARCH-w64-mingw32/lib/libwinpthread-1.dll $QTOX_PREFIX_DIR