initial commit
This commit is contained in:
parent
f555d223d3
commit
c0c365a8b2
34
.bash_aliases
Normal file
34
.bash_aliases
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
alias ll='ls --color=auto -lh'
|
||||||
|
alias l.='ls --color=auto -d .*'
|
||||||
|
|
||||||
|
alias diff='diff --color=auto'
|
||||||
|
alias grep='grep --color=auto'
|
||||||
|
alias ip='ip -color=auto'
|
||||||
|
alias pupdate='paru -Syu --devel'
|
||||||
|
|
||||||
|
# Systemctl and Journalctl
|
||||||
|
alias sstart='systemctl start'
|
||||||
|
alias sstatus='systemctl status'
|
||||||
|
alias sstop='systemctl stop'
|
||||||
|
alias ju='journalctl -xeu'
|
||||||
|
alias jfu='journalctl -fu'
|
||||||
|
|
||||||
|
# dmesg
|
||||||
|
alias dmesg='sudo dmesg --color=always | bat'
|
||||||
|
|
||||||
|
# Docker
|
||||||
|
alias compose-reload='docker-compose down && docker-compose up -d'
|
||||||
|
alias compose-up='docker-compose up -d'
|
||||||
|
alias compose-down='docker-compose down'
|
||||||
|
|
||||||
|
# Kitty Commands
|
||||||
|
alias edit='edit-in-kitty'
|
||||||
|
alias s='kitty +kitten ssh'
|
||||||
|
alias lsh='ls --hyperlink=auto'
|
||||||
|
alias send='kitty +kitten transfer'
|
||||||
|
alias recv='kitty +kitten transfer --direction=receive'
|
||||||
|
|
||||||
|
# Konsole
|
||||||
|
# alias remotecol='konsoleprofile colors=LinuxColors'
|
||||||
|
# alias resetcol='konsoleprofile colors=Dracula'
|
||||||
|
# alias ssh-artix='remotecol; ssh artix; resetcol;'
|
7
.bash_profile
Normal file
7
.bash_profile
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#
|
||||||
|
# ~/.bash_profile
|
||||||
|
#
|
||||||
|
|
||||||
|
[[ -f ~/.bashrc ]] && . ~/.bashrc
|
||||||
|
|
||||||
|
export PATH="$HOME/.local/bin:$PATH"
|
111
.bashrc
Normal file
111
.bashrc
Normal file
|
@ -0,0 +1,111 @@
|
||||||
|
#
|
||||||
|
# ~/.bashrc
|
||||||
|
#
|
||||||
|
# [[ $- == *i* ]] && source /usr/share/blesh/ble.sh --noattach
|
||||||
|
source_if_exist() {
|
||||||
|
[[ -f "$1" ]] && source "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
source_if_exist ~/.bash_aliases
|
||||||
|
source_if_exist /usr/share/doc/pkgfile/command-not-found.bash
|
||||||
|
|
||||||
|
d=.dircolors
|
||||||
|
test -r $d && eval "$(dircolors $d)"
|
||||||
|
|
||||||
|
complete -c man which
|
||||||
|
|
||||||
|
# Manage history
|
||||||
|
export HISTFILESIZE=100000
|
||||||
|
export HISTSIZE=100000
|
||||||
|
export HISTTIMEFORMAT="[%F %T] "
|
||||||
|
export HISTCONTROL=erasedups
|
||||||
|
|
||||||
|
shopt -s autocd
|
||||||
|
|
||||||
|
[[ -f /usr/bin/zoxide ]] && eval "$(zoxide init bash)"
|
||||||
|
|
||||||
|
|
||||||
|
if [[ $- != *i* ]] ; then
|
||||||
|
# Shell is non-interactive. Be done now!
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
shopt -s checkwinsize
|
||||||
|
shopt -s no_empty_cmd_completion
|
||||||
|
shopt -s histappend
|
||||||
|
|
||||||
|
#PROMPT_COMMAND='history -a'
|
||||||
|
|
||||||
|
# Change the window title of X terminals
|
||||||
|
case ${TERM} in
|
||||||
|
[aEkx]term*|rxvt*|gnome*|konsole*|interix|tmux*)
|
||||||
|
PS1='\[\033]0;\u@\h:\w\007\]'
|
||||||
|
;;
|
||||||
|
screen*)
|
||||||
|
PS1='\[\033k\u@\h:\w\033\\\]'
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
unset PS1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
use_color=false
|
||||||
|
if type -P dircolors >/dev/null ; then
|
||||||
|
LS_COLORS=
|
||||||
|
if [[ -f ~/.dir_colors ]] ; then
|
||||||
|
eval "$(dircolors -b ~/.dir_colors)"
|
||||||
|
elif [[ -f /etc/DIR_COLORS ]] ; then
|
||||||
|
eval "$(dircolors -b /etc/DIR_COLORS)"
|
||||||
|
else
|
||||||
|
eval "$(dircolors -b)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n ${LS_COLORS:+set} ]] ; then
|
||||||
|
use_color=true
|
||||||
|
else
|
||||||
|
unset LS_COLORS
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
case ${TERM} in
|
||||||
|
[aEkx]term*|rxvt*|gnome*|konsole*|screen|tmux|cons25|*color) use_color=true;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ${use_color} ; then
|
||||||
|
if [[ ${EUID} == 0 ]] ; then
|
||||||
|
PS1+='\[\033[01;31m\]\h\[\033[01;34m\] \w \$\[\033[00m\] '
|
||||||
|
else
|
||||||
|
PS1+='\[\033[01;32m\]\u@\h\[\033[01;34m\] \w \$\[\033[00m\] '
|
||||||
|
fi
|
||||||
|
|
||||||
|
#BSD#@export CLICOLOR=1
|
||||||
|
#GNU#@alias ls='ls --color=auto'
|
||||||
|
alias grep='grep --colour=auto'
|
||||||
|
else
|
||||||
|
# show root@ when we don't have colors
|
||||||
|
PS1+='\u@\h \w \$ '
|
||||||
|
fi
|
||||||
|
|
||||||
|
for sh in /etc/bash/bashrc.d/* ; do
|
||||||
|
[[ -r ${sh} ]] && source "${sh}"
|
||||||
|
done
|
||||||
|
|
||||||
|
# Try to keep environment pollution down, EPA loves us.
|
||||||
|
unset use_color sh
|
||||||
|
|
||||||
|
# >>> conda initialize >>>
|
||||||
|
# !! Contents within this block are managed by 'conda init' !!
|
||||||
|
__conda_setup="$('/opt/miniconda3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)"
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
eval "$__conda_setup"
|
||||||
|
else
|
||||||
|
if [ -f "/opt/miniconda3/etc/profile.d/conda.sh" ]; then
|
||||||
|
. "/opt/miniconda3/etc/profile.d/conda.sh"
|
||||||
|
else
|
||||||
|
export PATH="/opt/miniconda3/bin:$PATH"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
unset __conda_setup
|
||||||
|
# <<< conda initialize <<<
|
||||||
|
|
||||||
|
___MY_VMOPTIONS_SHELL_FILE="${HOME}/.jetbrains.vmoptions.sh"; if [ -f "${___MY_VMOPTIONS_SHELL_FILE}" ]; then . "${___MY_VMOPTIONS_SHELL_FILE}"; fi
|
251
.dircolors
Normal file
251
.dircolors
Normal file
|
@ -0,0 +1,251 @@
|
||||||
|
# Configuration file for dircolors, a utility to help you set the
|
||||||
|
# LS_COLORS environment variable used by GNU ls with the --color option.
|
||||||
|
|
||||||
|
# Copyright (C) 1996-2023 Free Software Foundation, Inc.
|
||||||
|
# Copying and distribution of this file, with or without modification,
|
||||||
|
# are permitted provided the copyright notice and this notice are preserved.
|
||||||
|
|
||||||
|
#
|
||||||
|
# The keywords COLOR, OPTIONS, and EIGHTBIT (honored by the
|
||||||
|
# slackware version of dircolors) are recognized but ignored.
|
||||||
|
|
||||||
|
# Global config options can be specified before TERM or COLORTERM entries
|
||||||
|
|
||||||
|
# ===================================================================
|
||||||
|
# Terminal filters
|
||||||
|
# ===================================================================
|
||||||
|
# Below are TERM or COLORTERM entries, which can be glob patterns, which
|
||||||
|
# restrict following config to systems with matching environment variables.
|
||||||
|
COLORTERM ?*
|
||||||
|
TERM Eterm
|
||||||
|
TERM ansi
|
||||||
|
TERM *color*
|
||||||
|
TERM con[0-9]*x[0-9]*
|
||||||
|
TERM cons25
|
||||||
|
TERM console
|
||||||
|
TERM cygwin
|
||||||
|
TERM *direct*
|
||||||
|
TERM dtterm
|
||||||
|
TERM gnome
|
||||||
|
TERM hurd
|
||||||
|
TERM jfbterm
|
||||||
|
TERM konsole
|
||||||
|
TERM kterm
|
||||||
|
TERM linux
|
||||||
|
TERM linux-c
|
||||||
|
TERM mlterm
|
||||||
|
TERM putty
|
||||||
|
TERM rxvt*
|
||||||
|
TERM screen*
|
||||||
|
TERM st
|
||||||
|
TERM terminator
|
||||||
|
TERM tmux*
|
||||||
|
TERM vt48;2;98;114;164
|
||||||
|
TERM xterm*
|
||||||
|
|
||||||
|
# ===================================================================
|
||||||
|
# Basic file attributes
|
||||||
|
# ===================================================================
|
||||||
|
# Below are the color init strings for the basic file types.
|
||||||
|
# One can use codes for 256 or more colors supported by modern terminals.
|
||||||
|
# The default color codes use the capabilities of an 8 color terminal
|
||||||
|
# with some additional attributes as per the following codes:
|
||||||
|
# Attribute codes:
|
||||||
|
# 00=none 01=bold 04=underscore 05=blink 07=reverse 08=concealed
|
||||||
|
# Text color codes:
|
||||||
|
# 38;2;33;34;44=black 38;2;255;85;85=red 38;2;80;250;123=green 38;2;241;250;140=yellow 38;2;189;147;249=blue 38;2;255;121;198=magenta 38;2;139;233;253=cyan 38;2;248;248;242=white
|
||||||
|
# Background color codes:
|
||||||
|
# 48;2;33;34;44=black 48;2;255;85;85=red 48;2;80;250;123=green 48;2;241;250;140=yellow 48;2;189;147;249=blue 48;2;255;121;198=magenta 48;2;139;233;253=cyan 48;2;248;248;242=white
|
||||||
|
#NORMAL 00 # no color code at all
|
||||||
|
#FILE 00 # regular file: use no color at all
|
||||||
|
RESET 0 # reset to "normal" color
|
||||||
|
DIR 01;38;2;189;147;249 # directory
|
||||||
|
LINK 01;38;2;139;233;253 # symbolic link. (If you set this to 'target' instead of a
|
||||||
|
# numerical value, the color is as for the file pointed to.)
|
||||||
|
MULTIHARDLINK 00 # regular file with more than one link
|
||||||
|
FIFO 48;2;33;34;44;38;2;241;250;140 # pipe
|
||||||
|
SOCK 01;38;2;255;121;198 # socket
|
||||||
|
DOOR 01;38;2;255;121;198 # door
|
||||||
|
BLK 48;2;33;34;44;38;2;241;250;140;01 # block device driver
|
||||||
|
CHR 48;2;33;34;44;38;2;241;250;140;01 # character device driver
|
||||||
|
ORPHAN 48;2;33;34;44;38;2;255;85;85;01 # symlink to nonexistent file, or non-stat'able file ...
|
||||||
|
MISSING 00 # ... and the files they point to
|
||||||
|
SETUID 38;2;248;248;242;48;2;255;85;85 # file that is setuid (u+s)
|
||||||
|
SETGID 38;2;33;34;44;48;2;241;250;140 # file that is setgid (g+s)
|
||||||
|
CAPABILITY 00 # file with capability (very expensive to lookup)
|
||||||
|
STICKY_OTHER_WRITABLE 38;2;33;34;44;48;2;80;250;123 # dir that is sticky and other-writable (+t,o+w)
|
||||||
|
OTHER_WRITABLE 38;2;189;147;249;48;2;80;250;123 # dir that is other-writable (o+w) and not sticky
|
||||||
|
STICKY 38;2;248;248;242;48;2;189;147;249 # dir with the sticky bit set (+t) and not other-writable
|
||||||
|
|
||||||
|
# This is for files with execute permission:
|
||||||
|
EXEC 01;38;2;80;250;123
|
||||||
|
|
||||||
|
# ===================================================================
|
||||||
|
# File extension attributes
|
||||||
|
# ===================================================================
|
||||||
|
# List any file extensions like '.gz' or '.tar' that you would like ls
|
||||||
|
# to color below. Put the suffix, a space, and the color init string.
|
||||||
|
# (and any comments you want to add after a '#').
|
||||||
|
# Suffixes are matched case insensitively, but if you define different
|
||||||
|
# init strings for separate cases, those will be honored.
|
||||||
|
#
|
||||||
|
|
||||||
|
# If you use DOS-style suffixes, you may want to uncomment the following:
|
||||||
|
#.cmd 01;38;2;80;250;123 # executables (bright green)
|
||||||
|
#.exe 01;38;2;80;250;123
|
||||||
|
#.com 01;38;2;80;250;123
|
||||||
|
#.btm 01;38;2;80;250;123
|
||||||
|
#.bat 01;38;2;80;250;123
|
||||||
|
# Or if you want to color scripts even if they do not have the
|
||||||
|
# executable bit actually set.
|
||||||
|
#.sh 01;38;2;80;250;123
|
||||||
|
#.csh 01;38;2;80;250;123
|
||||||
|
|
||||||
|
# archives or compressed (bright red)
|
||||||
|
.tar 01;38;2;255;85;85
|
||||||
|
.tgz 01;38;2;255;85;85
|
||||||
|
.arc 01;38;2;255;85;85
|
||||||
|
.arj 01;38;2;255;85;85
|
||||||
|
.taz 01;38;2;255;85;85
|
||||||
|
.lha 01;38;2;255;85;85
|
||||||
|
.lz4 01;38;2;255;85;85
|
||||||
|
.lzh 01;38;2;255;85;85
|
||||||
|
.lzma 01;38;2;255;85;85
|
||||||
|
.tlz 01;38;2;255;85;85
|
||||||
|
.txz 01;38;2;255;85;85
|
||||||
|
.tzo 01;38;2;255;85;85
|
||||||
|
.t7z 01;38;2;255;85;85
|
||||||
|
.zip 01;38;2;255;85;85
|
||||||
|
.z 01;38;2;255;85;85
|
||||||
|
.dz 01;38;2;255;85;85
|
||||||
|
.gz 01;38;2;255;85;85
|
||||||
|
.lrz 01;38;2;255;85;85
|
||||||
|
.lz 01;38;2;255;85;85
|
||||||
|
.lzo 01;38;2;255;85;85
|
||||||
|
.xz 01;38;2;255;85;85
|
||||||
|
.zst 01;38;2;255;85;85
|
||||||
|
.tzst 01;38;2;255;85;85
|
||||||
|
.bz2 01;38;2;255;85;85
|
||||||
|
.bz 01;38;2;255;85;85
|
||||||
|
.tbz 01;38;2;255;85;85
|
||||||
|
.tbz2 01;38;2;255;85;85
|
||||||
|
.tz 01;38;2;255;85;85
|
||||||
|
.deb 01;38;2;255;85;85
|
||||||
|
.rpm 01;38;2;255;85;85
|
||||||
|
.jar 01;38;2;255;85;85
|
||||||
|
.war 01;38;2;255;85;85
|
||||||
|
.ear 01;38;2;255;85;85
|
||||||
|
.sar 01;38;2;255;85;85
|
||||||
|
.rar 01;38;2;255;85;85
|
||||||
|
.alz 01;38;2;255;85;85
|
||||||
|
.ace 01;38;2;255;85;85
|
||||||
|
.zoo 01;38;2;255;85;85
|
||||||
|
.cpio 01;38;2;255;85;85
|
||||||
|
.7z 01;38;2;255;85;85
|
||||||
|
.rz 01;38;2;255;85;85
|
||||||
|
.cab 01;38;2;255;85;85
|
||||||
|
.wim 01;38;2;255;85;85
|
||||||
|
.swm 01;38;2;255;85;85
|
||||||
|
.dwm 01;38;2;255;85;85
|
||||||
|
.esd 01;38;2;255;85;85
|
||||||
|
|
||||||
|
# image formats
|
||||||
|
.avif 01;38;2;255;121;198
|
||||||
|
.jpg 01;38;2;255;121;198
|
||||||
|
.jpeg 01;38;2;255;121;198
|
||||||
|
.mjpg 01;38;2;255;121;198
|
||||||
|
.mjpeg 01;38;2;255;121;198
|
||||||
|
.gif 01;38;2;255;121;198
|
||||||
|
.bmp 01;38;2;255;121;198
|
||||||
|
.pbm 01;38;2;255;121;198
|
||||||
|
.pgm 01;38;2;255;121;198
|
||||||
|
.ppm 01;38;2;255;121;198
|
||||||
|
.tga 01;38;2;255;121;198
|
||||||
|
.xbm 01;38;2;255;121;198
|
||||||
|
.xpm 01;38;2;255;121;198
|
||||||
|
.tif 01;38;2;255;121;198
|
||||||
|
.tiff 01;38;2;255;121;198
|
||||||
|
.png 01;38;2;255;121;198
|
||||||
|
.svg 01;38;2;255;121;198
|
||||||
|
.svgz 01;38;2;255;121;198
|
||||||
|
.mng 01;38;2;255;121;198
|
||||||
|
.pcx 01;38;2;255;121;198
|
||||||
|
.mov 01;38;2;255;121;198
|
||||||
|
.mpg 01;38;2;255;121;198
|
||||||
|
.mpeg 01;38;2;255;121;198
|
||||||
|
.m2v 01;38;2;255;121;198
|
||||||
|
.mkv 01;38;2;255;121;198
|
||||||
|
.webm 01;38;2;255;121;198
|
||||||
|
.webp 01;38;2;255;121;198
|
||||||
|
.ogm 01;38;2;255;121;198
|
||||||
|
.mp4 01;38;2;255;121;198
|
||||||
|
.m4v 01;38;2;255;121;198
|
||||||
|
.mp4v 01;38;2;255;121;198
|
||||||
|
.vob 01;38;2;255;121;198
|
||||||
|
.qt 01;38;2;255;121;198
|
||||||
|
.nuv 01;38;2;255;121;198
|
||||||
|
.wmv 01;38;2;255;121;198
|
||||||
|
.asf 01;38;2;255;121;198
|
||||||
|
.rm 01;38;2;255;121;198
|
||||||
|
.rmvb 01;38;2;255;121;198
|
||||||
|
.flc 01;38;2;255;121;198
|
||||||
|
.avi 01;38;2;255;121;198
|
||||||
|
.fli 01;38;2;255;121;198
|
||||||
|
.flv 01;38;2;255;121;198
|
||||||
|
.gl 01;38;2;255;121;198
|
||||||
|
.dl 01;38;2;255;121;198
|
||||||
|
.xcf 01;38;2;255;121;198
|
||||||
|
.xwd 01;38;2;255;121;198
|
||||||
|
.yuv 01;38;2;255;121;198
|
||||||
|
.cgm 01;38;2;255;121;198
|
||||||
|
.emf 01;38;2;255;121;198
|
||||||
|
|
||||||
|
# https://wiki.xiph.org/MIME_Types_and_File_Extensions
|
||||||
|
.ogv 01;38;2;255;121;198
|
||||||
|
.ogx 01;38;2;255;121;198
|
||||||
|
|
||||||
|
# audio formats
|
||||||
|
.aac 00;38;2;139;233;253
|
||||||
|
.au 00;38;2;139;233;253
|
||||||
|
.flac 00;38;2;139;233;253
|
||||||
|
.m4a 00;38;2;139;233;253
|
||||||
|
.mid 00;38;2;139;233;253
|
||||||
|
.midi 00;38;2;139;233;253
|
||||||
|
.mka 00;38;2;139;233;253
|
||||||
|
.mp3 00;38;2;139;233;253
|
||||||
|
.mpc 00;38;2;139;233;253
|
||||||
|
.ogg 00;38;2;139;233;253
|
||||||
|
.ra 00;38;2;139;233;253
|
||||||
|
.wav 00;38;2;139;233;253
|
||||||
|
|
||||||
|
# https://wiki.xiph.org/MIME_Types_and_File_Extensions
|
||||||
|
.oga 00;38;2;139;233;253
|
||||||
|
.opus 00;38;2;139;233;253
|
||||||
|
.spx 00;38;2;139;233;253
|
||||||
|
.xspf 00;38;2;139;233;253
|
||||||
|
|
||||||
|
# backup files
|
||||||
|
*~ 00;38;2;98;114;164
|
||||||
|
*# 00;38;2;98;114;164
|
||||||
|
.bak 00;38;2;98;114;164
|
||||||
|
.crdownload 00;38;2;98;114;164
|
||||||
|
.dpkg-dist 00;38;2;98;114;164
|
||||||
|
.dpkg-new 00;38;2;98;114;164
|
||||||
|
.dpkg-old 00;38;2;98;114;164
|
||||||
|
.dpkg-tmp 00;38;2;98;114;164
|
||||||
|
.old 00;38;2;98;114;164
|
||||||
|
.orig 00;38;2;98;114;164
|
||||||
|
.part 00;38;2;98;114;164
|
||||||
|
.rej 00;38;2;98;114;164
|
||||||
|
.rpmnew 00;38;2;98;114;164
|
||||||
|
.rpmorig 00;38;2;98;114;164
|
||||||
|
.rpmsave 00;38;2;98;114;164
|
||||||
|
.swp 00;38;2;98;114;164
|
||||||
|
.tmp 00;38;2;98;114;164
|
||||||
|
.ucf-dist 00;38;2;98;114;164
|
||||||
|
.ucf-new 00;38;2;98;114;164
|
||||||
|
.ucf-old 00;38;2;98;114;164
|
||||||
|
|
||||||
|
#
|
||||||
|
# Subsequent TERM or COLORTERM entries, can be used to add / override
|
||||||
|
# config specific to those matching environment variables.
|
18
.jetbrains.vmoptions.sh
Normal file
18
.jetbrains.vmoptions.sh
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
#!/bin/sh
|
||||||
|
export IDEA_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/idea.vmoptions"
|
||||||
|
export CLION_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/clion.vmoptions"
|
||||||
|
export PHPSTORM_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/phpstorm.vmoptions"
|
||||||
|
export GOLAND_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/goland.vmoptions"
|
||||||
|
export PYCHARM_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/pycharm.vmoptions"
|
||||||
|
export WEBSTORM_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/webstorm.vmoptions"
|
||||||
|
export WEBIDE_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/webide.vmoptions"
|
||||||
|
export RIDER_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/rider.vmoptions"
|
||||||
|
export DATAGRIP_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/datagrip.vmoptions"
|
||||||
|
export RUBYMINE_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/rubymine.vmoptions"
|
||||||
|
export APPCODE_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/appcode.vmoptions"
|
||||||
|
export DATASPELL_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/dataspell.vmoptions"
|
||||||
|
export GATEWAY_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/gateway.vmoptions"
|
||||||
|
export JETBRAINS_CLIENT_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/jetbrains_client.vmoptions"
|
||||||
|
export JETBRAINSCLIENT_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/jetbrainsclient.vmoptions"
|
||||||
|
export STUDIO_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/studio.vmoptions"
|
||||||
|
export DEVECOSTUDIO_VM_OPTIONS="/home/hirad/Data/Tools/ja-netfilter-202x/ja-netfilter/vmoptions/devecostudio.vmoptions"
|
1
.profile
Normal file
1
.profile
Normal file
|
@ -0,0 +1 @@
|
||||||
|
___MY_VMOPTIONS_SHELL_FILE="${HOME}/.jetbrains.vmoptions.sh"; if [ -f "${___MY_VMOPTIONS_SHELL_FILE}" ]; then . "${___MY_VMOPTIONS_SHELL_FILE}"; fi
|
34
.zsh/aliases.zsh
Normal file
34
.zsh/aliases.zsh
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
alias ls='ls --color=auto'
|
||||||
|
alias ll='ls --color=auto -lh'
|
||||||
|
alias l.='ls --color=auto -d .*'
|
||||||
|
|
||||||
|
alias diff='diff --color=auto'
|
||||||
|
alias grep='grep --color=auto'
|
||||||
|
alias ip='ip -color=auto'
|
||||||
|
alias pupdate='paru -Syu --devel'
|
||||||
|
|
||||||
|
alias cd='z'
|
||||||
|
alias mkcd='mkdir $@ && cd $_'
|
||||||
|
|
||||||
|
# Systemctl and journalctl
|
||||||
|
alias sstart='systemctl restart'
|
||||||
|
alias sstatus='systemctl status'
|
||||||
|
alias sstop='systemctl stop'
|
||||||
|
alias ju='journalctl -xeu'
|
||||||
|
alias jfu='journalctl -fu'
|
||||||
|
|
||||||
|
# dmesg
|
||||||
|
alias dmesg='sudo dmesg --color=always | bat'
|
||||||
|
|
||||||
|
# Docker
|
||||||
|
alias compose-reload='docker-compose down && docker-compose up -d'
|
||||||
|
alias compose-up='docker-compose up -d'
|
||||||
|
alias compose-down='docker-compose down'
|
||||||
|
alias compose-pull='docker-compose pull'
|
||||||
|
|
||||||
|
# Kitty Commands
|
||||||
|
alias edit='edit-in-kitty'
|
||||||
|
alias s='kitty +kitten ssh'
|
||||||
|
alias lsh='ls --hyperlink=auto'
|
||||||
|
alias send='kitty +kitten transfer'
|
||||||
|
alias recv='kitty +kitten transfer --direction=receive'
|
65
.zsh/keys.zsh
Normal file
65
.zsh/keys.zsh
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
# 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
|
||||||
|
|
||||||
|
bindkey '^[[1;5A' history-beginning-search-backward
|
||||||
|
bindkey '^[[1;5B' history-beginning-search-forward
|
||||||
|
|
||||||
|
autoload -U history-search-end
|
||||||
|
zle -N history-beginning-search-backward-end history-search-end
|
||||||
|
zle -N history-beginning-search-forward-end history-search-end
|
||||||
|
bindkey "^[[A" history-beginning-search-backward-end
|
||||||
|
bindkey "^[[B" history-beginning-search-forward-end
|
||||||
|
|
||||||
|
# Use C-w to kill back to the previous space
|
||||||
|
zle -N backward-kill-space-word backward-kill-word-match
|
||||||
|
zstyle :zle:backward-kill-space-word word-style space
|
||||||
|
bindkey '^W' backward-kill-space-word
|
||||||
|
# Use C-u to kill to the beginning of the line
|
||||||
|
bindkey '^U' backward-kill-line
|
||||||
|
|
||||||
|
# Use C-x C-e to end the current commandline in $Visal
|
||||||
|
autoload -Uz edit-command-line
|
||||||
|
zle -N edit-command-line
|
||||||
|
bindkey '^X^E' edit-command-line
|
74
.zsh/themes/catppuccin_frappe-zsh-syntax-highlighting.zsh
Normal file
74
.zsh/themes/catppuccin_frappe-zsh-syntax-highlighting.zsh
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
# Catppuccin Frappe Theme (for zsh-syntax-highlighting)
|
||||||
|
#
|
||||||
|
# Paste this files contents inside your ~/.zshrc before you activate zsh-syntax-highlighting
|
||||||
|
ZSH_HIGHLIGHT_HIGHLIGHTERS=(main cursor)
|
||||||
|
typeset -gA ZSH_HIGHLIGHT_STYLES
|
||||||
|
|
||||||
|
# Main highlighter styling: https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters/main.md
|
||||||
|
#
|
||||||
|
## General
|
||||||
|
### Diffs
|
||||||
|
### Markup
|
||||||
|
## Classes
|
||||||
|
## Comments
|
||||||
|
ZSH_HIGHLIGHT_STYLES[comment]='fg=#626880'
|
||||||
|
## Constants
|
||||||
|
## Entitites
|
||||||
|
## Functions/methods
|
||||||
|
ZSH_HIGHLIGHT_STYLES[alias]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[suffix-alias]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[global-alias]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[function]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[precommand]='fg=#a6d189,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[autodirectory]='fg=#ef9f76,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-hyphen-option]='fg=#ef9f76'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-hyphen-option]='fg=#ef9f76'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument]='fg=#ca9ee6'
|
||||||
|
## Keywords
|
||||||
|
## Built ins
|
||||||
|
ZSH_HIGHLIGHT_STYLES[builtin]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[reserved-word]='fg=#a6d189'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[hashed-command]='fg=#a6d189'
|
||||||
|
## Punctuation
|
||||||
|
ZSH_HIGHLIGHT_STYLES[commandseparator]='fg=#e78284'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-unquoted]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[process-substitution-delimiter]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-delimiter]='fg=#e78284'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]='fg=#e78284'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-dollar-quoted-argument]='fg=#e78284'
|
||||||
|
## Serializable / Configuration Languages
|
||||||
|
## Storage
|
||||||
|
## Strings
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-quoted]='fg=#e5c890'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-quoted]='fg=#e5c890'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument]='fg=#e5c890'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument-unclosed]='fg=#ea999c'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument]='fg=#e5c890'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument-unclosed]='fg=#ea999c'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[rc-quote]='fg=#e5c890'
|
||||||
|
## Variables
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument-unclosed]='fg=#ea999c'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[assign]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[named-fd]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[numeric-fd]='fg=#c6d0f5'
|
||||||
|
## No category relevant in spec
|
||||||
|
ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=#ea999c'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path]='fg=#c6d0f5,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_pathseparator]='fg=#e78284,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix]='fg=#c6d0f5,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix_pathseparator]='fg=#e78284,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[globbing]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[history-expansion]='fg=#ca9ee6'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution-unquoted]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[process-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[arithmetic-expansion]='fg=?'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-unclosed]='fg=#ea999c'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[redirection]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[arg0]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[default]='fg=#c6d0f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[cursor]='fg=#c6d0f5'
|
74
.zsh/themes/catppuccin_latte-zsh-syntax-highlighting.zsh
Normal file
74
.zsh/themes/catppuccin_latte-zsh-syntax-highlighting.zsh
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
# Catppuccin Latte Theme (for zsh-syntax-highlighting)
|
||||||
|
#
|
||||||
|
# Paste this files contents inside your ~/.zshrc before you activate zsh-syntax-highlighting
|
||||||
|
ZSH_HIGHLIGHT_HIGHLIGHTERS=(main cursor)
|
||||||
|
typeset -gA ZSH_HIGHLIGHT_STYLES
|
||||||
|
|
||||||
|
# Main highlighter styling: https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters/main.md
|
||||||
|
#
|
||||||
|
## General
|
||||||
|
### Diffs
|
||||||
|
### Markup
|
||||||
|
## Classes
|
||||||
|
## Comments
|
||||||
|
ZSH_HIGHLIGHT_STYLES[comment]='fg=#acb0be'
|
||||||
|
## Constants
|
||||||
|
## Entitites
|
||||||
|
## Functions/methods
|
||||||
|
ZSH_HIGHLIGHT_STYLES[alias]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[suffix-alias]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[global-alias]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[function]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[precommand]='fg=#40a02b,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[autodirectory]='fg=#fe640b,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-hyphen-option]='fg=#fe640b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-hyphen-option]='fg=#fe640b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument]='fg=#8839ef'
|
||||||
|
## Keywords
|
||||||
|
## Built ins
|
||||||
|
ZSH_HIGHLIGHT_STYLES[builtin]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[reserved-word]='fg=#40a02b'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[hashed-command]='fg=#40a02b'
|
||||||
|
## Punctuation
|
||||||
|
ZSH_HIGHLIGHT_STYLES[commandseparator]='fg=#d20f39'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-unquoted]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[process-substitution-delimiter]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-delimiter]='fg=#d20f39'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]='fg=#d20f39'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-dollar-quoted-argument]='fg=#d20f39'
|
||||||
|
## Serializable / Configuration Languages
|
||||||
|
## Storage
|
||||||
|
## Strings
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-quoted]='fg=#df8e1d'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-quoted]='fg=#df8e1d'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument]='fg=#df8e1d'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument]='fg=#df8e1d'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[rc-quote]='fg=#df8e1d'
|
||||||
|
## Variables
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[assign]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[named-fd]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[numeric-fd]='fg=#4c4f69'
|
||||||
|
## No category relevant in spec
|
||||||
|
ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path]='fg=#4c4f69,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_pathseparator]='fg=#d20f39,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix]='fg=#4c4f69,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix_pathseparator]='fg=#d20f39,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[globbing]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[history-expansion]='fg=#8839ef'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution-unquoted]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[process-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[arithmetic-expansion]='fg=?'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[redirection]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[arg0]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[default]='fg=#4c4f69'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[cursor]='fg=#4c4f69'
|
74
.zsh/themes/catppuccin_macchiato-zsh-syntax-highlighting.zsh
Normal file
74
.zsh/themes/catppuccin_macchiato-zsh-syntax-highlighting.zsh
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
# Catppuccin Macchiato Theme (for zsh-syntax-highlighting)
|
||||||
|
#
|
||||||
|
# Paste this files contents inside your ~/.zshrc before you activate zsh-syntax-highlighting
|
||||||
|
ZSH_HIGHLIGHT_HIGHLIGHTERS=(main cursor)
|
||||||
|
typeset -gA ZSH_HIGHLIGHT_STYLES
|
||||||
|
|
||||||
|
# Main highlighter styling: https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters/main.md
|
||||||
|
#
|
||||||
|
## General
|
||||||
|
### Diffs
|
||||||
|
### Markup
|
||||||
|
## Classes
|
||||||
|
## Comments
|
||||||
|
ZSH_HIGHLIGHT_STYLES[comment]='fg=#5b6078'
|
||||||
|
## Constants
|
||||||
|
## Entitites
|
||||||
|
## Functions/methods
|
||||||
|
ZSH_HIGHLIGHT_STYLES[alias]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[suffix-alias]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[global-alias]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[function]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[precommand]='fg=#a6da95,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[autodirectory]='fg=#f5a97f,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-hyphen-option]='fg=#f5a97f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-hyphen-option]='fg=#f5a97f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument]='fg=#c6a0f6'
|
||||||
|
## Keywords
|
||||||
|
## Built ins
|
||||||
|
ZSH_HIGHLIGHT_STYLES[builtin]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[reserved-word]='fg=#a6da95'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[hashed-command]='fg=#a6da95'
|
||||||
|
## Punctuation
|
||||||
|
ZSH_HIGHLIGHT_STYLES[commandseparator]='fg=#ed8796'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-unquoted]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[process-substitution-delimiter]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-delimiter]='fg=#ed8796'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]='fg=#ed8796'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-dollar-quoted-argument]='fg=#ed8796'
|
||||||
|
## Serializable / Configuration Languages
|
||||||
|
## Storage
|
||||||
|
## Strings
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-quoted]='fg=#eed49f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-quoted]='fg=#eed49f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument]='fg=#eed49f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument-unclosed]='fg=#ee99a0'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument]='fg=#eed49f'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument-unclosed]='fg=#ee99a0'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[rc-quote]='fg=#eed49f'
|
||||||
|
## Variables
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument-unclosed]='fg=#ee99a0'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[assign]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[named-fd]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[numeric-fd]='fg=#cad3f5'
|
||||||
|
## No category relevant in spec
|
||||||
|
ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=#ee99a0'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path]='fg=#cad3f5,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_pathseparator]='fg=#ed8796,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix]='fg=#cad3f5,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix_pathseparator]='fg=#ed8796,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[globbing]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[history-expansion]='fg=#c6a0f6'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution-unquoted]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[process-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[arithmetic-expansion]='fg=?'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-unclosed]='fg=#ee99a0'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[redirection]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[arg0]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[default]='fg=#cad3f5'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[cursor]='fg=#cad3f5'
|
74
.zsh/themes/catppuccin_mocha-zsh-syntax-highlighting.zsh
Normal file
74
.zsh/themes/catppuccin_mocha-zsh-syntax-highlighting.zsh
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
# Catppuccin Mocha Theme (for zsh-syntax-highlighting)
|
||||||
|
#
|
||||||
|
# Paste this files contents inside your ~/.zshrc before you activate zsh-syntax-highlighting
|
||||||
|
ZSH_HIGHLIGHT_HIGHLIGHTERS=(main cursor)
|
||||||
|
typeset -gA ZSH_HIGHLIGHT_STYLES
|
||||||
|
|
||||||
|
# Main highlighter styling: https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters/main.md
|
||||||
|
#
|
||||||
|
## General
|
||||||
|
### Diffs
|
||||||
|
### Markup
|
||||||
|
## Classes
|
||||||
|
## Comments
|
||||||
|
ZSH_HIGHLIGHT_STYLES[comment]='fg=#585b70'
|
||||||
|
## Constants
|
||||||
|
## Entitites
|
||||||
|
## Functions/methods
|
||||||
|
ZSH_HIGHLIGHT_STYLES[alias]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[suffix-alias]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[global-alias]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[function]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[precommand]='fg=#a6e3a1,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[autodirectory]='fg=#fab387,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-hyphen-option]='fg=#fab387'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-hyphen-option]='fg=#fab387'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument]='fg=#cba6f7'
|
||||||
|
## Keywords
|
||||||
|
## Built ins
|
||||||
|
ZSH_HIGHLIGHT_STYLES[builtin]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[reserved-word]='fg=#a6e3a1'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[hashed-command]='fg=#a6e3a1'
|
||||||
|
## Punctuation
|
||||||
|
ZSH_HIGHLIGHT_STYLES[commandseparator]='fg=#f38ba8'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-unquoted]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[process-substitution-delimiter]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-delimiter]='fg=#f38ba8'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]='fg=#f38ba8'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-dollar-quoted-argument]='fg=#f38ba8'
|
||||||
|
## Serializable / Configuration Languages
|
||||||
|
## Storage
|
||||||
|
## Strings
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-quoted]='fg=#f9e2af'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-quoted]='fg=#f9e2af'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument]='fg=#f9e2af'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument]='fg=#f9e2af'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[rc-quote]='fg=#f9e2af'
|
||||||
|
## Variables
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[assign]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[named-fd]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[numeric-fd]='fg=#cdd6f4'
|
||||||
|
## No category relevant in spec
|
||||||
|
ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path]='fg=#cdd6f4,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_pathseparator]='fg=#f38ba8,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix]='fg=#cdd6f4,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix_pathseparator]='fg=#f38ba8,underline'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[globbing]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[history-expansion]='fg=#cba6f7'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution-unquoted]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[process-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[arithmetic-expansion]='fg=?'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-unclosed]='fg=#e64553'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[redirection]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[arg0]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[default]='fg=#cdd6f4'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[cursor]='fg=#cdd6f4'
|
90
.zsh/themes/dracula-zsh-syntax-highlighting.zsh
Normal file
90
.zsh/themes/dracula-zsh-syntax-highlighting.zsh
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
# Dracula Theme (for zsh-syntax-highlighting)
|
||||||
|
#
|
||||||
|
# https://github.com/zenorocha/dracula-theme
|
||||||
|
#
|
||||||
|
# Copyright 2021, All rights reserved
|
||||||
|
#
|
||||||
|
# Code licensed under the MIT license
|
||||||
|
# http://zenorocha.mit-license.org
|
||||||
|
#
|
||||||
|
# @author George Pickering <@bigpick>
|
||||||
|
# @author Zeno Rocha <hi@zenorocha.com>
|
||||||
|
# Paste this files contents inside your ~/.zshrc before you activate zsh-syntax-highlighting
|
||||||
|
ZSH_HIGHLIGHT_HIGHLIGHTERS=(main cursor)
|
||||||
|
typeset -gA ZSH_HIGHLIGHT_STYLES
|
||||||
|
# Default groupings per, https://spec.draculatheme.com, try to logically separate
|
||||||
|
# possible ZSH_HIGHLIGHT_STYLES settings accordingly...?
|
||||||
|
#
|
||||||
|
# Italics not yet supported by zsh; potentially soon:
|
||||||
|
# https://github.com/zsh-users/zsh-syntax-highlighting/issues/432
|
||||||
|
# https://www.zsh.org/mla/workers/2021/msg00678.html
|
||||||
|
# ... in hopes that they will, labelling accordingly with ,italic where appropriate
|
||||||
|
#
|
||||||
|
# Main highlighter styling: https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters/main.md
|
||||||
|
#
|
||||||
|
## General
|
||||||
|
### Diffs
|
||||||
|
### Markup
|
||||||
|
## Classes
|
||||||
|
## Comments
|
||||||
|
ZSH_HIGHLIGHT_STYLES[comment]='fg=#6272A4'
|
||||||
|
## Constants
|
||||||
|
## Entitites
|
||||||
|
## Functions/methods
|
||||||
|
ZSH_HIGHLIGHT_STYLES[alias]='fg=#50FA7B'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[suffix-alias]='fg=#50FA7B'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[global-alias]='fg=#50FA7B'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[function]='fg=#50FA7B'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command]='fg=#50FA7B'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[precommand]='fg=#50FA7B,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[autodirectory]='fg=#FFB86C,italic'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-hyphen-option]='fg=#FFB86C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-hyphen-option]='fg=#FFB86C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument]='fg=#BD93F9'
|
||||||
|
## Keywords
|
||||||
|
## Built ins
|
||||||
|
ZSH_HIGHLIGHT_STYLES[builtin]='fg=#8BE9FD'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[reserved-word]='fg=#8BE9FD'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[hashed-command]='fg=#8BE9FD'
|
||||||
|
## Punctuation
|
||||||
|
ZSH_HIGHLIGHT_STYLES[commandseparator]='fg=#FF79C6'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-unquoted]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[process-substitution-delimiter]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-delimiter]='fg=#FF79C6'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-double-quoted-argument]='fg=#FF79C6'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-dollar-quoted-argument]='fg=#FF79C6'
|
||||||
|
## Serializable / Configuration Languages
|
||||||
|
## Storage
|
||||||
|
## Strings
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-quoted]='fg=#F1FA8C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[command-substitution-delimiter-quoted]='fg=#F1FA8C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument]='fg=#F1FA8C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[single-quoted-argument-unclosed]='fg=#FF5555'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument]='fg=#F1FA8C'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[double-quoted-argument-unclosed]='fg=#FF5555'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[rc-quote]='fg=#F1FA8C'
|
||||||
|
## Variables
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-quoted-argument-unclosed]='fg=#FF5555'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[dollar-double-quoted-argument]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[assign]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[named-fd]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[numeric-fd]='fg=#F8F8F2'
|
||||||
|
## No category relevant in spec
|
||||||
|
ZSH_HIGHLIGHT_STYLES[unknown-token]='fg=#FF5555'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_pathseparator]='fg=#FF79C6'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[path_prefix_pathseparator]='fg=#FF79C6'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[globbing]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[history-expansion]='fg=#BD93F9'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[command-substitution-unquoted]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[process-substitution]='fg=?'
|
||||||
|
#ZSH_HIGHLIGHT_STYLES[arithmetic-expansion]='fg=?'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[back-quoted-argument-unclosed]='fg=#FF5555'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[redirection]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[arg0]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[default]='fg=#F8F8F2'
|
||||||
|
ZSH_HIGHLIGHT_STYLES[cursor]='standout'
|
240
.zsh/themes/dracula.zsh
Normal file
240
.zsh/themes/dracula.zsh
Normal file
|
@ -0,0 +1,240 @@
|
||||||
|
# -*- mode: sh; -*-
|
||||||
|
# vim: set ft=sh :
|
||||||
|
# Dracula Theme v1.2.5
|
||||||
|
#
|
||||||
|
# https://github.com/dracula/dracula-theme
|
||||||
|
#
|
||||||
|
# Copyright 2019, All rights reserved
|
||||||
|
#
|
||||||
|
# Code licensed under the MIT license
|
||||||
|
# http://zenorocha.mit-license.org
|
||||||
|
#
|
||||||
|
# @author Zeno Rocha <hi@zenorocha.com>
|
||||||
|
# @maintainer Avalon Williams <avalonwilliams@protonmail.com>
|
||||||
|
|
||||||
|
# Initialization {{{
|
||||||
|
source ${0:A:h}/lib/async.zsh
|
||||||
|
autoload -Uz add-zsh-hook
|
||||||
|
setopt PROMPT_SUBST
|
||||||
|
async_init
|
||||||
|
PROMPT=''
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Options {{{
|
||||||
|
# Set to 0 to disable the git status
|
||||||
|
DRACULA_DISPLAY_GIT=${DRACULA_DISPLAY_GIT:-1}
|
||||||
|
|
||||||
|
# Set to 1 to show the date
|
||||||
|
DRACULA_DISPLAY_TIME=${DRACULA_DISPLAY_TIME:-0}
|
||||||
|
|
||||||
|
# Set to 1 to show the 'context' segment
|
||||||
|
DRACULA_DISPLAY_CONTEXT=${DRACULA_DISPLAY_CONTEXT:-0}
|
||||||
|
|
||||||
|
# Changes the arrow icon
|
||||||
|
DRACULA_ARROW_ICON=${DRACULA_ARROW_ICON:-➜ }
|
||||||
|
|
||||||
|
# Set to 1 to use a new line for commands
|
||||||
|
DRACULA_DISPLAY_NEW_LINE=${DRACULA_DISPLAY_NEW_LINE:-0}
|
||||||
|
|
||||||
|
# Set to 1 to show full path of current working directory
|
||||||
|
DRACULA_DISPLAY_FULL_CWD=${DRACULA_DISPLAY_FULL_CWD:-0}
|
||||||
|
|
||||||
|
# function to detect if git has support for --no-optional-locks
|
||||||
|
dracula_test_git_optional_lock() {
|
||||||
|
local git_version=${DEBUG_OVERRIDE_V:-"$(git version | cut -d' ' -f3)"}
|
||||||
|
local git_version="$(git version | cut -d' ' -f3)"
|
||||||
|
# test for git versions < 2.14.0
|
||||||
|
case "$git_version" in
|
||||||
|
[0-1].*)
|
||||||
|
echo 0
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
2.[0-9].*)
|
||||||
|
echo 0
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
2.1[0-3].*)
|
||||||
|
echo 0
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# if version > 2.14.0 return true
|
||||||
|
echo 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# use --no-optional-locks flag on git
|
||||||
|
DRACULA_GIT_NOLOCK=${DRACULA_GIT_NOLOCK:-$(dracula_test_git_optional_lock)}
|
||||||
|
|
||||||
|
# time format string
|
||||||
|
if [[ -z "$DRACULA_TIME_FORMAT" ]]; then
|
||||||
|
DRACULA_TIME_FORMAT="%-H:%M"
|
||||||
|
# check if locale uses AM and PM
|
||||||
|
if locale -ck LC_TIME 2>/dev/null | grep -q '^t_fmt="%r"$'; then
|
||||||
|
DRACULA_TIME_FORMAT="%-I:%M%p"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Status segment {{{
|
||||||
|
dracula_arrow() {
|
||||||
|
if [[ "$1" = "start" ]] && (( ! DRACULA_DISPLAY_NEW_LINE )); then
|
||||||
|
print -P "$DRACULA_ARROW_ICON"
|
||||||
|
elif [[ "$1" = "end" ]] && (( DRACULA_DISPLAY_NEW_LINE )); then
|
||||||
|
print -P "\n$DRACULA_ARROW_ICON"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# arrow is green if last command was successful, red if not,
|
||||||
|
# turns yellow in vi command mode
|
||||||
|
PROMPT+='%(1V:%F{yellow}:%(?:%F{green}:%F{red}))%B$(dracula_arrow start)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Time segment {{{
|
||||||
|
dracula_time_segment() {
|
||||||
|
if (( DRACULA_DISPLAY_TIME )); then
|
||||||
|
print -P "%D{$DRACULA_TIME_FORMAT} "
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT+='%F{green}%B$(dracula_time_segment)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# User context segment {{{
|
||||||
|
dracula_context() {
|
||||||
|
if (( DRACULA_DISPLAY_CONTEXT )); then
|
||||||
|
if [[ -n "${SSH_CONNECTION-}${SSH_CLIENT-}${SSH_TTY-}" ]] || (( EUID == 0 )); then
|
||||||
|
echo '%n@%m '
|
||||||
|
else
|
||||||
|
echo '%n '
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT+='%F{magenta}%B$(dracula_context)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Directory segment {{{
|
||||||
|
dracula_directory() {
|
||||||
|
if (( DRACULA_DISPLAY_FULL_CWD )); then
|
||||||
|
print -P '%~ '
|
||||||
|
else
|
||||||
|
print -P '%c '
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT+='%F{blue}%B$(dracula_directory)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Custom variable {{{
|
||||||
|
custom_variable_prompt() {
|
||||||
|
[[ -z "$DRACULA_CUSTOM_VARIABLE" ]] && return
|
||||||
|
echo "%F{yellow}$DRACULA_CUSTOM_VARIABLE "
|
||||||
|
}
|
||||||
|
|
||||||
|
PROMPT+='$(custom_variable_prompt)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Async git segment {{{
|
||||||
|
|
||||||
|
dracula_git_status() {
|
||||||
|
(( ! DRACULA_DISPLAY_GIT )) && return
|
||||||
|
cd "$1"
|
||||||
|
|
||||||
|
local ref branch lockflag
|
||||||
|
|
||||||
|
(( DRACULA_GIT_NOLOCK )) && lockflag="--no-optional-locks"
|
||||||
|
|
||||||
|
ref=$(=git $lockflag symbolic-ref --quiet HEAD 2>/dev/null)
|
||||||
|
|
||||||
|
case $? in
|
||||||
|
0) ;;
|
||||||
|
128) return ;;
|
||||||
|
*) ref=$(=git $lockflag rev-parse --short HEAD 2>/dev/null) || return ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
branch=${ref#refs/heads/}
|
||||||
|
|
||||||
|
if [[ -n $branch ]]; then
|
||||||
|
echo -n "${ZSH_THEME_GIT_PROMPT_PREFIX}${branch}"
|
||||||
|
|
||||||
|
local git_status icon
|
||||||
|
git_status="$(LC_ALL=C =git $lockflag status 2>&1)"
|
||||||
|
|
||||||
|
if [[ "$git_status" =~ 'new file:|deleted:|modified:|renamed:|Untracked files:' ]]; then
|
||||||
|
echo -n "$ZSH_THEME_GIT_PROMPT_DIRTY"
|
||||||
|
else
|
||||||
|
echo -n "$ZSH_THEME_GIT_PROMPT_CLEAN"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -n "$ZSH_THEME_GIT_PROMPT_SUFFIX"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
dracula_git_callback() {
|
||||||
|
DRACULA_GIT_STATUS="$3"
|
||||||
|
zle && zle reset-prompt
|
||||||
|
async_stop_worker dracula_git_worker dracula_git_status "$(pwd)"
|
||||||
|
}
|
||||||
|
|
||||||
|
dracula_git_async() {
|
||||||
|
async_start_worker dracula_git_worker -n
|
||||||
|
async_register_callback dracula_git_worker dracula_git_callback
|
||||||
|
async_job dracula_git_worker dracula_git_status "$(pwd)"
|
||||||
|
}
|
||||||
|
|
||||||
|
add-zsh-hook precmd dracula_git_async
|
||||||
|
|
||||||
|
PROMPT+='$DRACULA_GIT_STATUS'
|
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN=") %F{green}%B✔ "
|
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY=") %F{yellow}%B✗ "
|
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX="%F{cyan}%B("
|
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%f%b"
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# Linebreak {{{
|
||||||
|
PROMPT+='%(1V:%F{yellow}:%(?:%F{green}:%F{red}))%B$(dracula_arrow end)'
|
||||||
|
# }}}
|
||||||
|
|
||||||
|
# define widget without clobbering old definitions
|
||||||
|
dracula_defwidget() {
|
||||||
|
local fname=dracula-wrap-$1
|
||||||
|
local prev=($(zle -l -L "$1"))
|
||||||
|
local oldfn=${prev[4]:-$1}
|
||||||
|
|
||||||
|
# if no existing zle functions, just define it normally
|
||||||
|
if [[ -z "$prev" ]]; then
|
||||||
|
zle -N $1 $2
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# if already defined, return
|
||||||
|
[[ "${prev[4]}" = $fname ]] && return
|
||||||
|
|
||||||
|
oldfn=${prev[4]:-$1}
|
||||||
|
|
||||||
|
zle -N dracula-old-$oldfn $oldfn
|
||||||
|
|
||||||
|
eval "$fname() { $2 \"\$@\"; zle dracula-old-$oldfn -- \"\$@\"; }"
|
||||||
|
|
||||||
|
zle -N $1 $fname
|
||||||
|
}
|
||||||
|
|
||||||
|
# ensure vi mode is handled by prompt
|
||||||
|
dracula_zle_update() {
|
||||||
|
if [[ $KEYMAP = vicmd ]]; then
|
||||||
|
psvar[1]=vicmd
|
||||||
|
else
|
||||||
|
psvar[1]=''
|
||||||
|
fi
|
||||||
|
|
||||||
|
zle reset-prompt
|
||||||
|
zle -R
|
||||||
|
}
|
||||||
|
|
||||||
|
dracula_defwidget zle-line-init dracula_zle_update
|
||||||
|
dracula_defwidget zle-keymap-select dracula_zle_update
|
||||||
|
|
||||||
|
# Ensure effects are reset
|
||||||
|
PROMPT+='%f%b'
|
672
.zsh/themes/lib/async.zsh
Normal file
672
.zsh/themes/lib/async.zsh
Normal file
|
@ -0,0 +1,672 @@
|
||||||
|
#!/usr/bin/env zsh
|
||||||
|
|
||||||
|
#
|
||||||
|
# zsh-async
|
||||||
|
#
|
||||||
|
# version: v1.8.5
|
||||||
|
# author: Mathias Fredriksson
|
||||||
|
# url: https://github.com/mafredri/zsh-async
|
||||||
|
#
|
||||||
|
|
||||||
|
typeset -g ASYNC_VERSION=1.8.5
|
||||||
|
# Produce debug output from zsh-async when set to 1.
|
||||||
|
typeset -g ASYNC_DEBUG=${ASYNC_DEBUG:-0}
|
||||||
|
|
||||||
|
# Execute commands that can manipulate the environment inside the async worker. Return output via callback.
|
||||||
|
_async_eval() {
|
||||||
|
local ASYNC_JOB_NAME
|
||||||
|
# Rename job to _async_eval and redirect all eval output to cat running
|
||||||
|
# in _async_job. Here, stdout and stderr are not separated for
|
||||||
|
# simplicity, this could be improved in the future.
|
||||||
|
{
|
||||||
|
eval "$@"
|
||||||
|
} &> >(ASYNC_JOB_NAME=[async/eval] _async_job 'command -p cat')
|
||||||
|
}
|
||||||
|
|
||||||
|
# Wrapper for jobs executed by the async worker, gives output in parseable format with execution time
|
||||||
|
_async_job() {
|
||||||
|
# Disable xtrace as it would mangle the output.
|
||||||
|
setopt localoptions noxtrace
|
||||||
|
|
||||||
|
# Store start time for job.
|
||||||
|
float -F duration=$EPOCHREALTIME
|
||||||
|
|
||||||
|
# Run the command and capture both stdout (`eval`) and stderr (`cat`) in
|
||||||
|
# separate subshells. When the command is complete, we grab write lock
|
||||||
|
# (mutex token) and output everything except stderr inside the command
|
||||||
|
# block, after the command block has completed, the stdin for `cat` is
|
||||||
|
# closed, causing stderr to be appended with a $'\0' at the end to mark the
|
||||||
|
# end of output from this job.
|
||||||
|
local jobname=${ASYNC_JOB_NAME:-$1} out
|
||||||
|
out="$(
|
||||||
|
local stdout stderr ret tok
|
||||||
|
{
|
||||||
|
stdout=$(eval "$@")
|
||||||
|
ret=$?
|
||||||
|
duration=$(( EPOCHREALTIME - duration )) # Calculate duration.
|
||||||
|
|
||||||
|
print -r -n - $'\0'${(q)jobname} $ret ${(q)stdout} $duration
|
||||||
|
} 2> >(stderr=$(command -p cat) && print -r -n - " "${(q)stderr}$'\0')
|
||||||
|
)"
|
||||||
|
if [[ $out != $'\0'*$'\0' ]]; then
|
||||||
|
# Corrupted output (aborted job?), skipping.
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Grab mutex lock, stalls until token is available.
|
||||||
|
read -r -k 1 -p tok || return 1
|
||||||
|
|
||||||
|
# Return output (<job_name> <return_code> <stdout> <duration> <stderr>).
|
||||||
|
print -r -n - "$out"
|
||||||
|
|
||||||
|
# Unlock mutex by inserting a token.
|
||||||
|
print -n -p $tok
|
||||||
|
}
|
||||||
|
|
||||||
|
# The background worker manages all tasks and runs them without interfering with other processes
|
||||||
|
_async_worker() {
|
||||||
|
# Reset all options to defaults inside async worker.
|
||||||
|
emulate -R zsh
|
||||||
|
|
||||||
|
# Make sure monitor is unset to avoid printing the
|
||||||
|
# pids of child processes.
|
||||||
|
unsetopt monitor
|
||||||
|
|
||||||
|
# Redirect stderr to `/dev/null` in case unforseen errors produced by the
|
||||||
|
# worker. For example: `fork failed: resource temporarily unavailable`.
|
||||||
|
# Some older versions of zsh might also print malloc errors (know to happen
|
||||||
|
# on at least zsh 5.0.2 and 5.0.8) likely due to kill signals.
|
||||||
|
exec 2>/dev/null
|
||||||
|
|
||||||
|
# When a zpty is deleted (using -d) all the zpty instances created before
|
||||||
|
# the one being deleted receive a SIGHUP, unless we catch it, the async
|
||||||
|
# worker would simply exit (stop working) even though visible in the list
|
||||||
|
# of zpty's (zpty -L). This has been fixed around the time of Zsh 5.4
|
||||||
|
# (not released).
|
||||||
|
if ! is-at-least 5.4.1; then
|
||||||
|
TRAPHUP() {
|
||||||
|
return 0 # Return 0, indicating signal was handled.
|
||||||
|
}
|
||||||
|
fi
|
||||||
|
|
||||||
|
local -A storage
|
||||||
|
local unique=0
|
||||||
|
local notify_parent=0
|
||||||
|
local parent_pid=0
|
||||||
|
local coproc_pid=0
|
||||||
|
local processing=0
|
||||||
|
|
||||||
|
local -a zsh_hooks zsh_hook_functions
|
||||||
|
zsh_hooks=(chpwd periodic precmd preexec zshexit zshaddhistory)
|
||||||
|
zsh_hook_functions=(${^zsh_hooks}_functions)
|
||||||
|
unfunction $zsh_hooks &>/dev/null # Deactivate all zsh hooks inside the worker.
|
||||||
|
unset $zsh_hook_functions # And hooks with registered functions.
|
||||||
|
unset zsh_hooks zsh_hook_functions # Cleanup.
|
||||||
|
|
||||||
|
close_idle_coproc() {
|
||||||
|
local -a pids
|
||||||
|
pids=(${${(v)jobstates##*:*:}%\=*})
|
||||||
|
|
||||||
|
# If coproc (cat) is the only child running, we close it to avoid
|
||||||
|
# leaving it running indefinitely and cluttering the process tree.
|
||||||
|
if (( ! processing )) && [[ $#pids = 1 ]] && [[ $coproc_pid = $pids[1] ]]; then
|
||||||
|
coproc :
|
||||||
|
coproc_pid=0
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
child_exit() {
|
||||||
|
close_idle_coproc
|
||||||
|
|
||||||
|
# On older version of zsh (pre 5.2) we notify the parent through a
|
||||||
|
# SIGWINCH signal because `zpty` did not return a file descriptor (fd)
|
||||||
|
# prior to that.
|
||||||
|
if (( notify_parent )); then
|
||||||
|
# We use SIGWINCH for compatibility with older versions of zsh
|
||||||
|
# (pre 5.1.1) where other signals (INFO, ALRM, USR1, etc.) could
|
||||||
|
# cause a deadlock in the shell under certain circumstances.
|
||||||
|
kill -WINCH $parent_pid
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Register a SIGCHLD trap to handle the completion of child processes.
|
||||||
|
trap child_exit CHLD
|
||||||
|
|
||||||
|
# Process option parameters passed to worker.
|
||||||
|
while getopts "np:uz" opt; do
|
||||||
|
case $opt in
|
||||||
|
n) notify_parent=1;;
|
||||||
|
p) parent_pid=$OPTARG;;
|
||||||
|
u) unique=1;;
|
||||||
|
z) notify_parent=0;; # Uses ZLE watcher instead.
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
# Terminate all running jobs, note that this function does not
|
||||||
|
# reinstall the child trap.
|
||||||
|
terminate_jobs() {
|
||||||
|
trap - CHLD # Ignore child exits during kill.
|
||||||
|
coproc : # Quit coproc.
|
||||||
|
coproc_pid=0 # Reset pid.
|
||||||
|
|
||||||
|
if is-at-least 5.4.1; then
|
||||||
|
trap '' HUP # Catch the HUP sent to this process.
|
||||||
|
kill -HUP -$$ # Send to entire process group.
|
||||||
|
trap - HUP # Disable HUP trap.
|
||||||
|
else
|
||||||
|
# We already handle HUP for Zsh < 5.4.1.
|
||||||
|
kill -HUP -$$ # Send to entire process group.
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
killjobs() {
|
||||||
|
local tok
|
||||||
|
local -a pids
|
||||||
|
pids=(${${(v)jobstates##*:*:}%\=*})
|
||||||
|
|
||||||
|
# No need to send SIGHUP if no jobs are running.
|
||||||
|
(( $#pids == 0 )) && continue
|
||||||
|
(( $#pids == 1 )) && [[ $coproc_pid = $pids[1] ]] && continue
|
||||||
|
|
||||||
|
# Grab lock to prevent half-written output in case a child
|
||||||
|
# process is in the middle of writing to stdin during kill.
|
||||||
|
(( coproc_pid )) && read -r -k 1 -p tok
|
||||||
|
|
||||||
|
terminate_jobs
|
||||||
|
trap child_exit CHLD # Reinstall child trap.
|
||||||
|
}
|
||||||
|
|
||||||
|
local request do_eval=0
|
||||||
|
local -a cmd
|
||||||
|
while :; do
|
||||||
|
# Wait for jobs sent by async_job.
|
||||||
|
read -r -d $'\0' request || {
|
||||||
|
# Unknown error occurred while reading from stdin, the zpty
|
||||||
|
# worker is likely in a broken state, so we shut down.
|
||||||
|
terminate_jobs
|
||||||
|
|
||||||
|
# Stdin is broken and in case this was an unintended
|
||||||
|
# crash, we try to report it as a last hurrah.
|
||||||
|
print -r -n $'\0'"'[async]'" $(( 127 + 3 )) "''" 0 "'$0:$LINENO: zpty fd died, exiting'"$'\0'
|
||||||
|
|
||||||
|
# We use `return` to abort here because using `exit` may
|
||||||
|
# result in an infinite loop that never exits and, as a
|
||||||
|
# result, high CPU utilization.
|
||||||
|
return $(( 127 + 1 ))
|
||||||
|
}
|
||||||
|
|
||||||
|
# We need to clean the input here because sometimes when a zpty
|
||||||
|
# has died and been respawned, messages will be prefixed with a
|
||||||
|
# carraige return (\r, or \C-M).
|
||||||
|
request=${request#$'\C-M'}
|
||||||
|
|
||||||
|
# Check for non-job commands sent to worker
|
||||||
|
case $request in
|
||||||
|
_killjobs) killjobs; continue;;
|
||||||
|
_async_eval*) do_eval=1;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Parse the request using shell parsing (z) to allow commands
|
||||||
|
# to be parsed from single strings and multi-args alike.
|
||||||
|
cmd=("${(z)request}")
|
||||||
|
|
||||||
|
# Name of the job (first argument).
|
||||||
|
local job=$cmd[1]
|
||||||
|
|
||||||
|
# Check if a worker should perform unique jobs, unless
|
||||||
|
# this is an eval since they run synchronously.
|
||||||
|
if (( !do_eval )) && (( unique )); then
|
||||||
|
# Check if a previous job is still running, if yes,
|
||||||
|
# skip this job and let the previous one finish.
|
||||||
|
for pid in ${${(v)jobstates##*:*:}%\=*}; do
|
||||||
|
if [[ ${storage[$job]} == $pid ]]; then
|
||||||
|
continue 2
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Guard against closing coproc from trap before command has started.
|
||||||
|
processing=1
|
||||||
|
|
||||||
|
# Because we close the coproc after the last job has completed, we must
|
||||||
|
# recreate it when there are no other jobs running.
|
||||||
|
if (( ! coproc_pid )); then
|
||||||
|
# Use coproc as a mutex for synchronized output between children.
|
||||||
|
coproc command -p cat
|
||||||
|
coproc_pid="$!"
|
||||||
|
# Insert token into coproc
|
||||||
|
print -n -p "t"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if (( do_eval )); then
|
||||||
|
shift cmd # Strip _async_eval from cmd.
|
||||||
|
_async_eval $cmd
|
||||||
|
else
|
||||||
|
# Run job in background, completed jobs are printed to stdout.
|
||||||
|
_async_job $cmd &
|
||||||
|
# Store pid because zsh job manager is extremely unflexible (show jobname as non-unique '$job')...
|
||||||
|
storage[$job]="$!"
|
||||||
|
fi
|
||||||
|
|
||||||
|
processing=0 # Disable guard.
|
||||||
|
|
||||||
|
if (( do_eval )); then
|
||||||
|
do_eval=0
|
||||||
|
|
||||||
|
# When there are no active jobs we can't rely on the CHLD trap to
|
||||||
|
# manage the coproc lifetime.
|
||||||
|
close_idle_coproc
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Get results from finished jobs and pass it to the to callback function. This is the only way to reliably return the
|
||||||
|
# job name, return code, output and execution time and with minimal effort.
|
||||||
|
#
|
||||||
|
# If the async process buffer becomes corrupt, the callback will be invoked with the first argument being `[async]` (job
|
||||||
|
# name), non-zero return code and fifth argument describing the error (stderr).
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_process_results <worker_name> <callback_function>
|
||||||
|
#
|
||||||
|
# callback_function is called with the following parameters:
|
||||||
|
# $1 = job name, e.g. the function passed to async_job
|
||||||
|
# $2 = return code
|
||||||
|
# $3 = resulting stdout from execution
|
||||||
|
# $4 = execution time, floating point e.g. 2.05 seconds
|
||||||
|
# $5 = resulting stderr from execution
|
||||||
|
# $6 = has next result in buffer (0 = buffer empty, 1 = yes)
|
||||||
|
#
|
||||||
|
async_process_results() {
|
||||||
|
setopt localoptions unset noshwordsplit noksharrays noposixidentifiers noposixstrings
|
||||||
|
|
||||||
|
local worker=$1
|
||||||
|
local callback=$2
|
||||||
|
local caller=$3
|
||||||
|
local -a items
|
||||||
|
local null=$'\0' data
|
||||||
|
integer -l len pos num_processed has_next
|
||||||
|
|
||||||
|
typeset -gA ASYNC_PROCESS_BUFFER
|
||||||
|
|
||||||
|
# Read output from zpty and parse it if available.
|
||||||
|
while zpty -r -t $worker data 2>/dev/null; do
|
||||||
|
ASYNC_PROCESS_BUFFER[$worker]+=$data
|
||||||
|
len=${#ASYNC_PROCESS_BUFFER[$worker]}
|
||||||
|
pos=${ASYNC_PROCESS_BUFFER[$worker][(i)$null]} # Get index of NULL-character (delimiter).
|
||||||
|
|
||||||
|
# Keep going until we find a NULL-character.
|
||||||
|
if (( ! len )) || (( pos > len )); then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
while (( pos <= len )); do
|
||||||
|
# Take the content from the beginning, until the NULL-character and
|
||||||
|
# perform shell parsing (z) and unquoting (Q) as an array (@).
|
||||||
|
items=("${(@Q)${(z)ASYNC_PROCESS_BUFFER[$worker][1,$pos-1]}}")
|
||||||
|
|
||||||
|
# Remove the extracted items from the buffer.
|
||||||
|
ASYNC_PROCESS_BUFFER[$worker]=${ASYNC_PROCESS_BUFFER[$worker][$pos+1,$len]}
|
||||||
|
|
||||||
|
len=${#ASYNC_PROCESS_BUFFER[$worker]}
|
||||||
|
if (( len > 1 )); then
|
||||||
|
pos=${ASYNC_PROCESS_BUFFER[$worker][(i)$null]} # Get index of NULL-character (delimiter).
|
||||||
|
fi
|
||||||
|
|
||||||
|
has_next=$(( len != 0 ))
|
||||||
|
if (( $#items == 5 )); then
|
||||||
|
items+=($has_next)
|
||||||
|
$callback "${(@)items}" # Send all parsed items to the callback.
|
||||||
|
(( num_processed++ ))
|
||||||
|
elif [[ -z $items ]]; then
|
||||||
|
# Empty items occur between results due to double-null ($'\0\0')
|
||||||
|
# caused by commands being both pre and suffixed with null.
|
||||||
|
else
|
||||||
|
# In case of corrupt data, invoke callback with *async* as job
|
||||||
|
# name, non-zero exit status and an error message on stderr.
|
||||||
|
$callback "[async]" 1 "" 0 "$0:$LINENO: error: bad format, got ${#items} items (${(q)items})" $has_next
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
(( num_processed )) && return 0
|
||||||
|
|
||||||
|
# Avoid printing exit value when `setopt printexitvalue` is active.`
|
||||||
|
[[ $caller = trap || $caller = watcher ]] && return 0
|
||||||
|
|
||||||
|
# No results were processed
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Watch worker for output
|
||||||
|
_async_zle_watcher() {
|
||||||
|
setopt localoptions noshwordsplit
|
||||||
|
typeset -gA ASYNC_PTYS ASYNC_CALLBACKS
|
||||||
|
local worker=$ASYNC_PTYS[$1]
|
||||||
|
local callback=$ASYNC_CALLBACKS[$worker]
|
||||||
|
|
||||||
|
if [[ -n $2 ]]; then
|
||||||
|
# from man zshzle(1):
|
||||||
|
# `hup' for a disconnect, `nval' for a closed or otherwise
|
||||||
|
# invalid descriptor, or `err' for any other condition.
|
||||||
|
# Systems that support only the `select' system call always use
|
||||||
|
# `err'.
|
||||||
|
|
||||||
|
# this has the side effect to unregister the broken file descriptor
|
||||||
|
async_stop_worker $worker
|
||||||
|
|
||||||
|
if [[ -n $callback ]]; then
|
||||||
|
$callback '[async]' 2 "" 0 "$0:$LINENO: error: fd for $worker failed: zle -F $1 returned error $2" 0
|
||||||
|
fi
|
||||||
|
return
|
||||||
|
fi;
|
||||||
|
|
||||||
|
if [[ -n $callback ]]; then
|
||||||
|
async_process_results $worker $callback watcher
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_async_send_job() {
|
||||||
|
setopt localoptions noshwordsplit noksharrays noposixidentifiers noposixstrings
|
||||||
|
|
||||||
|
local caller=$1
|
||||||
|
local worker=$2
|
||||||
|
shift 2
|
||||||
|
|
||||||
|
zpty -t $worker &>/dev/null || {
|
||||||
|
typeset -gA ASYNC_CALLBACKS
|
||||||
|
local callback=$ASYNC_CALLBACKS[$worker]
|
||||||
|
|
||||||
|
if [[ -n $callback ]]; then
|
||||||
|
$callback '[async]' 3 "" 0 "$0:$LINENO: error: no such worker: $worker" 0
|
||||||
|
else
|
||||||
|
print -u2 "$caller: no such async worker: $worker"
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
zpty -w $worker "$@"$'\0'
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Start a new asynchronous job on specified worker, assumes the worker is running.
|
||||||
|
#
|
||||||
|
# Note if you are using a function for the job, it must have been defined before the worker was
|
||||||
|
# started or you will get a `command not found` error.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_job <worker_name> <my_function> [<function_params>]
|
||||||
|
#
|
||||||
|
async_job() {
|
||||||
|
setopt localoptions noshwordsplit noksharrays noposixidentifiers noposixstrings
|
||||||
|
|
||||||
|
local worker=$1; shift
|
||||||
|
|
||||||
|
local -a cmd
|
||||||
|
cmd=("$@")
|
||||||
|
if (( $#cmd > 1 )); then
|
||||||
|
cmd=(${(q)cmd}) # Quote special characters in multi argument commands.
|
||||||
|
fi
|
||||||
|
|
||||||
|
_async_send_job $0 $worker "$cmd"
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Evaluate a command (like async_job) inside the async worker, then worker environment can be manipulated. For example,
|
||||||
|
# issuing a cd command will change the PWD of the worker which will then be inherited by all future async jobs.
|
||||||
|
#
|
||||||
|
# Output will be returned via callback, job name will be [async/eval].
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_worker_eval <worker_name> <my_function> [<function_params>]
|
||||||
|
#
|
||||||
|
async_worker_eval() {
|
||||||
|
setopt localoptions noshwordsplit noksharrays noposixidentifiers noposixstrings
|
||||||
|
|
||||||
|
local worker=$1; shift
|
||||||
|
|
||||||
|
local -a cmd
|
||||||
|
cmd=("$@")
|
||||||
|
if (( $#cmd > 1 )); then
|
||||||
|
cmd=(${(q)cmd}) # Quote special characters in multi argument commands.
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Quote the cmd in case RC_EXPAND_PARAM is set.
|
||||||
|
_async_send_job $0 $worker "_async_eval $cmd"
|
||||||
|
}
|
||||||
|
|
||||||
|
# This function traps notification signals and calls all registered callbacks
|
||||||
|
_async_notify_trap() {
|
||||||
|
setopt localoptions noshwordsplit
|
||||||
|
|
||||||
|
local k
|
||||||
|
for k in ${(k)ASYNC_CALLBACKS}; do
|
||||||
|
async_process_results $k ${ASYNC_CALLBACKS[$k]} trap
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Register a callback for completed jobs. As soon as a job is finnished, async_process_results will be called with the
|
||||||
|
# specified callback function. This requires that a worker is initialized with the -n (notify) option.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_register_callback <worker_name> <callback_function>
|
||||||
|
#
|
||||||
|
async_register_callback() {
|
||||||
|
setopt localoptions noshwordsplit nolocaltraps
|
||||||
|
|
||||||
|
typeset -gA ASYNC_PTYS ASYNC_CALLBACKS
|
||||||
|
local worker=$1; shift
|
||||||
|
|
||||||
|
ASYNC_CALLBACKS[$worker]="$*"
|
||||||
|
|
||||||
|
# Enable trap when the ZLE watcher is unavailable, allows
|
||||||
|
# workers to notify (via -n) when a job is done.
|
||||||
|
if [[ ! -o interactive ]] || [[ ! -o zle ]]; then
|
||||||
|
trap '_async_notify_trap' WINCH
|
||||||
|
elif [[ -o interactive ]] && [[ -o zle ]]; then
|
||||||
|
local fd w
|
||||||
|
for fd w in ${(@kv)ASYNC_PTYS}; do
|
||||||
|
if [[ $w == $worker ]]; then
|
||||||
|
zle -F $fd _async_zle_watcher # Register the ZLE handler.
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Unregister the callback for a specific worker.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_unregister_callback <worker_name>
|
||||||
|
#
|
||||||
|
async_unregister_callback() {
|
||||||
|
typeset -gA ASYNC_CALLBACKS
|
||||||
|
|
||||||
|
unset "ASYNC_CALLBACKS[$1]"
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Flush all current jobs running on a worker. This will terminate any and all running processes under the worker, use
|
||||||
|
# with caution.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_flush_jobs <worker_name>
|
||||||
|
#
|
||||||
|
async_flush_jobs() {
|
||||||
|
setopt localoptions noshwordsplit
|
||||||
|
|
||||||
|
local worker=$1; shift
|
||||||
|
|
||||||
|
# Check if the worker exists
|
||||||
|
zpty -t $worker &>/dev/null || return 1
|
||||||
|
|
||||||
|
# Send kill command to worker
|
||||||
|
async_job $worker "_killjobs"
|
||||||
|
|
||||||
|
# Clear the zpty buffer.
|
||||||
|
local junk
|
||||||
|
if zpty -r -t $worker junk '*'; then
|
||||||
|
(( ASYNC_DEBUG )) && print -n "async_flush_jobs $worker: ${(V)junk}"
|
||||||
|
while zpty -r -t $worker junk '*'; do
|
||||||
|
(( ASYNC_DEBUG )) && print -n "${(V)junk}"
|
||||||
|
done
|
||||||
|
(( ASYNC_DEBUG )) && print
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Finally, clear the process buffer in case of partially parsed responses.
|
||||||
|
typeset -gA ASYNC_PROCESS_BUFFER
|
||||||
|
unset "ASYNC_PROCESS_BUFFER[$worker]"
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Start a new async worker with optional parameters, a worker can be told to only run unique tasks and to notify a
|
||||||
|
# process when tasks are complete.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_start_worker <worker_name> [-u] [-n] [-p <pid>]
|
||||||
|
#
|
||||||
|
# opts:
|
||||||
|
# -u unique (only unique job names can run)
|
||||||
|
# -n notify through SIGWINCH signal
|
||||||
|
# -p pid to notify (defaults to current pid)
|
||||||
|
#
|
||||||
|
async_start_worker() {
|
||||||
|
setopt localoptions noshwordsplit noclobber
|
||||||
|
|
||||||
|
local worker=$1; shift
|
||||||
|
local -a args
|
||||||
|
args=("$@")
|
||||||
|
zpty -t $worker &>/dev/null && return
|
||||||
|
|
||||||
|
typeset -gA ASYNC_PTYS
|
||||||
|
typeset -h REPLY
|
||||||
|
typeset has_xtrace=0
|
||||||
|
|
||||||
|
if [[ -o interactive ]] && [[ -o zle ]]; then
|
||||||
|
# Inform the worker to ignore the notify flag and that we're
|
||||||
|
# using a ZLE watcher instead.
|
||||||
|
args+=(-z)
|
||||||
|
|
||||||
|
if (( ! ASYNC_ZPTY_RETURNS_FD )); then
|
||||||
|
# When zpty doesn't return a file descriptor (on older versions of zsh)
|
||||||
|
# we try to guess it anyway.
|
||||||
|
integer -l zptyfd
|
||||||
|
exec {zptyfd}>&1 # Open a new file descriptor (above 10).
|
||||||
|
exec {zptyfd}>&- # Close it so it's free to be used by zpty.
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Workaround for stderr in the main shell sometimes (incorrectly) being
|
||||||
|
# reassigned to /dev/null by the reassignment done inside the async
|
||||||
|
# worker.
|
||||||
|
# See https://github.com/mafredri/zsh-async/issues/35.
|
||||||
|
integer errfd=-1
|
||||||
|
|
||||||
|
# Redirect of errfd is broken on zsh 5.0.2.
|
||||||
|
if is-at-least 5.0.8; then
|
||||||
|
exec {errfd}>&2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Make sure async worker is started without xtrace
|
||||||
|
# (the trace output interferes with the worker).
|
||||||
|
[[ -o xtrace ]] && {
|
||||||
|
has_xtrace=1
|
||||||
|
unsetopt xtrace
|
||||||
|
}
|
||||||
|
|
||||||
|
if (( errfd != -1 )); then
|
||||||
|
zpty -b $worker _async_worker -p $$ $args 2>&$errfd
|
||||||
|
else
|
||||||
|
zpty -b $worker _async_worker -p $$ $args
|
||||||
|
fi
|
||||||
|
local ret=$?
|
||||||
|
|
||||||
|
# Re-enable it if it was enabled, for debugging.
|
||||||
|
(( has_xtrace )) && setopt xtrace
|
||||||
|
(( errfd != -1 )) && exec {errfd}>& -
|
||||||
|
|
||||||
|
if (( ret )); then
|
||||||
|
async_stop_worker $worker
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! is-at-least 5.0.8; then
|
||||||
|
# For ZSH versions older than 5.0.8 we delay a bit to give
|
||||||
|
# time for the worker to start before issuing commands,
|
||||||
|
# otherwise it will not be ready to receive them.
|
||||||
|
sleep 0.001
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -o interactive ]] && [[ -o zle ]]; then
|
||||||
|
if (( ! ASYNC_ZPTY_RETURNS_FD )); then
|
||||||
|
REPLY=$zptyfd # Use the guessed value for the file desciptor.
|
||||||
|
fi
|
||||||
|
|
||||||
|
ASYNC_PTYS[$REPLY]=$worker # Map the file desciptor to the worker.
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Stop one or multiple workers that are running, all unfetched and incomplete work will be lost.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_stop_worker <worker_name_1> [<worker_name_2>]
|
||||||
|
#
|
||||||
|
async_stop_worker() {
|
||||||
|
setopt localoptions noshwordsplit
|
||||||
|
|
||||||
|
local ret=0 worker k v
|
||||||
|
for worker in $@; do
|
||||||
|
# Find and unregister the zle handler for the worker
|
||||||
|
for k v in ${(@kv)ASYNC_PTYS}; do
|
||||||
|
if [[ $v == $worker ]]; then
|
||||||
|
zle -F $k
|
||||||
|
unset "ASYNC_PTYS[$k]"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
async_unregister_callback $worker
|
||||||
|
zpty -d $worker 2>/dev/null || ret=$?
|
||||||
|
|
||||||
|
# Clear any partial buffers.
|
||||||
|
typeset -gA ASYNC_PROCESS_BUFFER
|
||||||
|
unset "ASYNC_PROCESS_BUFFER[$worker]"
|
||||||
|
done
|
||||||
|
|
||||||
|
return $ret
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Initialize the required modules for zsh-async. To be called before using the zsh-async library.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# async_init
|
||||||
|
#
|
||||||
|
async_init() {
|
||||||
|
(( ASYNC_INIT_DONE )) && return
|
||||||
|
typeset -g ASYNC_INIT_DONE=1
|
||||||
|
|
||||||
|
zmodload zsh/zpty
|
||||||
|
zmodload zsh/datetime
|
||||||
|
|
||||||
|
# Load is-at-least for reliable version check.
|
||||||
|
autoload -Uz is-at-least
|
||||||
|
|
||||||
|
# Check if zsh/zpty returns a file descriptor or not,
|
||||||
|
# shell must also be interactive with zle enabled.
|
||||||
|
typeset -g ASYNC_ZPTY_RETURNS_FD=0
|
||||||
|
[[ -o interactive ]] && [[ -o zle ]] && {
|
||||||
|
typeset -h REPLY
|
||||||
|
zpty _async_test :
|
||||||
|
(( REPLY )) && ASYNC_ZPTY_RETURNS_FD=1
|
||||||
|
zpty -d _async_test
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async() {
|
||||||
|
async_init
|
||||||
|
}
|
||||||
|
|
||||||
|
async "$@"
|
46
.zshrc
Normal file
46
.zshrc
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
# Enable Powerlevel10k instant prompt. Should stay close to the top of ~/.zshrc.
|
||||||
|
# Initialization code that may require console input (password prompts, [y/n]
|
||||||
|
# confirmations, etc.) must go above this block; everything else may go below.
|
||||||
|
if [[ -r "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh" ]]; then
|
||||||
|
source "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Lines configured by zsh-newuser-install
|
||||||
|
HISTFILE=~/.histfile
|
||||||
|
HISTSIZE=100000
|
||||||
|
SAVEHIST=100000
|
||||||
|
setopt HIST_IGNORE_ALL_DUPS
|
||||||
|
setopt autocd extendedglob nomatch notify
|
||||||
|
unsetopt beep
|
||||||
|
zstyle ':completion:*' matcher-list '' 'm:{a-z}={A-Za-z}'
|
||||||
|
# End of lines configured by zsh-newuser-install
|
||||||
|
# The following lines were added by compinstall
|
||||||
|
zstyle :compinstall filename '/home/hirad/.zshrc'
|
||||||
|
|
||||||
|
autoload -Uz compinit
|
||||||
|
compinit
|
||||||
|
# End of lines added by compinstall
|
||||||
|
|
||||||
|
# To customize prompt, run `p10k configure` or edit ~/.p10k.zsh.
|
||||||
|
[[ ! -f ~/.p10k.zsh ]] || source ~/.p10k.zsh
|
||||||
|
|
||||||
|
autoload -Uz select-word-style
|
||||||
|
select-word-style bash
|
||||||
|
|
||||||
|
d=.dircolors
|
||||||
|
test -r $d && eval $(dircolors $d)
|
||||||
|
|
||||||
|
source_if_exist() {
|
||||||
|
[[ -f "$1" ]] && source "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
source_if_exist ~/.zsh/themes/dracula-zsh-syntax-highlighting.zsh
|
||||||
|
source_if_exist /usr/share/zsh-theme-powerlevel10k/powerlevel10k.zsh-theme
|
||||||
|
source_if_exist ~/.zsh/keys.zsh
|
||||||
|
source_if_exist ~/.zsh/aliases.zsh
|
||||||
|
source_if_exist /usr/share/zsh/plugins/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
|
||||||
|
source_if_exist /usr/share/zsh/plugins/zsh-autosuggestions/zsh-autosuggestions.zsh
|
||||||
|
source_if_exist ~/.zsh/themes/dracula.zsh
|
||||||
|
|
||||||
|
[[ -f /usr/bin/zoxide ]] && eval "$(zoxide init zsh)"
|
||||||
|
___MY_VMOPTIONS_SHELL_FILE="${HOME}/.jetbrains.vmoptions.sh"; if [ -f "${___MY_VMOPTIONS_SHELL_FILE}" ]; then . "${___MY_VMOPTIONS_SHELL_FILE}"; fi
|
Loading…
Reference in a new issue