This is a simple package manager taking a slightly different approach than other available options like sirdi or inigo: It makes use of curated collections of packages linked to a specific version/commit of Idris2, which are guaranteed to properly work together (otherwise, that's a bug in the package collection). This is similar to what stack for Haskell does: It avoids dependency hell by design.
There is a second GitHub repository containing the package collections: idris2-pack-db. See instructions there if you want to make your own packages available to pack. The list of currently available packages plus their current build status can also be found here.
For detailed instructions and prerequisites, see installation. Assuming, you have already installed Chez Scheme you can set up pack and the corresponding Idris2 compiler with the following command:
bash -c "$(curl -fsSL https://raw.githubusercontent.com/stefan-hoeck/idris2-pack/main/install.bash)"
You will be asked about the name of your Chez Scheme executable during
the installation procedure. If all goes well, make sure to add
folder $HOME/.pack/bin
to your $PATH
variable.
For a list of commands and command-line options, type
pack help
In the following sections, we assume the $PACK_DIR/bin
folder
is on your path and you have installed
pack as described under installation.
To create a new library project, type
pack new lib idris2-library
replacing idris2-library
with the name of your library.
This will create a new package in the current directory consisting of a source directory, a default module, a skeleton test suite, a local pack.toml file and a .ipkg file.
A git repository will also be initialized together with a suitable .gitignore
file.
If you wish to create a new application project, replace lib
with app
.
To install a library from the package collection, run
pack install hedgehog
This will download and build the idris2-hedgehog library together with all its dependencies.
To build and install an application (for instance, the katla app), run
pack install-app katla
Note
Idris packages can contain additional instructions to run before and after build and installation of a package, we call them custom build hooks. This can be potentially dangerous because hooks may invoke arbitrary code in your system. By default pack prompts for continuation in case when requested package contains them, e.g.
Package lsp uses custom build hooks. Continue (yes/*no)?
If you no longer require katla and want to remove it, run
pack remove katla
It is also possible to work with local .ipkg
files as long
as they depend on packages known to pack:
pack build json.ipkg
pack typecheck elab-util.ipkg
The build tool can run executables, both from local
.ipkg
files as well as from installed applications. Command
line arguments to be passed on to the executable can be
listed after the package name or .ipkg
file:
pack run test.ipkg -n 50
pack run katla --help
You can use pack to start an Idris REPL session, optionally
with making dependencies listed in an .ipkg
file available
(these will first be built and installed if necessary):
pack repl
pack repl Test.idr
pack --with-ipkg rhone.ipkg repl src/Data/MSF.idr
User settings are stored in file $PACK_DIR/user/pack.toml
.
This file should have been generated automatically by pack
when setting up the application for the first time. The
different settings have been annotated with comments to
make it more accessible.
If you want to start using a new package collection,
edit the collection
field accordingly:
collection = "nightly-220507"
It is also possible to add local projects as well as GitHub
projects not yet managed by your package collection of choice
to the set of packages known to pack. For instance, assuming you
have a local project called hello
located in directory
/data/me/idris/hello
with .ipkg
file hello.ipkg
,
and you want to make this available to all package collections
you work with, add the following lines to pack.toml
:
[custom.all.hello]
type = "local"
path = "/data/me/idris/hello"
ipkg = "hello.ipkg"
If, on the other hand, you want to make this package only available
to package collection nightly-220506
, change the above to the
following:
[custom.nightly-220506.hello]
type = "local"
path = "/data/me/idris/hello"
ipkg = "hello.ipkg"
Likewise, you could at a GitHub project not yet known to pack to one or all of the package collections:
[custom.nightly-220506.hashmap]
type = "github"
url = "https://github.com/Z-snails/idris2-hashmap"
commit = "cb97afaa7c5d79dcb85901c6f5f87bed906fed81"
ipkg = "hashmap.ipkg"
Custom packages take precedence over official ones, so it is possible to override an officially supported package with a custom version of yours (either a local clone or perhaps a fork on GitHub).
You can also add a pack.toml
file locally to the root folder
of a project. Just as with the global pack.toml
file in directory
$HOME/.pack/user/
, you can specify the package collection to
use for a project as well as define additional local dependencies
and even override global package settings. Local settings take
precedence over global once. Pack will look for local pack.toml
files in all parent directories of the current working directory
(including the current working directory itself) and will stop
at the first one it finds.
It is important to understand, how pack keeps track of the libraries it installed, where it looks for user settings and package collections, and how it reuses existing versions of the Idris2 compiler and libraries.
These are stored as .toml
files in folder $HOME/.pack/db
.
If you want to download the latest package collections, you
can do so with the following command:
pack update-db
All packages, applications, and different versions of the Idris
compiler can be found in the subdirectories of
$HOME/.pack/install
. The path to a library or application
includes the commit hash of the Idris compiler it was built with,
as well as the commit hash used for the library or application itself.
For instance, if you installed commit 46bff04
of library
collie after building it
with commit 7a8635
of the Idris compiler, the library will
be found in folder
$HOME/.pack/install/7a8635/collie/46bff04/
The corresponding Idris compiler plus its standard libraries can be found in directory
$HOME/.pack/install/7a8635/idris2
Local packages listed in one of your pack.toml
files will
be installed in a subfolder called local
. For instance,
I have a local package called chem
, which - after being
built with the Idris compiler mentioned above - will
be installed in folder
$HOME/.pack/install/7a8635/local/chem
These will be installed in subfolder bin
of the directories
listed above. In addition, a wrapper script will be added to the
package collection's bin
folder, which can be found at
$HOME/.pack/[collection]/bin
This will be enough for executing an application via pack, for instance by running
pack exec katla
However, if you want to make these binaries available on your
command-line, you need to do two things: First, invoke
pack
with the switch
command:
pack switch nightly-220518
And second, add directory $HOME/.pack/bin
to your $PATH
variable.
There are two example projects explaining in detail how to use
pack to develop groups of related projects. The first, which
can be found in the example1
subfolder, sets up
two libraries plus a test suite for local development.
A detailed description how it works can be found here.
The second example in the folder example2
explains how to collaborate
on several packages in parallel via git. Details can be found
here.
Note
Please notice that if your application relies on the
IDRIS2_PACKAGE_PATH
environment variable (for example, an alternative backend for Idris) or your package uses a shared library or support files, setpackagePath
option totrue
in an appropriate section for you package in apack.toml
(both local and in the pack collection). You can see an example of such usage here. Technical details can be found here.
There is a lot of functionality still missing. Here's a non-comprehensive list:
- Support for local package collections
- Command for starting a REPL session
- Support for custom build directories
- Command for typechecking an Idris package
- Command for building a local Idris2 package
- Command for running an application
- Command for querying a data collection
- Command for listing current version of data collection
- Support for running tests