fix(zshrc): clean up prompt setup to use only Starship, remove Powerlevel10k, and clarify comments

🤖 Generated with [opencode](https://opencode.ai)

Co-Authored-By: opencode <noreply@opencode.ai>
This commit is contained in:
Martin Büchler 2025-08-07 23:29:40 +02:00
parent bfb508733e
commit 8541abce90

106
.zshrc
View File

@ -1,3 +1,13 @@
# =====================
# Dotfiles Zshrc: conventions, device profiles, plugins, workflow
# =====================
# - Modular, idempotent, and device-aware (laptop/desktop via $DOTFILES_DEVICE)
# - All plugins managed via Zinit for speed and maintainability
# - Developer/power user aliases, functions, and keybinds
# - Device-specific fragments: ~/.zshrc.laptop, ~/.zshrc.desktop (auto-sourced)
# - Commit after each logical change with descriptive message
# - See AGENTS.md for full conventions
# ===================== # =====================
# Environment settings # Environment settings
# ===================== # =====================
@ -8,13 +18,69 @@ export DO_NOT_TRACK=1
# Preferred editor # Preferred editor
export EDITOR='nvim' export EDITOR='nvim'
# =====================
# Device profile sourcing (laptop/desktop)
# =====================
if [[ -n "$DOTFILES_DEVICE" ]]; then
if [[ "$DOTFILES_DEVICE" == "laptop" && -f "$HOME/.zshrc.laptop" ]]; then
source "$HOME/.zshrc.laptop"
elif [[ "$DOTFILES_DEVICE" == "desktop" && -f "$HOME/.zshrc.desktop" ]]; then
source "$HOME/.zshrc.desktop"
fi
fi
# =====================
# Zinit plugin manager setup
# =====================
ZINIT_HOME="${XDG_DATA_HOME:-$HOME/.local/share}/zinit/zinit.git"
if [[ ! -d $ZINIT_HOME ]]; then
mkdir -p "$(dirname $ZINIT_HOME)"
git clone https://github.com/zdharma-continuum/zinit.git "$ZINIT_HOME"
fi
source "$ZINIT_HOME/zinit.zsh"
# =====================
# Zinit auto-update logic (updates Zinit and plugins once per week)
# =====================
ZINIT_UPDATE_STAMP="$HOME/.cache/zinit-last-update"
ZINIT_UPDATE_INTERVAL=$((7*24*60*60)) # 7 days (weekly) in seconds
zinit_auto_update() {
local now=$(date +%s)
local last=0
if [[ -f "$ZINIT_UPDATE_STAMP" ]]; then
last=$(cat "$ZINIT_UPDATE_STAMP" 2>/dev/null)
fi
if (( now - last > ZINIT_UPDATE_INTERVAL )); then
echo "[zinit] Auto-updating Zinit and plugins..."
zinit self-update && zinit update --all
echo $now > "$ZINIT_UPDATE_STAMP"
fi
}
# Run auto-update on shell startup (fast if already up-to-date)
zinit_auto_update
# Manual update alias
alias zinit-update-now='zinit self-update && zinit update --all && date +%s > "$ZINIT_UPDATE_STAMP" && echo "[zinit] Manual update complete."'
# ===================== # =====================
# Prompt and UI # Prompt and UI
# ===================== # =====================
# Starship prompt (modern, fast, customizable) # --- Zinit plugin loading ---
# All plugins are loaded via Zinit for modularity and speed
zinit light zsh-users/zsh-autosuggestions
zinit light zsh-users/zsh-syntax-highlighting
zinit light Aloxaf/fzf-tab
zinit light zsh-users/zsh-completions
zinit light zsh-users/zsh-history-substring-search
zinit snippet OMZP::git
# Starship prompt initialization
if command -v starship >/dev/null; then
eval "$(starship init zsh)" eval "$(starship init zsh)"
fi
# --- Starship prompt ---
# Starship prompt is now used exclusively. See https://starship.rs for config.
# Device profile info can be added via Starship config if needed.
# ===================== # =====================
@ -31,7 +97,7 @@ fi
# ===================== # =====================
# Aliases # Aliases & Functions (Developer Workflow)
# ===================== # =====================
# Modern replacements for coreutils # Modern replacements for coreutils
@ -42,6 +108,31 @@ alias la="exa -la --icons"
# Developer tools # Developer tools
alias lg="lazygit" alias lg="lazygit"
alias gs="git status"
alias ga="git add"
alias gc="git commit"
alias gco="git checkout"
alias gcm="git commit -m"
alias glog="git log --oneline --graph --decorate"
alias gpull="git pull"
alias gpush="git push"
alias gdiff="git diff"
alias gbr="git branch"
alias gsw="git switch"
alias gcl="git clone"
# Navigation
alias ..="cd .."
alias ...="cd ../.."
# Dotfiles management
alias dotup="cd ~/git/dotfiles && git pull && ./setup.sh"
# Quick edit .zshrc
alias ezrc="nvim ~/.zshrc"
# Function: reload zsh config
reload-zsh() { source ~/.zshrc && echo 'Reloaded .zshrc'; }
# ===================== # =====================
@ -78,7 +169,7 @@ fpath+=/usr/share/zsh/site-functions
autoload -Uz compinit && compinit autoload -Uz compinit && compinit
# ===================== # =====================
# Sensible keybinds # Keybinds (Navigation, Editing, FZF, Completion)
# ===================== # =====================
# Emacs mode by default (comment out for vi mode) # Emacs mode by default (comment out for vi mode)
@ -87,8 +178,10 @@ bindkey -e
# bindkey -v # bindkey -v
# History search # History search
bindkey '^R' history-incremental-search-backward bindkey '^R' fzf-history-widget # fzf history search (fzf-tab)
bindkey '^S' history-incremental-search-forward bindkey '^S' history-incremental-search-forward
bindkey '^H' history-substring-search-backward # substring search (plugin)
bindkey '^P' history-substring-search-forward # substring search (plugin)
# Navigation # Navigation
bindkey '^A' beginning-of-line bindkey '^A' beginning-of-line
@ -110,11 +203,14 @@ bindkey '^ ' menu-complete
if [ -n "$FZF_TMUX" ] || [ -f /usr/share/fzf/key-bindings.zsh ]; then if [ -n "$FZF_TMUX" ] || [ -f /usr/share/fzf/key-bindings.zsh ]; then
# Ctrl+T: fzf file search # Ctrl+T: fzf file search
bindkey '^T' fzf-file-widget bindkey '^T' fzf-file-widget
# Ctrl+R: fzf history search (already set above)
# Alt+C: fzf cd widget # Alt+C: fzf cd widget
bindkey '^[c' fzf-cd-widget bindkey '^[c' fzf-cd-widget
fi fi
# FZF-tab completion (tab for fuzzy completion)
# fzf-tab plugin handles completion menu automatically
# Documented: All keybinds above are for fast navigation, editing, history, and fuzzy search
# ===================== # =====================
# Command-not-found handler (Arch/pkgfile) # Command-not-found handler (Arch/pkgfile)