-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathhome.nix
138 lines (118 loc) · 3.22 KB
/
home.nix
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
{
config,
lib,
pkgs,
...
}:
{
nixpkgs.overlays = [
# ...
];
nixpkgs.config.allowUnfreePredicate =
pkg:
builtins.elem (lib.getName pkg) [
"1password-cli"
"ngrok"
];
# Home Manager needs a bit of information about you and the paths it should
# manage.
# home.username = user.name;
# home.homeDirectory = user.homeDir;
# This value determines the Home Manager release that your configuration is
# compatible with. This helps avoid breakage when a new Home Manager release
# introduces backwards incompatible changes.
#
# You should not change this value, even if you update Home Manager. If you do
# want to update the value, then make sure to first check the Home Manager
# release notes.
home.stateVersion = "24.11"; # Please read the comment before changing.
# The home.packages option allows you to install Nix packages into your
# environment.
home.packages = [
# # Adds the 'hello' command to your environment. It prints a friendly
# # "Hello, world!" when run.
# pkgs.hello
# other langs
pkgs.php
pkgs.ruby
pkgs.rustup
# git
pkgs.git
# zsh
pkgs.zsh
pkgs.sheldon
# tmux
pkgs.tmux
# nix
pkgs.nixd
pkgs.nixfmt-rfc-style
# middlewares
pkgs.postgresql_16
pkgs.mysql80
pkgs.redis
pkgs.sqlite
# CLIs for cloud services
pkgs.google-cloud-sdk
pkgs.ngrok
# tools
pkgs._1password-cli
pkgs.btop
pkgs.diff-pdf
pkgs.graphviz
pkgs.htop
pkgs.jq
pkgs.semgrep
pkgs.tree
(pkgs.callPackage ./pkgs/aqua.nix { })
# gnu
pkgs.coreutils
pkgs.findutils
pkgs.gawk
pkgs.gnugrep
pkgs.gnused
# only darwin
pkgs.blueutil
pkgs.mas
pkgs.reattach-to-user-namespace
pkgs.skhd
pkgs.yabai
# fonts
pkgs.hackgen-font
pkgs.hackgen-nf-font
# # It is sometimes useful to fine-tune packages, for example, by applying
# # overrides. You can do that directly here, just don't forget the
# # parentheses. Maybe you want to install Nerd Fonts with a limited number of
# # fonts?
# (pkgs.nerdfonts.override { fonts = [ "FantasqueSansMono" ]; })
# # You can also create simple shell scripts directly inside your
# # configuration. For example, this adds a command 'my-hello' to your
# # environment:
# (pkgs.writeShellScriptBin "my-hello" ''
# echo "Hello, ${config.home.username}!"
# '')
];
home.file = {
# Create symlink with ./bin/deploy-config-files.
};
# Home Manager can also manage your environment variables through
# 'home.sessionVariables'. If you don't want to manage your shell through Home
# Manager then you have to manually source 'hm-session-vars.sh' located at
# either
#
# ~/.nix-profile/etc/profile.d/hm-session-vars.sh
#
# or
#
# ~/.local/state/nix/profiles/profile/etc/profile.d/hm-session-vars.sh
#
# or
#
# /etc/profiles/per-user/masayuki.izumi/etc/profile.d/hm-session-vars.sh
#
home.sessionVariables = {
# https://github.com/kkharji/sqlite.lua/blob/d0ffd70/lua/sqlite/defs.lua#L18
LIBSQLITE = "${pkgs.sqlite.out}/lib/libsqlite3.dylib";
};
# Let Home Manager install and manage itself.
programs.home-manager.enable = true;
}