diff --git a/.config/nvim/pack/plugins/opt/lspconfig b/.config/nvim/pack/plugins/opt/lspconfig index ee2e8c6..d8d48b7 160000 --- a/.config/nvim/pack/plugins/opt/lspconfig +++ b/.config/nvim/pack/plugins/opt/lspconfig @@ -1 +1 @@ -Subproject commit ee2e8c63cff0a8bfc7f4ef985ea466f10bb7e691 +Subproject commit d8d48b7a8ce12605378fba6391348b99e8a7a4c1 diff --git a/.config/nvim/pack/plugins/opt/telescope b/.config/nvim/pack/plugins/opt/telescope index f174a03..5c7db40 160000 --- a/.config/nvim/pack/plugins/opt/telescope +++ b/.config/nvim/pack/plugins/opt/telescope @@ -1 +1 @@ -Subproject commit f174a0367b4fc7cb17710d867e25ea792311c418 +Subproject commit 5c7db4055d89f9057d562f4f8b9d03189c9f9786 diff --git a/.config/nvim/pack/plugins/opt/treesitter b/.config/nvim/pack/plugins/opt/treesitter index 3eb6577..682fa45 160000 --- a/.config/nvim/pack/plugins/opt/treesitter +++ b/.config/nvim/pack/plugins/opt/treesitter @@ -1 +1 @@ -Subproject commit 3eb6577a3b58e4d0e76057ad1309255678739b61 +Subproject commit 682fa459173208997092adf872baa66a7f04692d diff --git a/.config/zsh/ohmyzsh b/.config/zsh/ohmyzsh index a7d910c..0066280 160000 --- a/.config/zsh/ohmyzsh +++ b/.config/zsh/ohmyzsh @@ -1 +1 @@ -Subproject commit a7d910c3a61d8599f748a8ddae59ecdd9424022a +Subproject commit 0066280c3e971e1e45a9037f6d0b993dabcc3576 diff --git a/bin/dkprune b/bin/dkprune index 005678f..a1b1f53 100755 --- a/bin/dkprune +++ b/bin/dkprune @@ -1,5 +1,8 @@ #!/bin/bash +#TODO: group flags into one command +# like -I == $i -a + function usage() { cat << EOF Usage: $0 -hcCviIna @@ -73,40 +76,46 @@ while getopts hcCviIna o; do esac done -if [ "$((CLEAN & C))" == "$C" ]; then - docker container ls -aq | xargs docker stop + +VALUES=( + "$a" + "$((c + i + n))" + "$((c + I + n))" + "$((c + v + n))" + "$c" + "$v" + "$i" + "$I" + "$n" +) + +SYS="docker system" +CON="docker container" +VOL="docker volume" +IMG="docker image" +NET="docker network" +PRUNE="prune -f" +COMMANDS=( + "$SYS $PRUNE -a --volumes" + "$SYS $PRUNE" + "$SYS $PRUNE -a" + "$SYS $PRUNE --volumes" + "$CON $PRUNE" + "$VOL $PRUNE" + "$IMG $PRUNE" + "$IMG $PRUNE -a" + "$NET $PRUNE" +) + +if [ "$((CLEAN & "$C"))" == "$C" ]; then + $CON ls -aq | xargs $CON stop fi -if [ "$((CLEAN & c))" == "$c" ]; then - docker container prune -f -fi -PRUNE="docker system prune -f" -case "$CLEAN" in - "$v") - docker volume prune -f - ;; - "$i") - docker image prune -f - ;; - "$I") - docker image prune -af - ;; - "$n") - docker network prune -f - ;; - "$((c + i + n))") - $PRUNE - ;; - "$((c + I + n))") - $PRUNE -a - ;; - "$((c + v + n))") - $PRUNE --volumes - ;; - "$a") - $PRUNE -a --volumes - ;; - *) - ;; -esac +for idx in "${!VALUES[@]}"; do + mask="${VALUES[$idx]}" + if [ "$((CLEAN & mask))" == "$mask" ]; then + bash -c "${COMMANDS[$idx]}" + CLEAN="$((CLEAN - mask))" + fi +done