From ea3689a5c705ee545ba46e45adc1ebfb9143f26c Mon Sep 17 00:00:00 2001 From: fricklerhandwerk Date: Wed, 18 Oct 2023 12:04:34 +0200 Subject: [PATCH] move devmode helper into flake this cleans up the top-level directory and hopefully makes the setup slightly more obvious --- README.md | 2 +- flake.nix | 46 ++++++++++++++++++++++++++++++++++------------ live | 1 - live.py | 13 ------------- 4 files changed, 35 insertions(+), 27 deletions(-) delete mode 100755 live delete mode 100644 live.py diff --git a/README.md b/README.md index 0292d8e69..29bda9def 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ Official documentation for getting things done with Nix. ## Contributing -Run `./live` and open a browser at . +Run `nix-shell --run devmode` and open a browser at . As you make changes your browser should auto-reload within a few seconds. diff --git a/flake.nix b/flake.nix index 2ed694fad..ee5561b4f 100644 --- a/flake.nix +++ b/flake.nix @@ -4,7 +4,7 @@ inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05"; inputs.flake-utils.url = "github:numtide/flake-utils"; - outputs = { self, nixpkgs, flake-utils}: + outputs = { self, nixpkgs, flake-utils }: flake-utils.lib.eachDefaultSystem (system: let pkgs = import nixpkgs { @@ -15,7 +15,36 @@ (import ./overlay.nix) ]; }; - in { + devmode = + let + pythonEnvironment = pkgs.python310.withPackages (ps: with ps; [ + livereload + ]); + script = '' + from livereload import Server, shell + + server = Server() + + build_docs = shell("nix build") + + print("Doing an initial build of the docs...") + build_docs() + + server.watch("source/*", build_docs) + server.watch("source/**/*", build_docs) + server.watch("_templates/*.html", build_docs) + server.serve(root="result/") + ''; + in + pkgs.writeShellApplication { + name = "devmode"; + runtimeInputs = [ pythonEnvironment ]; + text = '' + python ${pkgs.writeText "live.py" script} + ''; + }; + in + { packages.default = pkgs.stdenv.mkDerivation { name = "nix-dev"; src = self; @@ -39,17 +68,10 @@ }; devShells.default = pkgs.mkShell { - buildInputs = with pkgs.python310.pkgs; [ + inputsFrom = [ self.packages.${system}.default ]; + packages = with pkgs.python310.pkgs; [ black - livereload - linkify-it-py - myst-parser - sphinx - sphinx-book-theme - sphinx-copybutton - sphinx-design - sphinx-notfound-page - sphinx-sitemap + devmode ]; }; } diff --git a/live b/live deleted file mode 100755 index a3cd512ae..000000000 --- a/live +++ /dev/null @@ -1 +0,0 @@ -nix-shell --run "python live.py" diff --git a/live.py b/live.py deleted file mode 100644 index 3ca621bcb..000000000 --- a/live.py +++ /dev/null @@ -1,13 +0,0 @@ -from livereload import Server, shell - -server = Server() - -build_docs = shell("make html") - -print("Doing an initial build of the docs...") -build_docs() - -server.watch("source/*", build_docs) -server.watch("source/**/*", build_docs) -server.watch("_templates/*.html", build_docs) -server.serve(root="build/html")