/*
* Empire - A multi-player, client/server Internet based war game.
- * Copyright (C) 1986-2013, Dave Pare, Jeff Bailey, Thomas Ruschak,
+ * Copyright (C) 1986-2021, Dave Pare, Jeff Bailey, Thomas Ruschak,
* Ken Stevens, Steve McClure, Markus Armbruster
*
* Empire is free software: you can redistribute it and/or modify
* Known contributors to this file:
* David Muir Sharnoff
* Steve McClure, 1998
+ * Markus Armbruster, 2004-2013
*/
#include <config.h>
#include "commands.h"
-#include "news.h"
-#include "optlist.h"
-
/*
* format: setres thing <sect> <#>
*/
int
-setsector(void)
+c_setsector(void)
{
struct sctstr sect;
char *what;
- int amt, current;
+ int amt, ret;
char *p;
struct nstr_sect nstr;
char buf[1024];
what = getstarg(player->argp[1],
"Give what (iron, gold, oil, uranium, fertility, owner, eff., mob., work, avail., oldown, mines)? ",
buf);
- if (!what)
+ if (!what || !*what)
return RET_SYN;
char0 = what[0];
char1 = what[1];
if (!p || !*p)
return RET_SYN;
amt = atoi(p);
- check_sect_ok(§);
+ if (!check_sect_ok(§))
+ return RET_FAIL;
switch (char0) {
case 'i':
- current = sect.sct_min;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- if (sect.sct_own != 0)
- resnoise(§, 1, "Iron ore content",
- (int)sect.sct_min, current);
- sect.sct_min = (unsigned char)current;
+ ret = edit_sect_i(§, "i", sect.sct_min + amt);
break;
case 'g':
- current = sect.sct_gmin;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- if (sect.sct_own != 0)
- resnoise(§, 1, "Gold content",
- (int)sect.sct_gmin, current);
- sect.sct_gmin = (unsigned char)current;
+ ret = edit_sect_i(§, "g", sect.sct_gmin + amt);
break;
case 'o':
switch (char1) {
case 'i':
- current = sect.sct_oil;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- if (sect.sct_own != 0)
- resnoise(§, 1, "Oil content",
- (int)sect.sct_oil, current);
- sect.sct_oil = (unsigned char)current;
+ ret = edit_sect_i(§, "c", sect.sct_oil + amt);
+ break;
break;
case 'w':
- if ((amt < 0) || (amt > MAXNOC - 1))
- return RET_SYN;
- pr("Owner of %s changed from %s (#%d) to %s (#%d).\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum),
- cname(sect.sct_own), sect.sct_own, cname(amt), amt);
- if (sect.sct_own) {
- wu(player->cnum, sect.sct_own,
- "Sector %s lost to deity intervention\n",
- xyas(sect.sct_x, sect.sct_y, sect.sct_own));
- }
- if (amt)
- wu(player->cnum, amt,
- "Sector %s gained from deity intervention\n",
- xyas(sect.sct_x, sect.sct_y, amt));
- sect.sct_own = (natid)amt;
+ ret = edit_sect(§, "o", p);
break;
case 'l':
- if ((amt < 0) || (amt > MAXNOC - 1))
- return RET_SYN;
- pr("Old owner of %s changed from %s (#%d) to %s (#%d).\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum),
- cname(sect.sct_oldown),
- sect.sct_oldown, cname(amt), amt);
- sect.sct_oldown = (natid)amt;
+ ret = edit_sect(§, "O", p);
break;
default:
pr("huh?\n");
}
break;
case 'e':
- current = sect.sct_effic;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- pr("Efficiency in %s changed to %d.\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum), current);
- sect.sct_effic = current;
+ ret = edit_sect_i(§, "e", sect.sct_effic + amt);
break;
case 'm':
switch (char1) {
case 'i':
- current = sect.sct_mines;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > MINES_MAX)
- current = MINES_MAX;
- if (sect.sct_own != 0 && sect.sct_own == sect.sct_oldown)
- resnoise(§, 1, "Mines", sect.sct_mines, current);
- sect.sct_mines = current;
+ ret = edit_sect_i(§, "M", sect.sct_mines + amt);
break;
case 'o':
- current = sect.sct_mobil;
- current += amt;
- if (current < -127)
- current = -127;
- if (current > 127)
- current = 127;
- pr("Mobility in %s changed to %d.\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum), current);
- sect.sct_mobil = current;
+ ret = edit_sect_i(§, "m", sect.sct_mobil + amt);
break;
default:
pr("huh?\n");
}
break;
case 'a':
- current = sect.sct_avail;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 9999)
- current = 9999;
- pr("Available in %s changed to %d.\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum), current);
- sect.sct_avail = (short)current;
+ ret = edit_sect_i(§, "a", sect.sct_avail + amt);
break;
case 'w':
- current = sect.sct_work;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- pr("Work in %s changed to %d.\n",
- xyas(sect.sct_x, sect.sct_y, player->cnum), current);
- sect.sct_work = (unsigned char)current;
+ ret = edit_sect_i(§, "w", sect.sct_work + amt);
break;
case 'f':
- current = sect.sct_fertil;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- if (sect.sct_own != 0)
- resnoise(§, 1, "Fertility content",
- (int)sect.sct_fertil, current);
- sect.sct_fertil = (unsigned char)current;
+ ret = edit_sect_i(§, "f", sect.sct_fertil + amt);
break;
case 'u':
- current = sect.sct_uran;
- current += amt;
- if (current < 0)
- current = 0;
- if (current > 100)
- current = 100;
- if (sect.sct_own != 0)
- resnoise(§, 1, "Uranium content",
- (int)sect.sct_uran, current);
- sect.sct_uran = (unsigned char)current;
+ ret = edit_sect_i(§, "u", sect.sct_uran + amt);
break;
default:
pr("huh?\n");
- return RET_SYN;
+ ret = RET_SYN;
}
+ if (ret != RET_OK)
+ return ret;
putsect(§);
}
return RET_OK;
}
-
-static void
-resbenefit(natid who, int good)
-{
- if (!opt_GODNEWS)
- return;
-
- if (good) {
- if (who)
- nreport(player->cnum, N_AIDS, who, 1);
- } else {
- if (who)
- nreport(player->cnum, N_HURTS, who, 1);
- }
-}
-
-void
-resnoise(struct sctstr *sptr, int public_amt, char *name, int old,
- int new)
-{
- char p[100];
-
- pr("%s of %s changed from %d to %d\n",
- name, xyas(sptr->sct_x, sptr->sct_y, player->cnum), old, new);
- if (public_amt)
- (void)sprintf(p, "changed from %d to %d", old, new);
- else
- (void)sprintf(p, "%s", old < new ? "increased" : "decreased");
- if (sptr->sct_own)
- wu(0, sptr->sct_own,
- "%s in %s was %s by an act of %s\n",
- name, xyas(sptr->sct_x, sptr->sct_y, sptr->sct_own),
- p, cname(player->cnum));
- resbenefit(sptr->sct_own, (old < new));
-}