summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHekuran <hekurangashi@protonmail.com>2020-11-30 20:45:38 +0100
committerHekuran <hekurangashi@protonmail.com>2020-11-30 20:45:38 +0100
commit7a7c5f8bfdd4c41d36f98a4d92494d678dd185f4 (patch)
tree392428676821b1cad1369c14a2228c28fc175368
parent8ab3d03681479263a11b05f7f1b53157f61e8c3b (diff)
fixed not being able to copy URL with a dash in it
-rw-r--r--config.h10
-rwxr-xr-xst-urlhandler24
2 files changed, 26 insertions, 8 deletions
diff --git a/config.h b/config.h
index a6c70ac..feabb62 100644
--- a/config.h
+++ b/config.h
@@ -234,11 +234,13 @@ MouseKey mkeys[] = {
{ Button5, TERMMOD, zoom, {.f = -1} },
};
-static char *openurlcmd[] = { "/bin/sh", "-c", "st-urlhandler", "externalpipe", NULL };
+static char *openurlcmd[] = { "/bin/sh", "-c", "st-urlhandler -o", "externalpipe", NULL };
-static char *copyurlcmd[] = { "/bin/sh", "-c",
- "tmp=$(sed 's/.*│//g' | tr -d '\n' | grep -aEo '(((http|https|gopher|gemini|ftp|ftps|git)://|www\\.)[a-zA-Z0-9.]*[:]?[a-zA-Z0-9./@$&%?$#=_-~]*)|((magnet:\\?xt=urn:btih:)[a-zA-Z0-9]*)' | uniq | sed 's/^www./http:\\/\\/www\\./g' ); IFS=; [ ! -z $tmp ] && echo $tmp | dmenu -i -p 'Copy which url?' -l 10 | tr -d '\n' | xclip -selection clipboard",
- "externalpipe", NULL };
+static char *copyurlcmd[] = { "/bin/sh", "-c", "st-urlhandler -c", "externalpipe", NULL };
+
+/* static char *copyurlcmd[] = { "/bin/sh", "-c", */
+/* "tmp=$(sed 's/.*│//g' | tr -d '\n' | grep -aEo '(((http|https|gopher|gemini|ftp|ftps|git)://|www\\.)[a-zA-Z0-9.]*[:]?[a-zA-Z0-9./@$&%?$#=_-~]*)|((magnet:\\?xt=urn:btih:)[a-zA-Z0-9]*)' | uniq | sed 's/^www./http:\\/\\/www\\./g' ); IFS=; [ ! -z $tmp ] && echo $tmp | dmenu -i -p 'Copy which url?' -l 10 | tr -d '\n' | xclip -selection clipboard", */
+/* "externalpipe", NULL }; */
static char *copyoutput[] = { "/bin/sh", "-c", "st-copyout", "externalpipe", NULL };
diff --git a/st-urlhandler b/st-urlhandler
index 0d39dd5..a73a5bc 100755
--- a/st-urlhandler
+++ b/st-urlhandler
@@ -1,7 +1,6 @@
#!/bin/sh
-urlregex="(((http|https)://|www\\.)[a-zA-Z0-9.]*[:]?[a-zA-Z0-9./@$&%?$\#=_~-]*)|((magnet:\\?xt=urn:btih:)[a-zA-Z0-9]*)"
-
+geturl() {
# First remove linebreaks and mutt sidebars:
urls="$(sed 's/.*│//g' | tr -d '\n' |
grep -aEo "$urlregex" | # grep only urls as defined above.
@@ -9,7 +8,24 @@ urls="$(sed 's/.*│//g' | tr -d '\n' |
sed 's/^www./http:\/\/www\./g')"
[ -z "$urls" ] && exit
+}
+
+openurl() {
+ urlregex="(((http|https)://|www\\.)[a-zA-Z0-9.]*[:]?[a-zA-Z0-9./@$&%?$\#=_~-]*)|((magnet:\\?xt=urn:btih:)[a-zA-Z0-9]*)"
+ geturl
+ chosen="$(echo "$urls" | dmenu -i -p 'Follow which url?' -l 10)"
+ setsid xdg-open "$chosen" >/dev/null 2>&1 &
+}
-chosen="$(echo "$urls" | dmenu -i -p 'Follow which url?' -l 10)"
+copyurl() {
+ urlregex="(((http|https|gopher|gemini|ftp|ftps|git)://|www\\.)[a-zA-Z0-9.]*[:]?[a-zA-Z0-9./@$&%?$\#=_~-]*)|((magnet:\\?xt=urn:btih:)[a-zA-Z0-9]*)"
+ geturl
+ echo $urls | dmenu -i -p 'Copy which url?' -l 10 | tr -d '\n' | xclip -selection clipboard
+}
-setsid xdg-open "$chosen" >/dev/null 2>&1 &
+while getopts "hoc" o; do case "${o}" in
+ h) printf "Optional arguments for custom use:\\n -c: copy\\n -o: xdg-open\\n -h: Show this message\\n" && exit 1 ;;
+ o) openurl ;;
+ c) copyurl ;;
+ *) printf "Invalid option: -%s\\n" "$OPTARG" && exit 1 ;;
+esac done