update README; remove NZ things; don't list hlint as a tool

main
Robert Pearce 2020-09-22 21:55:39 -04:00
parent eab1186a9f
commit 52431847d6
No known key found for this signature in database
GPG Key ID: 07A0E482E5616C9B
3 changed files with 40 additions and 3 deletions

View File

@ -3,3 +3,42 @@
[![built with nix](https://builtwithnix.org/badge.svg)](https://builtwithnix.org)
[Hakyll](https://jaspervdj.be/hakyll/) + [Nix](https://nixos.org/) template
## Features
tl;dr: `nix-build` will collect all your pinned dependencies, build your hakyll
site, and output the built site in a `result/` directory. If you set up the
[main GitHub Action](./.github/workflows/main.yml) with what it needs (your
[cachix](https://cachix.org) cache, and your app needs a `CACHIX_SIGNING_KEY`
secret), it will deploy your built site to a `gh-pages` branch.
* Hakyll (see [the generator folder](./generator))
* Haskell `nix-shell` environment inside the `generator` folder through which
you can run `hakyll-site watch` and all other hakyll commands, including
the ability to run `ghci` and load haskell modules for testing
* Ability to patch hakyll via `hakyll.patch`
* Ability to provide nixpkgs overrides for packages whose versions need to
come from [hackage](https://hackage.haskell.org)
* RSS & Atom XML feed generation
* Sitemap generation
* Reasonable pandoc markdown customization to make it as close to GitHub's
style as possible
* `Slug.hs` module that makes nice URIs
* Many other opinionated general website setup features that should be very
helpful
* Nix
* Pinned [nixpkgs](https://github.com/NixOS/nixpkgs), [niv](https://github.com/nmattia/niv),
and [pre-commit-hooks.nix](https://github.com/cachix/pre-commit-hooks.nix)
* `nix-build` will build your site into a `result/` directory
* `nix-shell` in the root will give you a shell with the `tools` dependencies
in [./nix/default.nix](./nix/default.nix)
* `nix-shell` in [./generator](./generator) will give you a haskell shell with
your `hakyll-site` available, as well as `ghci`
* Dev linting via [pre-commit-hooks.nix](https://github.com/cachix/pre-commit-hooks.nix)
* [nix-linter](https://github.com/Synthetica9/nix-linter)
* [nixpkgs-fmt](https://github.com/nix-community/nixpkgs-fmt)
* [ormolu](https://github.com/tweag/ormolu)
* [shellcheck](https://github.com/koalaman/shellcheck)
* Encourages dev use of [lorri](https://github.com/target/lorri)
* Deployment through a [GitHub Actions](https://github.com/features/actions)
build with [cachix](https://cachix.org) and deploying to
[GitHub Pages](https://pages.github.com/) via a `gh-pages` branch

View File

@ -82,8 +82,7 @@ main = hakyllWith config $ do
route idRoute
compile $ do
posts <- recentFirst =<< loadAll "posts/*"
nzPages <- loadAll "new-zealand/**"
let pages = posts <> nzPages
let pages = posts
sitemapCtx =
constField "root" root
<> constField "siteName" siteName

View File

@ -22,7 +22,6 @@ in
generator
pkgs.niv
pkgs.pre-commit
pre-commit-hooks.hlint
pre-commit-hooks.nixpkgs-fmt
pre-commit-hooks.ormolu
];