commit 6e8ca18edc6caf6c3a007849edbb23b98fad4fd9
Author: Michael Buch <[email protected]>
Date:   Wed Apr 18 02:07:25 2018 +0100

    Ported the copyurl patch to post-0.8.1 release. Mainly it involved
    removing the deprecated selcopy function. I have used it for a while
    and have not encountered issues. I did not address other outstanding FixMes.
    and

diff --git a/st.suckless.org/patches/copyurl/index.md 
b/st.suckless.org/patches/copyurl/index.md
index b3da397a..ea9f263b 100644
--- a/st.suckless.org/patches/copyurl/index.md
+++ b/st.suckless.org/patches/copyurl/index.md
@@ -20,6 +20,7 @@ Download
  * [st-copyurl-0.7.diff](st-copyurl-0.7.diff)
  * [st-copyurl-20161105-8c99915.diff](st-copyurl-20161105-8c99915.diff)
  * [st-copyurl-20170802-e2ee5ee.diff](st-copyurl-20170802-e2ee5ee.diff)
+ * [st-copyurl-20180418-7e810b5.diff](st-copyurl-20180418-7e810b5.diff)
 
 Authors
 -------
@@ -28,3 +29,4 @@ Authors
  * Laslo Hunhold - <[email protected]> (0.6 port)
  * David Phillips - <[email protected]> (git port)
  * Matthew Parnell - <[email protected]> (0.7, git ports)
+ * Michael Buch - <[email protected]> (0.8+ git port)
diff --git a/st.suckless.org/patches/copyurl/st-copyurl-20180418-7e810b5.diff 
b/st.suckless.org/patches/copyurl/st-copyurl-20180418-7e810b5.diff
new file mode 100644
index 00000000..7aee571c
--- /dev/null
+++ b/st.suckless.org/patches/copyurl/st-copyurl-20180418-7e810b5.diff
@@ -0,0 +1,109 @@
+From 7e810b5d11e16aa8b79e6057cc4b9fa55df1fc57 Mon Sep 17 00:00:00 2001
+From: Michael Buch <[email protected]>
+Date: Wed, 18 Apr 2018 01:12:09 +0100
+Subject: [PATCH] Port the copyurl patch to the 0.8.1 st release. Mainly fix
+ usage of depracted selcopy
+
+---
+ config.def.h |  1 +
+ st.c         | 62 ++++++++++++++++++++++++++++++++++++++++++++++++++++
+ st.h         |  1 +
+ 3 files changed, 64 insertions(+)
+
+diff --git a/config.def.h b/config.def.h
+index 82b1b09..cbe923e 100644
+--- a/config.def.h
++++ b/config.def.h
+@@ -178,6 +178,7 @@ static Shortcut shortcuts[] = {
+       { TERMMOD,              XK_Y,           selpaste,       {.i =  0} },
+       { TERMMOD,              XK_Num_Lock,    numlock,        {.i =  0} },
+       { TERMMOD,              XK_I,           iso14755,       {.i =  0} },
++      { MODKEY,               XK_l,           copyurl,        {.i =  0} },
+ };
+ 
+ /*
+diff --git a/st.c b/st.c
+index 0628707..3df99d9 100644
+--- a/st.c
++++ b/st.c
+@@ -2617,3 +2617,65 @@ redraw(void)
+       tfulldirt();
+       draw();
+ }
++
++/* select and copy the previous url on screen (do nothing if there's no url).
++ * known bug: doesn't handle urls that span multiple lines (wontfix)
++ * known bug: only finds first url on line (mightfix)
++ */
++void
++copyurl(const Arg *arg) {
++      /* () and [] can appear in urls, but excluding them here will reduce 
false
++       * positives when figuring out where a given url ends.
++       */
++      static char URLCHARS[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
++              "abcdefghijklmnopqrstuvwxyz"
++              "0123456789-._~:/?#@!$&'*+,;=%";
++
++      int i, row, startrow;
++      char *linestr = calloc(sizeof(char), term.col+1); /* assume ascii */
++      char *c, *match = NULL;
++
++      row = (sel.ob.x >= 0 && sel.nb.y > 0) ? sel.nb.y-1 : term.bot;
++      LIMIT(row, term.top, term.bot);
++      startrow = row;
++
++      /* find the start of the last url before selection */
++      do {
++              for (i = 0; i < term.col; ++i) {
++                      if (term.line[row][i].u > 127) /* assume ascii */
++                              continue;
++                      linestr[i] = term.line[row][i].u;
++              }
++              linestr[term.col] = '

Reply via email to