summary refs log tree commit diff
diff options
context:
space:
mode:
authorZach DeCook <zach.decook@bettercarpeople.com>2022-10-17 11:57:51 -0400
committerZach DeCook <zach.decook@bettercarpeople.com>2022-10-17 11:57:51 -0400
commitbef368a6363dadb025515a6a6d989d6cb7a3574f (patch)
treef6d0e5b0bf373690ee8e3355406bac74cbbfbf1b
downloaddotfiles-bef368a6363dadb025515a6a6d989d6cb7a3574f.tar.gz
work: initial commit
-rw-r--r--.bashrc176
-rw-r--r--.config/micro/bindings.json13
-rw-r--r--.config/micro/settings.json10
-rwxr-xr-x.local/bin/csv2INSERT.sh6
-rwxr-xr-x.local/bin/csv2sql.sh13
-rwxr-xr-x.local/bin/emojis.sh80
l---------.local/bin/sxmo_dmenu.sh1
-rwxr-xr-x.local/bin/uniq:16
-rwxr-xr-x.local/bin/wl-copy2
9 files changed, 317 insertions, 0 deletions
diff --git a/.bashrc b/.bashrc
new file mode 100644
index 0000000..dfdbdd4
--- /dev/null
+++ b/.bashrc
@@ -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