aboutsummaryrefslogtreecommitdiff
path: root/shellrc.d-desktop
diff options
context:
space:
mode:
Diffstat (limited to 'shellrc.d-desktop')
-rw-r--r--shellrc.d-desktop/desktop49
-rw-r--r--shellrc.d-desktop/xorg34
2 files changed, 83 insertions, 0 deletions
diff --git a/shellrc.d-desktop/desktop b/shellrc.d-desktop/desktop
new file mode 100644
index 0000000..52ca258
--- /dev/null
+++ b/shellrc.d-desktop/desktop
@@ -0,0 +1,49 @@
+# vim: ft=sh:
+# This is handy only on desktop and is useless on server
+
+alias mutt='neomutt'
+alias sdcv='sdcv -c'
+
+# Following section is applicable for any desktop but only for graphics##########
+# TODO add check for wayland
+[ -z "$DISPLAY" ] && return
+
+alias feh='feh --magick-timeout 10 -.'
+
+
+# This function should not be called externaly
+# It expects PID of surf instace as first argument and all other arguments should
+# be command to be called before kill is sent.
+__insurf_callback() {
+ local SPID=$1
+ shift
+ "$@"
+ echo kill $SPID SIGHUP
+ kill -s SIGHUP $SPID || exit 1
+}
+
+# Same as inrun but it opens first argument it founds in surf and then reloads
+# that instance automatically.
+insurf() {
+ (
+ set -e
+ # Run surf
+ surf "$1" &
+ local SPID=$!
+ trap "kill $SPID; trap '' EXIT; exit 0" EXIT INT QUIT TERM ABRT
+ # Insert our callback
+ local ISFIRST=true
+ for ARG in "$@"; do
+ if $ISFIRST; then
+ shift $#
+ ISFIRST=false
+ fi
+ set "$@" "$ARG"
+ if [ "$ARG" = "--" ]; then
+ set "$@" "__insurf_callback" "$SPID"
+ fi
+ done
+ # Run inrun
+ inrun "$@"
+ )
+}
diff --git a/shellrc.d-desktop/xorg b/shellrc.d-desktop/xorg
new file mode 100644
index 0000000..be9ef69
--- /dev/null
+++ b/shellrc.d-desktop/xorg
@@ -0,0 +1,34 @@
+# vim: ft=sh:
+# These are utility functions loaded when we are running in Xserver
+
+[ -z "$DISPLAY" ] && return # Ignore if there is no display set
+
+alias i='i3-msg'
+
+
+# Clip stdin to clipboard
+clip() {
+ # Note: printf as magic to remove trailing new lines
+ printf %s "$(cat)" | xclip -selection clipboard
+}
+
+# Clip current HEAD hash to clipboard
+# Optionally you can pass commit as argument
+gitclip() {
+ [ -n "$1" ] && local CMT="$1" || local CMT=HEAD
+ git rev-parse "$CMT"| clip
+}
+# Clip current head message to clipboard
+# Optionally you can pass commit as argument
+gitmclip() {
+ [ -n "$1" ] && local CMT="$1" || local CMT=HEAD
+ git log --format=%B -n 1 "$CMT" | clip
+}
+
+# Make screenshot
+xshot() {
+ import ~/xshot_$(date +%F_%H%M%S_%N).png
+}
+xshot-screen() {
+ import -screen ~/xshot_$(date +%F_%H%M%S_%N).png
+}