aboutsummaryrefslogtreecommitdiffstats
path: root/.ci
diff options
context:
space:
mode:
authorMike Blumenkrantz <zmike@samsung.com>2018-07-10 18:43:55 -0400
committerStefan Schmidt <s.schmidt@samsung.com>2018-07-26 08:55:58 +0200
commit005ba932344bbf4eb022df96ea24be67093324c0 (patch)
tree1296b517b2ec640ffe43cd54d468f4333076f474 /.ci
parentci: refactor all build steps into separate build scripts (diff)
downloadefl-005ba932344bbf4eb022df96ea24be67093324c0.tar.gz
ci: add ccache support
this enables and implements full support for ccache on travis builds fix https://phab.enlightenment.org/T7126 Differential Revision: https://phab.enlightenment.org/D6605 =also includes previously-submitted patches= ci: split out ccache config setup into separate script this provides a more unified place to set ccache options also enable ccache compression to cut down on cache upload/download overhead ref https://phab.enlightenment.org/D6613 ci: zero ccache stats before build and add some comments for options used zeroing the stats before each build will provide more insight into the cache performance for each build ref https://phab.enlightenment.org/D6621 ci: break out ccache stat printing into separate script continue to make travis.yml more readable ref https://phab.enlightenment.org/D6622 ci: add more ccache config options to improve cache direct hits ci: disable second cpp run for ccache this should avoid running cpp twice for files https://ccache.samba.org/manual.html#_the_preprocessor_mode
Diffstat (limited to '.ci')
-rw-r--r--.ci/ccache.conf7
-rwxr-xr-x.ci/ci-ccache-stats.sh9
-rwxr-xr-x.ci/ci-configure.sh11
-rwxr-xr-x.ci/ci-make-distcheck.sh5
-rwxr-xr-x.ci/ci-osx-deps.sh2
-rwxr-xr-x.ci/ci-setup-ccache.sh12
-rwxr-xr-x.ci/docker-ccache-setup.sh11
7 files changed, 52 insertions, 5 deletions
diff --git a/.ci/ccache.conf b/.ci/ccache.conf
new file mode 100644
index 0000000000..e9913800ca
--- /dev/null
+++ b/.ci/ccache.conf
@@ -0,0 +1,7 @@
+max_size = 500M
+compression = true
+compression_level = 1
+sloppiness = time_macros,include_file_mtime,include_file_ctime,file_macro
+run_second_cpp = false
+hash_dir = false
+
diff --git a/.ci/ci-ccache-stats.sh b/.ci/ci-ccache-stats.sh
new file mode 100755
index 0000000000..76b270488c
--- /dev/null
+++ b/.ci/ci-ccache-stats.sh
@@ -0,0 +1,9 @@
+#!/bin/sh
+
+set -e
+
+if [ "$DISTRO" != "" ] ; then
+ docker exec $(cat $HOME/cid) ccache -s
+else
+ ccache -s
+fi
diff --git a/.ci/ci-configure.sh b/.ci/ci-configure.sh
index 28897dafcc..86e280ec5f 100755
--- a/.ci/ci-configure.sh
+++ b/.ci/ci-configure.sh
@@ -49,7 +49,10 @@ if [ "$DISTRO" != "" ] ; then
if [ "$1" = "release-ready" ]; then
OPTS="$OPTS $RELEASE_READY_LINUX_COPTS"
fi
- docker run --env MAKEFLAGS="-j5" --env EIO_MONITOR_POLL=1 -v `pwd`:/src -w /src stefanschmidt1/ci-support-files:$DISTRO ./autogen.sh $OPTS
+ docker exec $(cat $HOME/cid) sh -c 'rm -f ~/.ccache/ccache.conf'
+ docker exec --env MAKEFLAGS="-j5" --env EIO_MONITOR_POLL=1 --env CC="ccache gcc" \
+ --env CXX="ccache g++" --env CFLAGS="-fdirectives-only" --env CXXFLAGS="-fdirectives-only" \
+ $(cat $HOME/cid) ./autogen.sh $OPTS
else
OSX_COPTS="--disable-cxx-bindings"
@@ -57,11 +60,13 @@ else
mkdir -p ~/Library/LaunchAgents
ln -sfv /usr/local/opt/d-bus/*.plist ~/Library/LaunchAgents
launchctl load ~/Library/LaunchAgents/org.freedesktop.dbus-session.plist
- export PATH="$(brew --prefix gettext)/bin:$PATH"
+ export PATH="/usr/local/opt/ccache/libexec:$(brew --prefix gettext)/bin:$PATH"
- export CFLAGS="-I/usr/local/opt/openssl/include $CFLAGS"
+ export CFLAGS="-I/usr/local/opt/openssl/include -frewrite-includes $CFLAGS"
+ export LDFLAGS="-L/usr/local/opt/openssl/lib $LDFLAGS"
export LDFLAGS="-L/usr/local/opt/openssl/lib $LDFLAGS"
# Normal build test of all targets
+ rm -f ~/.ccache/ccache.conf
./autogen.sh $OSX_COPTS
fi
diff --git a/.ci/ci-make-distcheck.sh b/.ci/ci-make-distcheck.sh
index 144b95782e..a00de9911c 100755
--- a/.ci/ci-make-distcheck.sh
+++ b/.ci/ci-make-distcheck.sh
@@ -7,7 +7,10 @@ if [ "$1" != "release-ready" ] ; then
fi
if [ "$DISTRO" != "" ] ; then
- docker exec --env MAKEFLAGS="-j5" --env EIO_MONITOR_POLL=1 $(cat $HOME/cid) make distcheck
+ docker exec --env MAKEFLAGS="-j5" --env EIO_MONITOR_POLL=1 --env CC="ccache gcc" \
+ --env CXX="ccache g++" \
+ --env CFLAGS="-fdirectives-only" --env CXXFLAGS="-fdirectives-only" \
+ $(cat $HOME/cid) make distcheck
else
export PATH="/usr/local/opt/ccache/libexec:$(brew --prefix gettext)/bin:$PATH"
make
diff --git a/.ci/ci-osx-deps.sh b/.ci/ci-osx-deps.sh
index 859842624e..95872f82f3 100755
--- a/.ci/ci-osx-deps.sh
+++ b/.ci/ci-osx-deps.sh
@@ -2,4 +2,4 @@
brew update
brew unlink python
-brew install gettext check bullet dbus fontconfig freetype fribidi gst-plugins-good gstreamer luajit openssl webp libsndfile glib libspectre libraw librsvg poppler lz4 pulseaudio
+brew install gettext check bullet dbus fontconfig freetype fribidi gst-plugins-good gstreamer luajit openssl webp libsndfile glib libspectre libraw librsvg poppler lz4 pulseaudio ccache
diff --git a/.ci/ci-setup-ccache.sh b/.ci/ci-setup-ccache.sh
new file mode 100755
index 0000000000..0a5087883f
--- /dev/null
+++ b/.ci/ci-setup-ccache.sh
@@ -0,0 +1,12 @@
+#!/bin/sh
+
+set -e
+
+if [ "$DISTRO" != "" ] ; then
+ docker exec $(cat $HOME/cid) sh -c ".ci/docker-ccache-setup.sh $1"
+ docker exec $(cat $HOME/cid) ccache -pz
+else
+ cp .ci/ccache.conf ~/.ccache
+ ccache -o base_dir="$(pwd)"
+ ccache -pz
+fi
diff --git a/.ci/docker-ccache-setup.sh b/.ci/docker-ccache-setup.sh
new file mode 100755
index 0000000000..748e743bf9
--- /dev/null
+++ b/.ci/docker-ccache-setup.sh
@@ -0,0 +1,11 @@
+#!/bin/sh
+
+CI_BUILD_TYPE="$1"
+
+cp .ci/ccache.conf ~/.ccache
+
+if [ "$1" = "release-ready" ] ; then
+ ccache -o base_dir="$(pwd)/$(grep '^PACKAGE_STRING' config.log|cut -d\' -f2|tr ' ' -)"
+else
+ ccache -o base_dir=$(pwd)
+fi