From 1c7c75173d95cf40b3bba328fdb2e54bcfb11f80 Mon Sep 17 00:00:00 2001 From: h7x4 Date: Sat, 7 Jun 2025 14:34:35 +0200 Subject: [PATCH] flake.nix: init --- .envrc | 1 + default.nix | 18 +++++++++++++++ flake.lock | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++ flake.nix | 41 ++++++++++++++++++++++++++++++++++ pyproject.toml | 10 +++++++-- shell.nix | 16 ++++++++++++++ 6 files changed, 144 insertions(+), 2 deletions(-) create mode 100644 .envrc create mode 100644 default.nix create mode 100644 flake.lock create mode 100644 flake.nix create mode 100644 shell.nix diff --git a/.envrc b/.envrc new file mode 100644 index 0000000..3550a30 --- /dev/null +++ b/.envrc @@ -0,0 +1 @@ +use flake diff --git a/default.nix b/default.nix new file mode 100644 index 0000000..92e882b --- /dev/null +++ b/default.nix @@ -0,0 +1,18 @@ +{ lib +, python3Packages +}: +python3Packages.buildPythonApplication { + pname = "libdib"; + version = "unstable"; + src = lib.cleanSource ./.; + + format = "pyproject"; + + nativeBuildInputs = with python3Packages; [ + setuptools + setuptools-scm + ]; + propagatedBuildInputs = with python3Packages; [ + sqlalchemy + ]; +} diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..14fcc7c --- /dev/null +++ b/flake.lock @@ -0,0 +1,60 @@ +{ + "nodes": { + "flake-utils": { + "inputs": { + "systems": "systems" + }, + "locked": { + "lastModified": 1731533236, + "narHash": "sha256-l0KFg5HjrsfsO/JpG+r7fRrqm12kzFHyUHqHCVpMMbI=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "11707dc2f618dd54ca8739b309ec4fc024de578b", + "type": "github" + }, + "original": { + "id": "flake-utils", + "type": "indirect" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1749143949, + "narHash": "sha256-QuUtALJpVrPnPeozlUG/y+oIMSLdptHxb3GK6cpSVhA=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "d3d2d80a2191a73d1e86456a751b83aa13085d7d", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixos-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "root": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": "nixpkgs" + } + }, + "systems": { + "locked": { + "lastModified": 1681028828, + "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", + "owner": "nix-systems", + "repo": "default", + "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", + "type": "github" + }, + "original": { + "owner": "nix-systems", + "repo": "default", + "type": "github" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..fe58438 --- /dev/null +++ b/flake.nix @@ -0,0 +1,41 @@ +{ + description = "Dibbler and Worblehat shadow voodoo magic"; + + inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; + + outputs = { self, nixpkgs, flake-utils }: let + inherit (nixpkgs) lib; + + systems = [ + "x86_64-linux" + "aarch64-linux" + "x86_64-darwin" + "aarch64-darwin" + ]; + + forAllSystems = f: lib.genAttrs systems (system: let + pkgs = nixpkgs.legacyPackages.${system}; + in f system pkgs); + in { + packages = forAllSystems (system: pkgs: { + default = self.packages.${system}.libdib; + libdib = pkgs.callPackage ./default.nix { + python3Packages = pkgs.python313Packages; + }; + }); + + overlays = { + default = self.overlays.libdib; + libdib = final: prev: { + inherit (self.packages.${prev.system}) libdib; + }; + }; + + devShells = forAllSystems (system: pkgs: { + default = self.devShells.${system}.libdib; + libdib = pkgs.callPackage ./shell.nix { + python = pkgs.python313; + }; + }); + }; +} diff --git a/pyproject.toml b/pyproject.toml index ac7efac..1604116 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -12,5 +12,11 @@ dependencies = [ ] [build-system] -requires = ["hatchling"] -build-backend = "hatchling.build" +requires = ["setuptools", "setuptools-scm"] +build-backend = "setuptools.build_meta" + +[tool.black] +line-length = 100 + +[tool.ruff] +line-length = 100 diff --git a/shell.nix b/shell.nix new file mode 100644 index 0000000..98008ba --- /dev/null +++ b/shell.nix @@ -0,0 +1,16 @@ +{ + mkShell, + python, + ruff, + uv, +}: + +mkShell { + packages = [ + ruff + uv + (python.withPackages (ps: with ps; [ + sqlalchemy + ])) + ]; +}