Now Emacs works on the Macbook
This commit is contained in:
parent
b4d239d34b
commit
3f39ace857
9 changed files with 158 additions and 127 deletions
235
flake.nix
235
flake.nix
|
@ -63,132 +63,133 @@
|
||||||
, ...
|
, ...
|
||||||
} @ inputs:
|
} @ inputs:
|
||||||
|
|
||||||
digga.lib.mkFlake
|
digga.lib.mkFlake
|
||||||
{
|
{
|
||||||
inherit self inputs;
|
inherit self inputs;
|
||||||
|
|
||||||
channelsConfig = { allowUnfree = true; };
|
channelsConfig = { allowUnfree = true; };
|
||||||
|
|
||||||
channels =
|
channels =
|
||||||
let
|
let
|
||||||
commonOverlays = [
|
commonOverlays = [
|
||||||
digga.overlays.patchedNix
|
digga.overlays.patchedNix
|
||||||
nur.overlay
|
nur.overlay
|
||||||
emacs-overlay.overlay
|
emacs-overlay.overlay
|
||||||
nvfetcher.overlay
|
nvfetcher.overlay
|
||||||
deploy.overlay
|
deploy.overlay
|
||||||
nixpkgs-wayland.overlay
|
nixpkgs-wayland.overlay
|
||||||
./pkgs/default.nix
|
./pkgs/default.nix
|
||||||
];
|
];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
stable = {
|
stable = {
|
||||||
imports = [ (digga.lib.importOverlays ./overlays) ];
|
imports = [ (digga.lib.importOverlays ./overlays) ];
|
||||||
overlays = commonOverlays;
|
overlays = commonOverlays;
|
||||||
};
|
|
||||||
unstable = {
|
|
||||||
imports = [ (digga.lib.importOverlays ./overlays) ];
|
|
||||||
overlays = commonOverlays;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
lib = import ./lib { lib = digga.lib // nixos.lib; };
|
|
||||||
|
|
||||||
sharedOverlays = [
|
|
||||||
(
|
|
||||||
final: prev: {
|
|
||||||
__dontExport = true;
|
|
||||||
lib = prev.lib.extend (
|
|
||||||
lfinal: lprev: {
|
|
||||||
our = self.lib;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
)
|
|
||||||
];
|
|
||||||
|
|
||||||
nixos = {
|
|
||||||
hostDefaults = {
|
|
||||||
channelName = "unstable";
|
|
||||||
imports = [ (digga.lib.importModules ./modules) ];
|
|
||||||
externalModules = [
|
|
||||||
{ lib.our = self.lib; }
|
|
||||||
digga.nixosModules.bootstrapIso
|
|
||||||
digga.nixosModules.nixConfig
|
|
||||||
home.nixosModules.home-manager
|
|
||||||
bud.nixosModules.bud
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
hosts = {
|
unstable = {
|
||||||
# mbp is added bypassing Digga's mkFlake and adding a specific output to this flake
|
imports = [ (digga.lib.importOverlays ./overlays) ];
|
||||||
pc = {
|
overlays = commonOverlays;
|
||||||
system = "x86_64-linux";
|
|
||||||
imports = [ { modules = ./hosts/pc; } ];
|
|
||||||
};
|
|
||||||
pbp = {
|
|
||||||
system = "aarch64-linux";
|
|
||||||
imports = [ { modules = ./hosts/pbp; } ];
|
|
||||||
modules = [
|
|
||||||
"${pinebook-pro}/pinebook_pro.nix"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
# imports = [ (digga.lib.importHosts ./hosts) ]; # same reason as above
|
};
|
||||||
importables = rec {
|
|
||||||
profiles = digga.lib.rakeLeaves ./profiles // {
|
lib = import ./lib { lib = digga.lib // nixos.lib; };
|
||||||
users = digga.lib.rakeLeaves ./users;
|
|
||||||
};
|
sharedOverlays = [
|
||||||
suites = with profiles; rec {
|
(
|
||||||
base = [ core users.ccr users.root ];
|
final: prev: {
|
||||||
};
|
__dontExport = true;
|
||||||
pbpKernelLatest = (
|
lib = prev.lib.extend (
|
||||||
import pinebook-pro-kernel-latest {
|
lfinal: lprev: {
|
||||||
system = "aarch64-linux";
|
our = self.lib;
|
||||||
overlays = [
|
|
||||||
(import "${pinebook-pro}/overlay.nix")
|
|
||||||
];
|
|
||||||
config.allowUnfree = true;
|
|
||||||
}
|
}
|
||||||
).pkgs.linuxPackages_pinebookpro_latest;
|
);
|
||||||
|
}
|
||||||
|
)
|
||||||
|
];
|
||||||
|
|
||||||
|
nixos = {
|
||||||
|
hostDefaults = {
|
||||||
|
channelName = "unstable";
|
||||||
|
imports = [ (digga.lib.importModules ./modules) ];
|
||||||
|
externalModules = [
|
||||||
|
{ lib.our = self.lib; }
|
||||||
|
digga.nixosModules.bootstrapIso
|
||||||
|
digga.nixosModules.nixConfig
|
||||||
|
home.nixosModules.home-manager
|
||||||
|
bud.nixosModules.bud
|
||||||
|
];
|
||||||
|
};
|
||||||
|
hosts = {
|
||||||
|
# mbp is added bypassing Digga's mkFlake and adding a specific output to this flake
|
||||||
|
pc = {
|
||||||
|
system = "x86_64-linux";
|
||||||
|
imports = [{ modules = ./hosts/pc; }];
|
||||||
|
};
|
||||||
|
pbp = {
|
||||||
|
system = "aarch64-linux";
|
||||||
|
imports = [{ modules = ./hosts/pbp; }];
|
||||||
|
modules = [
|
||||||
|
"${pinebook-pro}/pinebook_pro.nix"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
# imports = [ (digga.lib.importHosts ./hosts) ]; # same reason as above
|
||||||
home = {
|
importables = rec {
|
||||||
imports = [ (digga.lib.importModules ./users/modules) ];
|
profiles = digga.lib.rakeLeaves ./profiles // {
|
||||||
externalModules = [];
|
users = digga.lib.rakeLeaves ./users;
|
||||||
importables = rec {
|
|
||||||
profiles = digga.lib.rakeLeaves ./users/profiles;
|
|
||||||
suites = with profiles; rec {
|
|
||||||
base = [ direnv git zsh gpg password-store ];
|
|
||||||
shell = [ zsh exa fzf ];
|
|
||||||
gui = [ sway xdg gtk foot bat ];
|
|
||||||
browser = [ firefox chromium qutebrowser ];
|
|
||||||
multimedia = [ mpv zathura ];
|
|
||||||
dev = [ vim emacs vscode lorri direnv ];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
suites = with profiles; rec {
|
||||||
|
base = [ core users.ccr users.root ];
|
||||||
|
};
|
||||||
|
pbpKernelLatest = (
|
||||||
|
import pinebook-pro-kernel-latest {
|
||||||
|
system = "aarch64-linux";
|
||||||
|
overlays = [
|
||||||
|
(import "${pinebook-pro}/overlay.nix")
|
||||||
|
];
|
||||||
|
config.allowUnfree = true;
|
||||||
|
}
|
||||||
|
).pkgs.linuxPackages_pinebookpro_latest;
|
||||||
};
|
};
|
||||||
|
|
||||||
devshell = ./shell;
|
|
||||||
|
|
||||||
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
|
|
||||||
|
|
||||||
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations {};
|
|
||||||
|
|
||||||
defaultTemplate = self.templates.bud;
|
|
||||||
templates.bud.path = ./.;
|
|
||||||
templates.bud.description = "bud template";
|
|
||||||
|
|
||||||
}
|
|
||||||
// {
|
|
||||||
budModules = { devos = import ./bud; };
|
|
||||||
# checks.aarch64-linux = { }; # this line will be uncommented by Github Action in order since it can't build aarch64 derivations
|
|
||||||
}
|
|
||||||
// {
|
|
||||||
darwinConfigurations."mbp" = darwin.lib.darwinSystem {
|
|
||||||
system = "x86_64-darwin";
|
|
||||||
modules = [ home.darwinModules.home-manager ./hosts/mbp ];
|
|
||||||
inputs = { inherit darwin; };
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
home = {
|
||||||
|
imports = [ (digga.lib.importModules ./users/modules) ];
|
||||||
|
externalModules = [ ];
|
||||||
|
importables = rec {
|
||||||
|
profiles = digga.lib.rakeLeaves ./users/profiles;
|
||||||
|
suites = with profiles; rec {
|
||||||
|
base = [ direnv git zsh gpg password-store ];
|
||||||
|
shell = [ zsh exa fzf ];
|
||||||
|
gui = [ sway xdg gtk foot bat ];
|
||||||
|
browser = [ firefox chromium qutebrowser ];
|
||||||
|
multimedia = [ mpv zathura ];
|
||||||
|
dev = [ vim emacs vscode lorri direnv ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
devshell = ./shell;
|
||||||
|
|
||||||
|
homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations;
|
||||||
|
|
||||||
|
deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations { };
|
||||||
|
|
||||||
|
defaultTemplate = self.templates.bud;
|
||||||
|
templates.bud.path = ./.;
|
||||||
|
templates.bud.description = "bud template";
|
||||||
|
|
||||||
|
}
|
||||||
|
// {
|
||||||
|
budModules = { devos = import ./bud; };
|
||||||
|
# checks.aarch64-linux = { }; # this line will be uncommented by Github Action in order since it can't build aarch64 derivations
|
||||||
|
}
|
||||||
|
// {
|
||||||
|
darwinConfigurations."mbp" = darwin.lib.darwinSystem {
|
||||||
|
system = "x86_64-darwin";
|
||||||
|
modules = [ home.darwinModules.home-manager ./hosts/mbp ];
|
||||||
|
inputs = { inherit darwin; };
|
||||||
|
specialArgs = { inherit emacs-overlay; };
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{pkgs, home-manager, ...}:
|
{ pkgs, home-manager, emacs-overlay, ... }:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
../../users/andreaciceri
|
../../users/andreaciceri
|
||||||
|
@ -14,6 +14,8 @@
|
||||||
enableSSHSupport = true;
|
enableSSHSupport = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
nixpkgs.overlays = [ (import ../../pkgs) emacs-overlay.overlay ];
|
||||||
|
|
||||||
nix = {
|
nix = {
|
||||||
package = pkgs.nixUnstable;
|
package = pkgs.nixUnstable;
|
||||||
extraOptions = ''
|
extraOptions = ''
|
||||||
|
@ -27,4 +29,4 @@
|
||||||
options = "--delete-older-than 3d";
|
options = "--delete-older-than 3d";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ pkgs, ...}:
|
{ pkgs, emacs-overlay, ... }:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./configuration.nix
|
./configuration.nix
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
final: prev: {
|
final: prev: {
|
||||||
# keep sources this first
|
# keep sources this first
|
||||||
sources = prev.callPackage (import ./_sources/generated.nix) {};
|
sources = prev.callPackage (import ./_sources/generated.nix) { };
|
||||||
customEmacs = prev.callPackage (import ./emacs) {};
|
customEmacs = prev.callPackage (import ./emacs) { };
|
||||||
|
ungoogled-chromium = import ./ungoogled-chromium { inherit prev; };
|
||||||
|
vscodium = import ./vscodium { inherit prev; };
|
||||||
# then, call packages with `final.callPackage`
|
# then, call packages with `final.callPackage`
|
||||||
}
|
}
|
||||||
|
|
10
pkgs/ungoogled-chromium/default.nix
Normal file
10
pkgs/ungoogled-chromium/default.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{ prev, pkgs, ... }:
|
||||||
|
|
||||||
|
prev.runCommandNoCC "wrap-chromium"
|
||||||
|
{ buildInputs = with pkgs; [ makeWrapper ]; }
|
||||||
|
''
|
||||||
|
makeWrapper ${c}/bin/chromium $out/bin/chromium \
|
||||||
|
--add-flags "--enable-features=UseOzonePlatform" \
|
||||||
|
--add-flags "--ozone-platform=wayland"
|
||||||
|
ln -sf ${c}/share $out/share
|
||||||
|
''
|
10
pkgs/vscodium/default.nix
Normal file
10
pkgs/vscodium/default.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{ prev, pkgs, ... }:
|
||||||
|
|
||||||
|
prev.runCommandNoCC "codium"
|
||||||
|
{ buildInputs = with pkgs; [ makeWrapper ]; }
|
||||||
|
''
|
||||||
|
makeWrapper ${prev.vscodium}/bin/codium $out/bin/codium \
|
||||||
|
--add-flags "--enable-features=UseOzonePlatform" \
|
||||||
|
--add-flags "--ozone-platform=wayland"
|
||||||
|
ln -sf ${prev.vscodium}/share $out/share
|
||||||
|
''
|
7
profiles/chromecast/default.nix
Normal file
7
profiles/chromecast/default.nix
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
networking.firewall.extraCommands = ''
|
||||||
|
iptables -I INPUT -p udp -m udp --dport 32768:60999 -j ACCEPT
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,15 +1,15 @@
|
||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, emacs-overlay, ... }: {
|
||||||
home-manager.users."andreaciceri" = {...}: {
|
home-manager.users."andreaciceri" = { ... }: {
|
||||||
imports = [
|
imports = [
|
||||||
../profiles/bat
|
../profiles/bat
|
||||||
../profiles/fzf
|
../profiles/fzf
|
||||||
../profiles/zsh
|
../profiles/zsh
|
||||||
../profiles/direnv
|
../profiles/direnv
|
||||||
../profiles/exa
|
../profiles/exa
|
||||||
|
../profiles/emacs
|
||||||
];
|
];
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
yarn
|
yarn
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,10 +12,9 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
python-language-server
|
|
||||||
fd
|
fd
|
||||||
ag
|
ag
|
||||||
nixpkgs-fmt
|
nixpkgs-fmt
|
||||||
rnix-lsp
|
rnix-lsp
|
||||||
];
|
] ++ (if config.network.hostname != "mbp" then python-language-server else [ ]);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue