Build win{32,64} binaries with LDC
This commit is contained in:
parent
313b886799
commit
793a575b1c
43
.travis.yml
43
.travis.yml
|
@ -23,7 +23,7 @@ jobs:
|
||||||
include:
|
include:
|
||||||
- stage: GitHub Release
|
- stage: GitHub Release
|
||||||
#if: tag IS present
|
#if: tag IS present
|
||||||
d: ldc-1.8.0
|
d: ldc-1.13.0
|
||||||
os: linux
|
os: linux
|
||||||
script: echo "Deploying to GitHub releases ..." && ./release.sh
|
script: echo "Deploying to GitHub releases ..." && ./release.sh
|
||||||
deploy:
|
deploy:
|
||||||
|
@ -37,7 +37,7 @@ jobs:
|
||||||
tags: true
|
tags: true
|
||||||
- stage: GitHub Release
|
- stage: GitHub Release
|
||||||
#if: tag IS present
|
#if: tag IS present
|
||||||
d: ldc-1.8.0
|
d: ldc-1.13.0
|
||||||
os: osx
|
os: osx
|
||||||
script: echo "Deploying to GitHub releases ..." && ./release.sh
|
script: echo "Deploying to GitHub releases ..." && ./release.sh
|
||||||
deploy:
|
deploy:
|
||||||
|
@ -60,16 +60,35 @@ jobs:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- p7zip-full
|
- p7zip-full
|
||||||
- wine
|
deploy:
|
||||||
deploy:
|
provider: releases
|
||||||
provider: releases
|
api_key: $GH_REPO_TOKEN
|
||||||
api_key: $GH_REPO_TOKEN
|
file_glob: true
|
||||||
file_glob: true
|
file: bin/dfmt-*.zip
|
||||||
file: bin/dfmt-*.zip
|
skip_cleanup: true
|
||||||
skip_cleanup: true
|
on:
|
||||||
on:
|
repo: dlang-community/dfmt
|
||||||
repo: dlang-community/dfmt
|
tags: true
|
||||||
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:
|
stages:
|
||||||
- name: test
|
- name: test
|
||||||
if: type = pull_request or (type = push and branch = master)
|
if: type = pull_request or (type = push and branch = master)
|
||||||
|
|
3
makefile
3
makefile
|
@ -8,6 +8,9 @@ DMD_FLAGS := -O -inline $(DMD_COMMON_FLAGS)
|
||||||
DMD_TEST_FLAGS := -unittest -g $(DMD_COMMON_FLAGS)
|
DMD_TEST_FLAGS := -unittest -g $(DMD_COMMON_FLAGS)
|
||||||
LDC_FLAGS := -g -w -oq $(INCLUDE_PATHS)
|
LDC_FLAGS := -g -w -oq $(INCLUDE_PATHS)
|
||||||
GDC_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
|
DC ?= dmd
|
||||||
LDC ?= ldc2
|
LDC ?= ldc2
|
||||||
GDC ?= gdc
|
GDC ?= gdc
|
||||||
|
|
|
@ -1,26 +1,21 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
# Build the Windows binaries under Linux (requires wine)
|
# Build the Windows binaries under Linux
|
||||||
set -eux -o pipefail
|
set -eux -o pipefail
|
||||||
VERSION=$(git describe --abbrev=0 --tags)
|
|
||||||
OS=windows
|
BIN_NAME=dfmt
|
||||||
ARCH_SUFFIX="x86"
|
|
||||||
|
|
||||||
# Allow the script to be run from anywhere
|
# Allow the script to be run from anywhere
|
||||||
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
||||||
cd $DIR
|
cd $DIR
|
||||||
|
|
||||||
# Step 1: download the DMD binaries
|
source setup-ldc-windows.sh
|
||||||
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
|
|
||||||
|
|
||||||
# Step 2: Run DMD via wineconsole
|
# Run LDC with cross-compilation
|
||||||
archiveName="dfmt-$VERSION-$OS-$ARCH_SUFFIX.zip"
|
archiveName="$BIN_NAME-$VERSION-$OS-$ARCH_SUFFIX.zip"
|
||||||
echo "Building $archiveName"
|
echo "Building $archiveName"
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
git describe --tags > bin/githash.txt # no git installed under Wine
|
DC=ldmd2 make ldc
|
||||||
DC="$DIR/dmd2/windows/bin/dmd.exe" wine cmd /C build.bat
|
|
||||||
|
|
||||||
cd bin
|
cd bin
|
||||||
zip "$archiveName" dfmt.exe
|
mv "${BIN_NAME}" "${BIN_NAME}.exe"
|
||||||
|
zip "$archiveName" "${BIN_NAME}.exe"
|
||||||
|
|
|
@ -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 <<EOF
|
||||||
|
"x86_64-.*-windows-msvc":
|
||||||
|
{
|
||||||
|
switches = [
|
||||||
|
"-defaultlib=phobos2-ldc,druntime-ldc",
|
||||||
|
"-link-defaultlib-shared=false",
|
||||||
|
];
|
||||||
|
lib-dirs = [
|
||||||
|
"%%ldcbinarypath%%/../lib-win64",
|
||||||
|
];
|
||||||
|
};
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# Step 1b: download the LDC x86 windows binaries
|
||||||
|
if [ "${ARCH}" == 32 ] && [ ! -d "ldc2-${LDC_VERSION}-windows-x86" ] ; then
|
||||||
|
wget "https://github.com/ldc-developers/ldc/releases/download/v1.13.0/ldc2-${LDC_VERSION}-windows-x86.7z"
|
||||||
|
7z x "ldc2-${LDC_VERSION}-windows-x86.7z" > /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 <<EOF
|
||||||
|
"i686-.*-windows-msvc":
|
||||||
|
{
|
||||||
|
switches = [
|
||||||
|
"-defaultlib=phobos2-ldc,druntime-ldc",
|
||||||
|
"-link-defaultlib-shared=false",
|
||||||
|
];
|
||||||
|
lib-dirs = [
|
||||||
|
"%%ldcbinarypath%%/../lib-win32",
|
||||||
|
];
|
||||||
|
};
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set suffices and compilation flags
|
||||||
|
if [ "$ARCH" == "64" ] ; then
|
||||||
|
ARCH_SUFFIX="x86_64"
|
||||||
|
export DFLAGS="-mtriple=x86_64-windows-msvc"
|
||||||
|
else
|
||||||
|
ARCH_SUFFIX="x86"
|
||||||
|
export DFLAGS="-mtriple=i686-windows-msvc"
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in New Issue