Now Emacs works on the Macbook

This commit is contained in:
Andrea Ciceri 2021-10-11 23:58:20 +02:00
parent b4d239d34b
commit 3f39ace857
No known key found for this signature in database
GPG key ID: AAFD2423608B645B
9 changed files with 158 additions and 127 deletions

235
flake.nix
View file

@ -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; };
}; };
};
} }

View file

@ -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";
}; };
}; };
} }

View file

@ -1,4 +1,4 @@
{ pkgs, ...}: { pkgs, emacs-overlay, ... }:
{ {
imports = [ imports = [
./configuration.nix ./configuration.nix

View file

@ -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`
} }

View 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
View 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
''

View file

@ -0,0 +1,7 @@
{
config = {
networking.firewall.extraCommands = ''
iptables -I INPUT -p udp -m udp --dport 32768:60999 -j ACCEPT
'';
};
}

View file

@ -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
]; ];
}; };
} }

View file

@ -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 [ ]);
} }