we have to initialize escapec before processing arguments
[unix-history] / usr / src / usr.bin / window / wwmove.c
CommitLineData
0d032a5f 1#ifndef lint
7edc52ec 2static char sccsid[] = "@(#)wwmove.c 3.5 %G%";
0d032a5f
EW
3#endif
4
5#include "ww.h"
6
7/*
8 * Move a window. Should be unattached.
9 */
10wwmove(w, row, col)
11register struct ww *w;
12{
f2a77fe1
EW
13 register dr, dc;
14 register i;
15
0d032a5f
EW
16 if (w->ww_forw != 0 || w->ww_back != 0)
17 return; /* sanity */
18
f2a77fe1
EW
19 dr = row - w->ww_w.t;
20 dc = col - w->ww_w.l;
21
22 w->ww_w.t += dr;
23 w->ww_w.b += dr;
24 w->ww_w.l += dc;
25 w->ww_w.r += dc;
26
27 w->ww_b.t += dr;
28 w->ww_b.b += dr;
29 w->ww_b.l += dc;
30 w->ww_b.r += dc;
0d032a5f
EW
31
32 w->ww_i.t = MAX(w->ww_w.t, 0);
33 w->ww_i.b = MIN(w->ww_w.b, wwnrow);
34 w->ww_i.nr = w->ww_i.b - w->ww_i.t;
35 w->ww_i.l = MAX(w->ww_w.l, 0);
36 w->ww_i.r = MIN(w->ww_w.r, wwncol);
37 w->ww_i.nc = w->ww_i.r - w->ww_i.l;
f2a77fe1
EW
38
39 w->ww_cur.r += dr;
40 w->ww_cur.c += dc;
41
42 w->ww_win -= dr;
43 for (i = w->ww_w.t; i < w->ww_w.b; i++)
44 w->ww_win[i] -= dc;
f2a77fe1
EW
45 if (w->ww_fmap != 0) {
46 w->ww_fmap -= dr;
47 for (i = w->ww_w.t; i < w->ww_w.b; i++)
48 w->ww_fmap[i] -= dc;
49 }
50 w->ww_nvis -= dr;
c1e16556
EW
51 for (i = w->ww_i.t; i < w->ww_i.b; i++) {
52 register j = w->ww_i.l;
53 register char *win = &w->ww_win[i][j];
84ad208b 54 register char *smap = &wwsmap[i][j];
c1e16556
EW
55 int nvis = 0;
56
84ad208b
EW
57 for (; j < w->ww_i.r; j++, win++, smap++)
58 if (*win == 0 && *smap == w->ww_index)
c1e16556
EW
59 nvis++;
60 w->ww_nvis[i] = nvis;
61 }
f2a77fe1
EW
62 w->ww_buf -= dr;
63 for (i = w->ww_b.t; i < w->ww_b.b; i++)
64 w->ww_buf[i] -= dc;
0d032a5f 65}