]> git.armaanb.net Git - st.git/commitdiff
Add key to send a break to the serial line
authorRoberto E. Vargas Caballero <k0ga@shike2.com>
Tue, 8 Sep 2015 10:10:11 +0000 (12:10 +0200)
committerRoberto E. Vargas Caballero <k0ga@shike2.com>
Tue, 8 Sep 2015 10:10:11 +0000 (12:10 +0200)
config.def.h
st.1
st.c

index 11a0c02ffa9913c745d6786c63a9e81a02168dc7..7129fa188e10229743b343a23bcedee07d83d011 100644 (file)
@@ -134,6 +134,7 @@ static Mousekey mshortcuts[] = {
 
 static Shortcut shortcuts[] = {
        /* mask                 keysym          function        argument */
+       { XK_NO_MOD,            XK_Pause,       sendbreak,      {.i =  0} },
        { ControlMask,          XK_Print,       toggleprinter,  {.i =  0} },
        { ShiftMask,            XK_Print,       printscreen,    {.i =  0} },
        { XK_ANY_MOD,           XK_Print,       printsel,       {.i =  0} },
diff --git a/st.1 b/st.1
index 29e3163e7cdc08114d37899d195fd76d33cbb39f..f2f3f0e57733014fffce357013f83c3936805f4d 100644 (file)
--- a/st.1
+++ b/st.1
@@ -122,6 +122,9 @@ and all the remaining arguments are used as a command
 even without it.
 .SH SHORTCUTS
 .TP
+.B Pause
+Send a break in the serial line
+.TP
 .B Ctrl-Print Screen
 Toggle if st should print to the
 .I iofile.
diff --git a/st.c b/st.c
index 256f8f5912026027715c6fe7494fefa7757c4e83..780431605f3e4aa915785de0471e785a10406a33 100644 (file)
--- a/st.c
+++ b/st.c
@@ -17,6 +17,7 @@
 #include <sys/time.h>
 #include <sys/types.h>
 #include <sys/wait.h>
+#include <termios.h>
 #include <time.h>
 #include <unistd.h>
 #include <libgen.h>
@@ -333,6 +334,7 @@ static void xzoomreset(const Arg *);
 static void printsel(const Arg *);
 static void printscreen(const Arg *) ;
 static void toggleprinter(const Arg *);
+static void sendbreak(const Arg *);
 
 /* Config.h for applying patches and the configuration. */
 #include "config.h"
@@ -2578,6 +2580,13 @@ strreset(void)
        memset(&strescseq, 0, sizeof(strescseq));
 }
 
+void
+sendbreak(const Arg *arg)
+{
+       if (tcsendbreak(cmdfd, 0))
+               perror("Error sending break");
+}
+
 void
 tprinter(char *s, size_t len)
 {