⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pl_6.c

📁 早期freebsd实现
💻 C
字号:
/* * Copyright (c) 1983, 1993 *	The Regents of the University of California.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *	This product includes software developed by the University of *	California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors *    may be used to endorse or promote products derived from this software *    without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */#ifndef lintstatic char sccsid[] = "@(#)pl_6.c	8.1 (Berkeley) 5/31/93";#endif /* not lint */#include "player.h"repair(){	char c;	register char *repairs;	register struct shipspecs *ptr = mc;	register int count;#define FIX(x, m) (m - ptr->x > count \	? (ptr->x += count, count = 0) : (count -= m - ptr->x, ptr->x = m))	if (repaired || loaded || fired || changed || turned()) {		Signal("No hands free to repair", (struct ship *)0);		return;	}	c = sgetch("Repair (hull, guns, rigging)? ", (struct ship *)0, 1);	switch (c) {		case 'h':			repairs = &mf->RH;			break;		case 'g':			repairs = &mf->RG;			break;		case 'r':			repairs = &mf->RR;			break;		default:			Signal("Avast heaving!", (struct ship *)0);			return;	}	if (++*repairs >= 3) {		count = 2;		switch (c) {		case 'h': {			int max = ptr->guns/4;			if (ptr->hull < max) {				FIX(hull, max);				Write(W_HULL, ms, 0, ptr->hull, 0, 0, 0);			}			break;			}		case 'g':			if (ptr->gunL < ptr->gunR) {				int max = ptr->guns/5 - ptr->carL;				if (ptr->gunL < max) {					FIX(gunL, max);					Write(W_GUNL, ms, 0, ptr->gunL,						ptr->carL, 0, 0);				}			} else {				int max = ptr->guns/5 - ptr->carR;				if (ptr->gunR < max) {					FIX(gunR, max);					Write(W_GUNR, ms, 0, ptr->gunR,						ptr->carR, 0, 0);				}			}			break;		case 'r':#define X 2			if (ptr->rig4 >= 0 && ptr->rig4 < X) {				FIX(rig4, X);				Write(W_RIG4, ms, 0, ptr->rig4, 0, 0, 0);			}			if (count && ptr->rig3 < X) {				FIX(rig3, X);				Write(W_RIG3, ms, 0, ptr->rig3, 0, 0, 0);			}			if (count && ptr->rig2 < X) {				FIX(rig2, X);				Write(W_RIG2, ms, 0, ptr->rig2, 0, 0, 0);			}			if (count && ptr->rig1 < X) {				FIX(rig1, X);				Write(W_RIG1, ms, 0, ptr->rig1, 0, 0, 0);			}			break;		}		if (count == 2) {			Signal("Repairs completed.", (struct ship *)0);			*repairs = 2;		} else {			*repairs = 0;			blockalarm();			draw_stat();			unblockalarm();		}	}	blockalarm();	draw_slot();	unblockalarm();	repaired = 1;}turned(){	register char *p;	for (p = movebuf; *p; p++)		if (*p == 'r' || *p == 'l')			return 1;	return 0;}loadplayer(){	char c;	register loadL, loadR, ready, load;	if (!mc->crew3) {		Signal("Out of crew", (struct ship *)0);		return;	}	loadL = mf->loadL;	loadR = mf->loadR;	if (!loadL && !loadR) {		c = sgetch("Load which broadside (left or right)? ",			(struct ship *)0, 1);		if (c == 'r')			loadL = 1;		else			loadR = 1;	}	if (!loadL && loadR || loadL && !loadR) {		c = sgetch("Reload with (round, double, chain, grape)? ",			(struct ship *)0, 1);		switch (c) {		case 'r':			load = L_ROUND;			ready = 0;			break;		case 'd':			load = L_DOUBLE;			ready = R_DOUBLE;			break;		case 'c':			load = L_CHAIN;			ready = 0;			break;		case 'g':			load = L_GRAPE;			ready = 0;			break;		default:			Signal("Broadside not loaded.",				(struct ship *)0);			return;		}		if (!loadR) {			mf->loadR = load;			mf->readyR = ready|R_LOADING;		} else {			mf->loadL = load;			mf->readyL = ready|R_LOADING;		}		loaded = 1;	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -