# Archsetup Project Context ## Overview Arch Linux installation and configuration scripts with dotfiles managed via GNU Stow. Supports both X11 (DWM) and Wayland (Hyprland) setups. ## Project Structure - `archsetup` - Main installation script with functions for packages, configs, services - `dotfiles/common/` - Shared dotfiles for all desktop environments (stowed to ~) - `dotfiles/dwm/` - DWM/X11-specific dotfiles (8 scripts) - `dotfiles/hyprland/` - Hyprland-specific dotfiles (7 scripts) - `docs/` - Documentation and package lists - `reference-repos/` - External dotfile references - `Makefile` - GNU Stow operations for dotfile management ## Makefile Targets ``` make stow dwm # Fresh install (common + dwm) make stow hyprland # Fresh install (common + hyprland) make restow dwm # Refresh links after git pull make reset hyprland # Fix conflicts, keep repo version make unstow dwm # Remove all symlinks make import common # fzf select → import to common/ make import dwm # fzf select → import to dwm/ make import hyprland # fzf select → import to hyprland/ ``` ## Script Counts ``` dotfiles/common/.local/bin/ → 33 universal scripts dotfiles/dwm/.local/bin/ → 8 X11/DWM scripts dotfiles/hyprland/.local/bin/ → 7 Hyprland scripts ``` ### DWM Scripts (8) Scripts bound in ~/code/dwm/config.def.h (on velox): - brightness (XF86 keys), toggle-touchpad (Mod+F9), dmenuexitmenu (Mod+Shift+Q) - Plus: airplanemodetoggle, colorpick, dmenuunicode, screenshotmenu, wallsearch ### Hyprland Scripts (7) All actively used in configs: - cycle-layout, layout-navigate, pinentry-fuzzel, set-theme - toggle-scratchpad, waybar-layout, waybar-netspeed ## Shell Configuration ``` ~/.profile → Environment variables only (POSIX compatible) ~/.bash_profile → Sources .profile + .bashrc for login shells ~/.bashrc → Bash-specific settings, sources .bashrc.d/ ~/.zshrc → Zsh-specific settings, sources .zshrc.d/ ~/.profile.d/ → Modular env vars (display, framework, auto-tmux, hyprland) ~/.bashrc.d/ → Modular bash configs (aliases, fzf, git, media, utilities, emacs) ~/.zshrc.d/ → Modular zsh configs (same + arch-downgrade) ``` ## Current Theme (Dupre) - **GTK**: Adwaita-dark - **Qt**: Adwaita-Dark (via adwaita-qt5/qt6, QT_STYLE_OVERRIDE) - **Icons**: Papirus-Dark - **Cursors**: capitaine-cursors-light (size 24) - **Color palette**: bg #151311, gold #d7af5f, steel #969385, blue #67809c ## Key Configuration Files - `dotfiles/hyprland/.config/hypr/hyprland.conf` - Main Hyprland config - `dotfiles/hyprland/.config/themes/dupre/` - Dupre theme files - `dotfiles/common/.profile.d/` - Shell environment scripts - `dotfiles/common/.config/qt5ct/qt5ct.conf` - Qt5 theming - `dotfiles/common/.config/qt6ct/qt6ct.conf` - Qt6 theming ## Pending Work - Task #4: Evaluate Euphonica MPD client (May 2026) ## Recent Changes (Jan 2026) - Added Makefile for GNU Stow operations (stow, restow, reset, unstow, import) - Renamed dotfiles/system/ to dotfiles/common/ for clarity - Cleaned up scripts: common 44→33, dwm 50→8, hyprland 8→7 - Deleted unused configs: ghostty, lf, mopidy, nitrogen, pychess, JetBrains, youtube-dl, sublime-merge - Added yt-dlp config and org-protocol-setup script - Fixed yt-dlp aliases: --add-metadata → --embed-metadata - Refactored shell configs: proper .profile/.bashrc/.zshrc separation - Created .bashrc.d/ and .zshrc.d/ for modular configs - Added Qt theming with adwaita-qt5/qt6 - Pruned ~90 desktop files from app menu with NoDisplay=true overrides ## Notes - Desktop file overrides go in `dotfiles/hyprland/.local/share/applications/` - MPD is configured but mpv handles audio file associations - BerkeleyMono Nerd Font is the primary monospace font - DWM keybindings defined in ~/code/dwm/config.def.h on velox - audacious config kept in common/ for potential future use