Skip to content

Commit 156e5cb

Browse files
authored
Merge pull request #32 from haskellari/ghc-9.12
Support GHC-9.12, tagged-0.8.9
2 parents 64d9ca1 + 87a30be commit 156e5cb

File tree

4 files changed

+45
-30
lines changed

4 files changed

+45
-30
lines changed

.github/workflows/haskell-ci.yml

+30-20
Original file line numberDiff line numberDiff line change
@@ -8,9 +8,9 @@
88
#
99
# For more information, see https://github.com/haskell-CI/haskell-ci
1010
#
11-
# version: 0.19.20240708
11+
# version: 0.19.20250315
1212
#
13-
# REGENDATA ("0.19.20240708",["github","cabal.project"])
13+
# REGENDATA ("0.19.20250315",["github","cabal.project"])
1414
#
1515
name: Haskell-CI
1616
on:
@@ -23,7 +23,7 @@ on:
2323
jobs:
2424
linux:
2525
name: Haskell-CI - Linux - ${{ matrix.compiler }}
26-
runs-on: ubuntu-20.04
26+
runs-on: ubuntu-24.04
2727
timeout-minutes:
2828
60
2929
container:
@@ -32,19 +32,24 @@ jobs:
3232
strategy:
3333
matrix:
3434
include:
35+
- compiler: ghc-9.12.2
36+
compilerKind: ghc
37+
compilerVersion: 9.12.2
38+
setup-method: ghcup
39+
allow-failure: false
3540
- compiler: ghc-9.10.1
3641
compilerKind: ghc
3742
compilerVersion: 9.10.1
3843
setup-method: ghcup
3944
allow-failure: false
40-
- compiler: ghc-9.8.2
45+
- compiler: ghc-9.8.4
4146
compilerKind: ghc
42-
compilerVersion: 9.8.2
47+
compilerVersion: 9.8.4
4348
setup-method: ghcup
4449
allow-failure: false
45-
- compiler: ghc-9.6.5
50+
- compiler: ghc-9.6.6
4651
compilerKind: ghc
47-
compilerVersion: 9.6.5
52+
compilerVersion: 9.6.6
4853
setup-method: ghcup
4954
allow-failure: false
5055
- compiler: ghc-9.4.8
@@ -79,15 +84,29 @@ jobs:
7984
allow-failure: false
8085
fail-fast: false
8186
steps:
82-
- name: apt
87+
- name: apt-get install
8388
run: |
8489
apt-get update
8590
apt-get install -y --no-install-recommends gnupg ca-certificates dirmngr curl git software-properties-common libtinfo5
91+
- name: Install GHCup
92+
run: |
8693
mkdir -p "$HOME/.ghcup/bin"
87-
curl -sL https://downloads.haskell.org/ghcup/0.1.30.0/x86_64-linux-ghcup-0.1.30.0 > "$HOME/.ghcup/bin/ghcup"
94+
curl -sL https://downloads.haskell.org/ghcup/0.1.40.0/x86_64-linux-ghcup-0.1.40.0 > "$HOME/.ghcup/bin/ghcup"
8895
chmod a+x "$HOME/.ghcup/bin/ghcup"
89-
"$HOME/.ghcup/bin/ghcup" install ghc "$HCVER" || (cat "$HOME"/.ghcup/logs/*.* && false)
96+
- name: Install cabal-install
97+
run: |
9098
"$HOME/.ghcup/bin/ghcup" install cabal 3.12.1.0 || (cat "$HOME"/.ghcup/logs/*.* && false)
99+
echo "CABAL=$HOME/.ghcup/bin/cabal-3.12.1.0 -vnormal+nowrap" >> "$GITHUB_ENV"
100+
- name: Install GHC (GHCup)
101+
if: matrix.setup-method == 'ghcup'
102+
run: |
103+
"$HOME/.ghcup/bin/ghcup" install ghc "$HCVER" || (cat "$HOME"/.ghcup/logs/*.* && false)
104+
HC=$("$HOME/.ghcup/bin/ghcup" whereis ghc "$HCVER")
105+
HCPKG=$(echo "$HC" | sed 's#ghc$#ghc-pkg#')
106+
HADDOCK=$(echo "$HC" | sed 's#ghc$#haddock#')
107+
echo "HC=$HC" >> "$GITHUB_ENV"
108+
echo "HCPKG=$HCPKG" >> "$GITHUB_ENV"
109+
echo "HADDOCK=$HADDOCK" >> "$GITHUB_ENV"
91110
env:
92111
HCKIND: ${{ matrix.compilerKind }}
93112
HCNAME: ${{ matrix.compiler }}
@@ -98,21 +117,12 @@ jobs:
98117
echo "LANG=C.UTF-8" >> "$GITHUB_ENV"
99118
echo "CABAL_DIR=$HOME/.cabal" >> "$GITHUB_ENV"
100119
echo "CABAL_CONFIG=$HOME/.cabal/config" >> "$GITHUB_ENV"
101-
HCDIR=/opt/$HCKIND/$HCVER
102-
HC=$("$HOME/.ghcup/bin/ghcup" whereis ghc "$HCVER")
103-
HCPKG=$(echo "$HC" | sed 's#ghc$#ghc-pkg#')
104-
HADDOCK=$(echo "$HC" | sed 's#ghc$#haddock#')
105-
echo "HC=$HC" >> "$GITHUB_ENV"
106-
echo "HCPKG=$HCPKG" >> "$GITHUB_ENV"
107-
echo "HADDOCK=$HADDOCK" >> "$GITHUB_ENV"
108-
echo "CABAL=$HOME/.ghcup/bin/cabal-3.12.1.0 -vnormal+nowrap" >> "$GITHUB_ENV"
109120
HCNUMVER=$(${HC} --numeric-version|perl -ne '/^(\d+)\.(\d+)\.(\d+)(\.(\d+))?$/; print(10000 * $1 + 100 * $2 + ($3 == 0 ? $5 != 1 : $3))')
110121
echo "HCNUMVER=$HCNUMVER" >> "$GITHUB_ENV"
111122
echo "ARG_TESTS=--enable-tests" >> "$GITHUB_ENV"
112123
echo "ARG_BENCH=--enable-benchmarks" >> "$GITHUB_ENV"
113124
echo "HEADHACKAGE=false" >> "$GITHUB_ENV"
114125
echo "ARG_COMPILER=--$HCKIND --with-compiler=$HC" >> "$GITHUB_ENV"
115-
echo "GHCJSARITH=0" >> "$GITHUB_ENV"
116126
env:
117127
HCKIND: ${{ matrix.compilerKind }}
118128
HCNAME: ${{ matrix.compiler }}
@@ -228,8 +238,8 @@ jobs:
228238
rm -f cabal.project.local
229239
$CABAL v2-build $ARG_COMPILER --disable-tests --disable-benchmarks all
230240
- name: save cache
231-
uses: actions/cache/save@v4
232241
if: always()
242+
uses: actions/cache/save@v4
233243
with:
234244
key: ${{ runner.os }}-${{ matrix.compiler }}-${{ github.sha }}
235245
path: ~/.cabal/store

CHANGELOG.md

+5
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,8 @@
1+
## 1.0.6
2+
3+
- Support GHC-9.12.1
4+
- Fix a small bug QuarterOfYear instance
5+
16
## 1.0.5
27

38
- Support GHC-8.6.5...9.10.1

binary-instances.cabal

+6-6
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,6 @@
11
cabal-version: 2.2
22
name: binary-instances
3-
version: 1.0.5
4-
x-revision: 1
3+
version: 1.0.6
54
synopsis: Orphan instances for binary
65
description:
76
`binary-instances` defines orphan instances for types in some popular packages.
@@ -21,9 +20,10 @@ tested-with:
2120
|| ==9.0.2
2221
|| ==9.2.8
2322
|| ==9.4.8
24-
|| ==9.6.5
25-
|| ==9.8.2
23+
|| ==9.6.6
24+
|| ==9.8.4
2625
|| ==9.10.1
26+
|| ==9.12.2
2727

2828
extra-source-files: CHANGELOG.md
2929

@@ -35,13 +35,13 @@ library
3535
default-language: Haskell2010
3636
hs-source-dirs: src
3737
build-depends:
38-
, base >=4.6.0.1 && <4.21
38+
, base >=4.6.0.1 && <4.22
3939
, binary >=0.5.1.1 && <0.8.10
4040
, text >=1.2.3.0 && <1.3 || >=2.0 && <2.2
4141

4242
build-depends:
4343
, case-insensitive >=1.2.1.0 && <1.2.2
44-
, tagged >=0.8.8 && <0.8.9
44+
, tagged >=0.8.8 && <0.8.10
4545

4646
build-depends:
4747
, aeson ^>=2.2.2.0

src/Data/Binary/Instances/Time.hs

+4-4
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,7 @@ instance Binary Time.DayOfWeek where
8686
4 -> Time.Thursday
8787
5 -> Time.Friday
8888
6 -> Time.Saturday
89-
_ -> error "panic: get @DayOfWeek"
89+
j -> error $ "panic: get @DayOfWeek: " ++ show (i, j)
9090

9191
instance Binary Time.Month where
9292
put (Time.MkMonth m) = put m
@@ -104,9 +104,9 @@ instance Binary Time.QuarterOfYear where
104104

105105
get = do
106106
i <- get
107-
return $ case mod (i :: Word8) 7 of
107+
return $ case mod (i :: Word8) 4 of
108108
1 -> Time.Q1
109109
2 -> Time.Q2
110110
3 -> Time.Q3
111-
4 -> Time.Q4
112-
_ -> error "panic: get @DayOfWeek"
111+
0 -> Time.Q4
112+
j -> error $ "panic: get @QuarterOfYear: " ++ show (i, j)

0 commit comments

Comments
 (0)