diff options
author | James McCoy <jamessan@jamessan.com> | 2018-05-01 07:02:11 -0400 |
---|---|---|
committer | James McCoy <jamessan@jamessan.com> | 2018-05-01 07:02:44 -0400 |
commit | d5da357925dffb84c9c6c49fd6c1fbdf6508cb7f (patch) | |
tree | 1556355f8990b5a79abaf46e23f21f7c1428990b | |
parent | 58b210e1146f5fe3dd1affe4ab81a3cf48ae27ab (diff) | |
download | rneovim-d5da357925dffb84c9c6c49fd6c1fbdf6508cb7f.tar.gz rneovim-d5da357925dffb84c9c6c49fd6c1fbdf6508cb7f.tar.bz2 rneovim-d5da357925dffb84c9c6c49fd6c1fbdf6508cb7f.zip |
travis: Enable ccache
-rw-r--r-- | .travis.yml | 5 | ||||
-rwxr-xr-x | ci/before_cache.sh | 3 | ||||
-rwxr-xr-x | ci/before_script.sh | 3 | ||||
-rw-r--r-- | ci/common/build.sh | 4 | ||||
-rwxr-xr-x | ci/install.sh | 2 |
5 files changed, 16 insertions, 1 deletions
diff --git a/.travis.yml b/.travis.yml index 3cd21170b7..ab32b38f3d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -41,6 +41,10 @@ env: # default target name for functional tests - FUNCTIONALTEST=functionaltest - CI_TARGET=tests + # Environment variables for ccache + - CCACHE_COMPRESS=1 + - CCACHE_SLOPPINESS=time_macros,file_macro + - CCACHE_BASEDIR="$TRAVIS_BUILD_DIR" jobs: include: @@ -118,6 +122,7 @@ branches: cache: apt: true + ccache: true directories: - "$HOME/.cache/pip" - "$HOME/.cache/nvim-deps" diff --git a/ci/before_cache.sh b/ci/before_cache.sh index d99b8e68c6..c8a1fd5b71 100755 --- a/ci/before_cache.sh +++ b/ci/before_cache.sh @@ -14,6 +14,9 @@ rm -f "${HOME}/.cache/pip/selfcheck.json" echo "before_cache.sh: cache size" du -d 2 "${HOME}/.cache" | sort -n +echo "before_cache.sh: ccache stats" +ccache -s 2>/dev/null || true + # Update the third-party dependency cache only if the build was successful. if ended_successfully; then rm -rf "${HOME}/.cache/nvim-deps" diff --git a/ci/before_script.sh b/ci/before_script.sh index 445996a8df..49b4e068b5 100755 --- a/ci/before_script.sh +++ b/ci/before_script.sh @@ -20,6 +20,9 @@ if [[ -n "${LLVM_SYMBOLIZER}" ]] && [[ ! $(type -P "${LLVM_SYMBOLIZER}") ]]; the exit 1 fi +# Show ccache stats so we can compare in before_cache +ccache -s 2>/dev/null || true + if [[ "${TRAVIS_OS_NAME}" == osx ]]; then # Adds user to a dummy group. # That allows to test changing the group of the file by `os_fchown`. diff --git a/ci/common/build.sh b/ci/common/build.sh index 53d20ebf9b..a3cf64d47a 100644 --- a/ci/common/build.sh +++ b/ci/common/build.sh @@ -30,7 +30,9 @@ build_deps() { mkdir -p "${DEPS_DOWNLOAD_DIR}" # Use cached dependencies if $CACHE_MARKER exists. - if test -f "${CACHE_MARKER}" && ! test "${CACHE_ENABLE}" = "false" ; then + if test "${CACHE_ENABLE}" = "false" ; then + export CCACHE_RECACHE=1 + elif test -f "${CACHE_MARKER}" ; then echo "Using third-party dependencies from Travis cache (last update: $(_stat "${CACHE_MARKER}"))." cp -r "${HOME}/.cache/nvim-deps"/. "${DEPS_BUILD_DIR}" cp -r "${HOME}/.cache/nvim-deps-downloads" "${DEPS_DOWNLOAD_DIR}" diff --git a/ci/install.sh b/ci/install.sh index 053549d6db..50f3490b63 100755 --- a/ci/install.sh +++ b/ci/install.sh @@ -11,6 +11,8 @@ if [[ "${TRAVIS_OS_NAME}" == osx ]]; then brew install ninja brew install gettext brew reinstall -s libtool + brew install ccache + export PATH="/usr/local/opt/ccache/libexec:$PATH" fi echo "Install neovim module for Python 3." |