From f2ae35d4f9230887d22d6d98df8bf05d4e49e056 Mon Sep 17 00:00:00 2001 From: revol-xut Date: Tue, 14 Nov 2023 21:46:15 +0100 Subject: [PATCH] adding nix packaging --- .gitignore | 2 +- derivation.nix | 23 ++++++++++++++ flake.lock | 85 ++++++++++++++++++++++++++++++++++++++++++++++++++ flake.nix | 36 +++++++++++++++++++++ 4 files changed, 145 insertions(+), 1 deletion(-) create mode 100644 derivation.nix create mode 100644 flake.lock create mode 100644 flake.nix diff --git a/.gitignore b/.gitignore index b2bf095..efa62cb 100644 --- a/.gitignore +++ b/.gitignore @@ -29,4 +29,4 @@ pnpm-debug.log* # macOS-specific files .DS_Store - +result diff --git a/derivation.nix b/derivation.nix new file mode 100644 index 0000000..36a2497 --- /dev/null +++ b/derivation.nix @@ -0,0 +1,23 @@ +{ domain, mkPnpmPackage, pkg-config, vips, nodePackages_latest}: + +mkPnpmPackage { + src = ./.; + + installInPlace = true; + + postPatch = '' + substituteInPlace ascii.config.ts \ + --replace 'ascii.coffee' '${domain}' + ''; + + script = "build"; + + nativeBuildInputs = [pkg-config vips nodePackages_latest.pnpm]; + buildInputs = [pkg-config vips nodePackages_latest.pnpm]; + + + installPhase = '' + mkdir -p $out/bin + cp -r ./dist/* $out/bin/ + ''; +} diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..d4f9960 --- /dev/null +++ b/flake.lock @@ -0,0 +1,85 @@ +{ + "nodes": { + "flake-utils": { + "inputs": { + "systems": "systems" + }, + "locked": { + "lastModified": 1694529238, + "narHash": "sha256-zsNZZGTGnMOf9YpHKJqMSsa0dXbfmxeoJ7xHlrt+xmY=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "ff7b65b44d01cf9ba6a71320833626af21126384", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "flake-utils", + "type": "github" + } + }, + "nixpkgs": { + "locked": { + "lastModified": 1699781429, + "narHash": "sha256-UYefjidASiLORAjIvVsUHG6WBtRhM67kTjEY4XfZOFs=", + "owner": "NixOS", + "repo": "nixpkgs", + "rev": "e44462d6021bfe23dfb24b775cc7c390844f773d", + "type": "github" + }, + "original": { + "owner": "NixOS", + "ref": "nixos-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "pnpm2nix": { + "inputs": { + "flake-utils": [ + "flake-utils" + ], + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1699849420, + "narHash": "sha256-AV6tWNHNeMpjNkX/bXF3yBhfnw4gwkwAhbKlPOLfyFQ=", + "owner": "nzbr", + "repo": "pnpm2nix-nzbr", + "rev": "8159ff2aa5ebe90c3397c3a7ceccec9a9c2a0073", + "type": "github" + }, + "original": { + "owner": "nzbr", + "repo": "pnpm2nix-nzbr", + "type": "github" + } + }, + "root": { + "inputs": { + "flake-utils": "flake-utils", + "nixpkgs": "nixpkgs", + "pnpm2nix": "pnpm2nix" + } + }, + "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..8f6a9bb --- /dev/null +++ b/flake.nix @@ -0,0 +1,36 @@ +{ + inputs = { + nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; + pnpm2nix = { + url = "github:nzbr/pnpm2nix-nzbr"; + inputs.nixpkgs.follows = "nixpkgs"; + inputs.flake-utils.follows = "flake-utils"; + }; + + flake-utils.url = "github:numtide/flake-utils"; + }; + + outputs = { self, nixpkgs, pnpm2nix, flake-utils, ... }: + flake-utils.lib.eachDefaultSystem + (system: + let + pkgs = nixpkgs.legacyPackages.${system}; + package-ascii-coffee = pkgs.callPackage ./derivation.nix { + domain = "ascii.coffee"; + mkPnpmPackage = pnpm2nix.packages."${system}".mkPnpmPackage; + }; + in + rec { + checks = packages; + packages = { + ascii-coffee-website = package-ascii-coffee; + default = package-ascii-coffee; + }; + } + ) // { + overlays.default = final: prev: { + inherit (self.packages.${prev.system}) + ascii-coffee-website; + }; + }; +}