Skip to content

Commit

Permalink
Support Cabal-3.12 and GHC 9.10
Browse files Browse the repository at this point in the history
  • Loading branch information
andreasabel committed Jul 4, 2024
1 parent c7f3edd commit c322e12
Show file tree
Hide file tree
Showing 6 changed files with 161 additions and 46 deletions.
30 changes: 17 additions & 13 deletions .github/workflows/haskell-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@
#
# For more information, see https://github.com/andreasabel/haskell-ci
#
# version: 0.17.20231012
# version: 0.19.20240630
#
# REGENDATA ("0.17.20231012",["github","hackage-server.cabal"])
# REGENDATA ("0.19.20240630",["github","hackage-server.cabal"])
#
name: Haskell-CI
on:
Expand All @@ -32,19 +32,24 @@ jobs:
strategy:
matrix:
include:
- compiler: ghc-9.8.1
- compiler: ghc-9.10.1
compilerKind: ghc
compilerVersion: 9.8.1
compilerVersion: 9.10.1
setup-method: ghcup
allow-failure: false
- compiler: ghc-9.6.3
- compiler: ghc-9.8.2
compilerKind: ghc
compilerVersion: 9.6.3
compilerVersion: 9.8.2
setup-method: ghcup
allow-failure: false
- compiler: ghc-9.4.7
- compiler: ghc-9.6.5
compilerKind: ghc
compilerVersion: 9.4.7
compilerVersion: 9.6.5
setup-method: ghcup
allow-failure: false
- compiler: ghc-9.4.8
compilerKind: ghc
compilerVersion: 9.4.8
setup-method: ghcup
allow-failure: false
- compiler: ghc-9.2.8
Expand Down Expand Up @@ -74,11 +79,10 @@ jobs:
apt-get update
apt-get install -y --no-install-recommends gnupg ca-certificates dirmngr curl git software-properties-common libtinfo5
mkdir -p "$HOME/.ghcup/bin"
curl -sL https://downloads.haskell.org/ghcup/0.1.19.5/x86_64-linux-ghcup-0.1.19.5 > "$HOME/.ghcup/bin/ghcup"
curl -sL https://downloads.haskell.org/ghcup/0.1.20.0/x86_64-linux-ghcup-0.1.20.0 > "$HOME/.ghcup/bin/ghcup"
chmod a+x "$HOME/.ghcup/bin/ghcup"
"$HOME/.ghcup/bin/ghcup" config add-release-channel https://raw.githubusercontent.com/haskell/ghcup-metadata/master/ghcup-prereleases-0.0.7.yaml;
"$HOME/.ghcup/bin/ghcup" install ghc "$HCVER" || (cat "$HOME"/.ghcup/logs/*.* && false)
"$HOME/.ghcup/bin/ghcup" install cabal 3.10.1.0 || (cat "$HOME"/.ghcup/logs/*.* && false)
"$HOME/.ghcup/bin/ghcup" install cabal 3.12.1.0 || (cat "$HOME"/.ghcup/logs/*.* && false)
apt-get update
apt-get install -y libbrotli-dev libgd-dev
env:
Expand All @@ -98,7 +102,7 @@ jobs:
echo "HC=$HC" >> "$GITHUB_ENV"
echo "HCPKG=$HCPKG" >> "$GITHUB_ENV"
echo "HADDOCK=$HADDOCK" >> "$GITHUB_ENV"
echo "CABAL=$HOME/.ghcup/bin/cabal-3.10.1.0 -vnormal+nowrap" >> "$GITHUB_ENV"
echo "CABAL=$HOME/.ghcup/bin/cabal-3.12.1.0 -vnormal+nowrap" >> "$GITHUB_ENV"
HCNUMVER=$(${HC} --numeric-version|perl -ne '/^(\d+)\.(\d+)\.(\d+)(\.(\d+))?$/; print(10000 * $1 + 100 * $2 + ($3 == 0 ? $5 != 1 : $3))')
echo "HCNUMVER=$HCNUMVER" >> "$GITHUB_ENV"
echo "ARG_TESTS=--enable-tests" >> "$GITHUB_ENV"
Expand Down Expand Up @@ -183,7 +187,7 @@ jobs:
echo " ghc-options: -Werror=missing-methods" >> cabal.project
cat >> cabal.project <<EOF
EOF
$HCPKG list --simple-output --names-only | perl -ne 'for (split /\s+/) { print "constraints: $_ installed\n" unless /^(Cabal|Cabal-syntax|hackage-server|parsec|process|text)$/; }' >> cabal.project.local
$HCPKG list --simple-output --names-only | perl -ne 'for (split /\s+/) { print "constraints: any.$_ installed\n" unless /^(Cabal|Cabal-syntax|hackage-server|parsec|process|text)$/; }' >> cabal.project.local
cat cabal.project
cat cabal.project.local
- name: dump install plan
Expand Down
14 changes: 13 additions & 1 deletion exes/Main.hs
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
{-# LANGUAGE CPP #-}

{-# OPTIONS_GHC -fno-warn-incomplete-uni-patterns #-}

module Main where

import qualified Distribution.Server as Server
Expand Down Expand Up @@ -65,7 +68,11 @@ main :: IO ()
main = topHandler $ do
hSetBuffering stdout LineBuffering
args <- getArgs
#if !MIN_VERSION_Cabal(3,12,0)
case commandsRun (globalCommand commands) commands args of
#else
commandsRun (globalCommand commands) commands args >>= \case
#endif
CommandHelp help -> printHelp help
CommandList opts -> printOptionsList opts
CommandErrors errs -> printErrors errs
Expand All @@ -79,6 +86,7 @@ main = topHandler $ do

where
printHelp help = getProgName >>= putStr . help
printOptionsList :: [String] -> IO ()
printOptionsList = putStr . unlines
printErrors errs = do
putStr (intercalate "\n" errs)
Expand Down Expand Up @@ -154,7 +162,11 @@ optionVerbosity getter setter =
"Control verbosity (n is 0--3, default verbosity level is 1)"
getter setter
(optArg "n" (fmap Flag Verbosity.flagToVerbosity)
(Flag Verbosity.verbose)
(
#if MIN_VERSION_Cabal(3,12,0)
show Verbosity.verbose,
#endif
Flag Verbosity.verbose)
(fmap (Just . showForCabal) . flagToList))

optionStateDir :: (a -> Flag FilePath)
Expand Down
29 changes: 17 additions & 12 deletions hackage-server.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,10 @@ license: BSD-3-Clause
license-file: LICENSE

tested-with:
GHC == 9.8.1
GHC == 9.6.3
GHC == 9.4.7
GHC == 9.10.1
GHC == 9.8.2
GHC == 9.6.5
GHC == 9.4.8
GHC == 9.2.8
GHC == 9.0.2
GHC == 8.10.7
Expand Down Expand Up @@ -129,13 +130,13 @@ common defaults
-- see `cabal.project.local-ghc-${VERSION}` files
build-depends:
, array >= 0.5 && < 0.6
, base >= 4.13 && < 4.20
, base >= 4.13 && < 4.21
, binary >= 0.8 && < 0.9
, bytestring >= 0.10 && < 0.13
, containers >= 0.6.0 && < 0.8
, deepseq >= 1.4 && < 1.6
, directory >= 1.3 && < 1.4
, filepath >= 1.4 && < 1.5
, filepath >= 1.4 && < 1.6
, mtl >= 2.2.1 && < 2.4
-- we use Control.Monad.Except, introduced in mtl-2.2.1
, pretty >= 1.1 && < 1.2
Expand All @@ -148,19 +149,19 @@ common defaults
-- other dependencies shared by most components
build-depends:
, aeson >= 2.1.0.0 && < 2.3
, Cabal >= 3.10.1.0 && < 3.12
, Cabal-syntax >= 3.10.1.0 && < 3.12
, Cabal >= 3.10.1.0 && < 3.14
, Cabal-syntax >= 3.10.1.0 && < 3.14
-- Cabal-syntax needs to be bound to constrain hackage-security
-- see https://github.com/haskell/hackage-server/issues/1130
, fail ^>= 4.9.0
, network >= 3 && < 3.2
, network >= 3 && < 3.3
, network-bsd ^>= 2.8
, network-uri ^>= 2.6
, parsec ^>= 3.1.13
, tar ^>= 0.6
, unordered-containers ^>= 0.2.10
, vector ^>= 0.12 || ^>= 0.13.0.0
, zlib ^>= 0.6.2
, zlib ^>= 0.6.2 || ^>= 0.7.0.0

ghc-options:
-funbox-strict-fields
Expand All @@ -170,6 +171,7 @@ common defaults
if impl(ghc >= 8.10)
ghc-options: -Wno-unused-record-wildcards

default-extensions: LambdaCase, TupleSections
other-extensions: CPP, TemplateHaskell


Expand Down Expand Up @@ -407,7 +409,7 @@ library
build-depends:
, HStringTemplate ^>= 0.8
, HTTP ^>= 4000.3.16 || ^>= 4000.4.1
, QuickCheck ^>= 2.14
, QuickCheck >= 2.14 && < 2.16
, acid-state ^>= 0.16
, async ^>= 2.2.1
-- requires bumping http-io-streams
Expand Down Expand Up @@ -438,7 +440,7 @@ library
, haddock-library ^>= 1.11.0
-- haddock-library-1.11.0 changed type of markupOrderedList
-- see https://github.com/haskell/hackage-server/issues/1128
, happstack-server ^>= 7.7.1 || ^>= 7.8.0
, happstack-server ^>= 7.7.1 || ^>= 7.8.0 || ^>= 7.9.0
, hashable ^>= 1.3 || ^>= 1.4
, hs-captcha ^>= 1.0
, hslogger ^>= 1.3.1
Expand All @@ -452,7 +454,7 @@ library
, stm ^>= 2.5.0
, stringsearch ^>= 0.3.6.6
, tagged ^>= 0.8.5
, xhtml ^>= 3000.2.0.0
, xhtml >= 3000.2.0.0 && < 3000.4
, xmlgen ^>= 0.6
, xss-sanitize ^>= 0.3.6

Expand Down Expand Up @@ -611,6 +613,9 @@ benchmark RevDeps
build-depends:
, random ^>= 1.2
, gauge
-- gauge does not support base-4.20
if impl(ghc >= 9.10)
buildable: False
ghc-options: -with-rtsopts=-s
other-modules: RevDepCommon

Expand Down
107 changes: 93 additions & 14 deletions src/Distribution/Server/Framework/Instances.hs
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ instance SafeCopy VersionRange where
10 -> majorBoundVersion <$> safeGet -- since Cabal-2.0
_ -> fail "VersionRange.getCopy: bad tag"

-- !! KEEP IN SYNC with instance Arbitrary OS
instance SafeCopy OS where
errorTypeName _ = "OS"

Expand Down Expand Up @@ -173,6 +174,7 @@ instance SafeCopy OS where
#endif
_ -> fail "SafeCopy OS getCopy: unexpected tag"

-- !! KEEP IN SYNC with instance Arbitrary Arch
instance SafeCopy Arch where
errorTypeName _ = "Arch"

Expand All @@ -196,6 +198,12 @@ instance SafeCopy Arch where
putCopy AArch64 = contain $ putWord8 17
putCopy S390X = contain $ putWord8 18
putCopy Wasm32 = contain $ putWord8 19
#if MIN_VERSION_Cabal_syntax(3,12,0)
putCopy PPC64LE = contain $ putWord8 20
putCopy Sparc64 = contain $ putWord8 21
putCopy RISCV64 = contain $ putWord8 22
putCopy LoongArch64 = contain $ putWord8 23
#endif

getCopy = contain $ do
tag <- getWord8
Expand All @@ -220,8 +228,15 @@ instance SafeCopy Arch where
17 -> return AArch64
18 -> return S390X
19 -> return Wasm32
#if MIN_VERSION_Cabal_syntax(3,12,0)
20 -> return PPC64LE
21 -> return Sparc64
22 -> return RISCV64
23 -> return LoongArch64
#endif
_ -> fail "SafeCopy Arch getCopy: unexpected tag"

-- !! KEEP IN SYNC with instance Arbitrary CompilerFlavor
instance SafeCopy CompilerFlavor where
errorTypeName _ = "CompilerFlavor"

Expand All @@ -238,6 +253,9 @@ instance SafeCopy CompilerFlavor where
putCopy (HaskellSuite s) = contain $ putWord8 10 >> safePut s
putCopy GHCJS = contain $ putWord8 11
putCopy Eta = contain $ putWord8 12
#if MIN_VERSION_Cabal_syntax(3,12,1)
putCopy MHS = contain $ putWord8 13
#endif

getCopy = contain $ do
tag <- getWord8
Expand All @@ -255,6 +273,9 @@ instance SafeCopy CompilerFlavor where
10 -> return HaskellSuite <*> safeGet
11 -> return GHCJS
12 -> return Eta
#if MIN_VERSION_Cabal_syntax(3,12,1)
13 -> return MHS
#endif
_ -> fail "SafeCopy CompilerFlavor getCopy: unexpected tag"


Expand Down Expand Up @@ -363,6 +384,7 @@ instance Parsec UTCTime where
Just t -> return t
where
digit2 = replicateM 2 P.digit

-------------------
-- Arbitrary instances
--
Expand All @@ -376,31 +398,88 @@ instance Arbitrary Version where
instance Arbitrary PackageIdentifier where
arbitrary = PackageIdentifier <$> arbitrary <*> arbitrary

-- !! KEEP IN SYNC with instance SafeCopy CompilerFlavor
instance Arbitrary CompilerFlavor where
arbitrary = oneof [ pure OtherCompiler <*> vectorOf 3 (choose ('A', 'Z'))
, pure GHC, pure NHC, pure YHC, pure Hugs, pure HBC
, pure Helium, pure JHC, pure LHC, pure UHC ]
arbitrary = oneof
[ pure OtherCompiler <*> vectorOf 3 (choose ('A', 'Z'))
, pure GHC
, pure NHC
, pure YHC
, pure Hugs
, pure HBC
, pure Helium
, pure JHC
, pure LHC
, pure UHC
, pure HaskellSuite <*> vectorOf 3 (choose ('A', 'Z'))
, pure GHCJS
, pure Eta
#if MIN_VERSION_Cabal_syntax(3,12,1)
, pure MHS
#endif
]

instance Arbitrary CompilerId where
arbitrary = CompilerId <$> arbitrary <*> arbitrary

-- !! KEEP IN SYNC with instance SafeCopy Arch
instance Arbitrary Arch where
arbitrary = oneof [ pure OtherArch <*> vectorOf 3 (choose ('A', 'Z'))
, pure I386, pure X86_64, pure PPC, pure PPC64, pure Sparc
, pure Arm, pure Mips, pure SH, pure IA64, pure S390
, pure Alpha, pure Hppa, pure Rs6000, pure M68k, pure Vax ]
arbitrary = oneof
[ pure OtherArch <*> vectorOf 3 (choose ('A', 'Z'))
, pure I386
, pure X86_64
, pure PPC
, pure PPC64
, pure Sparc
, pure Arm
, pure Mips
, pure SH
, pure IA64
, pure S390
, pure Alpha
, pure Hppa
, pure Rs6000
, pure M68k
, pure Vax
, pure JavaScript
, pure AArch64
, pure S390X
, pure Wasm32
#if MIN_VERSION_Cabal_syntax(3,12,0)
, pure PPC64LE
, pure Sparc64
, pure RISCV64
, pure LoongArch64
#endif
]

-- !! KEEP IN SYNC with instance SafeCopy OS
instance Arbitrary OS where
arbitrary = oneof [ pure OtherOS <*> vectorOf 3 (choose ('A', 'Z'))
, pure Linux, pure Windows, pure OSX, pure FreeBSD
, pure OpenBSD, pure NetBSD, pure Solaris, pure AIX
, pure HPUX, pure IRIX, pure HaLVM, pure IOS
arbitrary = oneof
[ pure OtherOS <*> vectorOf 3 (choose ('A', 'Z'))
, pure Linux
, pure Windows
, pure OSX
, pure FreeBSD
, pure OpenBSD
, pure NetBSD
, pure Solaris
, pure AIX
, pure HPUX
, pure IRIX
, pure HaLVM
, pure IOS
, pure DragonFly
, pure Ghcjs
, pure Hurd
, pure Android
, pure Wasi
#if MIN_VERSION_Cabal_syntax(3,11,0)
, pure Haiku
, pure Haiku
#else
, pure $ OtherOS "haiku"
, pure $ OtherOS "haiku"
#endif
]
]

instance Arbitrary FlagName where
arbitrary = mkFlagName <$> vectorOf 4 (choose ('a', 'z'))
Expand Down
Loading

0 comments on commit c322e12

Please sign in to comment.