blob: ae6a8cc70359596af248faa0545f46daf0d6e037 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
# This file contains configuration for packages to install.
# It does not contain configuration for software that is already covered
# by other NixOS options (e.g. emacs)
{ config, pkgs, ... }:
let
fetchChannel = { rev, sha256 }: import (fetchTarball {
inherit sha256;
url = "https://github.com/NixOS/nixpkgs-channels/archive/${rev}.tar.gz";
}) { config.allowUnfree = true; };
# Channels last updated: 2014-05-01
# Instead of relying on Nix channels and ending up with out-of-sync
# situations between machines, the commit for the stable Nix channel
# is pinned here.
stable = fetchChannel {
rev = "ce0d9d638ded6119f19d87e433e160603683fb1b";
sha256 = "0na6kjk4xw6gqrn3a903yv3zfa64bspq2q3kd6wyf52y44j3s8sx";
};
# Certain packages from unstable are required in my daily setup. To
# get access to them, they are hand-picked from the unstable channel
# and set as overrides on the system package set.
unstable = fetchChannel {
rev = "1b1be29bf827fc177100ae175030b2fda4132e47";
sha256 = "0dnwyvh2xfbf35apf17iw59hscf1jdqn8nx7hm7yh9c0ypkh2qy3";
};
in {
# Configure the Nix package manager
nixpkgs = {
config.allowUnfree = true;
# To use the pinned channel, the original package set is thrown
# away in the overrides:
config.packageOverrides = oldPkgs: stable // {
wallpapers = import ./pkgs/wallpapers.nix;
pulseaudio-ctl = import pkgs/pulseaudio-ctl.nix;
kontemplate = unstable.kontemplate;
mq-cli = unstable.mq-cli;
# Override various Emacs packages from unstable:
pinnedEmacs = with unstable.emacsPackagesNg; {
counsel = melpaPackages.counsel;
counsel-tramp = melpaPackages.counsel-tramp;
company-lsp = company-lsp;
exwm = elpaPackages.exwm;
ivy = melpaPackages.ivy;
ivy-gitlab = melpaPackages.ivy-gitlab;
ivy-hydra = melpaPackages.ivy-hydra;
ivy-pass = melpaPackages.ivy-pass;
swiper = melpaPackages.swiper;
lsp-mode = lsp-mode;
lsp-rust = lsp-rust;
lsp-ui = lsp-ui;
};
};
};
# ... and declare packages to be installed.
environment.systemPackages = with pkgs; [
# Default nixos.* packages:
alacritty
binutils-unwrapped
cargo
curl
direnv
dnsutils
evince
exa
fd
file
firefox-unwrapped
fish
gcc
git
gnome3.dconf
gnome3.evolution
gnome3.glib_networking
gnumake
gnupg
google-cloud-sdk
gopass
htop
i3lock
iftop
jetbrains.idea-ultimate
jq
kontemplate
kubernetes
lispPackages.quicklisp
lxappearance-gtk3
manpages
maven
mq-cli
ngrok
nixops
numix-cursor-theme
numix-gtk-theme
numix-icon-theme
openjdk
openssl
openssl.dev
pass
pavucontrol
pkgconfig
pulseaudio-ctl
pwgen
qjackctl
ripgrep
rustup
sbcl
screen
siege
spotify
stdmanpages
tdesktop
terraform_0_10
tig
tmux
tokei
transmission
tree
units
unzip
vlc
xclip
xfce.xfce4-screenshooter
# Haskell packages:
cabal-install
ghc
hlint
stack
stack2nix
haskellPackages.intero
haskellPackages.stylish-haskell
haskellPackages.yesod-bin
];
}
|