dotfiles/flake.nix

104 lines
3.2 KiB
Nix
Raw Permalink Normal View History

2023-04-25 19:21:03 +00:00
{
description = "Your new nix config";
inputs = {
# Nixpkgs
2023-04-25 21:15:52 +00:00
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; # based unstable packages
nixpkgs-master.url = "github:nixos/nixpkgs/master"; # cringe stable packages
2023-04-25 19:21:03 +00:00
# Home manager
2023-04-25 20:10:57 +00:00
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-04-25 19:21:03 +00:00
2023-04-25 21:15:52 +00:00
# neovim-flake
neovim-flake = {
2023-07-24 17:33:10 +00:00
url = "github:notashelf/neovim-flake";
2023-04-25 21:15:52 +00:00
inputs.nixpkgs.follows = "nixpkgs";
};
2023-04-25 21:59:40 +00:00
# arrpc
arrpc = {
url = "github:notashelf/arrpc-flake";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-08-09 13:49:06 +00:00
# hyprland
hyprland.url = "github:hyprwm/Hyprland";
2023-04-25 19:21:03 +00:00
};
outputs = {
self,
nixpkgs,
home-manager,
2023-08-09 13:49:06 +00:00
hyprland,
2023-04-25 19:21:03 +00:00
...
} @ inputs: let
inherit (self) outputs;
forAllSystems = nixpkgs.lib.genAttrs [
"aarch64-linux"
"i686-linux"
"x86_64-linux"
"aarch64-darwin"
"x86_64-darwin"
];
in rec {
# Your custom packages
# Acessible through 'nix build', 'nix shell', etc
packages = forAllSystems (
system: let
pkgs = nixpkgs.legacyPackages.${system};
in
import ./pkgs {inherit pkgs;}
);
# Devshell for bootstrapping
# Acessible through 'nix develop' or 'nix-shell' (legacy)
devShells = forAllSystems (
system: let
pkgs = nixpkgs.legacyPackages.${system};
in
import ./shell.nix {inherit pkgs;}
);
# Your custom packages and modifications, exported as overlays
2023-04-25 20:10:57 +00:00
# overlays = import ./overlays {inherit inputs;}; # TODO: only use overlays when you understand what tthey do
2023-04-25 19:21:03 +00:00
# Reusable nixos modules you might want to export
# These are usually stuff you would upstream into nixpkgs
2023-04-25 20:10:57 +00:00
# nixosModules = import ./modules/public/nixos;
2023-04-25 19:21:03 +00:00
# Reusable home-manager modules you might want to export
# These are usually stuff you would upstream into home-manager
2023-04-25 20:10:57 +00:00
# homeManagerModules = import ./modules/public/home-manager;
2023-04-25 19:21:03 +00:00
# NixOS configuration entrypoint
# Available through 'nixos-rebuild --flake .#your-hostname'
2023-04-25 20:10:57 +00:00
nixosConfigurations = import ./hosts {inherit nixpkgs self outputs;};
2023-04-25 19:21:03 +00:00
# Standalone home-manager configuration entrypoint
# Available through 'home-manager --flake .#your-username@your-hostname'
homeConfigurations = {
"floppydisk@nixbox" = home-manager.lib.homeManagerConfiguration {
pkgs = nixpkgs.legacyPackages.x86_64-linux; # Home-manager requires 'pkgs' instance
extraSpecialArgs = {inherit inputs outputs;};
modules = [
2023-08-09 13:49:06 +00:00
hyprland.homeManagerModules.default
{wayland.windowManager.hyprland.enable = true;}
2023-04-25 19:21:03 +00:00
# > Our main home-manager configuration file <
2023-04-25 20:10:57 +00:00
./homes/floppydisk
2023-04-25 19:21:03 +00:00
];
};
2023-04-26 01:16:53 +00:00
"floppydisk@nixpad" = home-manager.lib.homeManagerConfiguration {
pkgs = nixpkgs.legacyPackages.x86_64-linux; # Home-manager requires 'pkgs' instance
extraSpecialArgs = {inherit inputs outputs;};
modules = [
hyprland.homeManagerModules.default
{wayland.windowManager.hyprland.enable = true;}
2023-04-26 01:16:53 +00:00
# > Our main home-manager configuration file <
./homes/floppydisk
];
};
2023-04-25 19:21:03 +00:00
};
};
}