* 'master' of https://github.com/facebook/Haxl:
  Try to compile with GHC 8.0.1
  Use hvr travis setup
  Update aeson and time
This commit is contained in:
Simon Marlow 2016-05-23 10:36:40 +01:00
commit f09fc218c3
3 changed files with 88 additions and 3 deletions

View File

@ -1 +1,81 @@
language: haskell # This file has been generated -- see https://github.com/hvr/multi-ghc-travis
language: c
sudo: false
cache:
directories:
- $HOME/.cabsnap
- $HOME/.cabal/packages
before_cache:
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/build-reports.log
- rm -fv $HOME/.cabal/packages/hackage.haskell.org/00-index.tar
matrix:
include:
- env: CABALVER=1.18 GHCVER=7.8.4
compiler: ": #GHC 7.8.4"
addons: {apt: {packages: [cabal-install-1.18,ghc-7.8.4], sources: [hvr-ghc]}}
- env: CABALVER=1.22 GHCVER=7.10.3
compiler: ": #GHC 7.10.3"
addons: {apt: {packages: [cabal-install-1.22,ghc-7.10.3], sources: [hvr-ghc]}}
- env: CABALVER=1.24 GHCVER=8.0.1
compiler: ": #GHC 8.0.1"
addons: {apt: {packages: [cabal-install-1.24,ghc-8.0.1], sources: [hvr-ghc]}}
before_install:
- unset CC
- export PATH=/opt/ghc/$GHCVER/bin:/opt/cabal/$CABALVER/bin:$PATH
install:
- cabal --version
- echo "$(ghc --version) [$(ghc --print-project-git-commit-id 2> /dev/null || echo '?')]"
- if [ -f $HOME/.cabal/packages/hackage.haskell.org/00-index.tar.gz ];
then
zcat $HOME/.cabal/packages/hackage.haskell.org/00-index.tar.gz >
$HOME/.cabal/packages/hackage.haskell.org/00-index.tar;
fi
- travis_retry cabal update -v
- sed -i 's/^jobs:/-- jobs:/' ${HOME}/.cabal/config
- cabal install --only-dependencies --enable-tests --enable-benchmarks --dry -v > installplan.txt
- sed -i -e '1,/^Resolving /d' installplan.txt; cat installplan.txt
# check whether current requested install-plan matches cached package-db snapshot
- if diff -u installplan.txt $HOME/.cabsnap/installplan.txt;
then
echo "cabal build-cache HIT";
rm -rfv .ghc;
cp -a $HOME/.cabsnap/ghc $HOME/.ghc;
cp -a $HOME/.cabsnap/lib $HOME/.cabsnap/share $HOME/.cabsnap/bin $HOME/.cabal/;
else
echo "cabal build-cache MISS";
rm -rf $HOME/.cabsnap;
mkdir -p $HOME/.ghc $HOME/.cabal/lib $HOME/.cabal/share $HOME/.cabal/bin;
cabal install --only-dependencies --enable-tests --enable-benchmarks;
fi
# snapshot package-db on cache miss
- if [ ! -d $HOME/.cabsnap ];
then
echo "snapshotting package-db to build-cache";
mkdir $HOME/.cabsnap;
cp -a $HOME/.ghc $HOME/.cabsnap/ghc;
cp -a $HOME/.cabal/lib $HOME/.cabal/share $HOME/.cabal/bin installplan.txt $HOME/.cabsnap/;
fi
# Here starts the actual work to be performed for the package under test;
# any command which exits with a non-zero exit code causes the build to fail.
script:
- if [ -f configure.ac ]; then autoreconf -i; fi
- cabal configure --enable-tests --enable-benchmarks -v2 # -v2 provides useful information for debugging
- cabal build # this builds all libraries and executables (including tests/benchmarks)
- cabal test
- cabal sdist # tests that a source-distribution can be generated
# Check that the resulting source distribution can be built & installed.
# If there are no other `.tar.gz` files in `dist`, this can be even simpler:
# `cabal install --force-reinstalls dist/*-*.tar.gz`
- SRC_TGZ=$(cabal info . | awk '{print $2;exit}').tar.gz &&
(cd dist && cabal install --force-reinstalls "$SRC_TGZ")
# EOF

View File

@ -740,6 +740,7 @@ cachedComputation req haxl = GenHaxl $ \env ref -> do
-- continuation: just try to evaluate the memo again. We know it is -- continuation: just try to evaluate the memo again. We know it is
-- already in the cache (because we just checked), so the computation -- already in the cache (because we just checked), so the computation
-- will never be used. -- will never be used.
retryMemo :: (Typeable (req a)) => req a -> GenHaxl u a
retryMemo req = retryMemo req =
cachedComputation req (throw (CriticalError "retryMemo")) cachedComputation req (throw (CriticalError "retryMemo"))

View File

@ -13,6 +13,10 @@ category: Concurrency
build-type: Simple build-type: Simple
stability: alpha stability: alpha
cabal-version: >= 1.10 cabal-version: >= 1.10
tested-with:
GHC==7.8.4,
GHC==7.10.3,
GHC==8.0.1
description: description:
Haxl is a library and EDSL for efficient scheduling of concurrent data Haxl is a library and EDSL for efficient scheduling of concurrent data
@ -39,7 +43,7 @@ library
build-depends: build-depends:
HUnit >= 1.2 && < 1.4, HUnit >= 1.2 && < 1.4,
aeson >= 0.6 && < 0.11, aeson >= 0.6 && < 0.12,
base == 4.*, base == 4.*,
bytestring >= 0.9 && < 0.11, bytestring >= 0.9 && < 0.11,
containers == 0.5.*, containers == 0.5.*,
@ -50,7 +54,7 @@ library
hashable == 1.2.*, hashable == 1.2.*,
pretty == 1.1.*, pretty == 1.1.*,
text >= 1.1.0.1 && < 1.3, text >= 1.1.0.1 && < 1.3,
time >= 1.4 && < 1.6, time >= 1.4 && < 1.7,
unordered-containers == 0.2.*, unordered-containers == 0.2.*,
vector >= 0.10 && <0.12 vector >= 0.10 && <0.12