2015-11-25 19:13:44 +03:00
|
|
|
|
---
|
|
|
|
|
title: Introduction
|
|
|
|
|
author: Frederik Rietdijk
|
|
|
|
|
date: 2015-11-25
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
# Introduction
|
|
|
|
|
|
2016-04-05 10:56:32 +03:00
|
|
|
|
The Nix Packages collection (Nixpkgs) is a set of thousands of packages for the
|
|
|
|
|
[Nix package manager](http://nixos.org/nix/), released under a
|
|
|
|
|
[permissive MIT/X11 license](https://github.com/NixOS/nixpkgs/blob/master/COPYING).
|
|
|
|
|
Packages are available for several platforms, and can be used with the Nix
|
|
|
|
|
package manager on most GNU/Linux distributions as well as NixOS.
|
|
|
|
|
|
|
|
|
|
This manual primarily describes how to write packages for the Nix Packages collection
|
|
|
|
|
(Nixpkgs). Thus it’s mainly for packagers and developers who want to add packages to
|
2015-11-25 19:13:44 +03:00
|
|
|
|
Nixpkgs. If you like to learn more about the Nix package manager and the Nix
|
|
|
|
|
expression language, then you are kindly referred to the [Nix manual](http://nixos.org/nix/manual/).
|
|
|
|
|
|
|
|
|
|
## Overview of Nixpkgs
|
|
|
|
|
|
|
|
|
|
Nix expressions describe how to build packages from source and are collected in
|
|
|
|
|
the [nixpkgs repository](https://github.com/NixOS/nixpkgs). Also included in the
|
2016-04-05 10:56:32 +03:00
|
|
|
|
collection are Nix expressions for
|
|
|
|
|
[NixOS modules](http://nixos.org/nixos/manual/index.html#sec-writing-modules).
|
|
|
|
|
With these expressions the Nix package manager can build binary packages.
|
2015-11-25 19:13:44 +03:00
|
|
|
|
|
|
|
|
|
Packages, including the Nix packages collection, are distributed through
|
|
|
|
|
[channels](http://nixos.org/nix/manual/#sec-channels). The collection is
|
|
|
|
|
distributed for users of Nix on non-NixOS distributions through the channel
|
|
|
|
|
`nixpkgs`. Users of NixOS generally use one of the `nixos-*` channels, e.g.
|
2016-04-05 10:56:32 +03:00
|
|
|
|
`nixos-16.03`, which includes all packages and modules for the stable NixOS
|
|
|
|
|
16.03. The purpose of stable NixOS releases are generally only given
|
2015-11-25 19:13:44 +03:00
|
|
|
|
security updates. More up to date packages and modules are available via the
|
|
|
|
|
`nixos-unstable` channel.
|
|
|
|
|
|
|
|
|
|
Both `nixos-unstable` and `nixpkgs` follow the `master` branch of the Nixpkgs
|
2016-04-05 10:56:32 +03:00
|
|
|
|
repository, although both do lag the `master` branch by generally
|
|
|
|
|
[a couple of days](http://howoldis.herokuapp.com/). Updates to a channel are
|
|
|
|
|
distributed as soon as all tests for that channel pass, e.g.
|
|
|
|
|
[this table](http://hydra.nixos.org/job/nixpkgs/trunk/unstable#tabs-constituents)
|
2015-11-25 19:13:44 +03:00
|
|
|
|
shows the status of tests for the `nixpkgs` channel.
|
|
|
|
|
|
|
|
|
|
The tests are conducted by a cluster called [Hydra](http://nixos.org/hydra/),
|
2016-04-05 10:56:32 +03:00
|
|
|
|
which also builds binary packages from the Nix expressions in Nixpkgs for
|
|
|
|
|
`x86_64-linux`, `i686-linux` and `x86_64-darwin`.
|
|
|
|
|
The binaries are made available via a [binary cache](https://cache.nixos.org).
|
2015-11-25 19:13:44 +03:00
|
|
|
|
|
|
|
|
|
The current Nix expressions of the channels are available in the
|
|
|
|
|
[`nixpkgs-channels`](https://github.com/NixOS/nixpkgs-channels) repository,
|
|
|
|
|
which has branches corresponding to the available channels. There is also the
|
2016-04-05 10:56:32 +03:00
|
|
|
|
[Nixpkgs Monitor](http://monitor.nixos.org) which keeps track of updates
|
|
|
|
|
and security vulnerabilities.
|