commit 63110a55873fb01f95f19487570151834f4ac33c
Author: Matthew Parnell <[email protected]>
Date:   Mon Aug 14 15:50:45 2017 +0100

    [st][copyurl] add missing patches
    
    st-copyurl-0.7.diff and st-copyurl-20170802-e2ee5ee.diff were missing
    from 1543a443ad5f6254b82451b07a55a27308cfb125
    
    As mentioned in 1543a44 message:
    
    > copyurl relies on an X-specific function; a quick hack is in place
    > to keep functionality; original author / current maintainer should
    > investigate alternative approach.

diff --git a/st.suckless.org/patches/copyurl/st-copyurl-0.7.diff 
b/st.suckless.org/patches/copyurl/st-copyurl-0.7.diff
new file mode 100644
index 00000000..a1983fcc
--- /dev/null
+++ b/st.suckless.org/patches/copyurl/st-copyurl-0.7.diff
@@ -0,0 +1,88 @@
+diff --git a/config.def.h b/config.def.h
+index b41747f..50321db 100644
+--- a/config.def.h
++++ b/config.def.h
+@@ -172,6 +172,7 @@ static Shortcut shortcuts[] = {
+       { MODKEY|ShiftMask,     XK_C,           clipcopy,       {.i =  0} },
+       { MODKEY|ShiftMask,     XK_V,           clippaste,      {.i =  0} },
+       { MODKEY,               XK_Num_Lock,    numlock,        {.i =  0} },
++      { MODKEY,               XK_l,           copyurl,        {.i =  0} },
+ };
+ 
+ /*
+diff --git a/st.c b/st.c
+index 2594c65..78201ff 100644
+--- a/st.c
++++ b/st.c
+@@ -336,6 +336,7 @@ static void printsel(const Arg *);
+ static void printscreen(const Arg *) ;
+ static void toggleprinter(const Arg *);
+ static void sendbreak(const Arg *);
++static void copyurl(const Arg *);
+ 
+ /* Config.h for applying patches and the configuration. */
+ #include "config.h"
+@@ -4402,3 +4403,63 @@ run:
+       return 0;
+ }
+ 
++/* 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