style: format (alejandra)

This commit is contained in:
zerosummed
2025-02-14 21:06:51 +03:00
parent 70021da132
commit e1c484b1c0
14 changed files with 363 additions and 341 deletions

View File

@@ -55,40 +55,33 @@
# This last approach is the one we're taking in this file. To make sure the removal of the
# nested nix/store happens immediately after the installPhase, before any other postInstall
# hooks run, this needs to be run in an override of `mkDerivation` and not in a setup hook.
{
lib,
stdenv,
postgresql,
nix-update-script,
}:
args:
let
buildPostgresqlExtension =
finalAttrs:
{
enableUpdateScript ? true,
...
}@prevAttrs:
{
}: args: let
buildPostgresqlExtension = finalAttrs: {enableUpdateScript ? true, ...} @ prevAttrs: {
passthru =
prevAttrs.passthru or { }
prevAttrs.passthru
or {}
// lib.optionalAttrs enableUpdateScript {
updateScript =
prevAttrs.passthru.updateScript or (nix-update-script (
prevAttrs.passthru.updateScript
or (nix-update-script (
lib.optionalAttrs (lib.hasInfix "unstable" prevAttrs.version) {
extraArgs = [ "--version=branch" ];
extraArgs = ["--version=branch"];
}
));
};
buildInputs = [ postgresql ] ++ prevAttrs.buildInputs or [ ];
buildInputs = [postgresql] ++ prevAttrs.buildInputs or [];
installFlags = [
installFlags =
[
"DESTDIR=${placeholder "out"}"
] ++ prevAttrs.installFlags or [ ];
]
++ prevAttrs.installFlags or [];
postInstall =
''
@@ -144,4 +137,4 @@ let
+ prevAttrs.postInstall or "";
};
in
stdenv.mkDerivation (lib.extends buildPostgresqlExtension (lib.toFunction args))
stdenv.mkDerivation (lib.extends buildPostgresqlExtension (lib.toFunction args))

162
flake.nix
View File

@@ -10,24 +10,31 @@
};
};
outputs = { self, nixpkgs, rust-overlay }:
let
outputs = {
self,
nixpkgs,
rust-overlay,
}: let
lib = nixpkgs.lib;
recursiveUpdate = lib.recursiveUpdate;
supportedSystems = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" ];
supportedSystems = ["x86_64-linux" "aarch64-linux" "x86_64-darwin"];
forSpecSystemsWithPkgs = supportedSystems: pkgOverlays: f:
builtins.foldl' (acc: system:
let
builtins.foldl' (
acc: system: let
pkgs = import nixpkgs {
inherit system;
overlays = pkgOverlays;
};
systemOutputs = f { system = system; pkgs = pkgs; };
systemOutputs = f {
system = system;
pkgs = pkgs;
};
in
recursiveUpdate acc systemOutputs
) {} supportedSystems;
) {}
supportedSystems;
forAllSystemsWithPkgs = pkgOverlays: f: forSpecSystemsWithPkgs supportedSystems pkgOverlays f;
@@ -37,22 +44,20 @@
dotEnv = builtins.getEnv "DOTENV";
minorEnvironment =
if dotEnv != "" then
if builtins.pathExists dotEnv then
parseEnv dotEnv
else
throw "${dotEnv} file not exist"
else
if builtins.pathExists ./.env then
parseEnv ./.env
else
{};
if dotEnv != ""
then
if builtins.pathExists dotEnv
then parseEnv dotEnv
else throw "${dotEnv} file not exist"
else if builtins.pathExists ./.env
then parseEnv ./.env
else {};
in
forAllSystemsWithPkgs [ (import rust-overlay) ] ({ system, pkgs }:
{
packages.${system} =
let
forAllSystemsWithPkgs [(import rust-overlay)] ({
system,
pkgs,
}: {
packages.${system} = let
rust = {
nativeBuildInputs = [
pkgs.pkgsBuildHost.rust-bin.stable."1.81.0".default
@@ -63,8 +68,7 @@
inherit (rust) nativeBuildInputs;
};
};
in
{
in {
nvim-alias = pkgs.callPackage ./package/nvim-alias.nix {};
bolt-unpack = pkgs.callPackage ./package/bolt-unpack.nix {};
nvim-pager = pkgs.callPackage ./package/nvim-pager.nix {};
@@ -81,17 +85,17 @@
};
};
devShells.${system} =
let
devShells.${system} = let
shells = self.devShells.${system};
in
{
in {
default = pkgs.mkShell {
buildInputs = (with self.packages.${system}; [
buildInputs =
(with self.packages.${system}; [
nvim-alias
#prettify-log
nvim-pager
]) ++ (with pkgs; [
])
++ (with pkgs; [
git
jq
yq-go
@@ -99,30 +103,34 @@
]);
# environment
PAGER="${self.packages.${system}.nvim-pager}/bin/pager";
PAGER = "${self.packages.${system}.nvim-pager}/bin/pager";
};
rust =
let
rustToolchain = if builtins.pathExists ./rust-toolchain.toml then
pkgs.pkgsBuildHost.rust-bin.fromRustupToolchainFile ./rust-toolchain.toml
else
pkgs.pkgsBuildHost.rust-bin.stable."1.81.0".default;
rust = let
rustToolchain =
if builtins.pathExists ./rust-toolchain.toml
then pkgs.pkgsBuildHost.rust-bin.fromRustupToolchainFile ./rust-toolchain.toml
else pkgs.pkgsBuildHost.rust-bin.stable."1.81.0".default;
in
shells.default //
(pkgs.mkShell {
shells.default
// (pkgs.mkShell {
nativeBuildInputs = [
rustToolchain
pkgs.pkg-config
];
});
haskell = shells.default // (pkgs.mkShell {
buildInputs = [ pkgs.stack ];
haskell =
shells.default
// (pkgs.mkShell {
buildInputs = [pkgs.stack];
});
};
nixosModules.${system} = {
"preset.default" = { pkgs, modulesPath, ... }: {
"preset.default" = {
pkgs,
modulesPath,
...
}: {
imports = [
(modulesPath + "/profiles/qemu-guest.nix")
];
@@ -144,7 +152,11 @@
"-vga qxl"
];
forwardPorts = [
{ from = "host"; host.port = 40500; guest.port = 22; }
{
from = "host";
host.port = 40500;
guest.port = 22;
}
];
};
@@ -157,30 +169,31 @@
networking.firewall = {
enable = true;
allowedTCPPorts = [ ];
allowedTCPPorts = [];
};
environment = {
defaultPackages = [];
systemPackages = (with pkgs; [
systemPackages =
(with pkgs; [
curl
neovim
yq-go
jq
htop-vim
]) ++ (with self.packages.${system}; [
])
++ (with self.packages.${system}; [
prettify-log
nvim-pager
]);
variables = {
PAGER=with self.packages.${system}; "${nvim-pager}/bin/pager";
PAGER = with self.packages.${system}; "${nvim-pager}/bin/pager";
};
};
system.stateVersion = "24.11";
};
"hardware.hetzner" = { ... }: {
"hardware.hetzner" = {...}: {
boot.loader.grub.device = "/dev/sda";
boot.initrd.availableKernelModules = [
"ata_piix"
@@ -188,13 +201,16 @@
"xen_blkfront"
"vmw_pvscsi"
];
boot.initrd.kernelModules = [ "nvme" ];
fileSystems."/" = { device = "/dev/sda1"; fsType = "ext4"; };
boot.initrd.kernelModules = ["nvme"];
fileSystems."/" = {
device = "/dev/sda1";
fsType = "ext4";
};
};
}) // {
overlays.default =
final: prev: (
};
})
// {
overlays.default = final: prev: (
let
version = "1.6.1";
buildHttpExt = versionSuffix: let
@@ -205,7 +221,8 @@
})) {
postgresql = prev."postgresql_${versionSuffix}";
};
in buildPostgresqlExtension {
in
buildPostgresqlExtension {
pname = "http";
inherit version;
src = prev.fetchFromGitHub {
@@ -214,34 +231,37 @@
rev = "v${version}";
hash = "sha256-C8eqi0q1dnshUAZjIsZFwa5FTYc7vmATF3vv2CReWPM=";
};
nativeBuildInputs = with prev; [ pkg-config curl ];
nativeBuildInputs = with prev; [pkg-config curl];
};
in
{
in {
hectic = self.packages.${prev.system};
postgresql_17 = prev.postgresql_17 // { pkgs = prev.postgresql_17.pkgs // { http = buildHttpExt "17"; }; };
postgresql_16 = prev.postgresql_16 // { pkgs = prev.postgresql_16.pkgs // { http = buildHttpExt "16"; }; };
postgresql_15 = prev.postgresql_15 // { pkgs = prev.postgresql_15.pkgs // { http = buildHttpExt "15"; }; };
postgresql_14 = prev.postgresql_14 // { pkgs = prev.postgresql_14.pkgs // { http = buildHttpExt "14"; }; };
});
postgresql_17 = prev.postgresql_17 // {pkgs = prev.postgresql_17.pkgs // {http = buildHttpExt "17";};};
postgresql_16 = prev.postgresql_16 // {pkgs = prev.postgresql_16.pkgs // {http = buildHttpExt "16";};};
postgresql_15 = prev.postgresql_15 // {pkgs = prev.postgresql_15.pkgs // {http = buildHttpExt "15";};};
postgresql_14 = prev.postgresql_14 // {pkgs = prev.postgresql_14.pkgs // {http = buildHttpExt "14";};};
}
);
lib = {
# -- For all systems --
inherit dotEnv minorEnvironment parseEnv forAllSystemsWithPkgs forSpecSystemsWithPkgs;
makeEnvironment = envVars:
builtins.listToAttrs
(map (name: { inherit name; value = self.lib.getEnv name; }) envVars);
(map (name: {
inherit name;
value = self.lib.getEnv name;
})
envVars);
# -- Env processing --
getEnv = varName: let
var = builtins.getEnv varName;
in
if var != "" then
var
else if minorEnvironment ? varName then
minorEnvironment."${varName}"
else
throw (envErrorMessage varName);
if var != ""
then var
else if minorEnvironment ? varName
then minorEnvironment."${varName}"
else throw (envErrorMessage varName);
# -- Cargo.toml --
cargoToml = src: (builtins.fromTOML (builtins.readFile "${src}/Cargo.toml"));

View File

@@ -1,5 +1,4 @@
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "unpack" ''
#!/usr/bin/env sh
set -e

View File

@@ -1,4 +1,4 @@
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "colorize" ''
awk '
BEGIN {

View File

@@ -1,5 +1,5 @@
# FIXME: very unstable (on every request opens pager) but works somehow
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "gh-tl" ''
set -euo pipefail

View File

@@ -1,4 +1,4 @@
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "migration-name" ''
curl --silent https://raw.githubusercontent.com/dwyl/english-words/master/words.txt | shuf -n2 | tr '\n' '_' | sed 's/_$//'
curl --silent https://raw.githubusercontent.com/dwyl/english-words/master/words.txt | shuf -n2 | tr '\n' '_' | sed 's/_$//'
''

View File

@@ -1,6 +1,6 @@
# necessary to load every time .nvimrc
# makes some magic to shading nvim but still uses nvim that shaded
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "nvim" ''
# Source .env file
if [ -f .env ]; then

View File

@@ -1,4 +1,4 @@
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "pager" ''
nvim -R --clean -c 'set buftype=nofile' -c 'nnoremap q :q!<CR>' -c 'set nowrap' \
-c 'set runtimepath^=${pkgs.vimPlugins.vim-plugin-AnsiEsc}' \

View File

@@ -1,9 +1,13 @@
{ cargoToml, nativeBuildInputs, pkgs, ... }:
let
{
cargoToml,
nativeBuildInputs,
pkgs,
...
}: let
src = ./.;
cargo = cargoToml src;
in
pkgs.rustPlatform.buildRustPackage {
pkgs.rustPlatform.buildRustPackage {
pname = cargo.package.name;
version = cargo.package.version;
@@ -12,4 +16,4 @@ pkgs.rustPlatform.buildRustPackage {
cargoLock.lockFile = ./Cargo.lock;
doCheck = true;
}
}

View File

@@ -1,9 +1,13 @@
{ cargoToml, nativeBuildInputs, pkgs, ... }:
let
{
cargoToml,
nativeBuildInputs,
pkgs,
...
}: let
src = ./.;
cargo = cargoToml src;
in
pkgs.rustPlatform.buildRustPackage {
pkgs.rustPlatform.buildRustPackage {
pname = cargo.package.name;
version = cargo.package.version;
@@ -12,4 +16,4 @@ pkgs.rustPlatform.buildRustPackage {
cargoLock.lockFile = ./Cargo.lock;
doCheck = true;
}
}

View File

@@ -1,9 +1,13 @@
{ cargoToml, nativeBuildInputs, pkgs, ... }:
let
{
cargoToml,
nativeBuildInputs,
pkgs,
...
}: let
src = ./.;
cargo = cargoToml src;
in
pkgs.rustPlatform.buildRustPackage {
pkgs.rustPlatform.buildRustPackage {
pname = cargo.package.name;
version = cargo.package.version;
@@ -12,4 +16,4 @@ pkgs.rustPlatform.buildRustPackage {
cargoLock.lockFile = ./Cargo.lock;
doCheck = true;
}
}

View File

@@ -1,7 +1,6 @@
{ pkgs, ... }:
let
{pkgs, ...}: let
name = "printobstacle";
in
pkgs.writeShellScriptBin "${name}" ''
pkgs.writeShellScriptBin "${name}" ''
printf "%s%s%s\n" "''${RED}" "$*" "''${RESET}"
''
''

View File

@@ -1,7 +1,6 @@
{ pkgs, ... }:
let
{pkgs, ...}: let
name = "printprogress";
in
pkgs.writeShellScriptBin "${name}" ''
pkgs.writeShellScriptBin "${name}" ''
printf "%s%s%s\n" "''${YELLOW}" "$*" "''${RESET}"
''
''

View File

@@ -1,14 +1,14 @@
{ pkgs, ... }:
{pkgs, ...}:
pkgs.writeShellScriptBin "supabase" ''
# Get the root of the repository
GIT_ROOT="$(git rev-parse --show-toplevel 2>/dev/null || echo .)"
# Get the root of the repository
GIT_ROOT="$(git rev-parse --show-toplevel 2>/dev/null || echo .)"
# Source .env from root of the repo if it exists
if [ -f "$GIT_ROOT/.env" ]; then
# Source .env from root of the repo if it exists
if [ -f "$GIT_ROOT/.env" ]; then
set -a
. "$GIT_ROOT/.env"
set +a
fi
fi
${pkgs.supabase-cli}/bin/supabase --workdir "$GIT_ROOT/web" $@
${pkgs.supabase-cli}/bin/supabase --workdir "$GIT_ROOT/web" $@
''