]> git.pond.sub.org Git - empserver/blobdiff - src/lib/update/nav_util.c
Update copyright notice
[empserver] / src / lib / update / nav_util.c
index 90769cd5843a5f286889649d92bb89c5bfe40b13..58c2a6319026d2d8f7dd3dc4ddffb09f51ce0a7c 100644 (file)
@@ -1,6 +1,6 @@
 /*
  *  Empire - A multi-player, client/server Internet based war game.
- *  Copyright (C) 1986-2000, Dave Pare, Jeff Bailey, Thomas Ruschak,
+ *  Copyright (C) 1986-2010, Dave Pare, Jeff Bailey, Thomas Ruschak,
  *                           Ken Stevens, Steve McClure
  *
  *  This program is free software; you can redistribute it and/or modify
  *
  *  ---
  *
- *  See the "LEGAL", "LICENSE", "CREDITS" and "README" files for all the
- *  related information and legal notices. It is expected that any future
- *  projects/authors will amend these files as needed.
+ *  See files README, COPYING and CREDITS in the root of the source
+ *  tree for related information and legal notices.  It is expected
+ *  that future projects/authors will amend these files as needed.
  *
  *  ---
  *
  *  nav_util.c: Utilities for autonav and sail
- * 
+ *
  *  Known contributors to this file:
- *     
+ *
  */
 
-#include "misc.h"
+#include <config.h>
 
-#include <ctype.h>
-#include "var.h"
-#include "ship.h"
-#include "plane.h"
+#include "item.h"
 #include "land.h"
-#include "nuke.h"
-#include "sect.h"
-#include "news.h"
-#include "xy.h"
 #include "nsc.h"
-#include "nat.h"
 #include "path.h"
-#include "file.h"
-#include "item.h"
-#include "optlist.h"
-#include "player.h"
+#include "plague.h"
+#include "plane.h"
+#include "ship.h"
 #include "update.h"
-#include "subs.h"
-#include "common.h"
-#include "gen.h"
-
-/* Format a ship name */
-int
-check_nav(struct sctstr *sect)
-{
-    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;
-}
 
-/* load a specific ship given its 
+/* load a specific ship given its
  * location and what field to modify.
  * new autonav code
- * Chad Zabel 6/1/94 
+ * Chad Zabel 6/1/94
  */
 int
-load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
+load_it(struct shpstr *sp, struct sctstr *psect, int i)
 {
-    int comm, shipown, amount, ship_amt, sect_amt;
+    int shipown, amount, ship_amt, sect_amt;
     int abs_max, max_amt, transfer;
+    i_type comm;
     struct mchrstr *vship;
 
     amount = sp->shp_lend[i];
     shipown = sp->shp_own;
     comm = sp->shp_tend[i];
-    if (CANT_HAPPEN((unsigned)comm > I_MAX))
+    if (CANT_HAPPEN(comm <= I_NONE || comm > I_MAX))
        return 0;
 
     ship_amt = sp->shp_item[comm];
     sect_amt = psect->sct_item[comm];
 
     /* check for disloyal civilians */
-    if (psect->sct_oldown != shipown && comm == V_CIVIL) {
+    if (psect->sct_oldown != shipown && comm == I_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)
+    if (comm == I_CIVIL || comm == I_MILIT)
        sect_amt--;             /* leave 1 civ or mil to hold the sector. */
     vship = &mchr[(int)sp->shp_type];
     abs_max = max_amt = vship->m_item[comm];
@@ -112,7 +79,7 @@ load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
     if (!abs_max)
        return 0;               /* can't load the ship, skip to the end. */
 
-    max_amt = min(sect_amt, max_amt - ship_amt);
+    max_amt = MIN(sect_amt, max_amt - ship_amt);
     if (max_amt <= 0 && (ship_amt != abs_max)) {
        sp->shp_autonav |= AN_LOADING;
        return 0;
@@ -128,12 +95,12 @@ load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
        transfer = abs_max - ship_amt;  /* then the max alowed */
     /* on the ship.        */
 
-    if (transfer == 0)
+    if (transfer <= 0)
        return 0;               /* nothing to move */
 
 
     sp->shp_item[comm] = ship_amt + transfer;
-    if (comm == V_CIVIL || comm == V_MILIT)
+    if (comm == I_CIVIL || comm == I_MILIT)
        sect_amt++;             /*adjustment */
     psect->sct_item[comm] = sect_amt - transfer;
 
@@ -148,22 +115,22 @@ load_it(register struct shpstr *sp, register struct sctstr *psect, int i)
 
 }
 
-/* unload_it 
+/* unload_it
  * A guess alot of this looks like load_it but because of its location
  * in the autonav code I had to split the 2 procedures up.
  * unload_it dumps all the goods from the ship to the harbor.
  * ONLY goods in the trade fields will be unloaded.
  * new autonav code
- * Chad Zabel 6/1/94  
+ * Chad Zabel 6/1/94
  */
 void
-unload_it(register struct shpstr *sp)
+unload_it(struct shpstr *sp)
 {
     struct sctstr *sectp;
     int i;
     int landowner;
     int shipown;
-    int comm;
+    i_type comm;
     int sect_amt;
     int ship_amt;
     int max_amt;
@@ -182,23 +149,23 @@ unload_it(register struct shpstr *sp)
            continue;
 
        comm = sp->shp_tend[i];
-       if (CANT_HAPPEN((unsigned)comm > I_MAX))
+       if (CANT_HAPPEN(comm <= I_NONE || comm > I_MAX))
            continue;
        ship_amt = sp->shp_item[comm];
        sect_amt = sectp->sct_item[comm];
 
        /* check for disloyal civilians */
-       if (sectp->sct_oldown != shipown && comm == V_CIVIL) {
+       if (sectp->sct_oldown != shipown && comm == I_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)
+       if (comm == I_CIVIL)
            ship_amt--;         /* This leaves 1 civs on board the ship */
 
-       max_amt = min(ship_amt, ITEM_MAX - sect_amt);
+       max_amt = MIN(ship_amt, ITEM_MAX - sect_amt);
        if (max_amt <= 0)
            continue;
 
@@ -211,59 +178,3 @@ unload_it(register struct shpstr *sp)
            sectp->sct_pstage = PLG_EXPOSED;
     }
 }
-
-/* auto_fuel_ship 
- * Assume a check for fuel=0 has already been made and passed.  
- * Try to fill a ship using petro. and then oil.            
- * 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;
-
-    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);
-}