personal dotfiles: my Hyprland config
work: initial commit
| -rw-r--r-- | .bashrc | 176 | ||||
| -rw-r--r-- | .config/micro/bindings.json | 13 | ||||
| -rw-r--r-- | .config/micro/settings.json | 10 | ||||
| -rwxr-xr-x | .local/bin/csv2INSERT.sh | 6 | ||||
| -rwxr-xr-x | .local/bin/csv2sql.sh | 13 | ||||
| -rwxr-xr-x | .local/bin/emojis.sh | 80 | ||||
| l--------- | .local/bin/sxmo_dmenu.sh | 1 | ||||
| -rwxr-xr-x | .local/bin/uniq: | 16 | ||||
| -rwxr-xr-x | .local/bin/wl-copy | 2 |
9 files changed, 317 insertions, 0 deletions
@@ -0,0 +1,176 @@ +# ~/.bashrc: executed by bash(1) for non-login shells. +# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) +# for examples + +# If not running interactively, don't do anything +case $- in + *i*) ;; + *) return;; +esac + +# don't put duplicate lines or lines starting with space in the history. +# See bash(1) for more options +HISTCONTROL=ignoreboth + +# append to the history file, don't overwrite it +shopt -s histappend + +# for setting history length see HISTSIZE and HISTFILESIZE in bash(1) +HISTSIZE=10000 +HISTFILESIZE=20000 + +# check the window size after each command and, if necessary, +# update the values of LINES and COLUMNS. +shopt -s checkwinsize + +# If set, the pattern "**" used in a pathname expansion context will +# match all files and zero or more directories and subdirectories. +#shopt -s globstar + +# make less more friendly for non-text input files, see lesspipe(1) +[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)" + +# set variable identifying the chroot you work in (used in the prompt below) +if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then + debian_chroot=$(cat /etc/debian_chroot) +fi + +# set a fancy prompt (non-color, unless we know we "want" color) +case "$TERM" in + xterm-color|*-256color) color_prompt=yes;; +esac + +# uncomment for a colored prompt, if the terminal has the capability; turned +# off by default to not distract the user: the focus in a terminal window +# should be on the output of commands, not on the prompt +#force_color_prompt=yes + +if [ -n "$force_color_prompt" ]; then + if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then + # We have color support; assume it's compliant with Ecma-48 + # (ISO/IEC-6429). (Lack of such support is extremely rare, and such + # a case would tend to support setf rather than setaf.) + color_prompt=yes + else + color_prompt= + fi +fi + +if [ "$color_prompt" = yes ]; then + PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ ' +else + PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ ' +fi +unset color_prompt force_color_prompt + +# BCP prompt. +parse_git_branch() { + git branch 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/🌱 \1/' +} +export PS1="[\t \[\e[0;33m\]\w\[\e[0;35m\]\[\e[0;32m\]\$(parse_git_branch)\[\e[0;35m\]\[\033[00m\]] " + + +# If this is an xterm set the title to dir +case "$TERM" in +xterm*|rxvt*) + PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\W\a\]$PS1" + ;; +*) + ;; +esac + +# Zach Set title +#PS1_SET_TITLE='\[\e]0;\u@\h:\w\a\]' +#PS1="${PS1_SET_TITLE}${PS1}" + + +# enable color support of ls and also add handy aliases +if [ -x /usr/bin/dircolors ]; then + test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)" + alias ls='ls --color=auto' + #alias dir='dir --color=auto' + #alias vdir='vdir --color=auto' + + alias grep='grep --color=auto' + alias fgrep='fgrep --color=auto' + alias egrep='egrep --color=auto' +fi + +# colored GCC warnings and errors +#export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01' + +# some more ls aliases +alias ll='ls -alF' +alias la='ls -A' +alias l='ls -CF' + +# Add an "alert" alias for long running commands. Use like so: +# sleep 10; alert +alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"' + +# Alias definitions. +# You may want to put all your additions into a separate file like +# ~/.bash_aliases, instead of adding them here directly. +# See /usr/share/doc/bash-doc/examples in the bash-doc package. + +if [ -f ~/.bash_aliases ]; then + . ~/.bash_aliases +fi + +# enable programmable completion features (you don't need to enable +# this, if it's already enabled in /etc/bash.bashrc and /etc/profile +# sources /etc/bash.bashrc). +if ! shopt -oq posix; then + if [ -f /usr/share/bash-completion/bash_completion ]; then + . /usr/share/bash-completion/bash_completion + elif [ -f /etc/bash_completion ]; then + . /etc/bash_completion + fi +fi + + +# BCP stuff + +alias pake='export COLUMNS;./vendor/indeyets/pake/bin/pake' + +export NODE_OPTIONS="--max_old_space_size=8192" + +# Zach stuff +mggrep () { TT micro $(git grep -n "$@" | cut -d: -f1,2); }; + +mfi () { TT micro $(echo "$@" | xargs -n1 find . -not -path './vendor/*' -name | head -n 50); }; +mfd () { TT micro $(echo "$@" | xargs -n1 fd --exclude=vendor -- | head -n 50); }; + + +gg () { git grep -n "$@" | cut -d: -f1,2; }; +fin () { echo "$@" | xargs -n1 find . -not -path './vendor/*' -name | head -n 50; }; + + +# basic stuff +#alias mgm='micro $(git status -s --ignore-submodules -uno | grep -v "^D " | grep -v "^ D" | sed "s/^...//g" | sed "s/[^>]* -> //g")' +# micro git modified line-wise (open each line in a separate buffer) +#alias mgml='micro $(git diff HEAD --relative | diff-so-fancy | grep "@" | cut -d" " -f2)' +# micro git modified +#alias mgm='micro $(git diff --relative |egrep "^(\+\+\+|@@)" |uniq -w3|sed "s/+++ b/./g" |sed "s/^@@[^+]\++//g" | sed "s/@@.*//g" | paste - - -d:)' +# but start on a good line BCP +alias mgm='TT micro $(git diff HEAD --relative | diff-so-fancy | grep "@.*@" | cut -d" " -f2 | grep -v "^$" | grep -v "*" | uniq:)' + +# micro git staged +#alias mgs='micro $(git status -s --ignore-submodules -uno | grep "^M" | sed "s/^...//g" | sed "s/[^>]* -> //g")' +alias mgs='TT micro $(git diff HEAD --staged --relative | diff-so-fancy | grep "@.*@" | cut -d" " -f2 | grep -v "^$" | grep -v "*" | uniq:)' + + +# TT stuff +alias mycli='TT mycli' +#alias micro='TT micro' +alias senpai='TT senpai' + +# Typos +alias mimcro='TT micro' +alias micmro='TT micro' + +## dgs +alias mycli_admin='mycli --defaults-group-suffix=_admin' +alias mycli_prodsup='mycli --defaults-group-suffix=_ProdSup' + +eval $(thefuck --alias frick) diff --git a/.config/micro/bindings.json b/.config/micro/bindings.json new file mode 100644 index 0000000..5a7992e --- /dev/null +++ b/.config/micro/bindings.json @@ -0,0 +1,13 @@ +{ + "Alt-/": "lua:comment.comment", + "Alt-u": "command:upper", + "Alt-l": "command:lower", + "Ctrl-Down": "SpawnMultiCursorDown", + "Ctrl-MouseWheelDown": "CursorDown", + "Ctrl-MouseWheelUp": "CursorUp", + "Ctrl-Up": "SpawnMultiCursorUp", + //"CtrlA": "StartOfTextToggle", + "ShiftPageUp": "SelectPageUp", + "ShiftPageDown": "SelectPageDown", + "CtrlUnderscore": "lua:comment.comment" +} diff --git a/.config/micro/settings.json b/.config/micro/settings.json new file mode 100644 index 0000000..40123c2 --- /dev/null +++ b/.config/micro/settings.json @@ -0,0 +1,10 @@ +{ + "autoclose": false, + "autosu": true, + "basename": true, + "colorscheme": "solarized", + "mkparents": true, + "parsecursor": true, + "softwrap": true, + "tabstospaces": true +} diff --git a/.local/bin/csv2INSERT.sh b/.local/bin/csv2INSERT.sh new file mode 100755 index 0000000..1e20a67 --- /dev/null +++ b/.local/bin/csv2INSERT.sh @@ -0,0 +1,6 @@ +#!/bin/sh + +read line +echo "INSERT INTO $1 ($line) VALUES" +csv2sql.sh | head -c -2 +echo ";" diff --git a/.local/bin/csv2sql.sh b/.local/bin/csv2sql.sh new file mode 100755 index 0000000..7f4a8d5 --- /dev/null +++ b/.local/bin/csv2sql.sh @@ -0,0 +1,13 @@ +#!/bin/sh +# Quote everything, +tr , "\t" | +sed 's/\t\([^"\t]\+\)/\t"\1"/g' | +sed 's/\([^"\t]\+\)\t/"\1"\t/g' | +# replace empty with null, +sed 's/\t\t/\tnull\t/g' | +sed 's/\t\t/\tnull\t/g' | +sed 's/\t$/\tnull/g' | +sed 's/^\t/null\t/g' | +tr "\t" , | +# and add parens around each line +sed 's/^/(/g' | sed 's/$/),/g' diff --git a/.local/bin/emojis.sh b/.local/bin/emojis.sh new file mode 100755 index 0000000..9ba19ad --- /dev/null +++ b/.local/bin/emojis.sh @@ -0,0 +1,80 @@ +#!/bin/sh + +# http://www.unicode.org/Public/emoji/14.0/emoji-test.txt +# alpine package unicode-character-database installs this here: +# title="😀 Emoji Input" +input=/usr/share/unicode/emoji/emoji-test.txt + +prefix=$1 + +topmenu(){ + menu=$(grep ' group: ' "$input" | cut -d: -f2 |sed 's/^ //g'|awk 'BEGIN{print "All Emojis"}(1){print}END{print "exit"}'| $prefix sxmo_dmenu.sh -i --header Emojis) + case "$menu" in + "exit" | "") + exit;; + "All Emojis" ) + emojis;; + * ) + submenu "$menu";; + esac +} +submenu(){ + menu="$1" + submenu=$(grep group: "$input" |awk "BEGIN{print \"*\n..\"} + / group:/{ + if (pr){pr=0; exit} + } + (pr){print} + / group: $menu/{pr=1} + END{print \"exit\"} + " |cut -d: -f2|sed 's/^ //g'| $prefix sxmo_dmenu.sh -i --header "$menu") + case "$submenu" in + "exit" | "" ) + exit;; + ".." ) + topmenu;; + "*" ) + emojis "$menu";; + * ) + emojis "$menu" "$submenu";; + esac +} +emojis(){ + menu="$1" + submenu="$2" + start="group:" + end="# Status Counts" + if test "$submenu"; then + start="subgroup: $submenu" + end="group:" + elif test "$menu"; then + start=" group: $menu" + end=" group:" + fi + emoji=$(awk "BEGIN{print \"..\"} + /$end/{ + if (pr){pr=0; exit} + } + (pr){print} + /$start/{pr=1} + END{print \"exit\"} + " < $input | cut -d'#' -f2 | grep . | grep -v 'subtotal:' | grep -v 'group:' | sed 's/E\d\+.\d\+ *//g' | sed 's/^ //g' | grep -v ':.*skin'| $prefix sxmo_dmenu.sh -i --header "${submenu:-${menu:-All Emojis}}"| cut -d' ' -f1) + case "$emoji" in + "exit" | "" ) + exit;; + ".." ) + if test "$menu"; then + submenu "$menu" + else + topmenu + fi + ;; + * ) + wl-ime-type "$emoji" & + printf %s "$emoji" | wl-copy + emojis "$menu" "$submenu" + ;; + esac +} + +topmenu diff --git a/.local/bin/sxmo_dmenu.sh b/.local/bin/sxmo_dmenu.sh new file mode 120000 index 0000000..b97ccfa --- /dev/null +++ b/.local/bin/sxmo_dmenu.sh @@ -0,0 +1 @@ +/usr/bin/fzf
\ No newline at end of file diff --git a/.local/bin/uniq: b/.local/bin/uniq: new file mode 100755 index 0000000..50fcfa8 --- /dev/null +++ b/.local/bin/uniq: @@ -0,0 +1,16 @@ +#!/usr/bin/env python3 + +import fileinput +import sys + + +def main(): + old = '' + for line in fileinput.input(): + linenew = line.split(':')[0] + if old != linenew: + print(line, end='') + old = linenew + +if __name__ == '__main__': + sys.exit(main()) diff --git a/.local/bin/wl-copy b/.local/bin/wl-copy new file mode 100755 index 0000000..a53757b --- /dev/null +++ b/.local/bin/wl-copy @@ -0,0 +1,2 @@ +#!/bin/sh +xclip -in -selection clipboard |