Home Explore Blog CI



nixpkgs

1st chunk of `doc/languages-frameworks/hy.section.md`
f060e97631c3eafae469ef62f07d9a5fa2639765b7a27a2c000000010000048e
# Hy {#sec-language-hy}

## Installation {#ssec-hy-installation}

### Installation without packages {#installation-without-packages}

You can install `hy` via nix-env or by adding it to `configuration.nix` by referring to it as a `hy` attribute. This kind of installation adds `hy` to your environment and it successfully works with `python3`.

::: {.caution}
Packages that are installed with your python derivation, are not accessible by `hy` this way.
:::

### Installation with packages {#installation-with-packages}

Creating `hy` derivation with custom `python` packages is really simple and similar to the way that python does it. Attribute `hy` provides function `withPackages` that creates custom `hy` derivation with specified packages.

For example if you want to create shell with `matplotlib` and `numpy`, you can do it like so:

```ShellSession
$ nix-shell -p "hy.withPackages (ps: with ps; [ numpy matplotlib ])"
```

Or if you want to extend your `configuration.nix`:
```nix
{
  # ...

  environment.systemPackages = with pkgs; [
    (hy.withPackages (
      py-packages: with py-packages; [
        numpy
        matplotlib
      ]
    ))
  ];
}
```

Title: Hy Language Installation
Summary
This section describes how to install the Hy language on NixOS. It covers installation without packages (using nix-env or configuration.nix, which provides basic Hy functionality but doesn't include Python packages) and installation with packages (creating a custom Hy derivation with specified Python packages using the `withPackages` function).