2021-01-16 23:49:53 +01:00
|
|
|
export EDITOR=nvim
|
2022-03-30 15:45:32 +02:00
|
|
|
export HOSTNAME=`hostname 2>/dev/null || hostnamectl hostname`
|
2022-08-27 12:33:40 +02:00
|
|
|
export RIPGREP_CONFIG_PATH=~/.ripgreprc
|
2021-01-16 23:49:53 +01:00
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
if [ $USER = 'knyffen' ] || ([ $HOSTNAME = 'jry-thinkpad-t470' ] && [ $USER = 'jry' ]); then
|
2021-01-16 23:49:53 +01:00
|
|
|
alias rm="trash"
|
2022-08-27 12:45:16 +02:00
|
|
|
alias reboot="qdbus org.kde.Shutdown /Shutdown logoutAndReboot"
|
2021-01-16 23:49:53 +01:00
|
|
|
fi
|
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
#if [ $USER = 'knyffen' ]; then
|
|
|
|
# alias rm="trash"
|
|
|
|
# alias ssh-add="ssh-add /home/knyffen/.ssh/knyf-inator /home/knyffen/.ssh/Knyf-inatorV2 /home/knyffen/.ssh/git_knyffen_dk"
|
|
|
|
#fi
|
|
|
|
#
|
|
|
|
#if [ $USER = 'jry' ]; then
|
|
|
|
# alias ssh-add="ssh-add /home/jry/.ssh/knyf-inator /home/jry/.ssh/Knyf-inatorV2 /home/jry/.ssh/git_knyffen_dk /home/jry/.ssh/id_rsa"
|
|
|
|
#fi
|
|
|
|
|
2021-01-16 23:22:50 +01:00
|
|
|
alias sudo="sudo "
|
|
|
|
alias vim="nvim"
|
2021-01-16 23:49:53 +01:00
|
|
|
alias vi="nvim"
|
2021-01-16 23:22:50 +01:00
|
|
|
alias ghc="ghc -dynamic"
|
|
|
|
alias find_root="sudo find / 2>&1"
|
|
|
|
alias py="python"
|
|
|
|
alias zathura-t="tabbed -c zathura -e"
|
|
|
|
alias parsecd="LIBVA_DRIVER_NAME=iHD parsecd"
|
|
|
|
alias stack="/usr/bin/stack"
|
|
|
|
alias java_hidpi="java -Dsun.java2d.uiScale=2"
|
|
|
|
alias wol_desktop="ssh knyf wol BC:5F:F4:74:74:57"
|
2022-03-30 15:45:32 +02:00
|
|
|
alias wol_synology="ssh knyf wol 00:11:32:09:9F:12"
|
2021-01-16 23:22:50 +01:00
|
|
|
alias dd_progress='sudo kill -USR1 $(pgrep ^dd)'
|
|
|
|
alias co2="ssh knyf mhz14a -r -d /dev/ttyS0"
|
|
|
|
alias h2o="ssh knyf 'cd configfiles/BME280; ./get_temperature_humidity_and_idead_humidity.sh'"
|
2022-03-30 15:45:32 +02:00
|
|
|
alias probox="vim /home/knyffen/Nextcloud/Notes/Probox.md"
|
|
|
|
alias rebuild-detector="checkrebuild -v"
|
2022-09-01 20:22:05 +02:00
|
|
|
alias jix-vpn="sudo openvpn --config ~/Nextcloud/configfiles/openvpn/jobindex.conf"
|
2022-03-30 15:45:32 +02:00
|
|
|
alias enable_touch="xinput enable 'Wacom HID 51E3 Finger touch'"
|
|
|
|
alias disable_touch="xinput disable 'Wacom HID 51E3 Finger touch'"
|
2022-03-30 15:47:39 +02:00
|
|
|
alias ack="ack -T junkFiles"
|
|
|
|
function ack_open { nvim $( ack -m 1 -T junkFiles "$@" | grep -Po "^(?:lib|t|tmpl|python)/[^:]+:\d+" | tr '\n' ' ' ); }
|
2022-08-27 12:45:16 +02:00
|
|
|
alias pacman="nice -n 19 pacman --config ~/Nextcloud/configfiles/pacman.conf"
|
|
|
|
alias pamac="nice -n 19 pamac"
|
|
|
|
alias yay="nice -n 19 yay --config ~/Nextcloud/configfiles/pacman.conf"
|
2022-09-09 12:18:54 +02:00
|
|
|
alias restartplasma='systemctl --user restart plasma-plasmashell'
|
2022-08-27 12:45:16 +02:00
|
|
|
alias surf="GDK_BACKEND=x11 surf"
|
2022-10-12 16:12:03 +02:00
|
|
|
alias nvim-restore="ls ~/.local/share/nvim/swap/ | xargs basename -s .swp | tr % / | xargs nvim"
|
2021-01-16 23:22:50 +01:00
|
|
|
|
2021-01-16 23:49:53 +01:00
|
|
|
# git
|
|
|
|
alias gst="git status"
|
2022-08-27 12:33:40 +02:00
|
|
|
if [ `alias | grep '\sgbr=' | wc -l` != 0 ]; then
|
|
|
|
unalias gbr
|
|
|
|
fi
|
2022-04-27 09:43:35 +02:00
|
|
|
# alias gbr="git branch --sort=-committerdate"
|
|
|
|
# function gbr2 { git branch --sort=-committerdate | perl -pE 'my $branch = $_ =~ s/^[*+]?\s(\S+)\s*$/$1/r; my $merged = qx{git log \$(git rev-parse $branch) ^master --no-merges}; if ($merged) { $_ =~ s/^/[ ] / } else { $_ =~ s/^/[x] / };'; }
|
|
|
|
function gbr { git branch --sort=-committerdate --format '%(if)%(HEAD)%(then)*%(else)%(if)%(worktreepath)%(then)+%(else) %(end)%(end) %(align:width=40,position=left)%(refname:short)%(end) %(align:width=10,position=right)%(color:green)(%(committerdate:relative))%(end)' | perl -pE '$_ =~ /^[*+]?\s+(?<branch>\S+)\s*/; my $branch = $+{branch}; my $merged = qx{git log \$(git rev-parse $branch) ^master --no-merges}; if ($merged) { $_ =~ s/^/[ ] / } else { $_ =~ s/^/[x] / };'; }
|
2021-01-16 23:49:53 +01:00
|
|
|
function ggn { git grep -Pn --color=always "$@" :/; }
|
|
|
|
function ggt { git grep -Pn --color=always "$@" t/lib ; }
|
|
|
|
function ggp { ggn --color=always "$@" $(git rev-list --all); }
|
|
|
|
function ggl { ggn --color=always "$@" | less -R; }
|
|
|
|
function gdl { git diff --color=always "$@" | less -R; }
|
|
|
|
function ggtl { ggt --color=always "$@" | less -R; }
|
|
|
|
function ggpl { ggp --color=always "$@" | less -R; }
|
2022-10-12 16:19:51 +02:00
|
|
|
function rgl { rg --color=always "$@" | less -R; }
|
2021-01-16 23:49:53 +01:00
|
|
|
|
|
|
|
# git grep colors
|
|
|
|
git config --global color.grep.filename "Green"
|
|
|
|
git config --global color.grep.linenumber "Yellow"
|
|
|
|
git config --global color.grep.match "bold #ff4d00"
|
|
|
|
|
2022-03-30 15:47:39 +02:00
|
|
|
git() {
|
|
|
|
local subcommand1
|
|
|
|
local subcommand2
|
|
|
|
|
|
|
|
if (( "$#" == 0 )); then command git; return; fi
|
|
|
|
|
|
|
|
subcommand1=$1; shift
|
|
|
|
case $subcommand1 in
|
|
|
|
stash)
|
|
|
|
if (( "$#" == 0 )); then command git stash; return; fi
|
|
|
|
|
|
|
|
subcommand2=$1; shift
|
|
|
|
case $subcommand2 in
|
|
|
|
list)
|
|
|
|
command git stash list --pretty=format:"%C(bold magenta)%gd%C(reset): %<|(110)%s %C(green)(%cr)" "$@"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
command git "$subcommand1" "$subcommand2" "$@"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
command git "$subcommand1" "$@"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
}
|
|
|
|
|
2022-04-27 09:43:35 +02:00
|
|
|
alias TODO="ggn 'TODO: jry:?'"
|
2021-01-16 23:49:53 +01:00
|
|
|
|
2021-01-16 23:22:50 +01:00
|
|
|
title() {
|
2021-01-16 23:49:53 +01:00
|
|
|
# set input argument as window title
|
2021-01-16 23:22:50 +01:00
|
|
|
echo -ne "\033]30;$1\007"
|
|
|
|
}
|
|
|
|
|
|
|
|
expressvpn() {
|
2021-01-16 23:49:53 +01:00
|
|
|
local subcommand
|
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
if [ $# -eq 0 ]; then command expressvpn; return; fi
|
2021-01-16 23:49:53 +01:00
|
|
|
|
|
|
|
subcommand=$1; shift
|
|
|
|
case $subcommand in
|
|
|
|
connect)
|
|
|
|
if ! (command expressvpn "status" | grep -i "$@"); then
|
|
|
|
command expressvpn "disconnect";
|
|
|
|
fi
|
|
|
|
command "sudo /usr/bin/cp -f /etc/resolv.conf /etc/resolv.conf.backup"
|
|
|
|
command expressvpn "$subcommand" "$@"
|
|
|
|
;;
|
|
|
|
disconnect)
|
|
|
|
command expressvpn "$subcommand" "$@"
|
|
|
|
command "sudo /usr/bin/cp -f /etc/resolv.conf.backup /etc/resolv.conf"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
command expressvpn "$subcommand" "$@"
|
|
|
|
;;
|
|
|
|
esac
|
2021-01-16 23:22:50 +01:00
|
|
|
}
|
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
alias vpn=nordvpn
|
|
|
|
nordvpn() {
|
|
|
|
local subcommand
|
|
|
|
|
|
|
|
if [ $# -eq 0 ]; then command nordvpn; return; fi
|
|
|
|
|
|
|
|
subcommand=$1; shift
|
|
|
|
case $subcommand in
|
|
|
|
c)
|
|
|
|
command nordvpn "$subcommand" "$@"
|
|
|
|
;;
|
|
|
|
connect)
|
|
|
|
command nordvpn "$subcommand" "$@"
|
|
|
|
;;
|
|
|
|
d)
|
|
|
|
command nordvpn "$subcommand" "$@"
|
|
|
|
# command echo 'nameserver 192.168.1.1' | sudo tee /etc/resolv.conf
|
|
|
|
command sudo cp -f /etc/resolv.conf.bak /etc/resolv.conf
|
|
|
|
;;
|
|
|
|
disconnect)
|
|
|
|
command nordvpn "$subcommand" "$@"
|
|
|
|
# command echo 'nameserver 192.168.1.1' | sudo tee /etc/resolv.conf
|
|
|
|
command sudo cp -f /etc/resolv.conf.bak /etc/resolv.conf
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
command nordvpn "$subcommand" "$@"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
}
|
|
|
|
|
2021-01-16 23:22:50 +01:00
|
|
|
spin() {
|
|
|
|
local subcommand
|
|
|
|
local fname
|
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
if [ $# -eq 0 ]; then command spin; return; fi
|
2021-01-16 23:22:50 +01:00
|
|
|
|
|
|
|
subcommand=$1; shift
|
|
|
|
case $subcommand in
|
|
|
|
run)
|
|
|
|
shift
|
|
|
|
command spin "-run $@"
|
|
|
|
;;
|
|
|
|
run_bfs)
|
|
|
|
shift
|
|
|
|
command spin "-run -bfs $@"
|
|
|
|
;;
|
|
|
|
run_fair)
|
|
|
|
shift
|
|
|
|
command spin "-run -f $@"
|
|
|
|
;;
|
|
|
|
run_bfs_fair)
|
|
|
|
shift
|
|
|
|
command spin "-run -bfs -f $@"
|
|
|
|
;;
|
|
|
|
trace)
|
|
|
|
shift
|
|
|
|
fname=$1; shift
|
|
|
|
command "./pam -i $fname"
|
|
|
|
command "./pam -r $@ $fname"
|
|
|
|
;;
|
|
|
|
trace_depth)
|
|
|
|
shift
|
|
|
|
local depth
|
|
|
|
fname=$1; shift
|
|
|
|
depth=$1; shift
|
|
|
|
command "./pam -m$depth -i $fname"
|
|
|
|
command "./pam -m$depth -r $@ $fname"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
command spin "$subcommand $@"
|
|
|
|
esac;
|
|
|
|
}
|
2021-01-16 23:49:53 +01:00
|
|
|
|
2022-03-30 15:45:32 +02:00
|
|
|
if [ $USER = 'knyffen' ]; then
|
|
|
|
# Reduce priority of make commands, to preserve system responsiveness when e.g. compiling gcc
|
|
|
|
alias pamac="nice -n 19 pamac"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $HOSTNAME = 'gnu' ] && [ $USER = 'jry' ]; then
|
2021-01-16 23:49:53 +01:00
|
|
|
alias fzy="~/.fzy/fzy"
|
|
|
|
|
2022-04-27 09:43:35 +02:00
|
|
|
alias perlperl="/usr/bin/perl"
|
2022-08-27 12:33:40 +02:00
|
|
|
alias perlprove="/usr/bin/prove"
|
2021-01-16 23:49:53 +01:00
|
|
|
function prove { jix-shell TEST_METHOD=$TEST_METHOD BAIL_ON_FAIL=$BAIL_ON_FAIL prove "$@"; }
|
2022-04-27 09:43:35 +02:00
|
|
|
function prove-on-backend { jix-shell TEST_METHOD=$TEST_METHOD BAIL_ON_FAIL=$BAIL_ON_FAIL USER=$USER JIX_USERID=$JIX_USERID prove-on-backend "$@"; }
|
|
|
|
function perl { jix-shell TEST_METHOD=$TEST_METHOD BAIL_ON_FAIL=$BAIL_ON_FAIL USER=$USER JIX_USERID=$JIX_USERID perl -MJIX "$@"; }
|
|
|
|
alias open_url="jix-shell open_url"
|
|
|
|
alias colorlog="jix-shell colorlog.pl"
|
|
|
|
alias jix-gettext="jix-shell jix-gettext"
|
|
|
|
alias arc="jix-shell arc"
|
|
|
|
alias solr="ssh -L 1214:localhost:8983 solr@gnu.dev.job.dk firefox http://localhost:1214/solr/"
|
2022-10-12 16:12:03 +02:00
|
|
|
alias push-to-production="jix-shell push_to_production.sh"
|
2021-01-16 23:49:53 +01:00
|
|
|
|
|
|
|
function profiling {
|
|
|
|
local JIX_USERID=233476; # userid of JRY
|
|
|
|
local USER=jobdk;
|
|
|
|
local ROOT=$1;
|
|
|
|
shift;
|
|
|
|
local FORM=$@;
|
|
|
|
local COMMAND='use Test::More; use Test::JIX::Mojo;
|
|
|
|
use JIX::Env;
|
|
|
|
DB::disable_profile; # backup solution for setting NYTPROF=start=no env variable
|
|
|
|
JIX::Env->USER("'$USER'"); # backup solution for setting USER=jobdk env variable
|
|
|
|
my $t = Test::JIX::Mojo->new("JIX::Mojo");
|
|
|
|
my $c = JIX::CompanyUser->retrieve( { id => '$JIX_USERID' } );
|
|
|
|
$t->ua->inactivity_timeout(600);
|
|
|
|
$t->auto_html5_ok(0);
|
|
|
|
$t->login_companyuser($c);
|
|
|
|
$t->jix_get_ok([ "'$ROOT'", format=>"xml", form => { '$FORM' } ]);
|
|
|
|
for (0..9) {
|
|
|
|
$t->login_companyuser($c);
|
|
|
|
DB::enable_profile;
|
|
|
|
$t->jix_get_ok([ "'$ROOT'", format=>"xml", form => { '$FORM' } ]);
|
|
|
|
DB::disable_profile;
|
|
|
|
};
|
|
|
|
done_testing();';
|
|
|
|
echo "Command:";
|
|
|
|
echo "perl -d:NYTProf -E '$COMMAND'";
|
|
|
|
USER=jobdk NYTPROF=start=no perl -d:NYTProf -E "$COMMAND";
|
|
|
|
nytprofhtml;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Automatically keep a pointer to my latest SSH agent
|
|
|
|
MY_SSH_SOCK="/tmp/ssh-agent-$USER"
|
|
|
|
if test $SSH_AUTH_SOCK && [ $SSH_AUTH_SOCK != $MY_SSH_SOCK ]; then
|
|
|
|
ln -sf $SSH_AUTH_SOCK $MY_SSH_SOCK
|
|
|
|
export SSH_AUTH_SOCK=$MY_SSH_SOCK
|
|
|
|
fi
|
|
|
|
fi
|