From 793a575b1c33d58924e4f0945f15dacf1301246d Mon Sep 17 00:00:00 2001 From: Sebastian Wilzbach Date: Fri, 4 Jan 2019 20:15:56 +0100 Subject: [PATCH] Build win{32,64} binaries with LDC --- .travis.yml | 43 +++++++++++++++++++-------- makefile | 3 ++ release-windows.sh | 23 ++++++--------- setup-ldc-windows.sh | 70 ++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 113 insertions(+), 26 deletions(-) create mode 100644 setup-ldc-windows.sh diff --git a/.travis.yml b/.travis.yml index 904e4f1..aabf8e5 100644 --- a/.travis.yml +++ b/.travis.yml @@ -23,7 +23,7 @@ jobs: include: - stage: GitHub Release #if: tag IS present - d: ldc-1.8.0 + d: ldc-1.13.0 os: linux script: echo "Deploying to GitHub releases ..." && ./release.sh deploy: @@ -37,7 +37,7 @@ jobs: tags: true - stage: GitHub Release #if: tag IS present - d: ldc-1.8.0 + d: ldc-1.13.0 os: osx script: echo "Deploying to GitHub releases ..." && ./release.sh deploy: @@ -60,16 +60,35 @@ jobs: apt: packages: - p7zip-full - - wine - deploy: - provider: releases - api_key: $GH_REPO_TOKEN - file_glob: true - file: bin/dfmt-*.zip - skip_cleanup: true - on: - repo: dlang-community/dfmt - tags: true + deploy: + provider: releases + api_key: $GH_REPO_TOKEN + file_glob: true + file: bin/dfmt-*.zip + skip_cleanup: true + on: + repo: dlang-community/dfmt + tags: true + - stage: GitHub Release + #if: tag IS present + d: dmd + os: linux + language: generic + sudo: yes + script: echo "Deploying to GitHub releases ..." && ARCH=64 ./release-windows.sh + addons: + apt: + packages: + - p7zip-full + deploy: + provider: releases + api_key: $GH_REPO_TOKEN + file_glob: true + file: bin/dfmt-*.zip + skip_cleanup: true + on: + repo: dlang-community/dfmt + tags: true stages: - name: test if: type = pull_request or (type = push and branch = master) diff --git a/makefile b/makefile index 9a2ca55..1227910 100644 --- a/makefile +++ b/makefile @@ -8,6 +8,9 @@ DMD_FLAGS := -O -inline $(DMD_COMMON_FLAGS) DMD_TEST_FLAGS := -unittest -g $(DMD_COMMON_FLAGS) LDC_FLAGS := -g -w -oq $(INCLUDE_PATHS) GDC_FLAGS := -g -w -oq $(INCLUDE_PATHS) +override DMD_FLAGS += $(DFLAGS) +override LDC_FLAGS += $(DFLAGS) +override GDC_FLAGS += $(DFLAGS) DC ?= dmd LDC ?= ldc2 GDC ?= gdc diff --git a/release-windows.sh b/release-windows.sh index 956982a..49ce3a5 100755 --- a/release-windows.sh +++ b/release-windows.sh @@ -1,26 +1,21 @@ #!/usr/bin/env bash -# Build the Windows binaries under Linux (requires wine) +# Build the Windows binaries under Linux set -eux -o pipefail -VERSION=$(git describe --abbrev=0 --tags) -OS=windows -ARCH_SUFFIX="x86" + +BIN_NAME=dfmt # Allow the script to be run from anywhere DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" cd $DIR -# Step 1: download the DMD binaries -if [ ! -d dmd2 ] ; then - wget http://downloads.dlang.org/releases/2.x/2.079.0/dmd.2.079.0.windows.7z - 7z x dmd.2.079.0.windows.7z > /dev/null -fi +source setup-ldc-windows.sh -# Step 2: Run DMD via wineconsole -archiveName="dfmt-$VERSION-$OS-$ARCH_SUFFIX.zip" +# Run LDC with cross-compilation +archiveName="$BIN_NAME-$VERSION-$OS-$ARCH_SUFFIX.zip" echo "Building $archiveName" mkdir -p bin -git describe --tags > bin/githash.txt # no git installed under Wine -DC="$DIR/dmd2/windows/bin/dmd.exe" wine cmd /C build.bat +DC=ldmd2 make ldc cd bin -zip "$archiveName" dfmt.exe +mv "${BIN_NAME}" "${BIN_NAME}.exe" +zip "$archiveName" "${BIN_NAME}.exe" diff --git a/setup-ldc-windows.sh b/setup-ldc-windows.sh new file mode 100644 index 0000000..0656b5a --- /dev/null +++ b/setup-ldc-windows.sh @@ -0,0 +1,70 @@ +#!/usr/bin/env bash + +# sets up LDC for cross-compilation. Source this script, s.t. the new LDC is in PATH + +LDC_VERSION="1.13.0" +ARCH=${ARCH:-32} +VERSION=$(git describe --abbrev=0 --tags) +OS=windows + +# Step 0: install ldc +if [ ! -f install.sh ] ; then + wget https://dlang.org/install.sh +fi +. $(bash ./install.sh -a "ldc-${LDC_VERSION}") + +# for the install.sh script only +LDC_PATH="$(dirname $(dirname $(which ldc2)))" + +# Step 1a: download the LDC x64 windows binaries +if [ "${ARCH}" == 64 ] && [ ! -d "ldc2-${LDC_VERSION}-windows-x64" ] ; then + wget "https://github.com/ldc-developers/ldc/releases/download/v1.13.0/ldc2-${LDC_VERSION}-windows-x64.7z" + 7z x "ldc2-${LDC_VERSION}-windows-x64.7z" > /dev/null + # Step 2a: Add LDC windows binaries to LDC Linux + if [ ! -d "${LDC_PATH}/lib-win64" ] ; then + cp -r ldc2-1.13.0-windows-x64/lib "${LDC_PATH}/lib-win64" + cat >> "$LDC_PATH"/etc/ldc2.conf < /dev/null + # Step 2b: Add LDC windows binaries to LDC Linux + if [ ! -d "${LDC_PATH}/lib-win32" ] ; then + cp -r ldc2-1.13.0-windows-x86/lib "${LDC_PATH}/lib-win32" + cat >> "$LDC_PATH"/etc/ldc2.conf <