# Download Here are the ways to install hledger, organised by platform, with the usually most up-to-date methods at the top. ( hledger's usual release window is the first day or two of the month. Please [send updates](index.html#helpfeedback) for [this page](https://github.com/simonmichael/hledger/blob/master/site/download.md), and help packagers keep packages up to date. Click the version badges on the right for package/contact info. ) | | | Latest release is 1.14.1
[Release notes](http://hledger.org/release-notes) |--------------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | |
**Multiplatform** |
*The first three build from source, which is slower. See [Building from source](#b).* |
*This method installs:* | [hledger-install](#b1)
*Linux, Mac, WSL*
*Requires only bash.* | **`curl -sO https://raw.githubusercontent.com/simonmichael/hledger/master/hledger-install/hledger-install.sh`**
**`less hledger-install.sh`**    *# satisfy yourself that the script is safe*
**`bash hledger-install.sh`**
| Latest release | [stack]
*Linux, Mac, Windows[*]* | **`stack install --resolver=nightly-2019-03-09 hledger hledger-web hledger-ui`** | Latest release / any version | [cabal]
*Linux, Mac, Windows[*]* | **`cabal v2-update && cabal v2-install hledger-1.14.1 hledger-web-1.14 hledger-ui-1.14`** | Latest release / any version | | [Docker]
*Linux, Mac, Windows* | **`docker pull dastapov/hledger`** | [![](https://img.shields.io/badge/Docker_image-1.14.1-brightgreen.svg)](https://hub.docker.com/r/dastapov/hledger)
[more..](https://hub.docker.com/search?q=hledger&type=image&sort=updated_at&order=desc) | [Nix]
*Linux, Mac* | **`nix-env -i hledger-1.14.1 hledger-ui-1.14 hledger-web-1.14`**
*nix-channel --update may be needed. CI [build][nix unstable linux builds] [issues][nix unstable mac builds] can cause failure/large downloads, check those links/try with --dry-run first.* | [![nixpkgs unstable](https://repology.org/badge/version-for-repo/nix_unstable/hledger.svg)](https://github.com/NixOS/nixpkgs/search?o=desc&q=hledger&s=committer-date&type=Commits)
[![nixpkgs stable](https://repology.org/badge/version-for-repo/nix_stable/hledger.svg)][nix changes] | |
**Mac** | | [Homebrew] | **`brew install hledger`** | [![Homebrew](https://repology.org/badge/version-for-repo/homebrew/hledger.svg)](https://formulae.brew.sh/formula/hledger) | |
**Windows** | | Windows binaries | **[hledger.zip]** *from Appveyor CI* | [![](https://img.shields.io/badge/Windows_binaries-1.14.1+_20190309-brightgreen.svg)](https://ci.appveyor.com/project/simonmichael/hledger/build/artifacts) | [Linuxbrew] | **`brew install hledger`** | [![Linuxbrew](https://repology.org/badge/version-for-repo/linuxbrew/hledger.svg)](https://formulae.brew.sh/formula/hledger) | |
**GNU/Linux** | | [Linuxbrew] | **`brew install hledger`** | [![Linuxbrew](https://repology.org/badge/version-for-repo/linuxbrew/hledger.svg)](https://formulae.brew.sh/formula/hledger) | Arch | **`pacman -S hledger hledger-ui hledger-web`** | [![Arch](https://repology.org/badge/version-for-repo/arch/hledger.svg)](https://www.archlinux.org/packages/?sort=&q=hledger) | Gentoo | **`sudo layman -a haskell && sudo emerge hledger hledger-ui hledger-web`** | [![](https://img.shields.io/badge/Gentoo_package-1.14.1-brightgreen.svg)](https://gentoo.zugaina.org/Search?search=hledger) | Debian | **`sudo apt install hledger hledger-ui hledger-web`** | [![Debian Unstable](https://repology.org/badge/version-for-repo/debian_unstable/hledger.svg)](https://packages.debian.org/unstable/hledger)
[![Debian Testing](https://repology.org/badge/version-for-repo/debian_testing/hledger.svg)](https://packages.debian.org/testing/hledger)
[![Debian Stable](https://repology.org/badge/version-for-repo/debian_stable/hledger.svg)](https://packages.debian.org/stable/hledger)
[![Debian Oldstable](https://repology.org/badge/version-for-repo/debian_oldstable/hledger.svg)](https://packages.debian.org/oldstable/hledger)
[more..](https://packages.debian.org/search?searchon=names&keywords=hledger) | Ubuntu | **`sudo apt install hledger hledger-ui hledger-web`** | [![Ubuntu 19.04](https://repology.org/badge/version-for-repo/ubuntu_19_04/hledger.svg)](https://packages.ubuntu.com/disco/hledger)
[![Ubuntu 18.10](https://repology.org/badge/version-for-repo/ubuntu_18_10/hledger.svg)](https://packages.ubuntu.com/cosmic/hledger)
[![Ubuntu 18.04](https://repology.org/badge/version-for-repo/ubuntu_18_04/hledger.svg)](https://packages.ubuntu.com/bionic/hledger)
[![Ubuntu 16.04](https://repology.org/badge/version-for-repo/ubuntu_16_04/hledger.svg)](https://packages.ubuntu.com/xenial/hledger)
[![Ubuntu 14.04](https://repology.org/badge/version-for-repo/ubuntu_14_04/hledger.svg)](https://packages.ubuntu.com/trusty/hledger)
[more..](https://packages.ubuntu.com/search?suite=all&searchon=names&keywords=hledger) | Fedora | **`sudo dnf install hledger`** | [![Fedora Rawhide](https://img.shields.io/badge/Fedora_Rawhide_package-1.10-red.svg)](https://apps.fedoraproject.org/packages/hledger/)
[![Fedora 30](https://img.shields.io/badge/Fedora_30_package-1.5-red.svg)](https://apps.fedoraproject.org/packages/hledger/)
[![Fedora 29](https://repology.org/badge/version-for-repo/fedora_29/hledger.svg)](https://apps.fedoraproject.org/packages/hledger/)
[![Fedora 28](https://repology.org/badge/version-for-repo/fedora_28/hledger.svg)](https://apps.fedoraproject.org/packages/hledger/)
[![Fedora 27](https://repology.org/badge/version-for-repo/fedora_27/hledger.svg)](https://apps.fedoraproject.org/packages/hledger/)
[more..](https://apps.fedoraproject.org/packages/s/hledger) | Void | **`xbps-install -S hledger hledger-ui hledger-web`** | [![Void Linux x86_64](https://repology.org/badge/version-for-repo/void_x86_64/hledger.svg)](https://voidlinux.org/packages/?q=hledger) | |
**BSD** | | [OpenBSD WIP](https://github.com/jasperla/openbsd-wip#how-to-use-this-tree) | **`make -C /usr/ports/openbsd-wip/productivity/hledger install`** | [![openbsd-wip port](https://img.shields.io/badge/openbsd--wip_port-1.10-red.svg)](https://github.com/jasperla/openbsd-wip/tree/master/productivity/hledger)
[more..](https://github.com/jasperla/openbsd-wip/tree/master/productivity) | |
**Other** | | [Sandstorm]
*Community/private cloud platform* | **[HLedger Web app](https://apps.sandstorm.io/app/8x12h6p0x0nrzk73hfq6zh2jxtgyzzcty7qsatkg7jfg2mzw5n90)** | ![](https://img.shields.io/badge/Sandstorm_app-1.9.1-red.svg) | [*]: #windows-build-issues [Docker]: https://www.docker.com/products/docker-desktop [Homebrew]: https://brew.sh [Linuxbrew]: https://linuxbrew.sh [Nix]: https://nixos.org/nix [Sandstorm]: https://sandstorm.io [cabal]: https://www.haskell.org/cabal [hledger.zip]: https://ci.appveyor.com/api/buildjobs/gudfa3gv7pj94ab0/artifacts/hledger.zip [stack]: https://haskell.fpcomplete.com/get-started [notes]:: [debian contact]: debian-haskell@lists.debian.org (& Clint) [docker contact]: @adept [homebrew/linuxbrew contact]: @albins, @simonmichael [nix contact]: @peti [sandstorm contact]: @ocdtrekkie, @AaronM04, @ndarilek [stack/cabal contact]: @simonmichael [windows binaries contact]: @simonmichael [nix install variations]:: [nix-env -i hledger hledger-ui hledger-web]: [nix-env -i hledger-1.14.1 hledger-ui-1.14 hledger-web-1.14]: [nix-env -i -f '' -A hledger hledger-ui hledger-web]: [fetches latest unstable]: [nix-env -i -f channel:nixos-unstable -A hledger hledger-ui hledger-web]: [nixpkgs]: https://hydra.nixos.org/project/nixpkgs [nix changes]: https://github.com/NixOS/nixpkgs/search?o=desc&q=hledger&s=committer-date&type=Commits [nix mentions]: https://search.nix.gsc.io/?q=hledger [nix hydra jobs]: http://hydra.nixos.org/search?query=hledger [nix stable mac jobs]: https://hydra.nixos.org/jobset/nixpkgs/nixpkgs-19.03-darwin#tabs-jobs -> hledger. [nix unstable jobs]: https://hydra.nixos.org/jobset/nixpkgs/trunk#tabs-jobs -> hledger. [nix unstable linux builds]: https://hydra.nixos.org/job/nixpkgs/trunk/hledger.x86_64-linux [nix unstable mac builds]: https://hydra.nixos.org/job/nixpkgs/trunk/hledger.x86_64-darwin [repology badges, sometimes out of date]: https://repology.org/project/hledger/badges [custom badges]: https://shields.io ## Building from source Building hledger from source takes a bit longer than using a prebuilt package, but you can be sure of getting the latest release (or the latest dev version). Below are three ways to build hledger. But first, some general tips: - Building Haskell programs involves downloading and building and optimising a lot of dependencies. If you haven't built Haskell software before, your first hledger build could take up to an hour, 1-2G of free memory, and 1-2G of disk. - Future builds will be much faster. - You can kill a build and restart it later without losing progress. - If you get link errors (eg: "/bin/ld.gold: error: cannot find -ltinfo"), you might need to install some extra system packages (C packages provided by your platform - not haskell packages) and try again. To find the right system package, check the list below, or do a web search for the error message (and please send updates for this list): | |-----------------|------------------------------------------------------------------- | CentOS: | **`sudo yum install -y libstdc++-devel ncurses-devel zlib-devel`** | Debian, Ubuntu: | **`sudo apt install -y libtinfo-dev`** | Fedora, RHEL: | **`sudo dnf install -y gmp-devel ncurses-devel`** - Here are some known build issues and workarounds on certain platforms: [windows: hledger-ui is not available](https://github.com/jtdaugherty/vty/pull/1#issuecomment-297143444)\ [windows: build hangs using GHC 8.6.3](https://github.com/well-typed/generics-sop/issues/93)\ [windows: cross-environment non-ascii display issues](https://github.com/simonmichael/hledger/issues/961#issuecomment-471229644)\ [arch: haskell build advice from Arch wiki](https://wiki.archlinux.org/index.php/Haskell)\ [arch: No information found for ghc-8.4.2](https://github.com/commercialhaskell/stack/issues/3984)\ [freebsd 12: no cabal file found](https://github.com/simonmichael/hledger/issues/709)\ [openbsd 6: exec permission denied](https://deftly.net/posts/2017-10-12-using-cabal-on-openbsd.html)\ [openbsd: how to get stack](https://github.com/commercialhaskell/stack/issues/2822#issuecomment-318892816)\ - If you have trouble, please send me a copy/paste of the output, including the commands you typed, at least up to the first error, via [paste](http://paste.hledger.org) + [IRC](http://irc.hledger.org), or the [issue tracker](http://bugs.hledger.org), or [email](index.html#helpfeedback). ### Building with hledger-install.sh If you don't already have stack or cabal, or if you are having trouble with them, [hledger-install.sh](https://github.com/simonmichael/hledger/tree/master/hledger-install) is an easy and reliable way to get the latest hledger, on systems which have the bash shell (and are supported by GHC: mac, linux, unix-like environments on windows..). It automates the installation of stack or cabal and then building the hledger tools, avoiding common pitfalls. Here's how to run it (or, some folks will prefer to pipe it directly into bash): **`curl -s https://raw.githubusercontent.com/simonmichael/hledger/master/hledger-install/hledger-install.sh > hledger-install.sh`**\ **`less hledger-install.sh`** *# satisfy yourself that the script is safe*\ **`bash hledger-install.sh`** ### Building with stack [`stack`](http://haskell-lang.org/get-started) is the more reliable of Haskell's two build tools for new users. You need stack 1.7.1 or newer; the latest release (eg 1.9.3) is the most reliable. You can often run `stack upgrade` to upgrade it. 64-bit Windows users should choose the 64-bit version of stack. The following command installs the main hledger packages; **`stack install --resolver=lts-13 hledger-lib-1.14 hledger-1.14.1 hledger-web-1.14 \`**\   **`hledger-ui-1.14 brick-0.46 text-zipper-0.10.1 config-ini-0.2.4.0 data-clist-0.1.2.2 word-wrap-0.4.1`**\ If needed, you can save some time by omitting the [hledger-web](http://hackage.haskell.org/package/hledger-web) and [hledger-ui](http://hackage.haskell.org/package/hledger-ui) packages (and hledger-ui's extra dependencies: brick, text-zipper, config-ini etc.) On Windows, hledger-ui is not available. To estimate the build time remaining, add `--dry-run`. Some other [add-on tools](/hledger.html#third-party-add-ons) like [hledger-api](http://hackage.haskell.org/package/hledger-api), [hledger-iadd](http://hackage.haskell.org/package/hledger-iadd), and [hledger-interest](http://hackage.haskell.org/package/hledger-interest) can be installed like so: **`stack install --resolver=lts-13 hledger-lib-1.14 hledger-1.14.1 hledger-api-1.14 \`**\   **`hledger-interest-1.5.3 hledger-iadd-1.3.9 brick-0.46 text-zipper-0.10.1 config-ini-0.2.4.0 data-clist-0.1.2.2 word-wrap-0.4.1`**\ ### Building with cabal [cabal](https://www.haskell.org/cabal/) is the other Haskell build tool. If you're a cabal expert, use it in the usual way, eg: **`cabal v2-update`**\ **`cabal v2-install hledger-1.14.1 hledger-ui-1.14 hledger-web-1.14 \`**\   **`hledger-api-1.14 hledger-iadd-1.3.9 hledger-interest-1.5.3`**\ ### Set up PATH After building you may see a message about where the executables were installed. After installation, make sure this install directory is configured in your shell's \$PATH (preferably near the start of it, to preempt older hledger system packages you may have installed). The install directory is: | | on non-Windows systems | on Windows |--------------------|------------------------|------------------------------------------ | If stack was used | `$HOME/.local/bin` | `%APPDATA%\local\bin` (eg `C:\Users\Joe\AppData\Roaming\local\bin`) | If cabal was used | `$HOME/.cabal/bin` | `%APPDATA%\cabal\bin` How to configure \$PATH is platform- and shell-specific. If you are using bash, this should take care of it: **`echo "export PATH=~/.local/bin:~/.cabal/bin:$PATH" >> ~/.bashrc && source ~/.bashrc`** ### Test the installation You should now be able to run the hledger tools (whichever ones you installed) and see the expected versions: `$`**`hledger --version`**\ `hledger 1.14.1`\ `$`**`hledger-ui --version`**\ `hledger-ui 1.14`\ `$`**`hledger web --version`**\ `hledger-web 1.14`\ `$`**`hledger iadd --version`**\ `This is hledger-iadd version 1.3.9`\ And you can check that the unit tests pass (just for fun): `$`**`hledger test`**\ `...`\ `✅ 198 tests passed, no failures! 👍 🎉`\ ### Building the development version The master branch in hledger's git repo is stable enough for daily use, and includes the [latest improvements](https://github.com/simonmichael/hledger/commits/master). You'll need [git](https://en.wikipedia.org/wiki/Git) and [`stack`](http://haskell-lang.org/get-started) or [cabal](https://www.haskell.org/cabal/). This will build and install all of the main hledger tools using stack: **`git clone https://github.com/simonmichael/hledger`**\ **`cd hledger`**\ **`stack install`**\ cabal users may find the `cabal-install.sh` or `cabal.project` files useful. The --version output of development builds has a .99 suffix meaning "dev". So 1.14.99 means "1.15-dev", the in-development version of 1.15. ### Building the development version with docker You can also build development version in the docker container, which will take care of pulling all the necessary tools and dependencies: **`git clone https://github.com/simonmichael/hledger`**\ **`cd hledger/docker`**\ **`./build.sh`**\ This will build image tagged `hledger` with just the latest binaries inside. If you want to keep all the build artifacts and use the resulting image for hledger development, use `build-dev.sh` instead.