Xinqi Bao's Git
projects
/
st.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
Enforce a terminal size to reduce race conditions in too efficient apps.
[st.git]
/
st.c
diff --git
a/st.c
b/st.c
index
65a1866
..
3a0a519
100644
(file)
--- a/
st.c
+++ b/
st.c
@@
-415,7
+415,7
@@
static int32_t tdefcolor(int *, int *, int);
static void tdeftran(char);
static inline int match(uint, uint);
static void ttynew(void);
static void tdeftran(char);
static inline int match(uint, uint);
static void ttynew(void);
-static
void
ttyread(void);
+static
size_t
ttyread(void);
static void ttyresize(void);
static void ttysend(char *, size_t);
static void ttywrite(const char *, size_t);
static void ttyresize(void);
static void ttysend(char *, size_t);
static void ttywrite(const char *, size_t);
@@
-1440,6
+1440,8
@@
ttynew(void)
if (openpty(&m, &s, NULL, NULL, &w) < 0)
die("openpty failed: %s\n", strerror(errno));
if (openpty(&m, &s, NULL, NULL, &w) < 0)
die("openpty failed: %s\n", strerror(errno));
+ ttyresize();
+
switch (pid = fork()) {
case -1:
die("fork failed\n");
switch (pid = fork()) {
case -1:
die("fork failed\n");
@@
-1464,7
+1466,7
@@
ttynew(void)
}
}
}
}
-void
+size_t
ttyread(void)
{
static char buf[BUFSIZ];
ttyread(void)
{
static char buf[BUFSIZ];
@@
-1489,14
+1491,16
@@
ttyread(void)
/* keep any uncomplete utf8 char for the next call */
memmove(buf, ptr, buflen);
/* keep any uncomplete utf8 char for the next call */
memmove(buf, ptr, buflen);
+
+ return ret;
}
void
ttywrite(const char *s, size_t n)
{
}
void
ttywrite(const char *s, size_t n)
{
- fd_set wfd;
- struct timespec tv;
+ fd_set wfd, rfd;
ssize_t r;
ssize_t r;
+ size_t lim = 256;
/*
* Remember that we are using a pty, which might be a modem line.
/*
* Remember that we are using a pty, which might be a modem line.
@@
-1506,38
+1510,32
@@
ttywrite(const char *s, size_t n)
*/
while (n > 0) {
FD_ZERO(&wfd);
*/
while (n > 0) {
FD_ZERO(&wfd);
+ FD_ZERO(&rfd);
FD_SET(cmdfd, &wfd);
FD_SET(cmdfd, &wfd);
- tv.tv_sec = 0;
- tv.tv_nsec = 0;
+ FD_SET(cmdfd, &rfd);
/* Check if we can write. */
/* Check if we can write. */
- if (pselect(cmdfd+1,
NULL, &wfd, NULL, &tv
, NULL) < 0) {
+ if (pselect(cmdfd+1,
&rfd, &wfd, NULL, NULL
, NULL) < 0) {
if (errno == EINTR)
continue;
die("select failed: %s\n", strerror(errno));
}
if (errno == EINTR)
continue;
die("select failed: %s\n", strerror(errno));
}
- if(!FD_ISSET(cmdfd, &wfd)) {
- /* No, then free some buffer space. */
- ttyread();
- } else {
+ if (FD_ISSET(cmdfd, &wfd)) {
/*
/*
- * Only write
256 bytes at maximum. This seems to be a
- *
reasonable value for a serial line. Bigger values
- * might clog the I/O.
+ * Only write
the bytes written by ttywrite() or the
+ *
default of 256. This seems to be a reasonable value
+ *
for a serial line. Bigger values
might clog the I/O.
*/
*/
- r = write(cmdfd, s, (n < 256)? n : 256);
- if (r < 0) {
- die("write error on tty: %s\n",
- strerror(errno));
- }
+ if ((r = write(cmdfd, s, (n < lim)? n : lim)) < 0)
+ goto write_error;
if (r < n) {
/*
* We weren't able to write out everything.
* This means the buffer is getting full
* again. Empty it.
*/
if (r < n) {
/*
* We weren't able to write out everything.
* This means the buffer is getting full
* again. Empty it.
*/
- if (n <
256
)
- ttyread();
+ if (n <
lim
)
+
lim =
ttyread();
n -= r;
s += r;
} else {
n -= r;
s += r;
} else {
@@
-1545,7
+1543,13
@@
ttywrite(const char *s, size_t n)
break;
}
}
break;
}
}
+ if (FD_ISSET(cmdfd, &rfd))
+ lim = ttyread();
}
}
+ return;
+
+write_error:
+ die("write error on tty: %s\n", strerror(errno));
}
void
}
void
@@
-3235,7
+3239,7
@@
xclear(int x1, int y1, int x2, int y2)
void
xhints(void)
{
void
xhints(void)
{
- XClassHint class = {
opt_class ? opt_class : termname,
termname};
+ XClassHint class = {
termname, opt_class ? opt_class :
termname};
XWMHints wm = {.flags = InputHint, .input = 1};
XSizeHints *sizeh = NULL;
XWMHints wm = {.flags = InputHint, .input = 1};
XSizeHints *sizeh = NULL;
@@
-3467,7
+3471,7
@@
xinit(void)
if (xw.gm & XNegative)
xw.l += DisplayWidth(xw.dpy, xw.scr) - xw.w - 2;
if (xw.gm & YNegative)
if (xw.gm & XNegative)
xw.l += DisplayWidth(xw.dpy, xw.scr) - xw.w - 2;
if (xw.gm & YNegative)
- xw.t += Display
Width
(xw.dpy, xw.scr) - xw.h - 2;
+ xw.t += Display
Height
(xw.dpy, xw.scr) - xw.h - 2;
/* Events */
xw.attrs.background_pixel = dc.col[defaultbg].pixel;
/* Events */
xw.attrs.background_pixel = dc.col[defaultbg].pixel;
@@
-4327,7
+4331,7
@@
run(void)
void
usage(void)
{
void
usage(void)
{
- die("%s " VERSION " (c) 2010-201
5
st engineers\n"
+ die("%s " VERSION " (c) 2010-201
6
st engineers\n"
"usage: st [-a] [-v] [-c class] [-f font] [-g geometry] [-o file]\n"
" [-i] [-t title] [-T title] [-w windowid] [-e command ...]"
" [command ...]\n"
"usage: st [-a] [-v] [-c class] [-f font] [-g geometry] [-o file]\n"
" [-i] [-t title] [-T title] [-w windowid] [-e command ...]"
" [command ...]\n"