summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXiao Pan <xyz@flylightning.xyz>2025-09-06 17:36:23 +0800
committerXiao Pan <xyz@flylightning.xyz>2025-09-06 17:36:23 +0800
commit6f982c43ced07e62bfa66df384f007f43f5eb827 (patch)
treeb66ec37b6a5d09682a4a5b0ae88f7f9597856278
parentcdb312a182b144429ff457fc8390a4af8a65adf4 (diff)
wrap commentHEADmaster
-rwxr-xr-xsh/mvtr7
1 files changed, 4 insertions, 3 deletions
diff --git a/sh/mvtr b/sh/mvtr
index f8b373e..164e2c7 100755
--- a/sh/mvtr
+++ b/sh/mvtr
@@ -8,8 +8,9 @@
# ./_filename will be renamed ./filename, not what I want, need improve
# -exec can't replace -execdir here, can write a -exec version
-# `sed -E -e "s#/-#/#g"` maybe is to change a file named "-b" in a dir named "a": "a/-b" to "a/b",
-# not sure, git commit log see `cfg -l log -p -- /.config/bin/mvtr` which does not show the reason.
-# I guesed so because a file name as "a/-b" seems not possible, so "a/" should be a dir.
+# `sed -E -e "s#/-#/#g"` maybe is to change a file named "-b" in a dir named
+# "a": "a/-b" to "a/b", I forget, not sure, git commit log see `cfg -l log -p
+# -- /.config/bin/mvtr` which does not show the reason. I guesed so because a
+# file name as "a/-b" seems not possible, so "a/" should be a dir.
find "$@" -depth -execdir sh -c 'dest="$(echo "$1" | tr -d "\047" | sed -E -e "s/([[:lower:]])([[:upper:]])/\1_\2/g" | tr "[:upper:] " "[:lower:]_" | tr -s "[:punct:]" | sed -E -e "s#/-#/#g" -e "s/_([[:punct:]])/\1/g" -e "s/([[:punct:]])_/\1/g" | tr -s "[:punct:]")"; [ -e "$dest" ] || mv -v -- "$1" "$dest"' shell '{}' \;