feat: Clean up .zshrc
This commit is contained in:
@@ -11,15 +11,15 @@
|
||||
"lsp_signature.nvim": { "branch": "master", "commit": "a38da0a61c172bb59e34befc12efe48359884793" },
|
||||
"lspkind.nvim": { "branch": "master", "commit": "cff4ae321a91ee3473a92ea1a8c637e3a9510aec" },
|
||||
"markview.nvim": { "branch": "main", "commit": "d0ccc97b5c988fb28e5033abdf7b832b9dfaf897" },
|
||||
"mason-lspconfig.nvim": { "branch": "main", "commit": "ba9c2f0b93deb48d0a99ae0e8d8dd36f7cc286d6" },
|
||||
"mason-lspconfig.nvim": { "branch": "main", "commit": "fd69d5c782a28420d51b648a3d7fe88df569d391" },
|
||||
"mason.nvim": { "branch": "main", "commit": "e2f7f9044ec30067bc11800a9e266664b88cda22" },
|
||||
"monokai-pro.nvim": { "branch": "master", "commit": "2bad2a92fe0ff6c8581d33a853a1b17592b83239" },
|
||||
"nvim-cmp": { "branch": "main", "commit": "ae644feb7b67bf1ce4260c231d1d4300b19c6f30" },
|
||||
"nvim-colorizer.lua": { "branch": "master", "commit": "a065833f35a3a7cc3ef137ac88b5381da2ba302e" },
|
||||
"nvim-lspconfig": { "branch": "master", "commit": "e6528f4613c8db2e04be908eb2b5886d63f62a98" },
|
||||
"nvim-treesitter": { "branch": "master", "commit": "a7a3b9c10e8a5fe0da05ebb65db3ed1d164e612d" },
|
||||
"nvim-treesitter": { "branch": "master", "commit": "d7353a6b72008b38aa873ace49aa97bea257941b" },
|
||||
"nvim-ufo": { "branch": "main", "commit": "4cc3ba9303c0708b81fd681786a4835fd31518ac" },
|
||||
"nvim-web-devicons": { "branch": "master", "commit": "5be6c4e685618b99c3210a69375b38a1202369b4" },
|
||||
"nvim-web-devicons": { "branch": "master", "commit": "3722e3d1fb5fe1896a104eb489e8f8651260b520" },
|
||||
"oil.nvim": { "branch": "master", "commit": "fcca212c2e966fc3dec1d4baf888e670631d25d1" },
|
||||
"plenary.nvim": { "branch": "master", "commit": "a3e3bc82a3f95c5ed0d7201546d5d2c19b20d683" },
|
||||
"promise-async": { "branch": "main", "commit": "038d05664fedc920ba86720214c84a15ff7432b0" },
|
||||
|
||||
201
.zshrc
201
.zshrc
@@ -4,226 +4,37 @@
|
||||
# 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
|
||||
colored-man-pages
|
||||
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";
|
||||
}
|
||||
[ -f ~/zsh/aliases.sh ] && source ~/zsh/aliases.sh
|
||||
[ -f ~/zsh/functions.sh ] && source ~/zsh/functions.sh
|
||||
|
||||
# Custom theme
|
||||
PROMPT=""
|
||||
|
||||
# Arrow
|
||||
PROMPT+="%(?:%{$fg_bold[green]%}%1{➜%} :%{$fg[red]%}%? %{$fg_bold[red]%}%1{➜%} )"
|
||||
|
||||
# Path
|
||||
PROMPT+="%{$fg[cyan]%}%c%{$reset_color%} "
|
||||
|
||||
# Arrow
|
||||
PROMPT+="%(?:%{$fg_bold[green]%}%1{➜%} :%{$fg[red]%}%? %{$fg_bold[red]%}%1{➜%} )"
|
||||
|
||||
# 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
|
||||
}
|
||||
|
||||
18
zsh/aliases.sh
Normal file
18
zsh/aliases.sh
Normal file
@@ -0,0 +1,18 @@
|
||||
# Utility
|
||||
alias ..='cd ..'
|
||||
alias cls='clear'
|
||||
|
||||
alias vencord='sh -c "$(curl -sS https://raw.githubusercontent.com/Vendicated/VencordInstaller/main/install.sh)"'
|
||||
alias apps='cd ~/.local/share/applications/'
|
||||
|
||||
# SSH
|
||||
alias louis='ssh anton@192.168.178.48'
|
||||
|
||||
# LS
|
||||
alias ls='lsd'
|
||||
alias la='lsd -a'
|
||||
alias ll='lsd -l'
|
||||
|
||||
# WG
|
||||
alias wgon='wg-quick up ~/Downloads/wg0.conf'
|
||||
alias wgoff='wg-quick down ~/Downloads/wg0.conf'
|
||||
78
zsh/functions.sh
Normal file
78
zsh/functions.sh
Normal file
@@ -0,0 +1,78 @@
|
||||
# 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
|
||||
|
||||
# make and cd into directory
|
||||
into() {
|
||||
mkdir -p "$1" && cd "$1";
|
||||
}
|
||||
|
||||
# make a new terminal
|
||||
split() {
|
||||
(kitty . &)
|
||||
}
|
||||
|
||||
# === FUNCTIONS FOR COMMAND TIMING ===
|
||||
|
||||
# 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
|
||||
|
||||
timer_start=0
|
||||
}
|
||||
Reference in New Issue
Block a user