removed extra tt_col += n in gen_write
[unix-history] / usr / src / usr.bin / window / wwopen.c
index dc0cee7..d765235 100644 (file)
@@ -1,8 +1,16 @@
 #ifndef lint
 #ifndef lint
-static char *sccsid = "@(#)wwopen.c    3.10 83/08/26";
+static char sccsid[] = "@(#)wwopen.c   3.21 %G%";
 #endif
 
 #endif
 
+/*
+ * Copyright (c) 1983 Regents of the University of California,
+ * All rights reserved.  Redistribution permitted subject to
+ * the terms of the Berkeley Software License Agreement.
+ */
+
 #include "ww.h"
 #include "ww.h"
+#include <sys/types.h>
+#include <sys/socket.h>
 
 struct ww *
 wwopen(flags, nrow, ncol, row, col, nline)
 
 struct ww *
 wwopen(flags, nrow, ncol, row, col, nline)
@@ -17,6 +25,8 @@ wwopen(flags, nrow, ncol, row, col, nline)
                wwerrno = WWE_NOMEM;
                goto bad;
        }
                wwerrno = WWE_NOMEM;
                goto bad;
        }
+       w->ww_pty = -1;
+       w->ww_socket = -1;
 
        for (i = 0; i < NWW && wwindex[i] != 0; i++)
                ;
 
        for (i = 0; i < NWW && wwindex[i] != 0; i++)
                ;
@@ -26,26 +36,68 @@ wwopen(flags, nrow, ncol, row, col, nline)
        }
        w->ww_index = i;
 
        }
        w->ww_index = i;
 
-       if ((w->ww_w.nr = nrow) <= 0
-           || (w->ww_w.nc = ncol) <= 0
-           || (w->ww_w.l = col) < 0
-           || (w->ww_w.r = col + ncol) > wwncol
-           || (w->ww_w.t = row) < 0
-           || (w->ww_w.b = row + nrow) > wwnrow) {
-               wwerrno = WWE_SIZE;
-               goto bad;
-       }
-       w->ww_nline = MAX(nline, w->ww_w.nr);
+       if (nline < nrow)
+               nline = nrow;
+
+       w->ww_w.t = row;
+       w->ww_w.b = row + nrow;
+       w->ww_w.l = col;
+       w->ww_w.r = col + ncol;
+       w->ww_w.nr = nrow;
+       w->ww_w.nc = ncol;
+
+       w->ww_b.t = row;
+       w->ww_b.b = row + nline;
+       w->ww_b.l = col;
+       w->ww_b.r = col + ncol;
+       w->ww_b.nr = nline;
+       w->ww_b.nc = ncol;
+
+       w->ww_i.t = MAX(w->ww_w.t, 0);
+       w->ww_i.b = MIN(w->ww_w.b, wwnrow);
+       w->ww_i.l = MAX(w->ww_w.l, 0);
+       w->ww_i.r = MIN(w->ww_w.r, wwncol);
+       w->ww_i.nr = w->ww_i.b - w->ww_i.t;
+       w->ww_i.nc = w->ww_i.r - w->ww_i.l;
+
+       w->ww_cur.r = w->ww_w.t;
+       w->ww_cur.c = w->ww_w.l;
 
        if (flags & WWO_PTY) {
 
        if (flags & WWO_PTY) {
+               struct winsize winsize;
+
                if (wwgetpty(w) < 0)
                        goto bad;
                if (wwgetpty(w) < 0)
                        goto bad;
-               w->ww_haspty = 1;
-               if (wwsettty(w->ww_pty, &wwwintty) < 0)
+               if (wwsettty(w->ww_pty, &wwwintty, (struct ww_tty *)0) < 0)
+                       goto bad;
+               winsize.ws_row = nrow;
+               winsize.ws_col = ncol;
+               winsize.ws_xpixel = winsize.ws_ypixel = 0;
+               if (ioctl(w->ww_pty, (int)TIOCSWINSZ, (char *)&winsize) < 0) {
+                       wwerrno = WWE_SYS;
+                       goto bad;
+               }
+               w->ww_ispty = 1;
+       } else if (flags & WWO_SOCKET) {
+               int d[2];
+               if (socketpair(AF_UNIX, SOCK_STREAM, PF_UNSPEC, d) < 0) {
+                       wwerrno = WWE_SYS;
                        goto bad;
                        goto bad;
+               }
+               w->ww_pty = d[0];
+               w->ww_socket = d[1];
+       }
+       if (flags & (WWO_PTY|WWO_SOCKET)) {
+               if ((w->ww_ob = malloc(512)) == 0) {
+                       wwerrno = WWE_NOMEM;
+                       goto bad;
+               }
+               w->ww_obe = w->ww_ob + 512;
+               w->ww_obp = w->ww_obq = w->ww_ob;
        }
 
        }
 
-       w->ww_win = wwalloc(w->ww_w.nr, w->ww_w.nc, sizeof (char));
+       w->ww_win = wwalloc(w->ww_w.t, w->ww_w.l,
+               w->ww_w.nr, w->ww_w.nc, sizeof (char));
        if (w->ww_win == 0)
                goto bad;
        m = 0;
        if (w->ww_win == 0)
                goto bad;
        m = 0;
