diff options
author | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-12-30 22:33:46 +0100 |
---|---|---|
committer | Benedikt Peetz <benedikt.peetz@b-peetz.de> | 2024-12-30 22:33:46 +0100 |
commit | 58eed70ed403d109e0e416f765dd2035db6e393b (patch) | |
tree | be39dcfbfb967acb8cbb67c3035b7e459fd99b21 | |
parent | fix(modules/lf/ctpv/prev/achrive): Remove `arj` (diff) | |
download | nixos-config-58eed70ed403d109e0e416f765dd2035db6e393b.zip |
fix(pkgs/{atuin,ctpv}): Extend instead of replace
This allows me, to still benefit from upstream version updates.
-rw-r--r-- | modules/by-name/at/atuin/module.nix | 2 | ||||
-rw-r--r-- | modules/by-name/lf/lf/ctpv/default.nix | 2 | ||||
-rw-r--r-- | pkgs/by-name/at/atuin-dvorak/package.nix | 23 | ||||
-rw-r--r-- | pkgs/by-name/at/atuin-dvorak/set-dvorak-keybindings.patch (renamed from pkgs/by-name/at/atuin/set-dvorak-keybindings.patch) | 0 | ||||
-rw-r--r-- | pkgs/by-name/at/atuin/package.nix | 94 | ||||
-rw-r--r-- | pkgs/by-name/ct/ctpv-64-types/allow-up-to-64-types.patch (renamed from pkgs/by-name/ct/ctpv/allow-up-to-64-types.patch) | 0 | ||||
-rw-r--r-- | pkgs/by-name/ct/ctpv-64-types/package.nix | 15 | ||||
-rw-r--r-- | pkgs/by-name/ct/ctpv/package.nix | 45 |
8 files changed, 41 insertions, 140 deletions
diff --git a/modules/by-name/at/atuin/module.nix b/modules/by-name/at/atuin/module.nix index 2b9f32cf..604ee4ef 100644 --- a/modules/by-name/at/atuin/module.nix +++ b/modules/by-name/at/atuin/module.nix @@ -1,6 +1,7 @@ { config, lib, + pkgs, ... }: let cfg = config.soispha.programs.atuin; @@ -20,6 +21,7 @@ in { home-manager.users.soispha = { programs.atuin = { enable = true; + package = pkgs.atuin-dvorak; enableZshIntegration = config.soispha.programs.zsh.enable; settings = { key_path = "${config.age.secrets.atuin_encryption_key.path}"; diff --git a/modules/by-name/lf/lf/ctpv/default.nix b/modules/by-name/lf/lf/ctpv/default.nix index e25fa344..3748eca4 100644 --- a/modules/by-name/lf/lf/ctpv/default.nix +++ b/modules/by-name/lf/lf/ctpv/default.nix @@ -151,7 +151,7 @@ in { default = config.home-manager.users.soispha.xdg.dataHome; }; - package = lib.mkPackageOption pkgs "ctpv" {}; + package = lib.mkPackageOption pkgs "ctpv-64-types" {}; # TODO: This is necessary, as the `./prev` dir is imported separately and as such # cannot access the `./helpers.sh` file in it's parent directory. diff --git a/pkgs/by-name/at/atuin-dvorak/package.nix b/pkgs/by-name/at/atuin-dvorak/package.nix new file mode 100644 index 00000000..c651eb75 --- /dev/null +++ b/pkgs/by-name/at/atuin-dvorak/package.nix @@ -0,0 +1,23 @@ +{atuin}: +atuin.overrideAttrs (finalAttrs: previousAttrs: { + pname = previousAttrs.pname + "-dvorak"; + patches = + previousAttrs.patches + ++ [ + ./set-dvorak-keybindings.patch + ]; + + # atuin's default features include 'check-updates', which do not make sense + # for distribution builds. List all other default features. + buildNoDefaultFeatures = true; + buildFeatures = [ + "client" + # "sync" + # "server" + "clipboard" + # "daemon" + ]; + + # The checks don't compile without the `server` feature + doCheck = false; +}) diff --git a/pkgs/by-name/at/atuin/set-dvorak-keybindings.patch b/pkgs/by-name/at/atuin-dvorak/set-dvorak-keybindings.patch index 9ab3700a..9ab3700a 100644 --- a/pkgs/by-name/at/atuin/set-dvorak-keybindings.patch +++ b/pkgs/by-name/at/atuin-dvorak/set-dvorak-keybindings.patch diff --git a/pkgs/by-name/at/atuin/package.nix b/pkgs/by-name/at/atuin/package.nix deleted file mode 100644 index 7f58697a..00000000 --- a/pkgs/by-name/at/atuin/package.nix +++ /dev/null @@ -1,94 +0,0 @@ -# This has been taken from nixpkgs at: -# https://github.com/NixOS/nixpkgs/blob/5785b6bb5eaae44e627d541023034e1601455827/pkgs/by-name/at/atuin/package.nix -# I have just removed some features and added a patch for dvorak input. -{ - lib, - stdenv, - fetchFromGitHub, - installShellFiles, - rustPlatform, - libiconv, - buildPackages, - darwin, - nixosTests, -}: -rustPlatform.buildRustPackage rec { - pname = "atuin"; - version = "18.3.0"; - - src = fetchFromGitHub { - owner = "atuinsh"; - repo = "atuin"; - rev = "v${version}"; - hash = "sha256-Q3UI1IUD5Jz2O4xj3mFM7DqY3lTy3WhWYPa8QjJHTKE="; - }; - - # TODO: unify this to one hash because updater do not support this - cargoHash = - if stdenv.hostPlatform.isLinux - then "sha256-K4Vw/d0ZOROWujWr76I3QvfKefLhXLeFufUrgStAyjQ=" - else "sha256-8NAfE7cGFT64ntNXK9RT0D/MbDJweN7vvsG/KlrY4K4="; - - patches = [ - ./set-dvorak-keybindings.patch - ]; - - # atuin's default features include 'check-updates', which do not make sense - # for distribution builds. List all other default features. - buildNoDefaultFeatures = true; - buildFeatures = [ - "client" - # "sync" - # "server" - "clipboard" - # "daemon" - ]; - - nativeBuildInputs = [installShellFiles]; - - buildInputs = lib.optionals stdenv.hostPlatform.isDarwin [ - libiconv - darwin.apple_sdk_11_0.frameworks.AppKit - darwin.apple_sdk_11_0.frameworks.Security - darwin.apple_sdk_11_0.frameworks.SystemConfiguration - ]; - - preBuild = '' - export PROTOC=${buildPackages.protobuf}/bin/protoc - export PROTOC_INCLUDE="${buildPackages.protobuf}/include"; - ''; - - postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' - installShellCompletion --cmd atuin \ - --bash <($out/bin/atuin gen-completions -s bash) \ - --fish <($out/bin/atuin gen-completions -s fish) \ - --zsh <($out/bin/atuin gen-completions -s zsh) - ''; - - passthru.tests = { - inherit (nixosTests) atuin; - }; - - # The checks don't compile without the `server` feature - doCheck = false; - checkFlags = [ - # tries to make a network access - "--skip=registration" - # No such file or directory (os error 2) - "--skip=sync" - # PermissionDenied (Operation not permitted) - "--skip=change_password" - "--skip=multi_user_test" - "--skip=store::var::tests::build_vars" - # Tries to touch files - "--skip=build_aliases" - ]; - - meta = with lib; { - description = "Replacement for a shell history which records additional commands context with optional encrypted synchronization between machines"; - homepage = "https://github.com/atuinsh/atuin"; - license = licenses.mit; - maintainers = with maintainers; [SuperSandro2000 sciencentistguy _0x4A6F]; - mainProgram = "atuin"; - }; -} diff --git a/pkgs/by-name/ct/ctpv/allow-up-to-64-types.patch b/pkgs/by-name/ct/ctpv-64-types/allow-up-to-64-types.patch index fdecb754..fdecb754 100644 --- a/pkgs/by-name/ct/ctpv/allow-up-to-64-types.patch +++ b/pkgs/by-name/ct/ctpv-64-types/allow-up-to-64-types.patch diff --git a/pkgs/by-name/ct/ctpv-64-types/package.nix b/pkgs/by-name/ct/ctpv-64-types/package.nix new file mode 100644 index 00000000..763b0325 --- /dev/null +++ b/pkgs/by-name/ct/ctpv-64-types/package.nix @@ -0,0 +1,15 @@ +{ctpv}: +ctpv.overrideAttrs (finalAttrs: previousAttrs: { + pname = previousAttrs.pname + "-64-types"; + patches = + (previousAttrs.patches or []) + ++ [ + ./allow-up-to-64-types.patch + ]; + + preFixup = '' + wrapProgram $out/bin/ctpv --set PATH ""; + ''; + + meta.mainProgram = "ctpv"; +}) diff --git a/pkgs/by-name/ct/ctpv/package.nix b/pkgs/by-name/ct/ctpv/package.nix deleted file mode 100644 index 905366bf..00000000 --- a/pkgs/by-name/ct/ctpv/package.nix +++ /dev/null @@ -1,45 +0,0 @@ -{ - lib, - stdenv, - fetchFromGitHub, - makeWrapper, - file, - openssl, -}: -stdenv.mkDerivation rec { - pname = "ctpv"; - version = "1.1-unstable-2024-11-24"; - - src = fetchFromGitHub { - owner = "NikitaIvanovV"; - repo = pname; - rev = "4efa0f976eaf8cb814e0aba4f4f1a1d12ee9262e"; - hash = "sha256-tFBXCUey1lsNAg1mB0iQjDoH70qL8aytE6h9rhHlBe4="; - }; - - nativeBuildInputs = [makeWrapper]; - - buildInputs = [ - file # libmagic - openssl - ]; - - patches = [ - ./allow-up-to-64-types.patch - ]; - - makeFlags = ["PREFIX=$(out)"]; - - preFixup = '' - wrapProgram $out/bin/ctpv \ - --set PATH "${lib.makeBinPath []}"; - ''; - - meta = with lib; { - description = "File previewer for a terminal"; - homepage = "https://github.com/NikitaIvanovV/ctpv"; - license = licenses.mit; - platforms = platforms.linux; - maintainers = [maintainers.wesleyjrz]; - }; -} |