# Release 21.05 {#sec-release-21.05}

The 21.05 release branch became the stable branch in May, 2021.

## Highlights {#sec-release-21.05-highlights}

This release has the following notable changes:

-   The 'opt-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,

    ``` nix
    programs.broot.verbs = {
      "p" = { execution = ":parent"; };
    };
    ```

    becomes

    ``` nix
    programs.broot.verbs = [
      {
        invocation = "p";
        execution = ":parent";
      }
    ];
    ```

-   The [programs.mpv.package](#opt-programs.mpv.package) option has been changed to
    allow custom derivations. The following configuration is now
    possible:

    ``` nix
    programs.mpv.package = (pkgs.wrapMpv (pkgs.mpv-unwrapped.override {
      vapoursynthSupport = true;
    }) {
      extraMakeWrapperArgs = [
        "--prefix" "LD_LIBRARY_PATH" ":" "${pkgs.vapoursynth-mvtools}/lib/vapoursynth"
      ];
    });
    ```

    As a result of this change, [programs.mpv.package](#opt-programs.mpv.package) is no
    longer the resulting derivation. Use the newly introduced
    `programs.mpv.finalPackage` instead.

-   The [programs.rofi.extraConfig](#opt-programs.rofi.extraConfig) option is now an attribute
    set rather than a string. To migrate, move each line into the
    attribute set, removing the `rofi.` prefix from the keys. For
    example,

    ``` nix
    programs.rofi.extraConfig = ''
      rofi.show-icons: true
      rofi.modi: drun,emoji,ssh
    '';
    ```

    becomes

    ``` nix
    programs.rofi.extraConfig = {
      show-icons = true;
      modi = "drun,emoji,ssh";
    };
    ```

-   The [programs.rofi.theme](#opt-programs.rofi.theme) option now supports defining a
    theme using an attribute set, the following configuration is now
    possible:

    ``` nix
    programs.rofi.theme = let
      # Necessary to avoid quoting non-string values
      inherit (config.lib.formats.rasi) mkLiteral;
    in {
       "@import" = "~/.config/rofi/theme.rasi";

      "*" = {
        background-color = mkLiteral "#000000";
        foreground-color = mkLiteral "rgba ( 250, 251, 252, 100 % )";
        border-color = mkLiteral "#FFFFFF";
        width = 512;
      };

      "#textbox-prompt-colon" = {
        expand = false;
        str = ":";
        margin = mkLiteral "0px 0.3em 0em 0em";
        text-color = mkLiteral "@foreground-color";
      };
    };
    ```

-   The `services.redshift.extraOptions` and
    `services.gammastep.extraOptions` options were removed in favor of
    [services.redshift.settings](#opt-services.redshift.settings) and
    `services.gammastep.settings`, that are now an attribute set rather
    than a string. They also support new features not available before,
    for example:

    ``` nix
    services.redshift = {
      dawnTime = "6:00-7:45";
      duskTime = "18:35-20:15";
      settings = {
        redshift = {
          gamma = 0.8;
          adjustment-method = "randr";
        };

        randr = {
          screen = 0;
        };
      };
    };
    ```

    It is recommended to check either
    [redshift.conf.sample](https://github.com/jonls/redshift/blob/master/redshift.conf.sample)
    or
    [gammastep.conf.sample](https://gitlab.com/chinstrap/gammastep/-/blob/master/gammastep.conf.sample)
    for the available additional options in each program.

-   Specifying `programs.neomutt.binds.map` or
    `programs.neomutt.macros.map` as a single string is now deprecated
    in favor of specfiying it as a list of strings.

-   The `programs.neovim.configure` is deprecated in favor of other
    `programs.neovim` options; please use the other options at your
    disposal:

    ``` nix
    configure.packages.*.opt  -> programs.neovim.plugins = [ { plugin = ...; optional = true; }]
    configure.packages.*.start  -> programs.neovim.plugins = [ { plugin = ...; }]
    configure.customRC -> programs.neovim.extraConfig
    ```

-   Home Manager now respects the `NO_COLOR` environment variable as per
    <https://no-color.org/>.

-   Qt module now supports [qt.style.name](#opt-qt.style.name) to specify a theme
    name and [qt.style.package](#opt-qt.style.package) to specify a theme package. If
    you have set [qt.platformTheme](#opt-qt.platformTheme) to `gnome`, a
    [qt.style.package](#opt-qt.style.package) compatible with both Qt and Gtk is now
    required to be set. For instance:

    ``` nix
    qt = {
      platformTheme = "gnome";
      style = {
        name = "adwaita-dark";
        package = pkgs.adwaita-qt;
      };
    };
    ```

-   The library type `fontType` now has a `size` attribute in addition
    to `name`. For example:

    ``` nix
    font = {
      name = "DejaVu Sans";
      size = 8;
    };
    ```

-   The [programs.htop.settings](#opt-programs.htop.settings) option is introduced to
    replace individual options in `programs.htop`. To migrate, set the
    htop options directly in [programs.htop.settings](#opt-programs.htop.settings). For
    example:

    ``` nix
    programs.htop = {
      enabled = true;
      settings = {
         color_scheme = 5;
         delay = 15;
         highlight_base_name = 1;
         highlight_megabytes = 1;
         highlight_threads = 1;
      };
    };
    ```

## State Version Changes {#sec-release-21.05-state-version-changes}

The state version in this release includes the changes below. These
changes are only active if the `home.stateVersion` option is set to
\"21.05\" or later.

-   The `newsboat` module now stores generated configuration in
    `$XDG_CONFIG_HOME/newsboat`.