aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJon Turney <jon.turney@dronecode.org.uk>2020-08-23 17:49:42 +0100
committerJon Turney <jon.turney@dronecode.org.uk>2020-08-28 22:51:58 +0100
commit5b67246301dfe2cce50939273889f59010be27a5 (patch)
tree4f62ee996bec1bd2f2a7ca44593e6176d9069db2
parenta07872603774c369e5eec69f3f650bf1153842d8 (diff)
downloadnewlib-5b67246301dfe2cce50939273889f59010be27a5.zip
newlib-5b67246301dfe2cce50939273889f59010be27a5.tar.gz
newlib-5b67246301dfe2cce50939273889f59010be27a5.tar.bz2
Cygwin: Add github action to cross-build on Fedora
This helps avoid unpleasant surprises when we come to actually make a release (which are cross-built in this manner)
-rw-r--r--.github/workflows/cygwin.yml45
1 files changed, 45 insertions, 0 deletions
diff --git a/.github/workflows/cygwin.yml b/.github/workflows/cygwin.yml
new file mode 100644
index 0000000..cdad8e6
--- /dev/null
+++ b/.github/workflows/cygwin.yml
@@ -0,0 +1,45 @@
+name: cygwin
+
+on: push
+
+jobs:
+ fedora-build:
+ runs-on: ubuntu-latest
+ container: fedora:latest
+ strategy:
+ fail-fast: false
+ matrix:
+ include:
+ - target: x86_64-pc-cygwin
+ pkgarch: 64
+ - target: i686-pc-cygwin
+ pkgarch: 32
+ name: Fedora cross ${{ matrix.target }}
+
+ steps:
+ - uses: actions/checkout@v2
+
+ # install build tools
+ - run: dnf install -y make patch perl
+ - run: dnf install -y mingw${{ matrix.pkgarch }}-gcc-c++ mingw${{ matrix.pkgarch }}-winpthreads-static mingw${{ matrix.pkgarch }}-zlib-static
+
+ # cocom isn't packaged in Fedora, so we install from a 3rd party repo
+ - run: dnf install -y https://github.com/rpmsphere/noarch/raw/master/r/rpmsphere-release-$(rpm -E %fedora)-1.noarch.rpm
+ - run: dnf install -y cocom
+
+ # install cross-cygwin toolchain and libs from copr
+ - run: dnf install -y dnf-plugins-core
+ - run: dnf copr enable -y yselkowitz/cygwin
+ - run: dnf install -y cygwin${{ matrix.pkgarch }}-gcc-c++ cygwin${{ matrix.pkgarch }}-gettext cygwin${{ matrix.pkgarch }}-libbfd cygwin${{ matrix.pkgarch }}-libiconv cygwin${{ matrix.pkgarch }}-zlib
+
+ # install doc tools
+ - run: dnf install -y dblatex docbook2X docbook-xsl xmlto
+ - run: dnf install -y python3 python3-lxml python3-ply
+
+ # build
+ - run: mkdir build install
+ - run: cd build && ../configure --target=${{ matrix.target }} --prefix=$(realpath $(pwd)/../install)
+ - run: make -C build
+ - run: make -C build/*/newlib info man
+ - run: make -C build install
+ - run: make -C build/*/newlib install-info install-man