mirror of
https://github.com/nix-community/home-manager
synced 2024-12-27 04:09:47 +01:00
2257 lines
61 KiB
Nix
2257 lines
61 KiB
Nix
{ config, lib, options, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
|
|
cfg = config.news;
|
|
|
|
hostPlatform = pkgs.stdenv.hostPlatform;
|
|
|
|
entryModule = types.submodule ({ config, ... }: {
|
|
options = {
|
|
id = mkOption {
|
|
internal = true;
|
|
type = types.str;
|
|
description = ''
|
|
A unique entry identifier. By default it is a base16
|
|
formatted hash of the entry message.
|
|
'';
|
|
};
|
|
|
|
time = mkOption {
|
|
internal = true;
|
|
type = types.str;
|
|
example = "2017-07-10T21:55:04+00:00";
|
|
description = ''
|
|
News entry time stamp in ISO-8601 format. Must be in UTC
|
|
(ending in '+00:00').
|
|
'';
|
|
};
|
|
|
|
condition = mkOption {
|
|
internal = true;
|
|
default = true;
|
|
description = "Whether the news entry should be active.";
|
|
};
|
|
|
|
message = mkOption {
|
|
internal = true;
|
|
type = types.str;
|
|
description = "The news entry content.";
|
|
};
|
|
};
|
|
|
|
config = {
|
|
id = mkDefault (builtins.hashString "sha256" config.message);
|
|
};
|
|
});
|
|
|
|
in
|
|
|
|
{
|
|
meta.maintainers = [ maintainers.rycee ];
|
|
|
|
options = {
|
|
news = {
|
|
display = mkOption {
|
|
type = types.enum [ "silent" "notify" "show" ];
|
|
default = "notify";
|
|
description = ''
|
|
How unread and relevant news should be presented when
|
|
running <command>home-manager build</command> and
|
|
<command>home-manager switch</command>.
|
|
|
|
</para><para>
|
|
|
|
The options are
|
|
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><literal>silent</literal></term>
|
|
<listitem>
|
|
<para>
|
|
Do not print anything during build or switch. The
|
|
<command>home-manager news</command> command still
|
|
works for viewing the entries.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><literal>notify</literal></term>
|
|
<listitem>
|
|
<para>
|
|
The number of unread and relevant news entries will be
|
|
printed to standard output. The <command>home-manager
|
|
news</command> command can later be used to view the
|
|
entries.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term><literal>show</literal></term>
|
|
<listitem>
|
|
<para>
|
|
A pager showing unread news entries is opened.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
'';
|
|
};
|
|
|
|
entries = mkOption {
|
|
internal = true;
|
|
type = types.listOf entryModule;
|
|
default = [];
|
|
description = "News entries.";
|
|
};
|
|
};
|
|
};
|
|
|
|
config = {
|
|
# Add news entries in chronological order (i.e., latest time
|
|
# should be at the bottom of the list). The time should be
|
|
# formatted as given in the output of
|
|
#
|
|
# date --iso-8601=second --universal
|
|
#
|
|
# On darwin (or BSD like systems) use
|
|
#
|
|
# date -u +'%Y-%m-%dT%H:%M:%S+00:00'
|
|
news.entries = [
|
|
{
|
|
time = "2017-09-01T10:56:28+00:00";
|
|
message = ''
|
|
Hello! This is a news entry and it represents an
|
|
experimental new feature of Home Manager. The idea is to
|
|
inform you when something of importance happens in Home
|
|
Manager or its modules.
|
|
|
|
We will try to not disturb you about the same news more than
|
|
once so the next time you run
|
|
|
|
home-manager switch
|
|
|
|
or
|
|
|
|
home-manager build
|
|
|
|
it should not notify you about this text again.
|
|
|
|
News items may be conditional and will then only show if the
|
|
condition holds, for example if they are relevant to your
|
|
configuration.
|
|
|
|
If you want to see all relevant news then please use the
|
|
|
|
home-manager news
|
|
|
|
command.
|
|
|
|
Since this is an experimental feature any positive or
|
|
negative feedback would be greatly appreciated. For example,
|
|
by commenting in https://git.io/v5BJL.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-10T22:15:19+00:00";
|
|
condition = config.programs.zsh.enable;
|
|
message = ''
|
|
Home Manager now offers its own minimal zsh plugin manager
|
|
under the 'programs.zsh.plugins' option path. By statically
|
|
sourcing your plugins it achieves no startup overhead.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-12T13:11:48+00:00";
|
|
condition = (
|
|
config.programs.zsh.enable &&
|
|
config.programs.zsh.shellAliases != {}
|
|
);
|
|
message = ''
|
|
Aliases defined in 'programs.zsh.shellAliases'
|
|
are now have the highest priority. Such aliases will
|
|
not be redefined by the code in 'programs.zsh.initExtra'
|
|
or any external plugins.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-12T14:22:18+00:00";
|
|
message = ''
|
|
A new service is available: 'services.blueman-applet'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-13T11:30:22+00:00";
|
|
message = ''
|
|
A new service is available: 'services.compton'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-20T14:47:14+00:00";
|
|
message = ''
|
|
A new service is available: 'services.screen-locker'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-22T12:09:01+00:00";
|
|
condition = isString config.programs.git.extraConfig;
|
|
message = ''
|
|
The 'programs.git.extraConfig' parameter now accepts
|
|
attributes instead of strings which allows more flexible
|
|
configuration.
|
|
|
|
The string parameter type will be deprecated in the future,
|
|
please change your configuration file accordingly.
|
|
|
|
For example, if your configuration includes
|
|
|
|
programs.git.extraConfig = '''
|
|
[core]
|
|
editor = vim
|
|
''';
|
|
|
|
then you can now change it to
|
|
|
|
programs.git.extraConfig = {
|
|
core = {
|
|
editor = "vim";
|
|
};
|
|
};
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-27T07:28:54+00:00";
|
|
message = ''
|
|
A new program module is available: 'programs.command-not-found'.
|
|
|
|
Note, this differs from the NixOS system command-not-found
|
|
tool in that NIX_AUTO_INSTALL is not supported.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-09-28T12:39:36+00:00";
|
|
message = ''
|
|
A new program module is available: 'programs.rofi';
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-02T11:15:03+00:00";
|
|
condition = config.services.udiskie.enable;
|
|
message = ''
|
|
The udiskie service now defaults to automatically mounting
|
|
new devices. Previous behavior was to not automatically
|
|
mount. To restore this previous behavior add
|
|
|
|
services.udiskie.automount = false;
|
|
|
|
to your Home Manager configuration.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-04T18:36:07+00:00";
|
|
message = ''
|
|
A new module is available: 'xsession.windowManager.xmonad'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-06T08:21:43+00:00";
|
|
message = ''
|
|
A new service is available: 'services.polybar'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-09T16:38:34+00:00";
|
|
message = ''
|
|
A new module is available: 'fonts.fontconfig'.
|
|
|
|
In particular, the Boolean option
|
|
|
|
fonts.fontconfig.enableProfileFonts
|
|
|
|
was added for those who do not use NixOS and want to install
|
|
font packages using 'nix-env' or 'home.packages'. If you are
|
|
using NixOS then you do not need to enable this option.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-12T11:21:45+00:00";
|
|
condition = config.programs.zsh.enable;
|
|
message = ''
|
|
A new option in zsh module is available: 'programs.zsh.sessionVariables'.
|
|
|
|
This option can be used to set zsh specific session variables which
|
|
will be set only on zsh launch.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-15T13:59:47+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.man'.
|
|
|
|
This module is enabled by default and makes sure that manual
|
|
pages are installed for packages in 'home.packages'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-20T12:15:27+00:00";
|
|
condition = with config.systemd.user;
|
|
services != {} || sockets != {} || targets != {} || timers != {};
|
|
message = ''
|
|
Home Manager's interaction with systemd is now done using
|
|
'systemctl' from Nixpkgs, not the 'systemctl' in '$PATH'.
|
|
|
|
If you are using a distribution whose systemd is
|
|
incompatible with the version in Nixpkgs then you can
|
|
override this behavior by adding
|
|
|
|
systemd.user.systemctlPath = "/usr/bin/systemctl"
|
|
|
|
to your configuration. Home Manager will then use your
|
|
chosen version.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-23T23:10:29+00:00";
|
|
condition = !config.programs.home-manager.enable;
|
|
message = ''
|
|
Unfortunately, due to some internal restructuring it is no
|
|
longer possible to install the home-manager command when
|
|
having
|
|
|
|
home-manager = import ./home-manager { inherit pkgs; };
|
|
|
|
in the '~/.config/nixpkgs/config.nix' package override
|
|
section. Attempting to use the above override will now
|
|
result in the error "cannot coerce a set to a string".
|
|
|
|
To resolve this please delete the override from the
|
|
'config.nix' file and either link the Home Manager overlay
|
|
|
|
$ ln -s ~/.config/nixpkgs/home-manager/overlay.nix \
|
|
~/.config/nixpkgs/overlays/home-manager.nix
|
|
|
|
or add
|
|
|
|
programs.home-manager.enable = true;
|
|
|
|
to your Home Manager configuration. The latter is
|
|
recommended as the home-manager tool then is updated
|
|
automatically whenever you do a switch.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-23T23:26:17+00:00";
|
|
message = ''
|
|
A new module is available: 'nixpkgs'.
|
|
|
|
Like the identically named NixOS module, this allows you to
|
|
set Nixpkgs options and define Nixpkgs overlays. Note, the
|
|
changes you make here will not automatically apply to Nix
|
|
commands run outside Home Manager.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-28T23:39:55+00:00";
|
|
message = ''
|
|
A new module is available: 'xdg'.
|
|
|
|
If enabled, this module allows configuration of the XDG base
|
|
directory paths.
|
|
|
|
Whether the module is enabled or not, it also offers the
|
|
option 'xdg.configFile', which acts much like 'home.file'
|
|
except the target path is relative to the XDG configuration
|
|
directory. That is, unless `XDG_CONFIG_HOME` is configured
|
|
otherwise, the assignment
|
|
|
|
xdg.configFile.hello.text = "hello world";
|
|
|
|
will result in a file '$HOME/.config/hello'.
|
|
|
|
Most modules in Home Manager that previously were hard coded
|
|
to write configuration to '$HOME/.config' now use this
|
|
option and will therefore honor the XDG configuration
|
|
directory.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-10-31T11:46:07+00:00";
|
|
message = ''
|
|
A new window manager module is available: 'xsession.windowManager.i3'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-11-12T00:18:59+00:00";
|
|
message = ''
|
|
A new program module is available: 'programs.neovim'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-11-14T19:56:49+00:00";
|
|
condition = with config.xsession.windowManager; (
|
|
i3.enable && i3.config != null && i3.config.startup != []
|
|
);
|
|
message = ''
|
|
A new 'notification' option was added to
|
|
xsession.windowManager.i3.startup submodule.
|
|
|
|
Startup commands are now executed with the startup-notification
|
|
support enabled by default. Please, set 'notification' to false
|
|
where --no-startup-id option is necessary.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-11-17T10:36:10+00:00";
|
|
condition = config.xsession.windowManager.i3.enable;
|
|
message = ''
|
|
The i3 window manager module has been extended with the following options:
|
|
|
|
i3.config.keycodebindings
|
|
i3.config.window.commands
|
|
i3.config.window.hideEdgeBorders
|
|
i3.config.focus.mouseWarping
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-11-26T21:57:23+00:00";
|
|
message = ''
|
|
Two new modules are available:
|
|
|
|
'services.kbfs' and 'services.keybase'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-12-07T22:23:11+00:00";
|
|
message = ''
|
|
A new module is available: 'services.parcellite'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2017-12-11T17:23:12+00:00";
|
|
condition = config.home.activation ? reloadSystemd;
|
|
message = ''
|
|
The Boolean option 'systemd.user.startServices' is now
|
|
available. When enabled the current naive systemd unit
|
|
reload logic is replaced by a more sophisticated one that
|
|
attempts to automatically start, stop, and restart units as
|
|
necessary.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-02-02T11:15:00+00:00";
|
|
message = ''
|
|
A new program configuration is available: 'programs.mercurial'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-02-03T10:00:00+00:00";
|
|
message = ''
|
|
A new module is available: 'services.stalonetray'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-02-04T22:58:49+00:00";
|
|
condition = config.xsession.enable;
|
|
message = ''
|
|
A new option 'xsession.pointerCursor' is now available. It
|
|
allows specifying the pointer cursor theme and size. The
|
|
settings will be applied in the xsession, Xresources, and
|
|
GTK configurations.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-02-06T20:23:34+00:00";
|
|
message = ''
|
|
It is now possible to use Home Manager as a NixOS module.
|
|
This allows you to prepare user environments from the system
|
|
configuration file, which often is more convenient than
|
|
using the 'home-manager' tool. It also opens up additional
|
|
possibilities, for example, to automatically configure user
|
|
environments in NixOS declarative containers or on systems
|
|
deployed through NixOps.
|
|
|
|
This feature should be considered experimental for now and
|
|
some critial limitations apply. For example, it is currently
|
|
not possible to use 'nixos-rebuild build-vm' when using the
|
|
Home Manager NixOS module. That said, it should be
|
|
reasonably robust and stable for simpler use cases.
|
|
|
|
To make Home Manager available in your NixOS system
|
|
configuration you can add
|
|
|
|
imports = [
|
|
"''${builtins.fetchTarball https://github.com/nix-community/home-manager/archive/master.tar.gz}/nixos"
|
|
];
|
|
|
|
to your 'configuration.nix' file. This will introduce a new
|
|
NixOS option called 'home-manager.users' whose type is an
|
|
attribute set mapping user names to Home Manager
|
|
configurations.
|
|
|
|
For example, a NixOS configuration may include the lines
|
|
|
|
users.users.eve.isNormalUser = true;
|
|
home-manager.users.eve = {
|
|
home.packages = [ pkgs.atool pkgs.httpie ];
|
|
programs.bash.enable = true;
|
|
};
|
|
|
|
and after a 'nixos-rebuild switch' the user eve's
|
|
environment should include a basic Bash configuration and
|
|
the packages atool and httpie.
|
|
|
|
More detailed documentation on the intricacies of this new
|
|
feature is slowly forthcoming.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-02-19T21:45:26+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.pidgin'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-03-04T06:54:26+00:00";
|
|
message = ''
|
|
A new module is available: 'services.unclutter'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-03-07T21:38:27+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.fzf'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-03-25T06:49:57+00:00";
|
|
condition = with config.programs.ssh; enable && matchBlocks != {};
|
|
message = ''
|
|
Options set through the 'programs.ssh' module are now placed
|
|
at the end of the SSH configuration file. This was done to
|
|
make it possible to override global options such as
|
|
'ForwardAgent' or 'Compression' inside a host match block.
|
|
|
|
If you truly need to override an SSH option across all match
|
|
blocks then the new option
|
|
|
|
programs.ssh.extraOptionOverrides
|
|
|
|
can be used.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-04-19T07:42:01+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.autorandr'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-04-19T15:44:55+00:00";
|
|
condition = config.programs.git.enable;
|
|
message = ''
|
|
A new option 'programs.git.includes' is available. Additional
|
|
Git configuration files may be included via
|
|
|
|
programs.git.includes = [
|
|
{ path = "~/path/to/config.inc"; }
|
|
];
|
|
|
|
or conditionally via
|
|
|
|
programs.git.includes = [
|
|
{ path = "~/path/to/config.inc"; condition = "gitdir:~/src/"; }
|
|
];
|
|
|
|
and the corresponding '[include]' or '[includeIf]' sections will be
|
|
appended to the main Git configuration file.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-05-01T20:49:31+00:00";
|
|
message = ''
|
|
A new module is available: 'services.mbsync'.
|
|
'';
|
|
}
|
|
{
|
|
time = "2018-05-03T12:34:47+00:00";
|
|
message = ''
|
|
A new module is available: 'services.flameshot'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-05-18T18:34:15+00:00";
|
|
message = ''
|
|
A new module is available: 'qt'
|
|
|
|
At the moment this module allows you to set up Qt to use the
|
|
GTK+ theme, and not much else.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-06-05T01:36:45+00:00";
|
|
message = ''
|
|
A new module is available: 'services.kdeconnect'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-06-09T09:11:59+00:00";
|
|
message = ''
|
|
A new module is available: `programs.newsboat`.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-01T14:33:15+00:00";
|
|
message = ''
|
|
A new module is available: 'accounts.email'.
|
|
|
|
As the name suggests, this new module offers a number of
|
|
options for configuring email accounts. This, for example,
|
|
includes the email address and owner's real name but also
|
|
server settings for IMAP and SMTP.
|
|
|
|
The intent is to have a central location for account
|
|
specific configuration that other modules can use.
|
|
|
|
Note, this module is still somewhat experimental and its
|
|
structure should not be seen as final. Feedback is greatly
|
|
appreciated, both positive and negative.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-01T16:07:04+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.mbsync'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-01T16:12:20+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.notmuch'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-07T15:48:56+00:00";
|
|
message = ''
|
|
A new module is available: 'xsession.windowManager.awesome'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-18T20:14:11+00:00";
|
|
message = ''
|
|
A new module is available: 'services.mpd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-31T13:33:39+00:00";
|
|
message = ''
|
|
A new module is available: 'services.status-notifier-watcher'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-07-31T13:47:06+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.direnv'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-17T20:30:14+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.fish'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-18T19:03:42+00:00";
|
|
condition = config.services.gpg-agent.enable;
|
|
message = ''
|
|
A new option is available: 'services.gpg-agent.extraConfig'.
|
|
|
|
Extra lines may be appended to $HOME/.gnupg/gpg-agent.conf
|
|
using this option.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-19T20:46:09+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new modules is available: 'programs.chromium'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-20T20:27:26+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.msmtp'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-21T20:13:50+00:00";
|
|
message = ''
|
|
A new module is available: 'services.pasystray'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-08-29T20:27:04+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.offlineimap'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-18T21:25:14+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.taskwarrior'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-18T21:43:54+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.zathura'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-20T19:26:40+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.noti'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-20T22:10:45+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.go'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-27T17:48:08+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.obs-studio'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-09-28T21:38:48+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.alot'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-10-20T09:30:57+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.urxvt'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-13T23:08:03+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.tmux'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-18T18:55:15+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.astroid'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-18T21:41:51+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.afew'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-19T00:40:34+00:00";
|
|
message = ''
|
|
A new nix-darwin module is available. Use it the same way the NixOS
|
|
module is used. A major limitation is that Home Manager services don't
|
|
work, as they depend explicitly on Linux and systemd user services.
|
|
However, 'home.file' and 'home.packages' do work. Everything else is
|
|
untested at this time.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-24T16:22:19+00:00";
|
|
message = ''
|
|
A new option 'home.stateVersion' is available. Its function
|
|
is much like the 'system.stateVersion' option in NixOS.
|
|
|
|
Briefly, the state version indicates a stable set of option
|
|
defaults. In the future, whenever Home Manager changes an
|
|
option default in a way that may cause program breakage it
|
|
will do so only for the unstable state version, currently
|
|
19.03. Once 19.03 becomes the stable version only backwards
|
|
compatible changes will be made and 19.09 becomes the
|
|
unstable state version.
|
|
|
|
The default value for this option is 18.09 but it may still
|
|
be a good idea to explicitly add
|
|
|
|
home.stateVersion = "18.09";
|
|
|
|
to your Home Manager configuration.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-25T22:10:15+00:00";
|
|
message = ''
|
|
A new module is available: 'services.nextcloud-client'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-11-25T22:55:12+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.vscode'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-12-04T21:54:38+00:00";
|
|
condition = config.programs.beets.settings != {};
|
|
message = ''
|
|
A new option 'programs.beets.enable' has been added.
|
|
Starting with state version 19.03 this option defaults to
|
|
false. For earlier versions it defaults to true if
|
|
'programs.beets.settings' is non-empty.
|
|
|
|
It is recommended to explicitly add
|
|
|
|
programs.beets.enable = true;
|
|
|
|
to your configuration.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-12-12T21:02:05+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.jq'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-12-24T16:26:16+00:00";
|
|
message = ''
|
|
A new module is available: 'dconf'.
|
|
|
|
Note, on NixOS you may need to add
|
|
|
|
services.dbus.packages = with pkgs; [ gnome3.dconf ];
|
|
|
|
to the system configuration for this module to work as
|
|
expected. In particular if you get the error message
|
|
|
|
The name ca.desrt.dconf was not provided by any .service files
|
|
|
|
when activating your Home Manager configuration.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2018-12-28T12:32:30+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.opam'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-01-18T00:21:56+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.matplotlib'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-01-26T13:20:37+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.xembed-sni-proxy'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-01-28T23:36:10+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.irssi'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-02-09T14:09:58+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.emacs'.
|
|
|
|
This module provides a user service that runs the Emacs
|
|
configured in
|
|
|
|
programs.emacs
|
|
|
|
as an Emacs daemon.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-02-16T20:33:56+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
When using Home Manager as a NixOS submodule it is now
|
|
possible to install packages using the NixOS
|
|
|
|
users.users.<name?>.packages
|
|
|
|
option. This is enabled by adding
|
|
|
|
home-manager.useUserPackages = true;
|
|
|
|
to your NixOS system configuration. This mode of operation
|
|
is necessary if you want to use 'nixos-rebuild build-vm'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-02-17T21:11:24+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.keychain'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-02-24T00:32:23+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new service is available: 'services.mpdris2'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-03-19T22:56:20+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.bat'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-03-19T23:07:34+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.lsd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-04-09T20:10:22+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.xcape'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-04-11T22:50:10+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
The type used for the systemd unit options under
|
|
|
|
systemd.user.services, systemd.user.sockets, etc.
|
|
|
|
has been changed to offer more robust merging of configurations.
|
|
|
|
If you don't override values within systemd units then you are not
|
|
affected by this change. Unfortunately, if you do override unit values
|
|
you may encounter errors due to this change.
|
|
|
|
In particular, if you get an error saying that a "unique option" is
|
|
"defined multiple times" then you need to use 'lib.mkForce'. For
|
|
example,
|
|
|
|
systemd.user.services.foo.Service.ExecStart = "/foo/bar";
|
|
|
|
becomes
|
|
|
|
systemd.user.services.foo.Service.ExecStart = lib.mkForce "/foo/bar";
|
|
|
|
We had to make this change because the old merging was causing too
|
|
many confusing situations for people. Apologies for potentially
|
|
breaking your configuration!
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-04-14T15:35:16+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.skim'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-04-22T12:43:20+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.alacritty'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-04-26T22:53:48+00:00";
|
|
condition = config.programs.vscode.enable;
|
|
message = ''
|
|
A new module is available: 'programs.vscode.haskell'.
|
|
|
|
Enable to add Haskell IDE Engine and syntax highlighting
|
|
support to your VSCode.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-05-04T23:56:39+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.rsibreak'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-05-07T20:49:29+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.mpv'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-05-30T17:49:29+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.xsuspender'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-06-03T21:47:10+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.gpg'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-06-09T12:19:18+00:00";
|
|
message = ''
|
|
Collisions between unmanaged and managed files can now be
|
|
automatically resolved by moving the target file to a new
|
|
path instead of failing the switch operation. To enable
|
|
this, use the new '-b' command line argument. For example,
|
|
|
|
home-manager -b bck switch
|
|
|
|
where 'bck' is the suffix to give the moved file. In this
|
|
case a colliding file 'foo.conf' will be moved to
|
|
'foo.conf.bck'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-06-19T17:49:29+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: `services.getmail`.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-07-02T09:27:56+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.broot'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-07-17T19:30:29+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.taskwarrior-sync'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-07-17T20:05:29+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.kakoune'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-08-08T11:49:35+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.hound'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-08-17T12:24:58+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.muchsync'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-08-18T14:22:41+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.dwm-status'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-08-28T10:18:07+00:00";
|
|
condition = config.programs.vim.enable;
|
|
message = ''
|
|
The 'programs.vim.plugins' option now accepts packages.
|
|
Specifying them as strings is deprecated.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-09-17T19:33:49+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.sxhkd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-09-26T21:05:24+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.starship'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-09-26T21:47:13+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.rtorrent'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-04T20:56:29+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.pazi'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-05T21:54:04+00:00";
|
|
condition = config.programs.zsh.enable;
|
|
message = ''
|
|
The 'programs.zsh.history.path' option behavior and the
|
|
default value has changed for state version 20.03 and above.
|
|
|
|
Specifically, '$HOME' will no longer be prepended to the
|
|
option value, which allows specifying absolute paths (e.g.
|
|
using the xdg module). Also, the default value is fixed to
|
|
'$HOME/.zsh_history' and 'dotDir' path is not prepended to
|
|
it anymore.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-17T18:47:40+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.lorri'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-24T17:46:57+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.spotifyd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-29T21:18:48+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.password-store'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-29T21:18:48+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.password-store-sync'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-11-29T22:46:49+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.unison'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-12-01T22:10:23+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'xdg.mime'.
|
|
|
|
If enabled, which it is by default, this module will create
|
|
the XDG mime database and desktop file database caches from
|
|
programs installed via Home Manager.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2019-12-08T19:48:26+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.readline'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-01-11T11:49:51+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.cbatticon'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-01-26T12:42:33+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'xsession.windowManager.bspwm'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-01-26T12:49:40+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.grobi'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-01-26T19:37:57+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.neomutt'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-02-23T10:19:48+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.kitty'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-02-26T21:20:55+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'wayland.windowManager.sway'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-04T18:55:03+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'programs.abook'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-07T11:43:26+00:00";
|
|
condition = config.programs.fish.enable;
|
|
message = ''
|
|
The option 'programs.fish.functions' has been reworked in
|
|
order to support all available flags, such as
|
|
'--description', '--on-event', and more.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-07T13:11:43+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
The NixOS module has a new option: 'home-manager.useGlobalPkgs'.
|
|
|
|
This enables using the system configuration's 'pkgs'
|
|
argument in Home Manager.
|
|
|
|
To learn more, see the installation section of the manual
|
|
|
|
https://nix-community.github.io/home-manager/#sec-install-nixos-module
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-07T14:12:50+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.lieer'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-07T14:12:50+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.lieer'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-15T16:55:28+00:00";
|
|
condition = config.programs.firefox.enable;
|
|
message = ''
|
|
In anticipation of Firefox dropping support for extension
|
|
sideloading[1], we now install extensions directly to
|
|
Firefox profiles managed through Home Manager's
|
|
|
|
'programs.firefox.profiles'
|
|
|
|
option.
|
|
|
|
Unfortunately this will most likely trigger an "Existing
|
|
file is in the way" error when activating your configuration
|
|
since Firefox keeps a copy of the add-on in the location
|
|
Home Manager wants to overwrite. If this is the case, remove
|
|
the listed '.xpi' files and try again.
|
|
|
|
This change also means that extensions installed through
|
|
Home Manager may disappear from unmanaged profiles in future
|
|
Firefox releases.
|
|
|
|
[1] https://blog.mozilla.org/addons/2019/10/31/firefox-to-discontinue-sideloaded-extensions/
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-17T21:56:26+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.keynav'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-03-24T22:17:20+00:00";
|
|
condition = config.services.compton.enable;
|
|
message = ''
|
|
The 'services.compton' module has been deprecated and
|
|
instead the new module 'services.picom' should be used. This
|
|
is because Nixpkgs no longer packages compton, and instead
|
|
packages the (mostly) compatible fork called picom.
|
|
|
|
The 'services.compton' and 'services.picom' modules have a
|
|
few differences:
|
|
|
|
- 'services.picom' has a new 'experimentalBackends'
|
|
option.
|
|
|
|
- 'vSync' is now a boolean value on 'services.picom', as
|
|
opposed to the string in 'services.compton'.
|
|
|
|
Migrating to the new picom service is simple - just change
|
|
all references to 'services.compton' to 'services.picom',
|
|
and adhere to the above changes.
|
|
|
|
The deprecated 'services.compton' will eventually be removed
|
|
in the future. Please update your configurations to use
|
|
'services.picom' as soon as possible.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-04-08T09:33:05+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'targets.genericLinux'.
|
|
|
|
When enabled, this module will configure various settings
|
|
and environment variables to make Home Manager and programs
|
|
installed through Nix work better on GNU/Linux distributions
|
|
other than NixOS.
|
|
|
|
It should not be enabled if your Home Manager configuration
|
|
is deployed on a NixOS host.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-04-08T11:51:15+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.qutebrowser'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-04-09T09:19:38+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.mako'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-04-23T19:45:26+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.lf'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-04-26T13:46:28+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.pulseeffects'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-05-03T11:13:07+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.i3status'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-05-03T11:21:42+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.aria2'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-05-04T21:19:43+00:00";
|
|
condition = config.programs.git.enable;
|
|
message = ''
|
|
The Git module now supports the 'delta' syntax highlighter.
|
|
|
|
It can be enabled through the option 'programs.git.delta.enable'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-05-12T20:09:54+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.dircolors'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-05-26T17:13:58+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.zoxide'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-03T17:46:11+00:00";
|
|
condition = config.programs.ssh.enable;
|
|
message = ''
|
|
The ssh module now supports the 'ServerAliveCountMax' option
|
|
both globally through
|
|
|
|
programs.ssh.serverAliveCountMax
|
|
|
|
and per match blocks
|
|
|
|
programs.ssh.matchBlocks.<name>.serverAliveCountMax
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-11T18:06:37+00:00";
|
|
condition = hostPlatform.isLinux && config.services.emacs.enable;
|
|
message = ''
|
|
The Emacs service now supports systemd socket activation.
|
|
|
|
It can be enabled through the option 'services.emacs.socketActivation.enable'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-12T17:48:01+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.clipmenu'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-12T07:08:09+00:00";
|
|
condition = config.programs.bash.enable;
|
|
message = ''
|
|
A new module is available: 'programs.powerline-go'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-14T13:30:19+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'service.fluidsynth'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-17T22:17:52+00:00";
|
|
condition = config.programs.git.enable;
|
|
message = ''
|
|
Since May 1, 2020 string values in Git configurations are
|
|
automatically escaped. If you have any manually escaped characters,
|
|
then you may need to restore them to their unescaped form to avoid
|
|
double escaping.
|
|
|
|
In other words, if you now have something along the lines of
|
|
|
|
programs.git.aliases.hello = '''"!echo $'Hello\\nWorld'"''';
|
|
|
|
you must replace it by the unescaped form
|
|
|
|
programs.git.aliases.hello = "!echo $'Hello\nWorld'";
|
|
|
|
Apologies for the belated notification!
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-06-23T20:06:39+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.ne'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-07-24T15:03:11+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.nushell'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-07-25T21:04:59+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.dropbox'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-08-13T22:15:27+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'programs.waybar'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-08-14T22:44:20+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.kanshi'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-08-25T22:14:01+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.mcfly'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-09-01T18:38:18+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.ncmpcpp'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-09-11T10:06:47+00:00";
|
|
condition = hostPlatform.isLinux && config.targets.genericLinux.enable;
|
|
message = ''
|
|
A new option 'targets.genericLinux.extraXdgDataDirs' is available
|
|
to setup the user environment with the OS's data files.
|
|
|
|
This is useful for example to get Bash completion for
|
|
'systemctl' which shouldn't be installed through Home Manager.
|
|
|
|
This is also useful to have non Home Manager applications
|
|
available in menus.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-09-09T06:54:59+00:00";
|
|
condition = config.programs.man.enable;
|
|
message = ''
|
|
A new option 'programs.man.generateCaches' was added to
|
|
support the apropos command.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-09-22T21:03:28+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.pet'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-09-29T21:21:44+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.mu'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-10-08T21:28:16+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.autojump'
|
|
|
|
The option `programs.bash.enableAutojump` is deprecated and this new
|
|
module should be used instead.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-10-12T00:12:23+00:00";
|
|
condition = config.programs.zsh.enable;
|
|
message = ''
|
|
A new zsh submodule is available: 'programs.zsh.prezto'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-10-22T21:10:38+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.gammastep'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-10-22T21:30:42+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.gh'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-11-01T11:17:02+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.caffeine'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-11-05T22:59:21+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'programs.i3status-rust'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-11-14T13:02:40+00:00";
|
|
condition = config.programs.broot.enable;
|
|
message = ''
|
|
The 'programs.broot.verbs' option is now a list rather than an
|
|
attribute set. To migrate, move the keys of the attrset into the
|
|
list items' 'invocation' keys. For example,
|
|
|
|
programs.broot.verbs = {
|
|
"p" = { execution = ":parent"; };
|
|
};
|
|
|
|
becomes
|
|
|
|
programs.broot.verbs = [
|
|
{
|
|
invocation = "p";
|
|
execution = ":parent";
|
|
}
|
|
];
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-12-01T20:46:14+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.wlsunset'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-12-09T22:34:33+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.pbgopy'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-12-18T22:22:25+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.rofi.pass'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2020-12-31T14:16:47+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.octant'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-01-01T08:51:11+00:00";
|
|
condition = config.pam.sessionVariables != {};
|
|
message = ''
|
|
The option 'pam.sessionVariables' will be deprecated in the future.
|
|
This is due to PAM 1.5.0 deprecating reading of the user environment.
|
|
The deprecation will not take place immediately but you may wish to
|
|
consider alternatives to PAM environment variables.
|
|
|
|
See
|
|
|
|
https://github.com/nix-community/home-manager/issues/1691
|
|
|
|
for discussion.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-01-02T07:49:15+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.plan9port'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-01-31T11:23:30+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.playerctld'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-01-28T15:07:34+00:00";
|
|
condition = hostPlatform.isDarwin;
|
|
message = ''
|
|
New options are available for 'targets.darwin':
|
|
|
|
- targets.darwin.defaults
|
|
|
|
This adds options for configuring macOS through the defaults(1)
|
|
system.
|
|
|
|
- targets.darwin.keybindings
|
|
|
|
This adds options for configuring the default keybindings for macOS
|
|
text fields.
|
|
|
|
- targets.darwin.search
|
|
|
|
This adds options for configuring the default search engine for
|
|
macOS.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-02-04T22:28:26+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.sbt'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-02-20T00:00:00+00:00";
|
|
condition = config.services.polybar.enable;
|
|
message = ''
|
|
The polybar configuration can now be written in a more nix-friendly format.
|
|
The new 'services.polybar.settings' option is an alternative to
|
|
'services.polybar.config' that supports nested keys and converts nix
|
|
lists to polybar-style 'foo-0, foo-1, ...' lists.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-02-25T22:36:43+00:00";
|
|
condition = config.programs.git.enable && any (msmtp: msmtp.enable)
|
|
(mapAttrsToList (name: account: account.msmtp)
|
|
config.accounts.email.accounts);
|
|
message = ''
|
|
Git will now defer to msmtp for sending emails if
|
|
'accounts.email.accounts.<name>.msmtp.enable' is true.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-03-03T22:16:05+00:00";
|
|
message = ''
|
|
Home Manager now respects the 'NO_COLOR' environment variable as per
|
|
https://no-color.org/.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-03-29T21:05:50+00:00";
|
|
message = ''
|
|
Configuration specified by 'programs.dircolors.extraConfig' is now
|
|
applied after 'programs.dircolors.settings'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-11T20:44:54+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.exa'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-23T10:00:00+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.pass-secret-service'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-26T07:00:00+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new service is available: 'services.poweralertd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-28T10:00:00+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new service is available: 'services.mpris-proxy'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-28T12:00:00+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.topgrade'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-30T22:05:01+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new service is available: 'services.barrier'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-01T15:16:08+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.lazygit'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-04-27T00:00:00+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.ncspot'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-02T11:22:42+00:00";
|
|
condition = hostPlatform.isLinux && config.services.sxhkd.enable;
|
|
message = ''
|
|
The sxhkd service now is started using 'xsession.initExtra',
|
|
therefore this module loses systemd service management capabilities
|
|
and works only if Home Manager starts the user X session.
|
|
|
|
The option 'services.sxhkd.extraPath' has been deprecated.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-06T20:47:37+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.etesync-dav'
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-06T11:01:41+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.nix-index'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-10T18:50:07+00:00";
|
|
message = ''
|
|
A new module is available: 'xdg.systemDirs'. Options are:
|
|
|
|
- xdg.systemDirs.config
|
|
|
|
Extra directory names to add to $XDG_CONFIG_DIRS in the user
|
|
session.
|
|
|
|
- xdg.systemDirs.data
|
|
|
|
Extra directory names to add to $XDG_DATA_DIRS in the user
|
|
session.
|
|
|
|
These variables are visible in both systemd user services and
|
|
login shells.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-18T12:22:42+00:00";
|
|
condition = config.services.syncthing != {};
|
|
message = ''
|
|
Setting 'services.syncthing.tray' as a boolean will be deprecated in
|
|
the future.
|
|
|
|
This is to make the syncthing tray package configurable, with
|
|
`services.syncthing.tray.package`, following QSyncthingTray becoming
|
|
no longer actively maintained. The default syncthing tray package has
|
|
also changed to https://github.com/Martchus/syncthingtray. To
|
|
continue as before, set `services.syncthing.tray.enable`.
|
|
|
|
See
|
|
|
|
https://github.com/nix-community/home-manager/pull/1257
|
|
|
|
for discussion.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-18T20:28:50+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'programs.foot'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-23T18:31:38+00:00";
|
|
condition = config.programs.mbsync.enable;
|
|
message = ''
|
|
mbsync channels no longer accepts the masterPattern or slavePattern
|
|
attribute keys. This is due to an upstream change.
|
|
They have been renamed: masterPattern -> farPattern, and
|
|
slavePattern -> nearPattern.
|
|
This is a stateful change, where the database file(s) used to keep track
|
|
of mail are silently upgraded once you upgrade both your configuration file
|
|
and the mbsync program.
|
|
|
|
Note that this change is non-reversible, meaning once you choose to switch to
|
|
near/farPattern, you can no longer use your previous slave/masterPattern
|
|
configuration file.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-10T20:41:44+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.rbw'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-05-30T15:22:10+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.piston-cli'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-02T04:24:10+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.xidlehook'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-07T20:44:00+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.pantalaimon'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-12T05:00:22+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.mangohud'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-16T01:26:16+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
The xmonad module now compiles the configuration before
|
|
linking the binary to the place xmonad expects to find
|
|
the compiled configuration (the binary).
|
|
|
|
This breaks recompilation of xmonad (i.e. the 'q' binding or
|
|
'xmonad --recompile').
|
|
|
|
If this behavior is undesirable, do not use the
|
|
'xsession.windowManager.xmonad.config' option. Instead, set the
|
|
contents of the configuration file with
|
|
'home.file.".xmonad/config.hs".text = "content of the file"'
|
|
or 'home.file.".xmonad/config.hs".source = ./path-to-config'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-24T22:36:11+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'i18n.inputMethod'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-06-22T14:43:53+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.himalaya'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-07-11T17:45:56+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.sm64ex'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-07-15T13:38:32+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.xsettingsd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-07-14T20:06:18+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.volnoti'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-07-23T22:22:31+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.trayer'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-07-19T01:30:46+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.notify-osd'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-08-10T21:28:40+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.java'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-08-11T13:55:51+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.easyeffects'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-08-16T21:59:02+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.git-sync'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-08-26T06:40:59+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.fnott'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-08-31T18:44:26+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'services.betterlockscreen'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-09-14T21:31:03+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.bottom'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-09-23T17:04:48+00:00";
|
|
condition = hostPlatform.isLinux && config.services.screen-locker.enable;
|
|
message = ''
|
|
'xautolock' is now optional in 'services.screen-locker', and the
|
|
'services.screen-locker' options have been reorganized for clarity.
|
|
See the 'xautolock' and 'xss-lock' options modules in
|
|
'services.screen-locker'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-10-05T20:55:07+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.atuin'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-10-05T22:15:00+00:00";
|
|
message = ''
|
|
A new module is available: 'programs.nnn'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-10-08T22:16:50+00:00";
|
|
condition = hostPlatform.isLinux && config.programs.rofi.enable;
|
|
message = ''
|
|
Rofi version '1.7.0' removed many options that were used by the module
|
|
and replaced them with custom themes, which are more flexible and
|
|
powerful.
|
|
|
|
You can replicate your old configuration by moving those options to
|
|
'programs.rofi.theme'. Keep in mind that the syntax is different so
|
|
you may need to do some changes.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-10-23T17:12:22+00:00";
|
|
condition = hostPlatform.isLinux;
|
|
message = ''
|
|
A new module is available: 'programs.hexchat'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-11-21T17:21:04+00:00";
|
|
condition = config.wayland.windowManager.sway.enable;
|
|
message = ''
|
|
A new module is available: 'wayland.windowManager.sway.swaynag'.
|
|
'';
|
|
}
|
|
|
|
{
|
|
time = "2021-11-23T20:26:37+00:00";
|
|
condition = config.programs.taskwarrior.enable;
|
|
message = ''
|
|
Taskwarrior version 2.6.0 respects XDG Specification for the config
|
|
file now. Option 'programs.taskwarrior.config' and friends now
|
|
generate the config file at '$XDG_CONFIG_HOME/task/taskrc' instead of
|
|
'~/.taskrc'.
|
|
'';
|
|
}
|
|
];
|
|
};
|
|
}
|