X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=st.c;h=c97712c3e8e115c126d840954edeec1ce0c06661;hb=78f8843bc7d6dc731f23d5ff3a8536fdcc5e4be6;hp=1711842e472cd93abcd003d0ee7d0dd698427e11;hpb=6166a1afc8c7875ce9ba62e5001040014269a26d;p=st.git diff --git a/st.c b/st.c index 1711842..c97712c 100644 --- a/st.c +++ b/st.c @@ -314,6 +314,9 @@ static void clippaste(const Arg *); static void numlock(const Arg *); static void selpaste(const Arg *); static void xzoom(const Arg *); +static void printsel(const Arg *); +static void printscreen(const Arg *) ; +static void toggleprinter(const Arg *); /* Config.h for applying patches and the configuration. */ #include "config.h" @@ -357,6 +360,7 @@ static void strreset(void); static int tattrset(int); static void tprinter(char *s, size_t len); +static void tdumpsel(void); static void tdumpline(int); static void tdump(void); static void tclearregion(int, int, int, int); @@ -433,6 +437,7 @@ static void selrequest(XEvent *); static void selinit(void); static void selsort(void); static inline bool selected(int, int); +static char *getsel(void); static void selcopy(void); static void selscroll(int, int); static void selsnap(int, int *, int *, int); @@ -953,8 +958,8 @@ bpress(XEvent *e) { } } -void -selcopy(void) { +char * +getsel(void) { char *str, *ptr; int x, y, bufsize, size, i, ex; Glyph *gp, *last; @@ -1013,7 +1018,12 @@ selcopy(void) { } *ptr = 0; } - xsetsel(str); + return str; +} + +void +selcopy(void) { + xsetsel(getsel()); } void @@ -1992,6 +2002,9 @@ csihandle(void) { case 1: tdumpline(term.c.y); break; + case 2: + tdumpsel(); + break; case 4: term.mode &= ~MODE_PRINT; break; @@ -2283,6 +2296,31 @@ tprinter(char *s, size_t len) { } void +toggleprinter(const Arg *arg) { + term.mode ^= MODE_PRINT; +} + +void +printscreen(const Arg *arg) { + tdump(); +} + +void +printsel(const Arg *arg) { + tdumpsel(); +} + +void +tdumpsel(void) +{ + char *ptr; + + ptr = getsel(); + tprinter(ptr, strlen(ptr)); + free(ptr); +} + +void tdumpline(int n) { Glyph *bp, *end;