Some checks failed
Nix Format Check / check-format (push) Failing after 39s
182 lines
5.3 KiB
Bash
182 lines
5.3 KiB
Bash
# HISTFILE Configuration (Bash equivalent)
|
|
HISTFILE=~/.bash_history
|
|
HISTSIZE=1000
|
|
HISTFILESIZE=2000 # Adjusted to match both histfile and size criteria
|
|
|
|
# Docker Compose Alias (Mostly for old shell scripts)
|
|
alias docker-compose='docker compose'
|
|
|
|
# tatool aliases
|
|
alias tls='tatool ls -g'
|
|
alias tps='tls'
|
|
alias ti='tatool doctor'
|
|
alias td='tatool doctor'
|
|
alias tr='tatool restart'
|
|
alias tsrc='tatool source'
|
|
|
|
# Modern tools aliases
|
|
alias l="eza --header --long --git --group-directories-first --group --icons --color=always --sort=name --hyperlink -o --no-permissions"
|
|
alias ll='l'
|
|
alias la='l -a'
|
|
alias cat='bat'
|
|
alias du='dust'
|
|
alias df='duf'
|
|
alias rm="trash-put"
|
|
|
|
# Docker Aliases
|
|
alias d='docker'
|
|
alias dc='docker compose'
|
|
alias dce='docker compose exec'
|
|
alias dcl='docker compose logs'
|
|
alias dcd='docker compose down'
|
|
alias dcu='docker compose up'
|
|
alias dcp='docker compose ps'
|
|
alias dcps='docker compose ps'
|
|
alias dcr='docker compose run'
|
|
alias ddpul='docker compose down && docker compose pull && docker compose up -d && docker compose logs -f'
|
|
alias docker-nuke='docker kill $(docker ps -q) && docker rm $(docker ps -a -q) && docker system prune --all --volumes --force && docker volume prune --force'
|
|
|
|
# Git aliases
|
|
alias g='git'
|
|
alias gg='git pull'
|
|
alias gl='git log --stat'
|
|
alias gp='git push'
|
|
alias gs='git status -s'
|
|
alias gst='git status'
|
|
alias ga='git add'
|
|
alias gc='git commit'
|
|
alias gcm='git commit -m'
|
|
alias gco='git checkout'
|
|
alias gcb='git checkout -b'
|
|
|
|
# NodeJS aliases
|
|
alias node='node-20'
|
|
alias npm='npm-20'
|
|
|
|
# Kubernetes aliases (Minikube)
|
|
alias kubectl="minikube kubectl --"
|
|
|
|
# netstat port in use check
|
|
alias port='netstat -atupn | grep LISTEN'
|
|
|
|
# random string (Syntax: random <length>)
|
|
alias random='openssl rand -base64'
|
|
|
|
# Alias for ls to l but only if it's an interactive shell because we don't want to override ls in scripts which could blow up in our face
|
|
if [ -t 1 ]; then
|
|
alias ls='l'
|
|
fi
|
|
|
|
# Alias for ssh.exe and ssh-add.exe on Windows WSL (microsoft-standard-WSL2)
|
|
if [[ $(uname -a) == *"microsoft-standard-WSL2"* ]]; then
|
|
alias op='op.exe'
|
|
fi
|
|
|
|
# PATH Manipulation
|
|
export PATH=$PATH:$HOME/.local/bin
|
|
export PATH=$PATH:$HOME/.cargo/bin
|
|
export PATH=$PATH:$HOME/dotfiles/bin
|
|
|
|
# Add flatpak to XDG_DATA_DIRS
|
|
export XDG_DATA_DIRS=$XDG_DATA_DIRS:/usr/share:/var/lib/flatpak/exports/share:$HOME/.local/share/flatpak/exports/share
|
|
|
|
# Allow unfree nixos
|
|
export NIXPKGS_ALLOW_UNFREE=1
|
|
|
|
# Allow insecure nixpkgs
|
|
export NIXPKGS_ALLOW_INSECURE=1
|
|
|
|
# Set DOTF_HOSTNAME to the hostname from .hostname file
|
|
# If this file doesn't exist, use mennos-unknown-hostname
|
|
export DOTF_HOSTNAME="mennos-unknown-hostname"
|
|
if [ -f $HOME/.hostname ]; then
|
|
export DOTF_HOSTNAME=$(cat $HOME/.hostname)
|
|
fi
|
|
|
|
# Tradaware / DiscountOffice Configuration
|
|
if [ -d "/home/menno/Projects/Work" ]; then
|
|
export TRADAWARE_DEVOPS=true
|
|
fi
|
|
|
|
# Flutter Web and other tools that require Chrome
|
|
export CHROME_EXECUTABLE=$(which brave-browser)
|
|
|
|
# 1Password Source Plugin (Assuming bash compatibility)
|
|
if [ -f /home/menno/.config/op/plugins.sh ]; then
|
|
source /home/menno/.config/op/plugins.sh
|
|
fi
|
|
|
|
# Initialize starship if available
|
|
if ! command -v starship &> /dev/null; then
|
|
echo "FYI, starship not found"
|
|
else
|
|
export STARSHIP_ENABLE_RIGHT_PROMPT=true
|
|
export STARSHIP_ENABLE_BASH_CONTINUATION=true
|
|
eval "$(starship init bash)"
|
|
fi
|
|
|
|
# Source nix home-manager
|
|
if [ -f "$HOME/.nix-profile/etc/profile.d/hm-session-vars.sh" ]; then
|
|
. "$HOME/.nix-profile/etc/profile.d/hm-session-vars.sh"
|
|
fi
|
|
|
|
# Source agent-bridge script for 1password
|
|
source $HOME/dotfiles/bin/1password-agent-bridge.sh
|
|
|
|
# zoxide if available
|
|
if command -v zoxide &> /dev/null; then
|
|
eval "$(zoxide init bash)"
|
|
fi
|
|
|
|
# Check if we are running from zellij, if not then launch it
|
|
launch_zellij_conditionally() {
|
|
if [ -z "$ZELLIJ" ]; then
|
|
# Don't launch zellij in tmux, vscode, screen or zeditor.
|
|
if [ ! -t 1 ] || [ -n "$TMUX" ] || [ -n "$VSCODE_STABLE" ] || [ -n "$STY" ] || [ -n "$ZED_TERM" ]; then
|
|
return
|
|
fi
|
|
|
|
# Launch zellij
|
|
zellij
|
|
|
|
# Exit if zellij exits properly with a zero exit code
|
|
if [ $? -eq 0 ]; then
|
|
exit $?
|
|
fi
|
|
|
|
echo "Zellij exited with a non-zero exit code, falling back to regular shell."
|
|
return
|
|
fi
|
|
}
|
|
|
|
# Disabled for now, I don't like the way it behaves but I don't want to remove it either
|
|
# launch_zellij_conditionally
|
|
|
|
# Source ble.sh if it exists
|
|
if [[ -f "${HOME}/.nix-profile/share/blesh/ble.sh" ]]; then
|
|
source "${HOME}/.nix-profile/share/blesh/ble.sh"
|
|
|
|
# Custom function for fzf history search
|
|
function fzf_history_search() {
|
|
local selected
|
|
selected=$(history | fzf --tac --height=40% --layout=reverse --border --info=inline \
|
|
--query="$READLINE_LINE" \
|
|
--color 'fg:#ebdbb2,bg:#282828,hl:#fabd2f,fg+:#ebdbb2,bg+:#3c3836,hl+:#fabd2f' \
|
|
--color 'info:#83a598,prompt:#bdae93,spinner:#fabd2f,pointer:#83a598,marker:#fe8019,header:#665c54' \
|
|
| sed 's/^ *[0-9]* *//')
|
|
if [[ -n "$selected" ]]; then
|
|
READLINE_LINE="$selected"
|
|
READLINE_POINT=${#selected}
|
|
fi
|
|
ble-redraw-prompt
|
|
}
|
|
|
|
# Bind Ctrl+R to our custom function
|
|
bind -x '"\C-r": fzf_history_search'
|
|
fi
|
|
|
|
# Display a welcome message for interactive shells
|
|
if [ -t 1 ]; then
|
|
dotf hello
|
|
fi
|