stack-all
A CLI tool for building Haskell projects easily over Stackage major versions.
This is how I do my Haskell build CI for projects locally with stack.
Usage
stack-all
by default runs stack build
over Stackage Nightly and
LTS major versions
(current default is nightly & major LTS versions back to lts-16)
corresponding to latest major ghc minor versions,
with appropriate stack --resolver
options.
Note that stack
only works if a stack.yaml
file exists.
If no stack.yaml
file is found in a .cabal project,
stack-all
will create one.
Of course it may still fail to build, but this allows for
quickly trying to build a package that does not include stack support.
Help output
$ stack-all --version
0.5.1
$ stack-all --help
Build over Stackage versions
Usage: stack-all [--version] [(-c|--create-config) | (-s|--make-lts)]
[-k|--keep-going] [-d|--debug] [--refresh-cache]
[-n|--newest MAJOR] [(-o|--oldest MAJOR) | (-a|--all-lts)]
[MAJORVER... [COMMAND...]]
stack-all builds projects easily across different Stackage versions
Available options:
-h,--help Show this help text
--version Show version
-c,--create-config Create a project .stack-all file
-s,--make-lts Create a stack-ltsXX.yaml file
-k,--keep-going Keep going even if an LTS fails
-d,--debug Verbose stack build output on error
--refresh-cache Force refresh of stackage snapshots.json cache
-n,--newest MAJOR Newest LTS release to build from
-o,--oldest MAJOR Oldest compatible LTS release
-a,--all-lts Try to build back to LTS 1 even
Overriding stack.yaml
stack-all
can use stack-ltsXX.yaml
files to override the default
stack.yaml
file for particular Stackage major versions.
Note that a stack-ltsXX.yaml
file will also be used for
older LTS major versions until another stack-ltsYY.yaml
file is found.
stack-nightly.yaml
is also supported, but used only for nightly.
For example if you have stack-lts20.yaml
and stack-lts18.yaml
files
in your project,
then stack.yaml
will be used as normal to build nightly, lts-22 and lts-21,
but stack-lts20.yaml
will be used for building lts-20 and lts-19,
and stack-lts18.yaml
will be used for lts-18, lts-16 (and older).
Since stack-all
overrides the exact resolver with the latest minor snapshot,
the exact minor Stackage version specified in the stack*.yaml
files
doesn't actually matter: stack-all
always uses the latest published
minor releases of Stackage major versions.
stack-ltsXX.yaml
files can be easily created using
stack-all --make-lts ltsXX
(or -s ltsXX
for short).
(Other versioned stack.yaml filenames like stack-ghc-8.8.yaml
are not currently supported.)
Specifying LTS versions
You can abbreviate lts-XX
args to ltsXX
on the commandline.
lts
is also accepted and resolved to the latest major LTS version.
You can also use ghc major version aliases:
eg ghc9.6
corresponds to lts22
or ghc-9.2
to lts-20
.
There are --oldest
and --newest
options to specify the range of
lts versions to build over:
You can specify the oldest major LTS to build for with eg stack-all -o lts14
.
Otherwise if not configured the default oldest LTS is currently lts-16
.
Similarly you can specify the newest LTS version to build from with
eg stack-all -n lts20
. (The default is to build from nightly.)
Alternatively, one can give one or more explicit LTS major versions to build
for as arguments: eg stack-all lts18
if you only wish to build that version.
Configuring the oldest and/or newest LTS to build
You can configure the oldest working LTS major version for your project
by running for example stack-all -c -o lts-18
which generates a .stack-all
project config file like this:
[versions]
# lts-16 too old
oldest = lts-18
(the comment line can be used to document why the older LTS doesn't work).
This specifies that the oldest LTS version to build for is lts-18.
The newest LTS to build with stack-all can similarly be configured:
stack-all -c -n lts21
or setting newest = lts-21
.
Running other stack commands
By default stack-all
just runs the stack build
command over
Stackage major versions.
You can also specify a stack command to run with options on the commandline:
eg
$ stack-all test --no-rerun-tests
will run stack test
over the LTS versions instead.
Happy stack building!
Install
The project is released on Hackage.
You can also build from git source with stack install
or cabal install
.
Collaboration
The project is hosted at https://github.com/juhp/stack-all
under a BSD license.