230 lines
7.2 KiB
Bash
230 lines
7.2 KiB
Bash
# If you come from bash you might have to change your $PATH.
|
|
# export PATH=$HOME/bin:$HOME/.local/bin:/usr/local/bin:$PATH
|
|
|
|
# Path to your Oh My Zsh installation.
|
|
export ZSH="$HOME/.oh-my-zsh"
|
|
|
|
# Set name of the theme to load --- if set to "random", it will
|
|
# load a random theme each time Oh My Zsh is loaded, in which case,
|
|
# to know which specific one was loaded, run: echo $RANDOM_THEME
|
|
# See https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
|
|
ZSH_THEME="robbyrussell"
|
|
|
|
# Set list of themes to pick from when loading at random
|
|
# Setting this variable when ZSH_THEME=random will cause zsh to load
|
|
# a theme from this variable instead of looking in $ZSH/themes/
|
|
# If set to an empty array, this variable will have no effect.
|
|
# ZSH_THEME_RANDOM_CANDIDATES=( "robbyrussell" "agnoster" )
|
|
|
|
# Uncomment the following line to use case-sensitive completion.
|
|
# CASE_SENSITIVE="true"
|
|
|
|
# Uncomment the following line to use hyphen-insensitive completion.
|
|
# Case-sensitive completion must be off. _ and - will be interchangeable.
|
|
# HYPHEN_INSENSITIVE="true"
|
|
|
|
# Uncomment one of the following lines to change the auto-update behavior
|
|
# zstyle ':omz:update' mode disabled # disable automatic updates
|
|
# zstyle ':omz:update' mode auto # update automatically without asking
|
|
zstyle ':omz:update' mode reminder # just remind me to update when it's time
|
|
|
|
# Uncomment the following line to change how often to auto-update (in days).
|
|
# zstyle ':omz:update' frequency 13
|
|
|
|
# Uncomment the following line if pasting URLs and other text is messed up.
|
|
# DISABLE_MAGIC_FUNCTIONS="true"
|
|
|
|
# Uncomment the following line to disable colors in ls.
|
|
# DISABLE_LS_COLORS="true"
|
|
|
|
# Uncomment the following line to disable auto-setting terminal title.
|
|
# DISABLE_AUTO_TITLE="true"
|
|
|
|
# Uncomment the following line to enable command auto-correction.
|
|
# ENABLE_CORRECTION="true"
|
|
|
|
# Uncomment the following line to display red dots whilst waiting for completion.
|
|
# You can also set it to another string to have that shown instead of the default red dots.
|
|
# e.g. COMPLETION_WAITING_DOTS="%F{yellow}waiting...%f"
|
|
# Caution: this setting can cause issues with multiline prompts in zsh < 5.7.1 (see #5765)
|
|
# COMPLETION_WAITING_DOTS="true"
|
|
|
|
# Uncomment the following line if you want to disable marking untracked files
|
|
# under VCS as dirty. This makes repository status check for large repositories
|
|
# much, much faster.
|
|
# DISABLE_UNTRACKED_FILES_DIRTY="true"
|
|
|
|
# Uncomment the following line if you want to change the command execution time
|
|
# stamp shown in the history command output.
|
|
# You can set one of the optional three formats:
|
|
# "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd"
|
|
# or set a custom format using the strftime function format specifications,
|
|
# see 'man strftime' for details.
|
|
# HIST_STAMPS="mm/dd/yyyy"
|
|
|
|
# Would you like to use another custom folder than $ZSH/custom?
|
|
# ZSH_CUSTOM=/path/to/new-custom-folder
|
|
|
|
# Which plugins would you like to load?
|
|
# Standard plugins can be found in $ZSH/plugins/
|
|
# Custom plugins may be added to $ZSH_CUSTOM/plugins/
|
|
# Example format: plugins=(rails git textmate ruby lighthouse)
|
|
# Add wisely, as too many plugins slow down shell startup.
|
|
plugins=(
|
|
git
|
|
zsh-syntax-highlighting
|
|
# zsh-autosuggestions
|
|
zsh-autocomplete
|
|
sudo
|
|
)
|
|
|
|
zstyle ':autocomplete:*' delay 0.1 # seconds (float)
|
|
|
|
# completions
|
|
# ZSH_AUTOSUGGEST_STRATEGY=(
|
|
# history
|
|
# completion
|
|
# )
|
|
#
|
|
# # Remove forward-char widgets from ACCEPT
|
|
# ZSH_AUTOSUGGEST_ACCEPT_WIDGETS=("${(@)ZSH_AUTOSUGGEST_ACCEPT_WIDGETS:#forward-char}")
|
|
# ZSH_AUTOSUGGEST_ACCEPT_WIDGETS=("${(@)ZSH_AUTOSUGGEST_ACCEPT_WIDGETS:#autosuggest-accept}")
|
|
#
|
|
# # Add forward-char widgets to PARTIAL_ACCEPT
|
|
# ZSH_AUTOSUGGEST_PARTIAL_ACCEPT_WIDGETS+=(autosuggest-accept)
|
|
|
|
source $ZSH/oh-my-zsh.sh
|
|
|
|
# User configuration
|
|
|
|
# export MANPATH="/usr/local/man:$MANPATH"
|
|
|
|
# You may need to manually set your language environment
|
|
# export LANG=en_US.UTF-8
|
|
|
|
# Preferred editor for local and remote sessions
|
|
if [[ -n $SSH_CONNECTION ]]; then
|
|
export EDITOR='vim'
|
|
else
|
|
export EDITOR='mvim'
|
|
fi
|
|
|
|
# Compilation flags
|
|
# export ARCHFLAGS="-arch $(uname -m)"
|
|
|
|
# Set personal aliases, overriding those provided by Oh My Zsh libs,
|
|
# plugins, and themes. Aliases can be placed here, though Oh My Zsh
|
|
# users are encouraged to define aliases within a top-level file in
|
|
# the $ZSH_CUSTOM folder, with .zsh extension. Examples:
|
|
# - $ZSH_CUSTOM/aliases.zsh
|
|
# - $ZSH_CUSTOM/macos.zsh
|
|
# For a full list of active aliases, run `alias`.
|
|
#
|
|
# Example aliases
|
|
# alias zshconfig="mate ~/.zshrc"
|
|
# alias ohmyzsh="mate ~/.oh-my-zsh"
|
|
|
|
# fzf
|
|
source <(fzf --zsh)
|
|
|
|
alias ..='cd ..'
|
|
alias cls='clear'
|
|
alias explorer='nautilus'
|
|
alias vencord='sh -c "$(curl -sS https://raw.githubusercontent.com/Vendicated/VencordInstaller/main/install.sh)"'
|
|
alias apps='cd ~/.local/share/applications/'
|
|
alias tasklist='ps -aux'
|
|
alias louis='ssh anton@192.168.178.48'
|
|
alias la='ls -a --color=auto'
|
|
alias ls='ls --color=auto'
|
|
alias grep='grep --color=auto'
|
|
# WG
|
|
alias wgon='wg-quick up ~/Downloads/wg0.conf'
|
|
alias wgoff='wg-quick down ~/Downloads/wg0.conf'
|
|
|
|
# Very helpful multi-functional clip command.
|
|
clip() {
|
|
if [ -t 0 ]; then
|
|
# Standard input is not a terminal (no pipe input)
|
|
if [ $# -eq 0 ]; then
|
|
# No arguments, print clipboard content
|
|
xclip -selection clipboard -o
|
|
else
|
|
# Arguments provided, pass them to xclip
|
|
echo "$*" | xclip -selection clipboard
|
|
fi
|
|
else
|
|
# Standard input is a terminal (pipe input)
|
|
xclip -selection clipboard
|
|
fi
|
|
}
|
|
# copy text
|
|
# $ clip "hello world"
|
|
# copy cmd output
|
|
# $ cat file.js | clip
|
|
# use copied data as values, for example run a script off the clipboard
|
|
# $ clip | python3 # runs what's in the clipboard using python3
|
|
|
|
into() {
|
|
mkdir -p "$1" && cd "$1";
|
|
}
|
|
|
|
# Custom theme
|
|
PROMPT=""
|
|
|
|
# Arrow
|
|
PROMPT+="%(?:%{$fg_bold[green]%}%1{➜%} :%{$fg[red]%}%? %{$fg_bold[red]%}%1{➜%} )"
|
|
|
|
# Path
|
|
PROMPT+="%{$fg[cyan]%}%c%{$reset_color%} "
|
|
|
|
# Git
|
|
PROMPT+='$(git_prompt_info)'
|
|
|
|
# This stuff is imported from the actual Robbyrussell theme.
|
|
# ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}git:(%{$fg[red]%}"
|
|
# ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} "
|
|
# ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}%1{✗%}"
|
|
# ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[blue]%})"
|
|
|
|
# Function to capture the start time of the command
|
|
preexec() {
|
|
timer_start=$EPOCHSECONDS
|
|
}
|
|
|
|
# Function to capture the end time of the command and calculate the elapsed time
|
|
precmd() {
|
|
local timer_end=$EPOCHSECONDS
|
|
local elapsed=$((timer_end - timer_start))
|
|
|
|
# Reset RPROMPT
|
|
RPROMPT=""
|
|
|
|
if (( elapsed > 36000 )); then
|
|
return
|
|
fi
|
|
|
|
if (( elapsed > 0 )); then
|
|
local color time_str
|
|
if (( elapsed >= 60 )); then
|
|
local minutes=$((elapsed / 60))
|
|
local seconds=$((elapsed % 60))
|
|
time_str="${minutes}m ${seconds}s"
|
|
color="%{$fg_bold[red]%}"
|
|
elif (( elapsed >= 10 )); then
|
|
time_str="${elapsed}s"
|
|
color="%{$fg_bold[blue]%}"
|
|
elif (( elapsed >= 5 )); then
|
|
time_str="${elapsed}s"
|
|
color="%{$fg_bold[yellow]%}"
|
|
elif (( elapsed >= 1 )); then
|
|
time_str="${elapsed}s"
|
|
color="%{$fg_bold[green]%}"
|
|
fi
|
|
|
|
# Set RPROMPT if elapsed time is greater than or equal to 1 second
|
|
if [[ -n $time_str ]]; then
|
|
RPROMPT="${color}${time_str}%{$reset_color%}"
|
|
fi
|
|
fi
|
|
}
|