.buildkite | ||
builder | ||
compiler | ||
docs | ||
examples | ||
lib | ||
mk-local-hackage-repo | ||
modules | ||
nix-tools | ||
nixpkgs | ||
overlays | ||
patches | ||
pkgs | ||
scripts | ||
test | ||
.gitattributes | ||
.gitignore | ||
build.nix | ||
changelog.md | ||
ci.nix | ||
config.nix | ||
COPYING | ||
default.nix | ||
hackage-src.json | ||
mkdocs.yml | ||
package-set.nix | ||
README.org | ||
release.nix | ||
shell.nix | ||
snapshots.nix | ||
stackage-src.json | ||
test-ghcjs.nix | ||
test-mingw32.nix | ||
test-rpi.nix | ||
test.nix |
- ⚠️ The Overlay branch #261 was merged. haskell.nix is now an overlay and the dependency on iohk-nix was dropped. Please see the updated documentation! Once any remaining issues are resolved, this will mark the 1.0 release of haskell.nix.
- Alternative Haskell Infrastructure for Nixpkgs
⚠️ The Overlay branch #261 was merged. haskell.nix is now an overlay and the dependency on iohk-nix was dropped. Please see the updated documentation! Once any remaining issues are resolved, this will mark the 1.0 release of haskell.nix. warning
Alternative Haskell Infrastructure for Nixpkgs
https://badge.buildkite.com/d453edcd29bd2f8f3f3b32c9b7d6777a33773d9671c37a6ccc.svg?branch=master https://img.shields.io/buildkite/c8d5a20d3ff0f440f82adb9190b43c16c91e5e47e8adfa867a/master.svg?label=nightly%20updates
haskell.nix
is an experimental new builder for Haskell packages.
It works by automatically translating your Cabal or Stack project and its dependencies into Nix code. It provides IFD (imports from derviation) functions that can minimize the amount of nix code you need to add.
For the documentation, see https://input-output-hk.github.io/haskell.nix/.
Quickstart
For cabal.project
project add a default.nix
:
{ pkgs ? import <nixpkgs> (import (builtins.fetchTarball https://github.com/input-output-hk/haskell.nix/archive/master.tar.gz))
, haskellCompiler ? "ghc865"
}:
pkgs.haskell-nix.cabalProject {
src = pkgs.haskell-nix.haskellLib.cleanGit { src = ./.; };
ghc = pkgs.buildPackages.pkgs.haskell-nix.compiler.${haskellCompiler};
}
For a stack.yaml
project add a default.nix
:
{ pkgs ? import <nixpkgs> (import (builtins.fetchTarball https://github.com/input-output-hk/haskell.nix/archive/master.tar.gz))
}:
pkgs.haskell-nix.stackProject {
src = pkgs.haskell-nix.haskellLib.cleanGit { src = ./.; };
}
To build the library component of a package in the project run:
nix build -f . your-package-name.components.library
To build an executable:
nix build -f . your-package-name.components.exes.your-exe-name
To open a shell for use with `cabal` run:
nix-shell -A shellFor
cabal new-build your-package-name
cabal new-repl your-package-name:library:your-package-name
Related repos
The haskell.nix
repository contains the runtime system for building
Haskell packages in Nix. It depends on other repos, which are:
- nix-tools — provides the programs for generating Nix expressions from Haskell projects.
- hackage.nix — the latest contents of the Hackage databases, converted to Nix expressions.
- stackage.nix — all of the Stackage snapshots, converted to Nix expressions.
IRC Channel
Join the #haskell.nix channel on irc.freenode.net to get help or discuss
the development of haskell.nix
and nix-tools
.