Wolfpack Empire - mirror of https://git.pond.sub.org/empserver
http://wolfpackempire.com/
A bridge (span or tower) must be splashed when it gets damaged below SCT_MINEFF. Likewise when its last supporting sector (bridge head or tower) gets damaged below SCT_MINEFF, unless EASY_BRIDGES is enabled. We need to check this whenever a bridge head, span or tower gets damaged. This is done in three places, and all of them screw up: * checksect() ignores damage to bridge heads. It also leaves writing back the sector it checks to the caller, which never happens when it's called from sct_postread(). Note that checksect() drowns all planes on bridges it splashes. Functions that need to exempt flying planes from such a fate have to splash bridges themselves. * sect_damage() ignores damage to bridge towers, and damage to bridge spans unless EASY_BRIDGES is enabled. It then runs checksect(), which compensates for these omissions, but happily drowns the planes sect_damage() attempts to protect. * eff_bomb() ignores damage to bridge heads. Collateral damage makes sect_damage() run, which compensates for the omission. This causes the following bugs: * Efficiency damage going through sect_damage() can drown planes it shouldn't. This affects pinpoint bombing when collateral damage splashes a bridge, and strategic bombing. The drowned planes then crash and burn when they attempt to land at their (just splashed) base. * Efficiency damage to bridge heads not going through sect_damage() fails to collapse unsupported bridges. This affects pin-bombing efficiency without collateral damage, and ground combat. Also deity commands edit, setsector and add, but that could be regarded as a feature. * If the sector file somehow ends up with an inefficient bridge span, it collapses on every read again and again, until it collapses on a write. Related problems exist with other actions of checksect(), and they're not addressed here. * If the sector file somehow ends up with adjacent inefficient bridge towers, checksect() on any of them recurses infinitely: - checksect() inefficient tower T1 - knockdown() T1, but don't write that back to the sector file - bridgefall() T1; this reads all adjacent sectors, including inefficient towert T2 - checksect() T2 - knockdown() T2, but don't write that back to the sector file - bridgefall() T1; this reads adjacent sectors including T1 - checksect() T1 ... This commit creates a new function bridge_damaged() to splash any bridges that became inefficient or unsupported after damage to a sector. To avoid the inifinite recursion, we call it in sct_prewrite() instead of checksect(). No uses knockdown() outside bridgefall.c remain, so give it internal linkage. |
||
---|---|---|
doc | ||
include | ||
info | ||
m4 | ||
man | ||
scripts | ||
src | ||
.gitignore | ||
bootstrap | ||
compile | ||
config.guess | ||
config.sub | ||
configure.ac | ||
COPYING | ||
CREDITS | ||
depcomp | ||
GNUmakefile.in | ||
INSTALL | ||
install-sh | ||
Make.mk | ||
README |
Welcome to Empire 4, code-named Wolfpack. Empire is a multi-player, client/server Internet based war game. Copyright (C) 1986-2008, Dave Pare, Jeff Bailey, Thomas Ruschak, Ken Stevens, Steve McClure This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License (in file `COPYING'), or (at your option) any later version. See file `CREDITS' for a list of contributors. Directory `doc' has additional information. File `doc/README' describes the files there and what they talk about. To build the server and set up a game, follow the steps below. (1) Unpacking the source tree If you downloaded a tarball, unpack it. If you're pulling from CVS, check out and run bootstrap. This requires recent versions of Autoconf and Automake to be installed. (2) Building a server Prerequisites: IEEE Std 1003.1-2001 (POSIX.1-2001), GNU make, a curses library, Perl, and either nroff or GNU troff (`groff'). See file `INSTALL' for detailed compilation and installation instructions. Quick guide for the impatient: run configure; make; make install. The last step is optional; everything runs fine right from the build tree. If make fails without doing anything, you're probably not using GNU make. Some systems have it installed as `gmake'. Solaris supports POSIX.1-2001, but you need to set up your environment for that. Try passing SHELL=/usr/xpg4/bin/sh PATH=/usr/xpg6/bin:/usr/xpg4/bin:$PATH to make. See standards(5) for details. (3) Creating a game * Create a configuration for your game. make install installs one in $prefix/etc/empire/econfig ($prefix is /usr/local unless you chose something else with configure). You can use pconfig to create another one. * Edit your configuration file. See doc/econfig for more information. Unless you put your configuration file in the default location (where make install installs it), you have to use -e with all programs to make them use your configuration. * Run files to set up your data directory. * Run fairland to create a world. For a sample world, try `fairland 10 30'. This creates file ./newcap_script, which will be used below. You can edit it to change country names and passwords. Check out fairland's manual page for more information. * Start the server. For development, you want to run it with -d in a debugger, see doc/debugging. Do not use -d for a real game! * Log in as deity POGO with password peter. This guide assumes you use the included client `empire', but other clients should work as well. For help, try `info'. To change the deity password, use `change re <password>'. * Create countries with `exec newcap_script'. Your game is now up! Naturally, there's more to running a real game than that, but that's beyond the scope of this file. Please report bugs to <wolfpack@wolfpackempire.com> or via SourceForge http://sourceforge.net/projects/empserver (registration required). For more information or help, try rec.games.empire on Usenet, or send e-mail to <wolfpack@wolfpackempire.com> and we'll try to answer if we can. Also check out our web site at "http://www.wolfpackempire.com". Have fun! Wolfpack!