]> git.pond.sub.org Git - empserver/blobdiff - src/lib/commands/scut.c
Update copyright notice.
[empserver] / src / lib / commands / scut.c
index 870dce735a57d8df7a3c9d769182e1e9d2dfe3cb..a0a7f2ed1cb36f1158444a191748299fafa7dad4 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-2007, Dave Pare, Jeff Bailey, Thomas Ruschak,
  *                           Ken Stevens, Steve McClure
  *
  *  This program is free software; you can redistribute it and/or modify
@@ -19,9 +19,9 @@
  *
  *  ---
  *
- *  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.
  *
  *  ---
  *
  *     
  */
 
-#include "misc.h"
-#include "player.h"
-#include "sect.h"
-#include "news.h"
-#include "var.h"
-#include "xy.h"
-#include "ship.h"
-#include "land.h"
-#include "plane.h"
-#include "nat.h"
-#include "nsc.h"
-#include "deity.h"
-#include "file.h"
+#include <config.h>
+
+#include <ctype.h>
 #include "commands.h"
+#include "empobj.h"
 #include "optlist.h"
 
 static void scuttle_land(struct lndstr *);
 
-union item_u {
-    struct shpstr ship;
-    struct plnstr plane;
-    struct lndstr land;
-};
-
-int
-scuttle_tradeship(struct shpstr *sp, int interactive)
-{
-    extern int trade_1_dist;   /* less than this gets no money */
-    extern int trade_2_dist;   /* less than this gets trade_1 money */
-    extern int trade_3_dist;   /* less than this gets trade_2 money */
-    extern float trade_1;      /* return on trade_1 distance */
-    extern float trade_2;      /* return on trade_2 distance */
-    extern float trade_3;      /* return on trade_3 distance */
-    extern float trade_ally_bonus;     /* 20% bonus for trading with allies */
-    extern float trade_ally_cut;       /* 10% bonus for ally you trade with */
-    float cash = 0;
-    float ally_cash = 0;
-    int dist;
-    struct sctstr sect;
-    struct mchrstr *mp;
-    struct natstr *np;
-    s_char buf[512];
-    struct natstr *natp;
-
-    mp = &mchr[(int)sp->shp_type];
-    getsect(sp->shp_x, sp->shp_y, &sect);
-    if (sect.sct_own && sect.sct_type == SCT_HARBR) {
-       dist = mapdist(sp->shp_x, sp->shp_y,
-                      sp->shp_orig_x, sp->shp_orig_y);
-       if (interactive)
-           pr("%s has gone %d sects\n", prship(sp), dist);
-       else
-           wu(0, sp->shp_own, "%s has gone %d sects\n", prship(sp), dist);
-       if (dist < trade_1_dist)
-           cash = 0;
-       else if (dist < trade_2_dist)
-           cash = (1.0 + trade_1 * ((float)dist));
-       else if (dist < trade_3_dist)
-           cash = (1.0 + trade_2 * ((float)dist));
-       else
-           cash = (1.0 + trade_3 * ((float)dist));
-       cash *= mp->m_cost;
-       cash *= (((float)sp->shp_effic) / 100.0);
-
-       if (sect.sct_own != sp->shp_own) {
-           cash *= (1.0 + trade_ally_bonus);
-           ally_cash = cash * trade_ally_cut;
-       }
-    }
-
-    if (!interactive && cash) {
-       natp = getnatp(sp->shp_own);
-       natp->nat_money += cash;
-       putnat(natp);
-       wu(0, sp->shp_own, "You just made $%d.\n", (int)cash);
-    } else if (!cash && !interactive) {
-       wu(0, sp->shp_own, "Unfortunately, you make $0 on this trade.\n");
-    } else if (cash && interactive) {
-       player->dolcost -= cash;
-    } else if (interactive) {
-       pr("You won't get any money if you scuttle in %s!",
-          xyas(sp->shp_x, sp->shp_y, player->cnum));
-       sprintf(buf, "Are you sure you want to scuttle %s? ", prship(sp));
-       return confirm(buf);
-    }
-
-    if (ally_cash) {
-       np = getnatp(sect.sct_own);
-       np->nat_money += ally_cash;
-       putnat(np);
-       wu(0, sect.sct_own,
-          "Trade with %s nets you $%d at %s\n",
-          cname(sp->shp_own),
-          (int)ally_cash, xyas(sect.sct_x, sect.sct_y, sect.sct_own));
-       if (sp->shp_own != sp->shp_orig_own)
-           nreport(sp->shp_own, N_PIRATE_TRADE, sp->shp_orig_own, 1);
-       else
-           nreport(sp->shp_own, N_TRADE, sect.sct_own, 1);
-    } else if (sp->shp_own != sp->shp_orig_own)
-       nreport(sp->shp_own, N_PIRATE_KEEP, sp->shp_orig_own, 1);
-
-    return 1;
-}
-
 int
 scut(void)
 {
     struct nstr_item ni;
-    union item_u item;
+    union empobj_storage item;
     int type;
     struct mchrstr *mp;
-    struct plchrstr *pp;
-    struct lchrstr *lp;
-    s_char *p;
-    s_char prompt[128];
-    s_char buf[1024];
+    char *p;
+    char prompt[128];
+    char buf[1024];
 
     if (!(p = getstarg(player->argp[1], "Ship, land, or plane? ", buf)))
        return RET_SYN;
@@ -171,7 +74,7 @@ scut(void)
        return RET_SYN;
     if (p && (isalpha(*p) || (*p == '*') || (*p == '~') || issector(p)
              || islist(p))) {
-       s_char y_or_n[80], bbuf[80];
+       char y_or_n[80], bbuf[80];
 
        if (type == EF_SHIP) {
            if (*p == '*')
@@ -211,11 +114,11 @@ scut(void)
        if (!confirm(y_or_n))
            return RET_FAIL;
     }
-    while (nxtitem(&ni, (s_char *)&item)) {
+    while (nxtitem(&ni, &item)) {
        if (!player->owner)
            continue;
        if (opt_MARKET) {
-           if (ontradingblock(type, (int *)&item.ship)) {
+           if (ontradingblock(type, &item.ship)) {
                pr("You cannot scuttle an item on the trading block!\n");
                continue;
            }
@@ -236,11 +139,9 @@ scut(void)
                   prland(&item.land));
                continue;
            }
-           lp = &lchr[(int)item.land.lnd_type];
            pr("%s", prland(&item.land));
            scuttle_land(&item.land);
        } else {
-           pp = &plchr[(int)item.plane.pln_type];
            pr("%s", prplane(&item.plane));
            if (item.plane.pln_ship >= 0) {
                struct shpstr ship;
@@ -248,10 +149,8 @@ scut(void)
                getship(item.plane.pln_ship, &ship);
                take_plane_off_ship(&item.plane, &ship);
            }
-           makelost(EF_PLANE, item.plane.pln_own, item.plane.pln_uid,
-                    item.plane.pln_x, item.plane.pln_y);
-           item.plane.pln_own = 0;
-           putplane(item.plane.pln_uid, (s_char *)&item.plane);
+           item.plane.pln_effic = 0;
+           putplane(item.plane.pln_uid, &item.plane);
        }
        pr(" scuttled in %s\n",
           xyas(item.ship.shp_x, item.ship.shp_y, player->cnum));
@@ -260,6 +159,82 @@ scut(void)
     return RET_OK;
 }
 
+int
+scuttle_tradeship(struct shpstr *sp, int interactive)
+{
+    float cash = 0;
+    float ally_cash = 0;
+    int dist;
+    struct sctstr sect;
+    struct mchrstr *mp;
+    struct natstr *np;
+    char buf[512];
+    struct natstr *natp;
+
+    mp = &mchr[(int)sp->shp_type];
+    getsect(sp->shp_x, sp->shp_y, &sect);
+    if (sect.sct_own && sect.sct_type == SCT_HARBR) {
+       dist = mapdist(sp->shp_x, sp->shp_y,
+                      sp->shp_orig_x, sp->shp_orig_y);
+       /* Don't disclose distance to to pirates */
+       if (sp->shp_own == sp->shp_orig_own) {
+           if (interactive)
+               pr("%s has gone %d sects\n", prship(sp), dist);
+           else
+               wu(0, sp->shp_own, "%s has gone %d sects\n",
+                  prship(sp), dist);
+       }
+       if (dist < trade_1_dist)
+           cash = 0;
+       else if (dist < trade_2_dist)
+           cash = 1.0 + trade_1 * dist;
+       else if (dist < trade_3_dist)
+           cash = 1.0 + trade_2 * dist;
+       else
+           cash = 1.0 + trade_3 * dist;
+       cash *= mp->m_cost;
+       cash *= sp->shp_effic / 100.0;
+
+       if (sect.sct_own != sp->shp_own) {
+           ally_cash = cash * trade_ally_cut;
+           cash *= (1.0 + trade_ally_bonus);
+       }
+    }
+
+    if (!interactive && cash) {
+       natp = getnatp(sp->shp_own);
+       natp->nat_money += cash;
+       putnat(natp);
+       wu(0, sp->shp_own, "You just made $%d.\n", (int)cash);
+    } else if (!cash && !interactive) {
+       wu(0, sp->shp_own, "Unfortunately, you make $0 on this trade.\n");
+    } else if (cash && interactive) {
+       player->dolcost -= cash;
+    } else if (interactive && sp->shp_own == sp->shp_orig_own) {
+       pr("You won't get any money if you scuttle in %s!",
+          xyas(sp->shp_x, sp->shp_y, player->cnum));
+       sprintf(buf, "Are you sure you want to scuttle %s? ", prship(sp));
+       return confirm(buf);
+    }
+
+    if (ally_cash) {
+       np = getnatp(sect.sct_own);
+       np->nat_money += ally_cash;
+       putnat(np);
+       wu(0, sect.sct_own,
+          "Trade with %s nets you $%d at %s\n",
+          cname(sp->shp_own),
+          (int)ally_cash, xyas(sect.sct_x, sect.sct_y, sect.sct_own));
+       if (sp->shp_own != sp->shp_orig_own)
+           nreport(sp->shp_own, N_PIRATE_TRADE, sp->shp_orig_own, 1);
+       else
+           nreport(sp->shp_own, N_TRADE, sect.sct_own, 1);
+    } else if (sp->shp_own != sp->shp_orig_own)
+       nreport(sp->shp_own, N_PIRATE_KEEP, sp->shp_orig_own, 1);
+
+    return 1;
+}
+
 void
 scuttle_ship(struct shpstr *sp)
 {
@@ -270,7 +245,7 @@ scuttle_ship(struct shpstr *sp)
 
     getsect(sp->shp_x, sp->shp_y, &sect);
     snxtitem_all(&ni, EF_PLANE);
-    while (nxtitem(&ni, (s_char *)&plane)) {
+    while (nxtitem(&ni, &plane)) {
        if (plane.pln_own == 0)
            continue;
        if (plane.pln_ship == sp->shp_uid) {
@@ -279,20 +254,18 @@ scuttle_ship(struct shpstr *sp)
                wu(0, plane.pln_own, "Plane %d scuttled in %s\n",
                   plane.pln_uid,
                   xyas(plane.pln_x, plane.pln_y, plane.pln_own));
-               makelost(EF_PLANE, plane.pln_own, plane.pln_uid,
-                        plane.pln_x, plane.pln_y);
-               plane.pln_own = 0;
+               plane.pln_effic = 0;
            } else {
                wu(0, plane.pln_own,
                   "Plane %d transferred off ship %d to %s\n",
                   plane.pln_uid, sp->shp_uid,
                   xyas(plane.pln_x, plane.pln_y, plane.pln_own));
            }
-           putplane(plane.pln_uid, (s_char *)&plane);
+           putplane(plane.pln_uid, &plane);
        }
     }
     snxtitem_all(&ni, EF_LAND);
-    while (nxtitem(&ni, (s_char *)&land)) {
+    while (nxtitem(&ni, &land)) {
        if (land.lnd_own == 0)
            continue;
        if (land.lnd_ship == sp->shp_uid) {
@@ -302,13 +275,12 @@ scuttle_ship(struct shpstr *sp)
                   "Land unit %d transferred off ship %d to %s\n",
                   land.lnd_uid, sp->shp_uid,
                   xyas(land.lnd_x, land.lnd_y, land.lnd_own));
-               putland(land.lnd_uid, (s_char *)&land);
+               putland(land.lnd_uid, &land);
            } else
                scuttle_land(&land);
        }
     }
-    makelost(EF_SHIP, sp->shp_own, sp->shp_uid, sp->shp_x, sp->shp_y);
-    sp->shp_own = 0;
+    sp->shp_effic = 0;
     putship(sp->shp_uid, sp);
 }
 
@@ -322,7 +294,7 @@ scuttle_land(struct lndstr *lp)
 
     getsect(lp->lnd_x, lp->lnd_y, &sect);
     snxtitem_all(&ni, EF_PLANE);
-    while (nxtitem(&ni, (s_char *)&plane)) {
+    while (nxtitem(&ni, &plane)) {
        if (plane.pln_own == 0)
            continue;
        if (plane.pln_land == lp->lnd_uid) {
@@ -331,20 +303,18 @@ scuttle_land(struct lndstr *lp)
                wu(0, plane.pln_own, "Plane %d scuttled in %s\n",
                   plane.pln_uid,
                   xyas(plane.pln_x, plane.pln_y, plane.pln_own));
-               makelost(EF_PLANE, plane.pln_own, plane.pln_uid,
-                        plane.pln_x, plane.pln_y);
-               plane.pln_own = 0;
+               plane.pln_effic = 0;
            } else {
                wu(0, plane.pln_own,
                   "Plane %d transferred off unit %d to %s\n",
                   plane.pln_uid, lp->lnd_uid,
                   xyas(plane.pln_x, plane.pln_y, plane.pln_own));
            }
-           putplane(plane.pln_uid, (s_char *)&plane);
+           putplane(plane.pln_uid, &plane);
        }
     }
     snxtitem_all(&ni, EF_LAND);
-    while (nxtitem(&ni, (s_char *)&land)) {
+    while (nxtitem(&ni, &land)) {
        if (land.lnd_own == 0)
            continue;
        if (land.lnd_land == lp->lnd_uid) {
@@ -354,12 +324,11 @@ scuttle_land(struct lndstr *lp)
                   "Land unit %d transferred off unit %d to %s\n",
                   land.lnd_uid, lp->lnd_uid,
                   xyas(land.lnd_x, land.lnd_y, land.lnd_own));
-               putland(land.lnd_uid, (s_char *)&land);
+               putland(land.lnd_uid, &land);
            } else
                scuttle_land(&land);
        }
     }
-    makelost(EF_LAND, lp->lnd_own, lp->lnd_uid, lp->lnd_x, lp->lnd_y);
-    lp->lnd_own = 0;
+    lp->lnd_effic = 0;
     putland(lp->lnd_uid, lp);
 }