Run a script automatically on sunrise and sunset
Find a file
q9i 48de041a44
Some checks failed
Cache binaries / tests (push) Has been cancelled
docs(workflow): rename main.yml
2024-08-16 20:22:15 -07:00
.github/workflows docs(workflow): rename main.yml 2024-08-16 20:22:15 -07:00
app fix: optimize external dependency specifications 2024-08-16 20:22:15 -07:00
.envrc chore: add .envrc for automatic dev env loading 2024-08-16 20:22:15 -07:00
.gitignore fix: correctly gitignore nix result 2024-08-16 20:22:15 -07:00
CHANGELOG.md initial commit 2024-07-13 19:50:43 -07:00
flake.lock deps(dev): switch to nix 2024-08-16 20:22:15 -07:00
flake.nix deps: add suntheme cachix to flake 2024-08-16 20:22:15 -07:00
LICENSE initial commit 2024-07-13 19:50:43 -07:00
README.md docs: formalize readme 2024-08-16 20:22:15 -07:00
suntheme.cabal deps(dev): switch to nix 2024-08-16 20:22:15 -07:00

Suntheme

Runs a script on sunrise and sunset, written in pure Haskell


You may be wondering how a program written in Haskell, the purely functional programming language, could possibly act on the real world by running a so-called "script."

It's simple. We take in the entire World as an input to a pure function, the IO Monad. It then maps the original World to a new (generated) World, with our desired IO actions carefully applied with mathematical precision.

From the second perspective, an IO action transforms the whole world. IO actions are actually pure, because they receive a unique world as an argument and then return the changed world.

See this for more information.

Hacking on suntheme

It's trivial to get started with suntheme development thanks to Nix, the purely functional package manager. Naturally, we leverage it as our primary package manager, both for Hackage and development tools like language servers and the like.

First, install Nix through your preferred avenue or local system administrator. If unsure, we recommend the Determinate Nix Installer. Make sure flakes and nix-command are enabled (the Determinate Installer will enable them by default).

Once you have nix, simply type:

nix develop

Say yes to any prompts asking you to allow substituters or trust public keys. Nix will fetch all of the required packages, such as GHC and Hackage dependencies. Additionally, you will have access to hlint and the haskell-language-server.

To create a build, type

nix build

A binary will be produced in result/bin/suntheme.

To make suntheme available in the shell without outputting to result, use

nix shell

This will build a binary just like nix build but add it temporarily to the PATH, so you can just type suntheme.

To build and run suntheme immediately without adding it to the PATH, use

nix run

This will build a binary just like nix shell but immediately execute it.