Compare commits

..

No commits in common. "e5260a945e77037aa01a49ced7166fb7533152b1" and "7c457d29de9064dc29a5803262d0f1836fc19a4e" have entirely different histories.

7 changed files with 34 additions and 48 deletions

View file

@ -86,25 +86,6 @@ My profile can be conveniently selected in [[./flake.nix][my flake.nix]] by sett
More detailed information on these profiles is in the [[./profiles][profiles directory]]. More detailed information on these profiles is in the [[./profiles][profiles directory]].
** Nix Wrapper Script
Some Nix commands are confusing, really long to type out, or require me to be in the directory with my dotfiles. To solve this, I wrote a [[./system/bin/phoenix.nix][wrapper script called phoenix]], which calls various scripts in the root of this directory.
TLDR:
- =phoenix sync= - Synchronize system and home-manager state with config files (essentially =nixos-rebuild switch= + =home-manager switch=)
- =phoenix sync system= - Only synchronize system state (essentially =nixos-rebuild switch=)
- =phoenix sync user= - Only synchronize home-manager state (essentially =home-manager switch=)
- =phoenix update= - Update all flake inputs without synchronizing system and home-manager states
- =phoenix upgrade= - Update flake.lock and synchronize system and home-manager states (=phoenix update= + =phoenix sync=)
- =phoenix refresh= - Call synchronization posthooks (mainly to refresh stylix and some dependent daemons)
- =phoenix pull= - Pull changes from upstream git and attempt to merge local changes (I use this to update systems other than my main system)
- =phoenix harden= - Ensure that all "system-level" files cannot be edited by an unprivileged user
- =phoenix soften= - Relax permissions so all dotfiles can be edited by a normal user (use temporarily for git or other operations)
- =phoenix gc= - Garbage collect the system and user nix stores
- =phoenix gc full= - Delete everything not currently in use
- =phoenix gc 15d= - Delete everything older than 15 days
- =phoenix gc 30d= - Delete everything older than 30 days
- =phoenix gc Xd= - Delete everything older than X days
** Star History ** Star History
Didn't think this would get that many [[https://star-history.com/#librephoenix/nixos-config&Date][stars on GitHub]], yet here we are: Didn't think this would get that many [[https://star-history.com/#librephoenix/nixos-config&Date][stars on GitHub]], yet here we are:
[[https://api.star-history.com/svg?repos=librephoenix/nixos-config&type=Date.png]] [[https://api.star-history.com/svg?repos=librephoenix/nixos-config&type=Date.png]]

View file

@ -24,7 +24,7 @@ nix run git+https://codeberg.org/librephoenix/nixos-config
This will install the dotfiles to =~/.dotfiles=, but if you'd like to install to a custom directory, just supply it as a positional argument, i.e: This will install the dotfiles to =~/.dotfiles=, but if you'd like to install to a custom directory, just supply it as a positional argument, i.e:
#+BEGIN_SRC sh :noeval #+BEGIN_SRC sh :noeval
# Install from gitlab # Install from gitlab
nix run gitlab:librephoenix/nixos-config -- /your/custom/directory nix run gitlab:librephoenix/nixos-config /your/custom/directory
#+END_SRC #+END_SRC
The script will ask for sudo permissions at certain points, /but you should not run the script as root/. The script will ask for sudo permissions at certain points, /but you should not run the script as root/.
@ -45,7 +45,7 @@ nix-shell -p git --command "nix run --experimental-features 'nix-command flakes'
This /should/ still work with a custom dotfiles directory too, i.e: This /should/ still work with a custom dotfiles directory too, i.e:
#+begin_src sh :noeval #+begin_src sh :noeval
nix-shell -p git --command "nix run --experimental-features 'nix-command flakes' gitlab:librephoenix/nixos-config -- /your/custom/directory" nix-shell -p git --command "nix run --experimental-features 'nix-command flakes' gitlab:librephoenix/nixos-config /your/custom/directory"
#+end_src #+end_src
At a certain point in the install script it will open =nano= (or whatever your $EDITOR is set to) and ask you to edit the =flake.nix=. You can edit as much or as little of the config variables as you like, and it will continue the install after you exit the editor. At a certain point in the install script it will open =nano= (or whatever your $EDITOR is set to) and ask you to edit the =flake.nix=. You can edit as much or as little of the config variables as you like, and it will continue the install after you exit the editor.
@ -104,6 +104,7 @@ git clone https://gitlab.com/librephoenix/nixos-config.git ~/.dotfiles
Any custom directory should also work: Any custom directory should also work:
#+BEGIN_SRC sh :noeval #+BEGIN_SRC sh :noeval
git clone https://gitlab.com/librephoenix/nixos-config.git /your/custom/directory git clone https://gitlab.com/librephoenix/nixos-config.git /your/custom/directory
/your/custom/directory/install.sh
#+END_SRC #+END_SRC
If you install to a custom directory, make sure to edit the =userSettings.dotfilesDir= in the beginning [[./flake.nix][flake.nix]], or else my [[./system/bin/phoenix.nix][phoenix wrapper script]] won't work. If you install to a custom directory, make sure to edit the =userSettings.dotfilesDir= in the beginning [[./flake.nix][flake.nix]], or else my [[./system/bin/phoenix.nix][phoenix wrapper script]] won't work.

View file

@ -3,7 +3,9 @@
# Automated script to install my dotfiles # Automated script to install my dotfiles
# Clone dotfiles # Clone dotfiles
if [ $# -gt 0 ] # TODO make ~/.dotfiles path arbitrary and make all other scripts conform to this
# using SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
if [ -z "$1" ]
then then
SCRIPT_DIR=$1 SCRIPT_DIR=$1
else else

View file

@ -20,10 +20,14 @@ My system-level Nix modules are organized into this directory:
- [[./wm][wm]] - Necessary system-level configuration to get various window managers, wayland compositors, and/or desktop environments working - [[./wm][wm]] - Necessary system-level configuration to get various window managers, wayland compositors, and/or desktop environments working
** Variables imported from flake.nix ** Variables imported from flake.nix
# TODO update this
Variables can be imported from [[../flake.nix][flake.nix]] by setting the =specialArgs= block inside the flake (see [[../flake.nix][my flake]] for more details). This allows variables to merely be managed in one place ([[../flake.nix][flake.nix]]) rather than having to manage them in multiple locations. Variables can be imported from [[../flake.nix][flake.nix]] by setting the =specialArgs= block inside the flake (see [[../flake.nix][my flake]] for more details). This allows variables to merely be managed in one place ([[../flake.nix][flake.nix]]) rather than having to manage them in multiple locations.
I use this to pass a few attribute sets: I currently import the following variables to the system config:
- =userSettings= - Settings for the normal user (see [[../flake.nix][flake.nix]] for more details) - =username= - Username
- =systemSettings= - Settings for the system (see [[../flake.nix][flake.nix]] for more details) - =hostname= - Hostname for machine
- =inputs= - Flake inputs (see [[../flake.nix][flake.nix]] for more details) - =timezone= - Timezone for machine
- =pkgs-stable= - Allows me to include stable versions of packages along with (my default) unstable versions of packages - =locale= - Locale for machine
- =theme= - base16 theme stored in ../themes to be used
- =backgroundUrl= - Direct link to background wallpaper (used for login screen)
- =backgroundSha256= - Checksum for background image used when downloading

View file

@ -31,17 +31,20 @@ My user-level Nix modules are organized into this directory:
- [[./shell/cli-collection.nix][cli-collection]] - Curated useful CLI utilities - [[./shell/cli-collection.nix][cli-collection]] - Curated useful CLI utilities
- [[./style][style]] - Stylix setup (system-wide base16 theme generation) - [[./style][style]] - Stylix setup (system-wide base16 theme generation)
- [[./wm][wm]] - Window manager, compositor, wayland compositor, and/or desktop environment setups - [[./wm][wm]] - Window manager, compositor, wayland compositor, and/or desktop environment setups
- [[./wm/hyprland][hyprland]]
- [[./wm/xmonad][xmonad]] - [[./wm/xmonad][xmonad]]
- [[./wm/picom][picom]] - [[./wm/picom][picom]]
** Variables imported from flake.nix ** Variables imported from flake.nix
# TODO update this
Variables can be imported from [[../flake.nix][flake.nix]] by setting the =extraSpecialArgs= block inside the flake (see [[../flake.nix][my flake]] for more details). This allows variables to merely be managed in one place ([[../flake.nix][flake.nix]]) rather than having to manage them in multiple locations. Variables can be imported from [[../flake.nix][flake.nix]] by setting the =extraSpecialArgs= block inside the flake (see [[../flake.nix][my flake]] for more details). This allows variables to merely be managed in one place ([[../flake.nix][flake.nix]]) rather than having to manage them in multiple locations.
I use this to pass a few attribute sets: I currently import the following variables to the system config:
- =userSettings= - Settings for the normal user (see [[../flake.nix][flake.nix]] for more details) - =username= - Username
- =systemSettings= - Settings for the system (see [[../flake.nix][flake.nix]] for more details) - =hostname= - Hostname for machine
- =inputs= - Flake inputs (see [[../flake.nix][flake.nix]] for more details) - =myHomeDir= - Absolute path to home directory derived from =username=
- =pkgs-stable= - Allows me to include stable versions of packages along with (my default) unstable versions of packages - =email= - Email
- =pkgs-emacs= - Pinned version of nixpkgs I use for Emacs and its dependencies - =dotfilesDir= - Path to my dotfiles directory on the system
- =pkgs-kdenlive= - Pinned version of nixpkgs I use for kdenlive - =theme= - base16 theme stored in ../themes to be used
- =themePolarity= - whether theme is =light= or =dark=
- =backgroundUrl= - Direct link to background wallpaper (used for login screen)
- =backgroundSha256= - Checksum for background image used when downloading

View file

@ -1244,11 +1244,7 @@ https://github.com/magit/magit/issues/460 (@cpitclaudel)."
"C-=" 'text-scale-increase "C-=" 'text-scale-increase
:desc "Decrease font size" :desc "Decrease font size"
"C--" 'text-scale-decrease "C--" 'text-scale-decrease)
:desc "Jump to dired"
"M-f" 'dired-jump
)
;;;------ ranger configuration ------;;; ;;;------ ranger configuration ------;;;
@ -1258,7 +1254,9 @@ https://github.com/magit/magit/issues/460 (@cpitclaudel)."
:desc "Toggle mark on current file" :desc "Toggle mark on current file"
"x" 'ranger-toggle-mark "x" 'ranger-toggle-mark
)
:desc "Open ranger"
"o d" 'ranger)
;;;-- hledger-mode configuration ;;;-- ;;;-- hledger-mode configuration ;;;--

View file

@ -1435,12 +1435,7 @@ https://github.com/magit/magit/issues/460 (@cpitclaudel)."
"C-=" 'text-scale-increase "C-=" 'text-scale-increase
:desc "Decrease font size" :desc "Decrease font size"
"C--" 'text-scale-decrease "C--" 'text-scale-decrease)
:desc "Jump to dired"
"M-f" 'dired-jump
)
#+END_SRC #+END_SRC
** Ranger Configuration ** Ranger Configuration
@ -1453,7 +1448,9 @@ https://github.com/magit/magit/issues/460 (@cpitclaudel)."
:desc "Toggle mark on current file" :desc "Toggle mark on current file"
"x" 'ranger-toggle-mark "x" 'ranger-toggle-mark
)
:desc "Open ranger"
"o d" 'ranger)
#+END_SRC #+END_SRC
** hledger-mode Configuration ** hledger-mode Configuration