Avoid recursive call to ttywrite from ttyread
authorRoberto E. Vargas Caballero <k0ga@shike2.com>
Sat, 21 Nov 2015 17:21:03 +0000 (18:21 +0100)
committerRoberto E. Vargas Caballero <k0ga@shike2.com>
Sat, 21 Nov 2015 17:21:03 +0000 (18:21 +0100)
Ttyread() calls to ttywrite, so if we check for reading before
that for writing in ttywrite we can get a circular call sequence.

st.c

diff --git a/st.c b/st.c
index a47f0942a8792d900295d6d7ff277c46b2029696..c5d62c1599dc55fd27e235fc30bd06a165fa912e 100644 (file)
--- a/st.c
+++ b/st.c
@@ -1518,8 +1518,6 @@ ttywrite(const char *s, size_t n)
                                continue;
                        die("select failed: %s\n", strerror(errno));
                }
-               if (FD_ISSET(cmdfd, &rfd))
-                       lim = ttyread();
                if (FD_ISSET(cmdfd, &wfd)) {
                        /*
                         * Only write the bytes written by ttywrite() or the
@@ -1543,6 +1541,8 @@ ttywrite(const char *s, size_t n)
                                break;
                        }
                }
+               if (FD_ISSET(cmdfd, &rfd))
+                       lim = ttyread();
        }
        return;