Home | History | Annotate | Line # | Download | only in sail
pl_6.c revision 1.11.40.1
      1  1.11.40.1       jym /*	$NetBSD: pl_6.c,v 1.11.40.1 2009/05/13 19:18:06 jym Exp $	*/
      2        1.3       cgd 
      3        1.1       cgd /*
      4        1.3       cgd  * Copyright (c) 1983, 1993
      5        1.3       cgd  *	The Regents of the University of California.  All rights reserved.
      6        1.1       cgd  *
      7        1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8        1.1       cgd  * modification, are permitted provided that the following conditions
      9        1.1       cgd  * are met:
     10        1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11        1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12        1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13        1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14        1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15       1.11       agc  * 3. Neither the name of the University nor the names of its contributors
     16        1.1       cgd  *    may be used to endorse or promote products derived from this software
     17        1.1       cgd  *    without specific prior written permission.
     18        1.1       cgd  *
     19        1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20        1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21        1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22        1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23        1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24        1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25        1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26        1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27        1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28        1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29        1.1       cgd  * SUCH DAMAGE.
     30        1.1       cgd  */
     31        1.1       cgd 
     32        1.4  christos #include <sys/cdefs.h>
     33        1.1       cgd #ifndef lint
     34        1.3       cgd #if 0
     35        1.3       cgd static char sccsid[] = "@(#)pl_6.c	8.1 (Berkeley) 5/31/93";
     36        1.3       cgd #else
     37  1.11.40.1       jym __RCSID("$NetBSD: pl_6.c,v 1.11.40.1 2009/05/13 19:18:06 jym Exp $");
     38        1.3       cgd #endif
     39        1.1       cgd #endif /* not lint */
     40        1.1       cgd 
     41        1.8     jwise #include <signal.h>
     42        1.9     jwise #include "extern.h"
     43        1.1       cgd #include "player.h"
     44        1.1       cgd 
     45  1.11.40.1       jym static int turned(void);
     46        1.7     jwise 
     47        1.4  christos void
     48        1.6     jwise repair(void)
     49        1.1       cgd {
     50        1.1       cgd 	char c;
     51        1.4  christos 	char *repairs;
     52        1.4  christos 	struct shipspecs *ptr = mc;
     53        1.4  christos 	int count;
     54        1.1       cgd 
     55        1.1       cgd #define FIX(x, m) (m - ptr->x > count \
     56        1.1       cgd 	? (ptr->x += count, count = 0) : (count -= m - ptr->x, ptr->x = m))
     57        1.1       cgd 
     58        1.1       cgd 	if (repaired || loaded || fired || changed || turned()) {
     59        1.4  christos 		Msg("No hands free to repair");
     60        1.1       cgd 		return;
     61        1.1       cgd 	}
     62        1.1       cgd 	c = sgetch("Repair (hull, guns, rigging)? ", (struct ship *)0, 1);
     63        1.1       cgd 	switch (c) {
     64        1.1       cgd 		case 'h':
     65        1.1       cgd 			repairs = &mf->RH;
     66        1.1       cgd 			break;
     67        1.1       cgd 		case 'g':
     68        1.1       cgd 			repairs = &mf->RG;
     69        1.1       cgd 			break;
     70        1.1       cgd 		case 'r':
     71        1.1       cgd 			repairs = &mf->RR;
     72        1.1       cgd 			break;
     73        1.1       cgd 		default:
     74        1.4  christos 			Msg("Avast heaving!");
     75        1.1       cgd 			return;
     76        1.1       cgd 	}
     77        1.1       cgd 	if (++*repairs >= 3) {
     78        1.1       cgd 		count = 2;
     79        1.1       cgd 		switch (c) {
     80        1.1       cgd 		case 'h': {
     81        1.1       cgd 			int max = ptr->guns/4;
     82        1.1       cgd 			if (ptr->hull < max) {
     83        1.1       cgd 				FIX(hull, max);
     84  1.11.40.1       jym 				send_hull(ms, ptr->hull);
     85        1.1       cgd 			}
     86        1.1       cgd 			break;
     87        1.1       cgd 			}
     88        1.1       cgd 		case 'g':
     89        1.1       cgd 			if (ptr->gunL < ptr->gunR) {
     90        1.1       cgd 				int max = ptr->guns/5 - ptr->carL;
     91        1.1       cgd 				if (ptr->gunL < max) {
     92        1.1       cgd 					FIX(gunL, max);
     93  1.11.40.1       jym 					send_gunl(ms, ptr->gunL, ptr->carL);
     94        1.1       cgd 				}
     95        1.1       cgd 			} else {
     96        1.1       cgd 				int max = ptr->guns/5 - ptr->carR;
     97        1.1       cgd 				if (ptr->gunR < max) {
     98        1.1       cgd 					FIX(gunR, max);
     99  1.11.40.1       jym 					send_gunr(ms, ptr->gunR, ptr->carR);
    100        1.1       cgd 				}
    101        1.1       cgd 			}
    102        1.1       cgd 			break;
    103        1.1       cgd 		case 'r':
    104        1.1       cgd #define X 2
    105        1.1       cgd 			if (ptr->rig4 >= 0 && ptr->rig4 < X) {
    106        1.1       cgd 				FIX(rig4, X);
    107  1.11.40.1       jym 				send_rig4(ms, ptr->rig4);
    108        1.1       cgd 			}
    109        1.1       cgd 			if (count && ptr->rig3 < X) {
    110        1.1       cgd 				FIX(rig3, X);
    111  1.11.40.1       jym 				send_rig3(ms, ptr->rig3);
    112        1.1       cgd 			}
    113        1.1       cgd 			if (count && ptr->rig2 < X) {
    114        1.1       cgd 				FIX(rig2, X);
    115  1.11.40.1       jym 				send_rig2(ms, ptr->rig2);
    116        1.1       cgd 			}
    117        1.1       cgd 			if (count && ptr->rig1 < X) {
    118        1.1       cgd 				FIX(rig1, X);
    119  1.11.40.1       jym 				send_rig1(ms, ptr->rig1);
    120        1.1       cgd 			}
    121        1.1       cgd 			break;
    122        1.1       cgd 		}
    123        1.1       cgd 		if (count == 2) {
    124        1.4  christos 			Msg("Repairs completed.");
    125        1.1       cgd 			*repairs = 2;
    126        1.1       cgd 		} else {
    127        1.1       cgd 			*repairs = 0;
    128        1.1       cgd 		}
    129        1.1       cgd 	}
    130        1.1       cgd 	repaired = 1;
    131        1.1       cgd }
    132        1.1       cgd 
    133        1.7     jwise static int
    134        1.6     jwise turned(void)
    135        1.1       cgd {
    136        1.4  christos 	char *p;
    137        1.1       cgd 
    138        1.1       cgd 	for (p = movebuf; *p; p++)
    139        1.1       cgd 		if (*p == 'r' || *p == 'l')
    140        1.1       cgd 			return 1;
    141        1.1       cgd 	return 0;
    142        1.1       cgd }
    143        1.1       cgd 
    144        1.4  christos void
    145        1.6     jwise loadplayer(void)
    146        1.1       cgd {
    147        1.1       cgd 	char c;
    148        1.4  christos 	int loadL, loadR, ready, load;
    149        1.1       cgd 
    150        1.1       cgd 	if (!mc->crew3) {
    151        1.4  christos 		Msg("Out of crew");
    152        1.1       cgd 		return;
    153        1.1       cgd 	}
    154        1.1       cgd 	loadL = mf->loadL;
    155        1.1       cgd 	loadR = mf->loadR;
    156        1.1       cgd 	if (!loadL && !loadR) {
    157        1.1       cgd 		c = sgetch("Load which broadside (left or right)? ",
    158        1.1       cgd 			(struct ship *)0, 1);
    159        1.1       cgd 		if (c == 'r')
    160        1.1       cgd 			loadL = 1;
    161        1.1       cgd 		else
    162        1.1       cgd 			loadR = 1;
    163        1.1       cgd 	}
    164        1.4  christos 	if ((!loadL && loadR) || (loadL && !loadR)) {
    165        1.1       cgd 		c = sgetch("Reload with (round, double, chain, grape)? ",
    166        1.1       cgd 			(struct ship *)0, 1);
    167        1.1       cgd 		switch (c) {
    168        1.1       cgd 		case 'r':
    169        1.1       cgd 			load = L_ROUND;
    170        1.1       cgd 			ready = 0;
    171        1.1       cgd 			break;
    172        1.1       cgd 		case 'd':
    173        1.1       cgd 			load = L_DOUBLE;
    174        1.1       cgd 			ready = R_DOUBLE;
    175        1.1       cgd 			break;
    176        1.1       cgd 		case 'c':
    177        1.1       cgd 			load = L_CHAIN;
    178        1.1       cgd 			ready = 0;
    179        1.1       cgd 			break;
    180        1.1       cgd 		case 'g':
    181        1.1       cgd 			load = L_GRAPE;
    182        1.1       cgd 			ready = 0;
    183        1.1       cgd 			break;
    184        1.1       cgd 		default:
    185        1.4  christos 			Msg("Broadside not loaded.");
    186        1.1       cgd 			return;
    187        1.1       cgd 		}
    188        1.1       cgd 		if (!loadR) {
    189        1.1       cgd 			mf->loadR = load;
    190        1.1       cgd 			mf->readyR = ready|R_LOADING;
    191        1.1       cgd 		} else {
    192        1.1       cgd 			mf->loadL = load;
    193        1.1       cgd 			mf->readyL = ready|R_LOADING;
    194        1.1       cgd 		}
    195        1.1       cgd 		loaded = 1;
    196        1.1       cgd 	}
    197        1.1       cgd }
    198