]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - sail/pl_7.c
1 /* $NetBSD: pl_7.c,v 1.16 2001/01/01 21:57:38 jwise Exp $ */
4 * Copyright (c) 1983, 1993
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. All advertising materials mentioning features or use of this software
16 * must display the following acknowledgement:
17 * This product includes software developed by the University of
18 * California, Berkeley and its contributors.
19 * 4. Neither the name of the University nor the names of its contributors
20 * may be used to endorse or promote products derived from this software
21 * without specific prior written permission.
23 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36 #include <sys/cdefs.h>
39 static char sccsid
[] = "@(#)pl_7.c 8.1 (Berkeley) 5/31/93";
41 __RCSID("$NetBSD: pl_7.c,v 1.16 2001/01/01 21:57:38 jwise Exp $");
45 #include <sys/ttydefaults.h>
60 static char sc_hasprompt
;
61 static const char *sc_prompt
;
62 static const char *sc_buf
;
72 char loaded
, fired
, changed
, repaired
;
75 char movebuf
[sizeof SHIP(0)->file
->movebuf
];
77 struct ship
*ms
; /* memorial structure, &cc->ship[player] */
78 struct File
*mf
; /* ms->file */
79 struct shipspecs
*mc
; /* ms->specs */
85 printf("Can't sail on this terminal.\n");
88 /* initscr() already done in SCREENTEST() */
89 view_w
= newwin(VIEW_Y
, VIEW_X
, VIEW_T
, VIEW_L
);
90 slot_w
= newwin(SLOT_Y
, SLOT_X
, SLOT_T
, SLOT_L
);
91 scroll_w
= newwin(SCROLL_Y
, SCROLL_X
, SCROLL_T
, SCROLL_L
);
92 stat_w
= newwin(STAT_Y
, STAT_X
, STAT_T
, STAT_L
);
93 turn_w
= newwin(TURN_Y
, TURN_X
, TURN_T
, TURN_L
);
106 /* alarm already turned off */
108 wmove(scroll_w
, SCROLL_Y
- 1, 0);
117 newturn(int n
__attribute__((__unused__
)))
119 repaired
= loaded
= fired
= changed
= 0;
123 if (mf
->readyL
& R_LOADING
) {
124 if (mf
->readyL
& R_DOUBLE
)
125 mf
->readyL
= R_LOADING
;
127 mf
->readyL
= R_LOADED
;
129 if (mf
->readyR
& R_LOADING
) {
130 if (mf
->readyR
& R_DOUBLE
)
131 mf
->readyR
= R_LOADING
;
133 mf
->readyR
= R_LOADED
;
136 Write(W_DDEAD
, SHIP(0), 0, 0, 0, 0);
139 wmove(scroll_w
, sc_line
, 0);
147 wprintw(scroll_w
, "%s%s", sc_prompt
, sc_buf
);
150 Write(W_ALIVE
, SHIP(0), 0, 0, 0, 0);
151 if (mf
->FS
&& (!mc
->rig1
|| windspeed
== 6))
152 Write(W_FS
, ms
, 0, 0, 0, 0);
154 Write(W_FS
, ms
, 2, 0, 0, 0);
158 if (mf
->captured
!= 0)
159 leave(LEAVE_CAPTURED
);
161 leave(LEAVE_HURRICAN
);
166 signal(SIGALRM
, newturn
);
172 Signal(const char *fmt
, struct ship
*ship
, ...)
182 fmtship(format
, sizeof(format
), fmt
, ship
);
183 vwprintw(scroll_w
, format
, ap
);
190 Msg(const char *fmt
, ...)
199 vwprintw(scroll_w
, fmt
, ap
);
207 if (++sc_line
>= SCROLL_Y
)
209 wmove(scroll_w
, sc_line
, 0);
218 static char buf
[BUFSIZ
];
220 fmtship(buf
, sizeof(buf
), p
, ship
);
224 waddstr(scroll_w
, buf
);
236 sgetch(const char *p
, struct ship
*ship
, int flag
)
243 while ((c
= wgetch(scroll_w
)) == EOF
)
245 if (flag
&& c
>= ' ' && c
< 0x7f)
252 sgetstr(const char *pr
, char *buf
, int n
)
257 prompt(pr
, (struct ship
*)0);
264 while ((c
= wgetch(scroll_w
)) == EOF
)
273 waddstr(scroll_w
, "\b \b");
278 if (c
>= ' ' && c
< 0x7f && p
< buf
+ n
- 1) {
294 wrefresh(scroll_w
); /* move the cursor */
305 && sp
->file
->row
> viewrow
306 && sp
->file
->row
< viewrow
+ VIEW_Y
307 && sp
->file
->col
> viewcol
308 && sp
->file
->col
< viewcol
+ VIEW_X
) {
309 wmove(view_w
, sp
->file
->row
- viewrow
,
310 sp
->file
->col
- viewcol
);
311 waddch(view_w
, colours(sp
));
313 sternrow(sp
) - viewrow
,
314 sterncol(sp
) - viewcol
);
315 waddch(view_w
, sterncolour(sp
));
325 wprintw(turn_w
, "%cTurn %d", dont_adjust
?'*':'-', turn
);
332 wmove(stat_w
, STAT_1
, 0);
333 wprintw(stat_w
, "Points %3d\n", mf
->points
);
334 wprintw(stat_w
, "Fouls %2d\n", fouled(ms
));
335 wprintw(stat_w
, "Grapples %2d\n", grappled(ms
));
337 wmove(stat_w
, STAT_2
, 0);
338 wprintw(stat_w
, " 0 %c(%c)\n",
339 maxmove(ms
, winddir
+ 3, -1) + '0',
340 maxmove(ms
, winddir
+ 3, 1) + '0');
341 waddstr(stat_w
, " \\|/\n");
342 wprintw(stat_w
, " -^-%c(%c)\n",
343 maxmove(ms
, winddir
+ 2, -1) + '0',
344 maxmove(ms
, winddir
+ 2, 1) + '0');
345 waddstr(stat_w
, " /|\\\n");
346 wprintw(stat_w
, " | %c(%c)\n",
347 maxmove(ms
, winddir
+ 1, -1) + '0',
348 maxmove(ms
, winddir
+ 1, 1) + '0');
349 wprintw(stat_w
, " %c(%c)\n",
350 maxmove(ms
, winddir
, -1) + '0',
351 maxmove(ms
, winddir
, 1) + '0');
353 wmove(stat_w
, STAT_3
, 0);
354 wprintw(stat_w
, "Load %c%c %c%c\n",
355 loadname
[mf
->loadL
], readyname(mf
->readyL
),
356 loadname
[mf
->loadR
], readyname(mf
->readyR
));
357 wprintw(stat_w
, "Hull %2d\n", mc
->hull
);
358 wprintw(stat_w
, "Crew %2d %2d %2d\n",
359 mc
->crew1
, mc
->crew2
, mc
->crew3
);
360 wprintw(stat_w
, "Guns %2d %2d\n", mc
->gunL
, mc
->gunR
);
361 wprintw(stat_w
, "Carr %2d %2d\n", mc
->carL
, mc
->carR
);
362 wprintw(stat_w
, "Rigg %d %d %d ", mc
->rig1
, mc
->rig2
, mc
->rig3
);
366 wprintw(stat_w
, "%d", mc
->rig4
);
373 if (!boarding(ms
, 0)) {
374 mvwaddstr(slot_w
, 0, 0, " ");
375 mvwaddstr(slot_w
, 1, 0, " ");
377 mvwaddstr(slot_w
, 1, 0, "OBP");
378 if (!boarding(ms
, 1)) {
379 mvwaddstr(slot_w
, 2, 0, " ");
380 mvwaddstr(slot_w
, 3, 0, " ");
382 mvwaddstr(slot_w
, 3, 0, "DBP");
384 wmove(slot_w
, SLOT_Y
-4, 0);
386 wprintw(slot_w
, "%dRH", mf
->RH
);
388 waddstr(slot_w
, " ");
389 wmove(slot_w
, SLOT_Y
-3, 0);
391 wprintw(slot_w
, "%dRG", mf
->RG
);
393 waddstr(slot_w
, " ");
394 wmove(slot_w
, SLOT_Y
-2, 0);
396 wprintw(slot_w
, "%dRR", mf
->RR
);
398 waddstr(slot_w
, " ");
402 wprintw(slot_w
,"%d", windspeed
);
403 mvwaddch(slot_w
, Y
, 0, ' ');
404 mvwaddch(slot_w
, Y
, 2, ' ');
405 mvwaddch(slot_w
, Y
-1, 0, ' ');
406 mvwaddch(slot_w
, Y
-1, 1, ' ');
407 mvwaddch(slot_w
, Y
-1, 2, ' ');
408 mvwaddch(slot_w
, Y
+1, 0, ' ');
409 mvwaddch(slot_w
, Y
+1, 1, ' ');
410 mvwaddch(slot_w
, Y
+1, 2, ' ');
411 wmove(slot_w
, Y
- dr
[winddir
], 1 - dc
[winddir
]);
427 waddch(slot_w
, '\\');
430 mvwaddch(slot_w
, Y
+ dr
[winddir
], 1 + dc
[winddir
], '+');
449 for (n
= 0; n
< BOX_X
; n
++)
452 for (n
= 0; n
< BOX_X
; n
++)
454 for (n
= BOX_T
+1; n
< BOX_B
; n
++) {
455 mvaddch(n
, BOX_L
, '|');
456 mvaddch(n
, BOX_R
, '|');
458 mvaddch(BOX_T
, BOX_L
, '+');
459 mvaddch(BOX_T
, BOX_R
, '+');
460 mvaddch(BOX_B
, BOX_L
, '+');
461 mvaddch(BOX_B
, BOX_R
, '+');
464 #define WSaIM "Wooden Ships & Iron Men"
465 wmove(view_w
, 2, (VIEW_X
- sizeof WSaIM
- 1) / 2);
466 waddstr(view_w
, WSaIM
);
467 wmove(view_w
, 4, (VIEW_X
- strlen(cc
->name
)) / 2);
468 waddstr(view_w
, cc
->name
);
471 move(LINE_T
, LINE_L
);
472 printw("Class %d %s (%d guns) '%s' (%c%c)",
474 classname
[mc
->class],
485 viewrow
= mf
->row
- VIEW_Y
/ 2;
486 viewcol
= mf
->col
- VIEW_X
/ 2;
492 viewrow
-= VIEW_Y
/ 3;
498 viewrow
+= VIEW_Y
/ 3;
504 viewcol
-= VIEW_X
/ 5;
510 viewcol
+= VIEW_X
/ 5;
518 if (mf
->row
< viewrow
+ VIEW_Y
/4)
519 viewrow
= mf
->row
- (VIEW_Y
- VIEW_Y
/4);
520 else if (mf
->row
> viewrow
+ (VIEW_Y
- VIEW_Y
/4))
521 viewrow
= mf
->row
- VIEW_Y
/4;
522 if (mf
->col
< viewcol
+ VIEW_X
/8)
523 viewcol
= mf
->col
- (VIEW_X
- VIEW_X
/8);
524 else if (mf
->col
> viewcol
+ (VIEW_X
- VIEW_X
/8))
525 viewcol
= mf
->col
- VIEW_X
/8;