Merge pull request 'base nix-packages on an overlay' (#81) from use-overlay-again into main
Some checks failed
Some checks failed
Reviewed-on: #81
This commit is contained in:
commit
b0ad8a7971
3 changed files with 211 additions and 81 deletions
65
default.nix
65
default.nix
|
@ -8,9 +8,72 @@
|
|||
{pkgs ? import <nixpkgs> {}}: let
|
||||
lib = import ./lib {inherit pkgs;}; # functions
|
||||
flake = (lib.importFlake {inherit (pkgs) system;}).defaultNix;
|
||||
pkgsWithOverlay = pkgs.appendOverlays [(import ./overlay.nix pkgs.system)];
|
||||
in
|
||||
{
|
||||
# The `lib`, `modules`, and `overlay` names are special
|
||||
inherit (flake) lib modules overlays;
|
||||
}
|
||||
// (flake.packages.${pkgs.system})
|
||||
// {
|
||||
inherit
|
||||
(pkgsWithOverlay)
|
||||
akkoma
|
||||
pleroma-fe
|
||||
admin-fe
|
||||
emoji-lotte
|
||||
emoji-volpeon-blobfox
|
||||
emoji-volpeon-blobfox-flip
|
||||
emoji-volpeon-bunhd
|
||||
emoji-volpeon-bunhd-flip
|
||||
emoji-volpeon-drgn
|
||||
emoji-volpeon-fox
|
||||
emoji-volpeon-gphn
|
||||
emoji-volpeon-raccoon
|
||||
emoji-volpeon-vlpn
|
||||
emoji-caro
|
||||
lotte-art
|
||||
alco-sans
|
||||
constructium
|
||||
fairfax
|
||||
fairfax-hd
|
||||
kreative-square
|
||||
nasin-nanpa
|
||||
matrix-media-repo
|
||||
mautrix-discord
|
||||
mautrix-whatsapp
|
||||
mautrix-signal
|
||||
mautrix-telegram
|
||||
python-mautrix
|
||||
python-tulir-telethon
|
||||
papermc
|
||||
python-plover-stroke
|
||||
python-rtf-tokenize
|
||||
plover
|
||||
plover-plugins-manager
|
||||
python-simplefuzzyset
|
||||
plover-plugin-emoji
|
||||
plover-plugin-tapey-tape
|
||||
plover-plugin-yaml-dictionary
|
||||
plover-plugin-machine-hid
|
||||
plover-plugin-rkb1-hid
|
||||
plover-dict-didoesdigital
|
||||
miifox-net
|
||||
old-homepage
|
||||
python-instagram
|
||||
element-web
|
||||
mautrix-cleanup
|
||||
woodpecker-agent
|
||||
woodpecker-cli
|
||||
woodpecker-frontend
|
||||
woodpecker-server
|
||||
hydra
|
||||
hydra-unstable
|
||||
;
|
||||
}
|
||||
// (
|
||||
if pkgs.system == "riscv64-linux"
|
||||
then {
|
||||
inherit (pkgsWithOverlay) vf2Kernel vf2KernelPackages;
|
||||
}
|
||||
else {}
|
||||
)
|
||||
|
|
131
flake.nix
131
flake.nix
|
@ -29,12 +29,11 @@
|
|||
};
|
||||
|
||||
outputs = {
|
||||
self,
|
||||
nixpkgs,
|
||||
flake-utils,
|
||||
gomod2nix,
|
||||
hydra,
|
||||
...
|
||||
} @ inputs:
|
||||
}:
|
||||
flake-utils.lib.eachSystem ["aarch64-darwin" "aarch64-linux" "x86_64-darwin" "x86_64-linux" "riscv64-linux"] (
|
||||
system: let
|
||||
pkgs = import nixpkgs {
|
||||
|
@ -42,12 +41,14 @@
|
|||
config.allowUnfree = true;
|
||||
config.allowUnsupportedSystem = true;
|
||||
overlays = [
|
||||
gomod2nix.overlays.default
|
||||
self.overlays.${system}.default
|
||||
];
|
||||
};
|
||||
in rec {
|
||||
formatter = pkgs.alejandra;
|
||||
|
||||
overlays.default = import ./overlay.nix system;
|
||||
|
||||
devShells.default = pkgs.mkShell {
|
||||
nativeBuildInputs = with pkgs; [
|
||||
statix
|
||||
|
@ -57,77 +58,69 @@
|
|||
|
||||
packages =
|
||||
{
|
||||
akkoma = pkgs.callPackage ./akkoma {};
|
||||
pleroma-fe = pkgs.callPackage ./akkoma/pleroma-fe {};
|
||||
admin-fe = pkgs.callPackage ./akkoma/admin-fe {};
|
||||
emoji-lotte = pkgs.callPackage ./art/emoji/lotte {};
|
||||
emoji-volpeon-blobfox = pkgs.callPackage ./art/emoji/volpeon/blobfox.nix {};
|
||||
emoji-volpeon-blobfox-flip = pkgs.callPackage ./art/emoji/volpeon/blobfox_flip.nix {};
|
||||
emoji-volpeon-bunhd = pkgs.callPackage ./art/emoji/volpeon/bunhd.nix {};
|
||||
emoji-volpeon-bunhd-flip = pkgs.callPackage ./art/emoji/volpeon/bunhd_flip.nix {};
|
||||
emoji-volpeon-drgn = pkgs.callPackage ./art/emoji/volpeon/drgn.nix {};
|
||||
emoji-volpeon-fox = pkgs.callPackage ./art/emoji/volpeon/fox.nix {};
|
||||
emoji-volpeon-gphn = pkgs.callPackage ./art/emoji/volpeon/gphn.nix {};
|
||||
emoji-volpeon-raccoon = pkgs.callPackage ./art/emoji/volpeon/raccoon.nix {};
|
||||
emoji-volpeon-vlpn = pkgs.callPackage ./art/emoji/volpeon/vlpn.nix {};
|
||||
emoji-caro = pkgs.callPackage ./art/emoji/caro {};
|
||||
lotte-art = pkgs.callPackage ./art/lotte {};
|
||||
alco-sans = pkgs.callPackage ./fonts/kreative/alco-sans.nix {};
|
||||
constructium = pkgs.callPackage ./fonts/kreative/constructium.nix {};
|
||||
fairfax = pkgs.callPackage ./fonts/kreative/fairfax.nix {};
|
||||
fairfax-hd = pkgs.callPackage ./fonts/kreative/fairfax-hd.nix {};
|
||||
kreative-square = pkgs.callPackage ./fonts/kreative/kreative-square.nix {};
|
||||
nasin-nanpa = pkgs.callPackage ./fonts/nasin-nanpa {};
|
||||
matrix-media-repo = pkgs.callPackage ./matrix/matrix-media-repo {};
|
||||
mautrix-discord = pkgs.callPackage ./matrix/mautrix-discord {};
|
||||
mautrix-whatsapp = pkgs.callPackage ./matrix/mautrix-whatsapp {};
|
||||
mautrix-signal = pkgs.callPackage ./matrix/mautrix-signal {};
|
||||
mautrix-telegram = pkgs.callPackage ./matrix/mautrix-telegram {};
|
||||
python-mautrix = pkgs.python3Packages.callPackage ./python/mautrix.nix {};
|
||||
python-tulir-telethon = pkgs.python3Packages.callPackage ./python/tulir-telethon.nix {};
|
||||
papermc = pkgs.callPackage ./minecraft/papermc {};
|
||||
python-plover-stroke = pkgs.python3Packages.callPackage ./plover/plover-stroke.nix {};
|
||||
python-rtf-tokenize = pkgs.python3Packages.callPackage ./python/rtf-tokenize.nix {};
|
||||
plover = pkgs.python3Packages.callPackage ./plover/plover {};
|
||||
plover-plugins-manager = pkgs.python3Packages.callPackage ./plover/plover-plugins-manager.nix {};
|
||||
python-simplefuzzyset = pkgs.python3Packages.callPackage ./python/simplefuzzyset.nix {};
|
||||
plover-plugin-emoji = pkgs.python3Packages.callPackage ./plover/plover-emoji.nix {};
|
||||
plover-plugin-tapey-tape = pkgs.python3Packages.callPackage ./plover/plover-tapey-tape.nix {};
|
||||
plover-plugin-yaml-dictionary = pkgs.python3Packages.callPackage ./plover/plover-yaml-dictionary.nix {};
|
||||
plover-plugin-machine-hid = pkgs.python3Packages.callPackage ./plover/plover-machine-hid.nix {};
|
||||
plover-plugin-rkb1-hid = pkgs.python3Packages.callPackage ./plover/plover-rkb1-hid.nix {};
|
||||
plover-dict-didoesdigital = pkgs.callPackage ./plover/didoesdigital-dictionary.nix {};
|
||||
miifox-net = pkgs.python3Packages.callPackage ./web/miifox-net.nix {};
|
||||
old-homepage = pkgs.callPackage ./web/old-homepage.nix {};
|
||||
python-instagram = pkgs.python3Packages.callPackage ./python/instagram.nix {};
|
||||
inherit (inputs.attic.packages.${pkgs.system}) attic attic-client attic-server;
|
||||
element-web = pkgs.callPackage ./matrix/element-web {};
|
||||
mautrix-cleanup = inputs.mautrix-cleanup.packages.${pkgs.system}.default;
|
||||
woodpecker-agent = pkgs.callPackage ./ci/woodpecker/agent.nix {};
|
||||
woodpecker-cli = pkgs.callPackage ./ci/woodpecker/cli.nix {};
|
||||
woodpecker-frontend = pkgs.callPackage ./ci/woodpecker/frontend.nix {};
|
||||
woodpecker-server = pkgs.callPackage ./ci/woodpecker/server.nix {};
|
||||
inherit
|
||||
(pkgs)
|
||||
akkoma
|
||||
pleroma-fe
|
||||
admin-fe
|
||||
emoji-lotte
|
||||
emoji-volpeon-blobfox
|
||||
emoji-volpeon-blobfox-flip
|
||||
emoji-volpeon-bunhd
|
||||
emoji-volpeon-bunhd-flip
|
||||
emoji-volpeon-drgn
|
||||
emoji-volpeon-fox
|
||||
emoji-volpeon-gphn
|
||||
emoji-volpeon-raccoon
|
||||
emoji-volpeon-vlpn
|
||||
emoji-caro
|
||||
lotte-art
|
||||
alco-sans
|
||||
constructium
|
||||
fairfax
|
||||
fairfax-hd
|
||||
kreative-square
|
||||
nasin-nanpa
|
||||
matrix-media-repo
|
||||
mautrix-discord
|
||||
mautrix-whatsapp
|
||||
mautrix-signal
|
||||
mautrix-telegram
|
||||
python-mautrix
|
||||
python-tulir-telethon
|
||||
papermc
|
||||
python-plover-stroke
|
||||
python-rtf-tokenize
|
||||
plover
|
||||
plover-plugins-manager
|
||||
python-simplefuzzyset
|
||||
plover-plugin-emoji
|
||||
plover-plugin-tapey-tape
|
||||
plover-plugin-yaml-dictionary
|
||||
plover-plugin-machine-hid
|
||||
plover-plugin-rkb1-hid
|
||||
plover-dict-didoesdigital
|
||||
miifox-net
|
||||
old-homepage
|
||||
python-instagram
|
||||
element-web
|
||||
mautrix-cleanup
|
||||
woodpecker-agent
|
||||
woodpecker-cli
|
||||
woodpecker-frontend
|
||||
woodpecker-server
|
||||
hydra
|
||||
hydra-unstable
|
||||
;
|
||||
}
|
||||
// (
|
||||
if system == "riscv64-linux"
|
||||
then rec {
|
||||
vf2Kernel = pkgs.callPackage ./linux/vf2 {kernelPatches = [];};
|
||||
vf2KernelPackages = pkgs.linuxPackagesFor vf2Kernel;
|
||||
then {
|
||||
inherit (pkgs) vf2Kernel vf2KernelPackages;
|
||||
}
|
||||
else {}
|
||||
) // (if system == "aarch64-linux" || system == "x86_64-linux" then {
|
||||
hydra = hydra.packages.${system}.hydra.overrideAttrs (super: {
|
||||
doCheck = false;
|
||||
patches = (super.patches or []) ++ [
|
||||
./ci/hydra/add-ca-support.patch
|
||||
./ci/hydra/add-gitea-push-hook.patch
|
||||
./ci/hydra/jobset-inputs-for-flakes.patch
|
||||
./ci/hydra/remove-hydra-size-limit.patch
|
||||
];
|
||||
});
|
||||
} else {});
|
||||
);
|
||||
|
||||
overlays = import ./overlays;
|
||||
modules = import ./modules;
|
||||
lib = import ./lib {inherit pkgs;};
|
||||
|
||||
|
|
98
overlay.nix
98
overlay.nix
|
@ -1,15 +1,89 @@
|
|||
# You can use this file as a nixpkgs overlay. This is useful in the
|
||||
# You can use this file as a nixself overlay. This is useful in the
|
||||
# case where you don't want to add the whole NUR namespace to your
|
||||
# configuration.
|
||||
self: super: let
|
||||
isReserved = n: n == "lib" || n == "overlays" || n == "modules";
|
||||
nameValuePair = n: v: {
|
||||
name = n;
|
||||
value = v;
|
||||
};
|
||||
nurAttrs = import ./default.nix {pkgs = super;};
|
||||
system: self: super: let
|
||||
lib = import ./lib {pkgs = super;}; # functions
|
||||
flake = (lib.importFlake {inherit system;}).defaultNix;
|
||||
|
||||
getFlakeOverlay = flakeName: overlay: self: super: let
|
||||
lib = import ./lib {pkgs = super;};
|
||||
flake = (lib.importFlake {inherit system;}).defaultNix;
|
||||
in
|
||||
builtins.listToAttrs
|
||||
(map (n: nameValuePair n nurAttrs.${n})
|
||||
(builtins.filter (n: !isReserved n)
|
||||
(builtins.attrNames nurAttrs)))
|
||||
flake.inputs.${flakeName}.outputs.overlays.${overlay} self super;
|
||||
|
||||
riscv-overlay = self: super: {
|
||||
vf2Kernel = self.callPackage ./linux/vf2 {kernelPatches = [];};
|
||||
vf2KernelPackages = super.linuxPackagesFor self.vf2Kernel;
|
||||
};
|
||||
|
||||
overlays = [
|
||||
(getFlakeOverlay "attic" "default")
|
||||
(getFlakeOverlay "hydra" "default")
|
||||
(getFlakeOverlay "gomod2nix" "default")
|
||||
(self: super: {
|
||||
akkoma = self.callPackage ./akkoma {};
|
||||
pleroma-fe = self.callPackage ./akkoma/pleroma-fe {};
|
||||
admin-fe = self.callPackage ./akkoma/admin-fe {};
|
||||
emoji-lotte = self.callPackage ./art/emoji/lotte {};
|
||||
emoji-volpeon-blobfox = self.callPackage ./art/emoji/volpeon/blobfox.nix {};
|
||||
emoji-volpeon-blobfox-flip = self.callPackage ./art/emoji/volpeon/blobfox_flip.nix {};
|
||||
emoji-volpeon-bunhd = self.callPackage ./art/emoji/volpeon/bunhd.nix {};
|
||||
emoji-volpeon-bunhd-flip = self.callPackage ./art/emoji/volpeon/bunhd_flip.nix {};
|
||||
emoji-volpeon-drgn = self.callPackage ./art/emoji/volpeon/drgn.nix {};
|
||||
emoji-volpeon-fox = self.callPackage ./art/emoji/volpeon/fox.nix {};
|
||||
emoji-volpeon-gphn = self.callPackage ./art/emoji/volpeon/gphn.nix {};
|
||||
emoji-volpeon-raccoon = self.callPackage ./art/emoji/volpeon/raccoon.nix {};
|
||||
emoji-volpeon-vlpn = self.callPackage ./art/emoji/volpeon/vlpn.nix {};
|
||||
emoji-caro = self.callPackage ./art/emoji/caro {};
|
||||
lotte-art = self.callPackage ./art/lotte {};
|
||||
alco-sans = self.callPackage ./fonts/kreative/alco-sans.nix {};
|
||||
constructium = self.callPackage ./fonts/kreative/constructium.nix {};
|
||||
fairfax = self.callPackage ./fonts/kreative/fairfax.nix {};
|
||||
fairfax-hd = self.callPackage ./fonts/kreative/fairfax-hd.nix {};
|
||||
kreative-square = self.callPackage ./fonts/kreative/kreative-square.nix {};
|
||||
nasin-nanpa = self.callPackage ./fonts/nasin-nanpa {};
|
||||
matrix-media-repo = self.callPackage ./matrix/matrix-media-repo {};
|
||||
mautrix-discord = self.callPackage ./matrix/mautrix-discord {};
|
||||
mautrix-whatsapp = self.callPackage ./matrix/mautrix-whatsapp {};
|
||||
mautrix-signal = self.callPackage ./matrix/mautrix-signal {};
|
||||
mautrix-telegram = self.callPackage ./matrix/mautrix-telegram {};
|
||||
python-mautrix = self.python3Packages.callPackage ./python/mautrix.nix {};
|
||||
python-tulir-telethon = self.python3Packages.callPackage ./python/tulir-telethon.nix {};
|
||||
papermc = self.callPackage ./minecraft/papermc {};
|
||||
python-plover-stroke = self.python3Packages.callPackage ./plover/plover-stroke.nix {};
|
||||
python-rtf-tokenize = self.python3Packages.callPackage ./python/rtf-tokenize.nix {};
|
||||
plover = self.python3Packages.callPackage ./plover/plover {};
|
||||
plover-plugins-manager = self.python3Packages.callPackage ./plover/plover-plugins-manager.nix {};
|
||||
python-simplefuzzyset = self.python3Packages.callPackage ./python/simplefuzzyset.nix {};
|
||||
plover-plugin-emoji = self.python3Packages.callPackage ./plover/plover-emoji.nix {};
|
||||
plover-plugin-tapey-tape = self.python3Packages.callPackage ./plover/plover-tapey-tape.nix {};
|
||||
plover-plugin-yaml-dictionary = self.python3Packages.callPackage ./plover/plover-yaml-dictionary.nix {};
|
||||
plover-plugin-machine-hid = self.python3Packages.callPackage ./plover/plover-machine-hid.nix {};
|
||||
plover-plugin-rkb1-hid = self.python3Packages.callPackage ./plover/plover-rkb1-hid.nix {};
|
||||
plover-dict-didoesdigital = self.callPackage ./plover/didoesdigital-dictionary.nix {};
|
||||
miifox-net = self.python3Packages.callPackage ./web/miifox-net.nix {};
|
||||
old-homepage = self.callPackage ./web/old-homepage.nix {};
|
||||
python-instagram = self.python3Packages.callPackage ./python/instagram.nix {};
|
||||
element-web = self.callPackage ./matrix/element-web {};
|
||||
mautrix-cleanup = flake.inputs.mautrix-cleanup.packages.${system}.default;
|
||||
woodpecker-agent = self.callPackage ./ci/woodpecker/agent.nix {};
|
||||
woodpecker-cli = self.callPackage ./ci/woodpecker/cli.nix {};
|
||||
woodpecker-frontend = self.callPackage ./ci/woodpecker/frontend.nix {};
|
||||
woodpecker-server = self.callPackage ./ci/woodpecker/server.nix {};
|
||||
hydra = super.hydra.overrideAttrs (super: {
|
||||
doCheck = false;
|
||||
patches =
|
||||
(super.patches or [])
|
||||
++ [
|
||||
./ci/hydra/add-ca-support.patch
|
||||
./ci/hydra/add-gitea-push-hook.patch
|
||||
./ci/hydra/jobset-inputs-for-flakes.patch
|
||||
./ci/hydra/remove-hydra-size-limit.patch
|
||||
];
|
||||
});
|
||||
hydra-unstable = self.hydra;
|
||||
})
|
||||
riscv-overlay
|
||||
];
|
||||
in
|
||||
super.lib.composeManyExtensions overlays self super
|
||||
|
|
Reference in a new issue