| 1 | #ifndef lint |
| 2 | static char sccsid[] = "@(#)wwmove.c 3.5 %G%"; |
| 3 | #endif |
| 4 | |
| 5 | #include "ww.h" |
| 6 | |
| 7 | /* |
| 8 | * Move a window. Should be unattached. |
| 9 | */ |
| 10 | wwmove(w, row, col) |
| 11 | register struct ww *w; |
| 12 | { |
| 13 | register dr, dc; |
| 14 | register i; |
| 15 | |
| 16 | if (w->ww_forw != 0 || w->ww_back != 0) |
| 17 | return; /* sanity */ |
| 18 | |
| 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; |
| 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; |
| 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; |
| 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; |
| 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]; |
| 54 | register char *smap = &wwsmap[i][j]; |
| 55 | int nvis = 0; |
| 56 | |
| 57 | for (; j < w->ww_i.r; j++, win++, smap++) |
| 58 | if (*win == 0 && *smap == w->ww_index) |
| 59 | nvis++; |
| 60 | w->ww_nvis[i] = nvis; |
| 61 | } |
| 62 | w->ww_buf -= dr; |
| 63 | for (i = w->ww_b.t; i < w->ww_b.b; i++) |
| 64 | w->ww_buf[i] -= dc; |
| 65 | } |