The nixpkgs manual contains references to both sri hash and explicit sha256 attributes. This is at best confusing to new users. Since the final destination is exclusive use of sri hashes, see nixos/rfcs#131, might as well push new users in that direction gently. Notable exceptions to sri hash support are builtins.fetchTarball, cataclysm-dda, coq, dockerTools.pullimage, elixir.override, and fetchCrate. None, other than builtins.fetchTarball, are fundamentally incompatible, but all currently accept explicit sha256 attributes as input. Because adding backwards compatibility is out of scope for this change, they have been left intact, but migration to sri format has been made for any using old hash formats. All hashes have been manually tested to be accurate, and updates were only made for missing upstream artefacts or bugs.
2.9 KiB
Nim
Overview
The Nim compiler, a builder function, and some packaged libraries are available in Nixpkgs. Until now each compiler release has been effectively backwards compatible so only the latest version is available.
Nim program packages in Nixpkgs
Nim programs can be built using nimPackages.buildNimPackage
. In the
case of packages not containing exported library code the attribute
nimBinOnly
should be set to true
.
The following example shows a Nim program that depends only on Nim libraries:
{ lib, nimPackages, fetchurl }:
nimPackages.buildNimPackage rec {
pname = "hottext";
version = "1.4";
nimBinOnly = true;
src = fetchurl {
url = "https://git.sr.ht/~ehmry/hottext/archive/v${version}.tar.gz";
hash = "sha256-hIUofi81zowSMbt1lUsxCnVzfJGN3FEiTtN8CEFpwzY=";
};
buildInputs = with nimPackages; [
bumpy
chroma
flatty
nimsimd
pixie
sdl2
typography
vmath
zippy
];
}
Nim library packages in Nixpkgs
Nim libraries can also be built using nimPackages.buildNimPackage
, but
often the product of a fetcher is sufficient to satisfy a dependency.
The fetchgit
, fetchFromGitHub
, and fetchNimble
functions yield an
output that can be discovered during the configurePhase
of buildNimPackage
.
Nim library packages are listed in pkgs/top-level/nim-packages.nix and implemented at pkgs/development/nim-packages.
The following example shows a Nim library that propagates a dependency on a non-Nim package:
{ lib, buildNimPackage, fetchNimble, SDL2 }:
buildNimPackage rec {
pname = "sdl2";
version = "2.0.4";
src = fetchNimble {
inherit pname version;
hash = "sha256-qDtVSnf+7rTq36WAxgsUZ8XoUk4sKwHyt8EJcY5WP+o=";
};
propagatedBuildInputs = [ SDL2 ];
}
buildNimPackage
parameters
All parameters from stdenv.mkDerivation
function are still supported. The
following are specific to buildNimPackage
:
-
nimBinOnly ? false
: Iftrue
then build only the programs listed in the Nimble file in the packages sources. -
nimbleFile
: Specify the Nimble file location of the package being built rather than discover the file at build-time. -
nimRelease ? true
: Build the package in release mode. -
nimDefines ? []
: A list of Nim defines. Key-value tuples are not supported. -
nimFlags ? []
: A list of command line arguments to pass to the Nim compiler. Use this to specify defines with arguments in the form of-d:${name}=${value}
. -
nimDoc
? false`: Build and install HTML documentation. -
buildInputs
? []: The packages listed here will be searched for*.nimble
files which are used to populate the Nim library path. Otherwise the standard behavior is in effect.