@@ -53,32 +105,27 @@ wwopen(flags, nrow, ncol, row, col, nline)
                m |= WWM_GLS;
        if (flags & WWO_REVERSE)
                m |= WWM_REV;
                m |= WWM_GLS;
        if (flags & WWO_REVERSE)
                m |= WWM_REV;
-       for (i = 0; i < w->ww_w.nr; i++)
-               for (j = 0; j < w->ww_w.nc; j++)
+       for (i = w->ww_w.t; i < w->ww_w.b; i++)
+               for (j = w->ww_w.l; j < w->ww_w.r; j++)
                        w->ww_win[i][j] = m;
                        w->ww_win[i][j] = m;
-       
-       w->ww_cov = wwalloc(w->ww_w.nr, w->ww_w.nc, sizeof (char));
-       if (w->ww_cov == 0)
-               goto bad;
-       for (i = 0; i < w->ww_w.nr; i++)
-               for (j = 0; j < w->ww_w.nc; j++)
-                       w->ww_cov[i][j] = WWX_NOBODY;
 
        if (flags & WWO_FRAME) {
 
        if (flags & WWO_FRAME) {
-               w->ww_fmap = wwalloc(w->ww_w.nr, w->ww_w.nc, sizeof (char));
+               w->ww_fmap = wwalloc(w->ww_w.t, w->ww_w.l,
+                       w->ww_w.nr, w->ww_w.nc, sizeof (char));
                if (w->ww_fmap == 0)
                if (w->ww_fmap == 0)
-                       wwerrno = WWE_NOMEM;
-               for (i = 0; i < wwnrow; i++)
-                       for (j = 0; j < wwncol; j++)
+                       goto bad;
+               for (i = w->ww_w.t; i < w->ww_w.b; i++)
+                       for (j = w->ww_w.l; j < w->ww_w.r; j++)
                                w->ww_fmap[i][j] = 0;
        }
                                w->ww_fmap[i][j] = 0;
        }
-       
+
        w->ww_buf = (union ww_char **)
        w->ww_buf = (union ww_char **)
-               wwalloc(w->ww_nline, w->ww_w.nc, sizeof (union ww_char));
+               wwalloc(w->ww_b.t, w->ww_b.l,
+                       w->ww_b.nr, w->ww_b.nc, sizeof (union ww_char));
        if (w->ww_buf == 0)
                goto bad;
        if (w->ww_buf == 0)
                goto bad;
-       for (i = 0; i < w->ww_nline; i++)
-               for (j = 0; j < w->ww_w.nc; j++)
+       for (i = w->ww_b.t; i < w->ww_b.b; i++)
+               for (j = w->ww_b.l; j < w->ww_b.r; j++)
                        w->ww_buf[i][j].c_w = ' ';
 
        w->ww_nvis = (short *)malloc((unsigned) w->ww_w.nr * sizeof (short));
                        w->ww_buf[i][j].c_w = ' ';
 
        w->ww_nvis = (short *)malloc((unsigned) w->ww_w.nr * sizeof (short));
@@ -86,28 +133,30 @@ wwopen(flags, nrow, ncol, row, col, nline)
                wwerrno = WWE_NOMEM;
                goto bad;
        }
                wwerrno = WWE_NOMEM;
                goto bad;
        }
+       w->ww_nvis -= w->ww_w.t;
        nvis = m ? 0 : w->ww_w.nc;
        nvis = m ? 0 : w->ww_w.nc;
-       for (i = 0; i < w->ww_w.nr; i++)
+       for (i = w->ww_w.t; i < w->ww_w.b; i++)
                w->ww_nvis[i] = nvis;
 
        w->ww_state = WWS_INITIAL;
                w->ww_nvis[i] = nvis;
 
        w->ww_state = WWS_INITIAL;
+       w->ww_oflags = flags;
        return wwindex[w->ww_index] = w;
 bad:
        if (w != 0) {
                if (w->ww_win != 0)
        return wwindex[w->ww_index] = w;
 bad:
        if (w != 0) {
                if (w->ww_win != 0)
-                       wwfree(w->ww_win);
-               if (w->ww_cov != 0)
-                       wwfree(w->ww_cov);
+                       wwfree(w->ww_win, w->ww_w.t);
                if (w->ww_fmap != 0)
                if (w->ww_fmap != 0)
-                       wwfree(w->ww_fmap);
+                       wwfree(w->ww_fmap, w->ww_w.t);
                if (w->ww_buf != 0)
                if (w->ww_buf != 0)
-                       wwfree((char **)w->ww_buf);
+                       wwfree((char **)w->ww_buf, w->ww_b.t);
                if (w->ww_nvis != 0)
                if (w->ww_nvis != 0)
-                       free((char *)w->ww_nvis);
-               if (w->ww_haspty) {
-                       (void) close(w->ww_tty);
+                       free((char *)(w->ww_nvis + w->ww_w.t));
+               if (w->ww_ob != 0)
+                       free(w->ww_ob);
+               if (w->ww_pty >= 0)
                        (void) close(w->ww_pty);
                        (void) close(w->ww_pty);
-               }
+               if (w->ww_socket >= 0)
+                       (void) close(w->ww_socket);
                free((char *)w);
        }
        return 0;
                free((char *)w);
        }
        return 0;