Indented with src/scripts/indent-emp.

This commit is contained in:
Markus Armbruster 2003-09-02 20:48:48 +00:00
parent 5f263a7753
commit 9b7adfbecc
437 changed files with 52211 additions and 51052 deletions

View file

@ -56,27 +56,27 @@
#include "gen.h"
/* Format a ship name */
int
int
check_nav(struct sctstr *sect)
{
extern struct dchrstr dchr[];
extern struct dchrstr dchr[];
switch (dchr[sect->sct_type].d_flg & 03) {
case NAVOK:
break;
switch (dchr[sect->sct_type].d_flg & 03) {
case NAVOK:
break;
case NAV_02:
if (sect->sct_effic < 2)
return CN_CONSTRUCTION;
break;
case NAV_60:
if (sect->sct_effic < 60)
return CN_CONSTRUCTION;
break;
default:
return CN_LANDLOCKED;
}
return CN_NAVIGABLE;
case NAV_02:
if (sect->sct_effic < 2)
return CN_CONSTRUCTION;
break;
case NAV_60:
if (sect->sct_effic < 60)
return CN_CONSTRUCTION;
break;
default:
return CN_LANDLOCKED;
}
return CN_NAVIGABLE;
}
/* load a specific ship given its
@ -84,74 +84,75 @@ check_nav(struct sctstr *sect)
* new autonav code
* Chad Zabel 6/1/94
*/
int
int
load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
{
int comm, shipown, amount, ship_amt, sect_amt,
abs_max, max_amt, transfer;
s_char item;
struct mchrstr *vship;
{
int comm, shipown, amount, ship_amt, sect_amt,
abs_max, max_amt, transfer;
s_char item;
struct mchrstr *vship;
amount = sp->shp_lend[i];
shipown = sp->shp_own;
item = sp->shp_tend[i]; /* commodity */
comm = com_num(&item);
amount = sp->shp_lend[i];
shipown = sp->shp_own;
item = sp->shp_tend[i]; /* commodity */
comm = com_num(&item);
ship_amt = getvar(comm,(s_char *) sp , EF_SHIP);
sect_amt = getvar(comm,(s_char *) psect, EF_SECTOR);
ship_amt = getvar(comm, (s_char *)sp, EF_SHIP);
sect_amt = getvar(comm, (s_char *)psect, EF_SECTOR);
/* check for disloyal civilians */
if (psect->sct_oldown != shipown && comm == V_CIVIL)
{ wu(0,shipown,"Ship #%d - unable to load disloyal civilians at %s.",
sp->shp_uid, xyas(psect->sct_x,psect->sct_y,psect->sct_own));
return 0;
}
if (comm == V_CIVIL || comm == V_MILIT)
sect_amt--; /* leave 1 civ or mil to hold the sector. */
vship = &mchr[(int)sp->shp_type];
abs_max = max_amt = (vl_find(comm,vship->m_vtype,
vship->m_vamt,(int) vship->m_nv));
if (!abs_max)
return 0; /* can't load the ship, skip to the end. */
/* check for disloyal civilians */
if (psect->sct_oldown != shipown && comm == V_CIVIL) {
wu(0, shipown,
"Ship #%d - unable to load disloyal civilians at %s.",
sp->shp_uid, xyas(psect->sct_x, psect->sct_y, psect->sct_own));
return 0;
}
if (comm == V_CIVIL || comm == V_MILIT)
sect_amt--; /* leave 1 civ or mil to hold the sector. */
vship = &mchr[(int)sp->shp_type];
abs_max = max_amt = (vl_find(comm, vship->m_vtype,
vship->m_vamt, (int)vship->m_nv));
max_amt = min (sect_amt, max_amt - ship_amt);
if (max_amt <= 0 && (ship_amt != abs_max)) {
sp->shp_autonav |= AN_LOADING;
return 0;
}
if (!abs_max)
return 0; /* can't load the ship, skip to the end. */
max_amt = min(sect_amt, max_amt - ship_amt);
if (max_amt <= 0 && (ship_amt != abs_max)) {
sp->shp_autonav |= AN_LOADING;
return 0;
}
transfer = amount - ship_amt;
if (transfer > sect_amt) { /* not enough in the */
transfer = sect_amt; /* sector to fill the */
sp->shp_autonav |= AN_LOADING; /* ship, set load flag */
}
if (ship_amt + transfer > abs_max) /* Do not load more */
transfer = abs_max-ship_amt; /* then the max alowed */
/* on the ship. */
transfer = amount - ship_amt;
if (transfer > sect_amt) { /* not enough in the */
transfer = sect_amt; /* sector to fill the */
sp->shp_autonav |= AN_LOADING; /* ship, set load flag */
}
if (ship_amt + transfer > abs_max) /* Do not load more */
transfer = abs_max - ship_amt; /* then the max alowed */
/* on the ship. */
if (transfer == 0)
return 0; /* nothing to move */
if (transfer == 0)
return 0; /* nothing to move */
putvar(comm, ship_amt + transfer, (s_char *)sp, EF_SHIP);
if (comm == V_CIVIL || comm == V_MILIT)
sect_amt++; /*adjustment*/
putvar(comm, sect_amt - transfer, (s_char *)psect, EF_SECTOR);
/* deal with the plague */
if (getvar(V_PSTAGE, (s_char *)psect, EF_SECTOR) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sp , EF_SHIP) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)sp, EF_SHIP);
if (getvar(V_PSTAGE, (s_char *)sp, EF_SHIP) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)psect, EF_SECTOR) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)psect, EF_SECTOR);
return 1; /* we did someloading return 1 to keep */
/* our loop happy in nav_ship() */
}
putvar(comm, ship_amt + transfer, (s_char *)sp, EF_SHIP);
if (comm == V_CIVIL || comm == V_MILIT)
sect_amt++; /*adjustment */
putvar(comm, sect_amt - transfer, (s_char *)psect, EF_SECTOR);
/* deal with the plague */
if (getvar(V_PSTAGE, (s_char *)psect, EF_SECTOR) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sp, EF_SHIP) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)sp, EF_SHIP);
if (getvar(V_PSTAGE, (s_char *)sp, EF_SHIP) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)psect, EF_SECTOR) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)psect, EF_SECTOR);
return 1; /* we did someloading return 1 to keep */
/* our loop happy in nav_ship() */
}
/* unload_it
* A guess alot of this looks like load_it but because of its location
@ -160,75 +161,77 @@ load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
* ONLY goods in the trade fields will be unloaded.
* new autonav code
* Chad Zabel 6/1/94
*/
*/
void
unload_it(register struct shpstr *sp)
{
struct sctstr *sectp;
s_char item;
int i;
int landowner;
int shipown;
int comm;
int sect_amt;
int ship_amt;
int abs_max = 99999; /* max amount a sector can hold. */
int max_amt;
int level;
struct sctstr *sectp;
s_char item;
int i;
int landowner;
int shipown;
int comm;
int sect_amt;
int ship_amt;
int abs_max = 99999; /* max amount a sector can hold. */
int max_amt;
int level;
sectp = getsectp(sp->shp_x,sp->shp_y);
sectp = getsectp(sp->shp_x, sp->shp_y);
landowner = sectp->sct_own;
shipown = sp->shp_own;
for(i=0;i<TMAX;++i) {
item = sp->shp_tend[i];
level = sp->shp_lend[i];
landowner = sectp->sct_own;
shipown = sp->shp_own;
if (item == ' ' || level == 0)
continue;
if (landowner == 0 )
continue;
if (sectp->sct_type != SCT_HARBR)
continue;
for (i = 0; i < TMAX; ++i) {
item = sp->shp_tend[i];
level = sp->shp_lend[i];
comm = com_num(&item);
ship_amt = getvar(comm,(s_char *) sp ,EF_SHIP);
sect_amt = getvar(comm,(s_char *) sectp ,EF_SECTOR);
if (item == ' ' || level == 0)
continue;
if (landowner == 0)
continue;
if (sectp->sct_type != SCT_HARBR)
continue;
/* check for disloyal civilians */
if (sectp->sct_oldown != shipown && comm == V_CIVIL)
{
wu(0,sp->shp_own,"Ship #%d - unable to unload civilians into a disloyal sector at %s.",
sp->shp_uid, xyas(sectp->sct_x,sectp->sct_y,sectp->sct_own));
continue;
}
if (comm == V_CIVIL)
ship_amt--; /* This leaves 1 civs on board the ship */
comm = com_num(&item);
ship_amt = getvar(comm, (s_char *)sp, EF_SHIP);
sect_amt = getvar(comm, (s_char *)sectp, EF_SECTOR);
if (sect_amt >= abs_max)
continue; /* The sector is full. */
/* check for disloyal civilians */
if (sectp->sct_oldown != shipown && comm == V_CIVIL) {
wu(0, sp->shp_own,
"Ship #%d - unable to unload civilians into a disloyal sector at %s.",
sp->shp_uid, xyas(sectp->sct_x, sectp->sct_y,
sectp->sct_own));
continue;
}
if (comm == V_CIVIL)
ship_amt--; /* This leaves 1 civs on board the ship */
max_amt = min (ship_amt,abs_max - sect_amt);
if (sect_amt >= abs_max)
continue; /* The sector is full. */
if (max_amt <= 0)
continue;
max_amt = min(ship_amt, abs_max - sect_amt);
putvar(comm, ship_amt - max_amt, (s_char *) sp ,EF_SHIP);
putvar(comm, sect_amt + max_amt, (s_char *) sectp,EF_SECTOR);
if (max_amt <= 0)
continue;
if (getvar(V_PSTAGE, (s_char *)sectp,EF_SECTOR) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sp ,EF_SHIP ) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED,(s_char *)sp, EF_SHIP);
if (getvar(V_PSTAGE, (s_char *)sp ,EF_SHIP ) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sectp,EF_SECTOR) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED,(s_char *)sectp, EF_SECTOR);
}
putvar(comm, ship_amt - max_amt, (s_char *)sp, EF_SHIP);
putvar(comm, sect_amt + max_amt, (s_char *)sectp, EF_SECTOR);
if (getvar(V_PSTAGE, (s_char *)sectp, EF_SECTOR) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sp, EF_SHIP) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)sp, EF_SHIP);
if (getvar(V_PSTAGE, (s_char *)sp, EF_SHIP) == PLG_INFECT &&
getvar(V_PSTAGE, (s_char *)sectp, EF_SECTOR) == PLG_HEALTHY)
putvar(V_PSTAGE, PLG_EXPOSED, (s_char *)sectp, EF_SECTOR);
}
}
}
/* com_num
* This small but useful bit of code runs through the list
* of commodities and return the integer value of the
@ -242,13 +245,13 @@ unload_it(register struct shpstr *sp)
int
com_num(s_char *ptr)
{
struct ichrstr *ip;
struct ichrstr *ip;
for(ip = &ichr[1];ip->i_mnem != 0; ip++) {
if (*ptr == ip->i_mnem)
return ip->i_vtype;
}
return 0; /*NOTREACHED*/
for (ip = &ichr[1]; ip->i_mnem != 0; ip++) {
if (*ptr == ip->i_mnem)
return ip->i_vtype;
}
return 0; /*NOTREACHED*/
}
@ -259,52 +262,52 @@ com_num(s_char *ptr)
* new autonav code.
* This should be merged with the fuel command someday.
* Chad Zabel 6/1/94
*/
*/
void
auto_fuel_ship(register struct shpstr *sp)
{
double d;
int totalfuel = 0;
int need;
int maxfuel;
int newfuel = 0;
int add_fuel = 0;
if (opt_FUEL == 0) return;
getship(sp->shp_uid,sp); /* refresh */
/* fill with petro */
maxfuel = mchr[(int)sp->shp_type].m_fuelc;
d = (double) maxfuel / 5.0;
if (( d-(int)d > 0.0 ))
d++;
need = (int)d;
double d;
int totalfuel = 0;
int need;
int maxfuel;
int newfuel = 0;
int add_fuel = 0;
newfuel = supply_commod(sp->shp_own,sp->shp_x,
sp->shp_y,I_PETROL,need);
add_fuel += newfuel * 5;
if (add_fuel > maxfuel)
add_fuel = maxfuel;
sp->shp_fuel += add_fuel;
totalfuel += add_fuel;
if (totalfuel == maxfuel) {
putship(sp->shp_uid,sp);
return; /* the ship is full */
}
add_fuel = 0;
/* fill with oil */
d = (double) (maxfuel - totalfuel) / 50.0;
if ((d-(int)d > 0.0))
d++;
need = (int)d;
if (opt_FUEL == 0)
return;
getship(sp->shp_uid, sp); /* refresh */
/* fill with petro */
maxfuel = mchr[(int)sp->shp_type].m_fuelc;
d = (double)maxfuel / 5.0;
if ((d - (int)d > 0.0))
d++;
need = (int)d;
newfuel = supply_commod(sp->shp_own,sp->shp_x,
sp->shp_y,I_OIL,need);
add_fuel = newfuel * 50;
if (add_fuel > maxfuel)
add_fuel = maxfuel;
sp->shp_fuel += add_fuel;
putship(sp->shp_uid,sp);
}
newfuel = supply_commod(sp->shp_own, sp->shp_x,
sp->shp_y, I_PETROL, need);
add_fuel += newfuel * 5;
if (add_fuel > maxfuel)
add_fuel = maxfuel;
sp->shp_fuel += add_fuel;
totalfuel += add_fuel;
if (totalfuel == maxfuel) {
putship(sp->shp_uid, sp);
return; /* the ship is full */
}
add_fuel = 0;
/* fill with oil */
d = (double)(maxfuel - totalfuel) / 50.0;
if ((d - (int)d > 0.0))
d++;
need = (int)d;
newfuel = supply_commod(sp->shp_own, sp->shp_x,
sp->shp_y, I_OIL, need);
add_fuel = newfuel * 50;
if (add_fuel > maxfuel)
add_fuel = maxfuel;
sp->shp_fuel += add_fuel;
putship(sp->shp_uid, sp);
}