From c4586d40262ed7762631dbd0312d8dd560cb9a10 Mon Sep 17 00:00:00 2001 From: Cameron Reed Date: Tue, 23 Apr 2024 22:20:33 -0600 Subject: [PATCH] initial commit --- .aliases | 42 +++++++++++++++ .gitignore | 1 + .zprofile | 13 +++++ .zshenv | 40 +++++++++++++++ .zshrc | 148 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 244 insertions(+) create mode 100644 .aliases create mode 100644 .gitignore create mode 100644 .zprofile create mode 100644 .zshenv create mode 100644 .zshrc diff --git a/.aliases b/.aliases new file mode 100644 index 0000000..64d82bd --- /dev/null +++ b/.aliases @@ -0,0 +1,42 @@ +#! /usr/bin/env zsh + +nixos_config="$HOME/nixos-config/hosts/nixos/configuration.nix" + + +if [ -f "$nixos_config" ]; then + alias edit_config="${EDITOR:-vim} $nixos_config" +fi + +unset nixos_config + + +if [ "$TERM" = 'xterm-kitty' ]; then + alias ssh='kitty +kitten ssh' + alias clear='printf "\033c"' +fi + + +alias grep='grep --color=auto' +if command -v eza &> /dev/null; then + alias ls='eza --icons=auto --group-directories-first' +else + alias ls='ls --color=auto' +fi + + +alias nv='nvim' +alias nvd='nvim .' +alias nvc='nvim -c "edit \$MYVIMRC"' + + +alias c='clear' +alias e='echo' +alias pf='printf' +alias nf='neofetch' + +alias :q='exit' +alias :wq='exit' + +bindkey -s '^o' 'lfcd\n' +bindkey -s '^n' 'nvd\n' + diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..dea2d4f --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +.zcompdump diff --git a/.zprofile b/.zprofile new file mode 100644 index 0000000..8678a26 --- /dev/null +++ b/.zprofile @@ -0,0 +1,13 @@ +# +# $ZDOTDIR/.zprofile +# + + +[[ -f ~/.profile ]] && . ~/.profile +[[ -f $ZDOTDIR/.zshrc ]] && . $ZDOTDIR/.zshrc + + +if [ "$XDG_SESSION_TYPE" = "wayland" ]; then + export MOZ_ENABLE_WAYLAND=1 +fi + diff --git a/.zshenv b/.zshenv new file mode 100644 index 0000000..d61f94d --- /dev/null +++ b/.zshenv @@ -0,0 +1,40 @@ +# +# $ZDOTDIR/.zshenv +# + + +if [ -d /opt/devkitpro ]; then + export DEVKITPRO=/opt/devkitpro + export DEVKITARM=$DEVKITPRO/devkitARM + export DEVKITPPC=$DEVKITPRO/devkitPPC +fi + + + +# Copied from arch linux's default /etc/profile +function append_path() { + [ ! -d "$1" ] && return + case ":$PATH:" in + *:"$1":*) + ;; + *) + PATH="${PATH:+$PATH:}$1" + esac +} + + +append_path "/home/cameron/.local/share/JetBrains/Toolbox/scripts" + + +export PATH +unset -f append_path + + + +EDITOR="vim" +if command -v nvim &> /dev/null; then + EDITOR="nvim" +fi + +export EDITOR + diff --git a/.zshrc b/.zshrc new file mode 100644 index 0000000..e1077f4 --- /dev/null +++ b/.zshrc @@ -0,0 +1,148 @@ +# +# $ZDOTDIR/.zshrc +# + +# If not running interactively, don't do anything +[[ $- != *i* ]] && return + + +source $ZDOTDIR/.aliases + + +CACHE_DIR=${XDG_CACHE_HOME:-$HOME/.cache} +STATE_DIR=${XDG_STATE_HOME:-$HOME/.local/state} + + +# The following lines were added by compinstall + +zstyle ':completion:*' completer _expand _complete _ignored +zstyle ':completion:*' ignore-parents parent pwd .. directory +zstyle ':completion:*' max-errors 2 +zstyle ':completion:*' prompt 'Corrected %e errors' +zstyle ':completion:*' squeeze-slashes true +zstyle ':completion:*' cache-path $CACHE_DIR/zsh/zcompcache +zstyle :compinstall filename '/home/cameron-arch/.config/zsh/.zshrc' + +autoload -Uz compinit +compinit -d $CACHE_DIR/zsh/zcompdump-$ZSH_VERSION +# End of lines added by compinstall + +# Lines configured by zsh-newuser-install +HISTFILE="$STATE_DIR/zsh/history" +HISTSIZE=1000 +SAVEHIST=1000 +setopt beep nomatch notify +bindkey -e +# End of lines configured by zsh-newuser-install + + +# create a zkbd compatible hash; +# to add other keys to this hash, see: man 5 terminfo +typeset -g -A key + +key[Home]="${terminfo[khome]}" +key[End]="${terminfo[kend]}" +key[Insert]="${terminfo[kich1]}" +key[Backspace]="${terminfo[kbs]}" +key[Delete]="${terminfo[kdch1]}" +key[Up]="${terminfo[kcuu1]}" +key[Down]="${terminfo[kcud1]}" +key[Left]="${terminfo[kcub1]}" +key[Right]="${terminfo[kcuf1]}" +key[PageUp]="${terminfo[kpp]}" +key[PageDown]="${terminfo[knp]}" +key[Shift-Tab]="${terminfo[kcbt]}" +key[Control-Left]="${terminfo[kLFT5]}" +key[Control-Right]="${terminfo[kRIT5]}" + +# setup key accordingly +[[ -n "${key[Home]}" ]] && bindkey -- "${key[Home]}" beginning-of-line +[[ -n "${key[End]}" ]] && bindkey -- "${key[End]}" end-of-line +[[ -n "${key[Insert]}" ]] && bindkey -- "${key[Insert]}" overwrite-mode +[[ -n "${key[Backspace]}" ]] && bindkey -- "${key[Backspace]}" backward-delete-char +[[ -n "${key[Delete]}" ]] && bindkey -- "${key[Delete]}" delete-char +[[ -n "${key[Up]}" ]] && bindkey -- "${key[Up]}" up-line-or-history +[[ -n "${key[Down]}" ]] && bindkey -- "${key[Down]}" down-line-or-history +[[ -n "${key[Left]}" ]] && bindkey -- "${key[Left]}" backward-char +[[ -n "${key[Right]}" ]] && bindkey -- "${key[Right]}" forward-char +[[ -n "${key[PageUp]}" ]] && bindkey -- "${key[PageUp]}" beginning-of-buffer-or-history +[[ -n "${key[PageDown]}" ]] && bindkey -- "${key[PageDown]}" end-of-buffer-or-history +[[ -n "${key[Shift-Tab]}" ]] && bindkey -- "${key[Shift-Tab]}" reverse-menu-complete +[[ -n "${key[Control-Left]}" ]] && bindkey -- "${key[Control-Left]}" backward-word +[[ -n "${key[Control-Right]}" ]] && bindkey -- "${key[Control-Right]}" forward-word + +# Finally, make sure the terminal is in application mode, when zle is +# active. Only then are the values from $terminfo valid. +if (( ${+terminfo[smkx]} && ${+terminfo[rmkx]} )); then + autoload -Uz add-zle-hook-widget + function zle_application_mode_start { echoti smkx } + function zle_application_mode_stop { echoti rmkx } + add-zle-hook-widget -Uz zle-line-init zle_application_mode_start + add-zle-hook-widget -Uz zle-line-finish zle_application_mode_stop +fi + + + +# Configure prompt +setopt prompt_subst +PROMPT_COLORS='' +PROMPT_PREFIXES='' + +function set_prompt() { + local colors=(${(@s:~:)PROMPT_COLORS}) + local prefixes=(${(@s:~:)PROMPT_PREFIXES}) + + local prefix='' + for i in $(seq 1 "${#prefixes[@]}"); do + prefix+="%F{${colors[$i]:-255}}${prefixes[$i]}%F{255} " + done + + PROMPT="[${prefix}%n@%m %1~]%(#.#.$) " +} + +typeset -a precmd_functions +precmd_functions+=(set_prompt) + + + +# Setup bookmarks +BOOKMARKS_DIR="$HOME/bookmarks" +mkdir -p "$BOOKMARKS_DIR" +export CDPATH="$HOME:$BOOKMARKS_DIR" + +function bookmark() { + target="$(pwd)" + mark_name="${1:-$(basename $(pwd))}" + + if [ -e "$BOOKMARKS_DIR/$mark_name" ]; then + echo "Bookmark for $mark_name already exists" + else + ln -s "$target" "$BOOKMARKS_DIR/$mark_name" + echo "Created bookmark $mark_name to $target" + fi +} + +function rmbookmark() { + if [ -z "$1" ]; then + echo "Usage: $0 [mark_name]" + else + if [ ! -L "$BOOKMARKS_DIR/$1" ]; then + echo "No bookmark with name $1" + else + rm "$BOOKMARKS_DIR/$1" + fi + fi +} + + + +# Initialize direnv if it exists +if command -v direnv &> /dev/null; then + eval "$(direnv hook zsh)" +fi + + +# Unset extra variables +unset CACHE_DIR +unset STATE_DIR +