summaryrefslogtreecommitdiff
path: root/home/xyz/.local
diff options
context:
space:
mode:
authorxyz <gky44px1999@gmail.com>2021-11-04 04:09:26 -0700
committerxyz <gky44px1999@gmail.com>2021-11-04 04:09:26 -0700
commitfe2405ddfc21603b156daa8ab052344f5f40fc73 (patch)
treebb68f0c1028e8158b3ee7e6f7b085a9e202ec814 /home/xyz/.local
parentd74011f09d917b7679110cbdc6d583fff19b8dfa (diff)
mvln, mv file then ln back
Diffstat (limited to 'home/xyz/.local')
-rwxr-xr-xhome/xyz/.local/bin/lastarg5
-rwxr-xr-xhome/xyz/.local/bin/mvln30
2 files changed, 35 insertions, 0 deletions
diff --git a/home/xyz/.local/bin/lastarg b/home/xyz/.local/bin/lastarg
new file mode 100755
index 00000000..58f1f14e
--- /dev/null
+++ b/home/xyz/.local/bin/lastarg
@@ -0,0 +1,5 @@
+#!/bin/sh
+# useage: lastarg "$@"
+
+shift $(($# - 1))
+echo "$1"
diff --git a/home/xyz/.local/bin/mvln b/home/xyz/.local/bin/mvln
new file mode 100755
index 00000000..fb540390
--- /dev/null
+++ b/home/xyz/.local/bin/mvln
@@ -0,0 +1,30 @@
+#!/bin/sh
+# edge cases give me headache
+
+lns () {
+ # prevent `mvln file1 file1` or `mvln dir1/file1 dir1/`
+ # which means `ln -s samename samename` or `ln -s dir/file dir/`
+ # both $1 and $2 here are realpath
+ [ "$1" != "$2" ] && ln -s -- "$1" "$2"
+}
+
+mv -i -- "$@"
+# consider `mvln file1 dir/file2`
+if [ $# -eq 2 ] && ! [ -d "$2" ]; then
+ # use realpath here
+ lns "$(realpath "$2")" "$(realpath "$1")"
+else
+ dir="$(realpath -- "$(lastarg "$@")")"
+ # steal from https://unix.stackexchange.com/a/353833/459013
+ while [ $# -gt 1 ]; do
+ to="$(realpath -- "$1")"
+ # prevent `mvln dir1/ dir1/`
+ if [ "$dir" != "$to" ]; then
+ lns "$dir/$(basename "$1")" "$to"
+ fi
+ shift
+ done
+fi
+
+# for test
+#rm -rf ~/test/A\ A/; mkdir -p ~/test/A\ A/; cp -r ~/test/0t/ ~/test/A\ A/1t/; mvln ~/test/A\ A/1t/* ~/test/A\ A/; tree ~/test/A\ A/