2014-08-24 10:18:18 -07:00
|
|
|
<section xmlns="http://docbook.org/ns/docbook"
|
|
|
|
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
|
|
xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
|
|
version="5.0"
|
|
|
|
xml:id="sec-ad-hoc-packages">
|
2018-05-01 16:57:09 -07:00
|
|
|
<title>Ad-Hoc Package Management</title>
|
2014-08-24 10:18:18 -07:00
|
|
|
|
2018-05-01 16:57:09 -07:00
|
|
|
<para>
|
|
|
|
With the command <command>nix-env</command>, you can install and uninstall
|
|
|
|
packages from the command line. For instance, to install Mozilla Thunderbird:
|
2014-08-24 10:18:18 -07:00
|
|
|
<screen>
|
2015-08-05 08:29:08 -07:00
|
|
|
$ nix-env -iA nixos.thunderbird</screen>
|
2018-05-01 16:57:09 -07:00
|
|
|
If you invoke this as root, the package is installed in the Nix profile
|
|
|
|
<filename>/nix/var/nix/profiles/default</filename> and visible to all users
|
|
|
|
of the system; otherwise, the package ends up in
|
|
|
|
<filename>/nix/var/nix/profiles/per-user/<replaceable>username</replaceable>/profile</filename>
|
|
|
|
and is not visible to other users. The <option>-A</option> flag specifies the
|
|
|
|
package by its attribute name; without it, the package is installed by
|
|
|
|
matching against its package name (e.g. <literal>thunderbird</literal>). The
|
|
|
|
latter is slower because it requires matching against all available Nix
|
|
|
|
packages, and is ambiguous if there are multiple matching packages.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Packages come from the NixOS channel. You typically upgrade a package by
|
|
|
|
updating to the latest version of the NixOS channel:
|
2014-08-24 10:18:18 -07:00
|
|
|
<screen>
|
|
|
|
$ nix-channel --update nixos
|
|
|
|
</screen>
|
2018-05-01 16:57:09 -07:00
|
|
|
and then running <literal>nix-env -i</literal> again. Other packages in the
|
|
|
|
profile are <emphasis>not</emphasis> affected; this is the crucial difference
|
|
|
|
with the declarative style of package management, where running
|
|
|
|
<command>nixos-rebuild switch</command> causes all packages to be updated to
|
|
|
|
their current versions in the NixOS channel. You can however upgrade all
|
|
|
|
packages for which there is a newer version by doing:
|
2014-08-24 10:18:18 -07:00
|
|
|
<screen>
|
|
|
|
$ nix-env -u '*'
|
|
|
|
</screen>
|
2018-05-01 16:57:09 -07:00
|
|
|
</para>
|
2014-08-24 10:18:18 -07:00
|
|
|
|
2018-05-01 16:57:09 -07:00
|
|
|
<para>
|
|
|
|
A package can be uninstalled using the <option>-e</option> flag:
|
2014-08-24 10:18:18 -07:00
|
|
|
<screen>
|
|
|
|
$ nix-env -e thunderbird
|
|
|
|
</screen>
|
2018-05-01 16:57:09 -07:00
|
|
|
</para>
|
2014-08-24 10:18:18 -07:00
|
|
|
|
2018-05-01 16:57:09 -07:00
|
|
|
<para>
|
|
|
|
Finally, you can roll back an undesirable <command>nix-env</command> action:
|
2014-08-24 10:18:18 -07:00
|
|
|
<screen>
|
|
|
|
$ nix-env --rollback
|
|
|
|
</screen>
|
2018-05-01 16:57:09 -07:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
<command>nix-env</command> has many more flags. For details, see the
|
|
|
|
<citerefentry>
|
|
|
|
<refentrytitle>nix-env</refentrytitle>
|
|
|
|
<manvolnum>1</manvolnum></citerefentry> manpage or the Nix manual.
|
|
|
|
</para>
|
2014-08-24 10:18:18 -07:00
|
|
|
</section>
|