(edit, prsect, doland): Fix `editing' sector coordinates (copies
sector). New: edit distribution sector, designation and new designation. From Ron Koenderink.
This commit is contained in:
parent
eb246aadd1
commit
7c6067466c
2 changed files with 62 additions and 28 deletions
|
@ -151,7 +151,7 @@ extern int dist(void);
|
|||
extern int drop(void);
|
||||
extern int dump(void);
|
||||
extern int echo(void);
|
||||
extern int doland(s_char, int, struct sctstr *);
|
||||
extern int doland(s_char, int, s_char *, struct sctstr *);
|
||||
extern int docountry(s_char, int, s_char *, float, natid, struct natstr *);
|
||||
extern int doship(s_char, int, s_char *, struct shpstr *);
|
||||
extern int dounit(s_char, int, s_char *, struct lndstr *);
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
* David Muir Sharnoff
|
||||
* Chad Zabel, 1994
|
||||
* Steve McClure, 1998-2000
|
||||
* Ron Koenderink, 2003
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
|
@ -63,7 +64,7 @@ static void prsect(struct sctstr *sect);
|
|||
static void noise(struct sctstr *sptr, int public_amt, s_char *name,
|
||||
int old, int new);
|
||||
static void benefit(natid who, int good);
|
||||
int doland(s_char op, int arg, struct sctstr *sect);
|
||||
int doland(s_char op, int arg, s_char *p, struct sctstr *sect);
|
||||
int docountry(s_char op, int arg, s_char *p, float farg, natid nat,
|
||||
struct natstr *np);
|
||||
int doship(s_char op, int arg, s_char *p, struct shpstr *ship);
|
||||
|
@ -71,9 +72,6 @@ int dounit(s_char op, int arg, s_char *p, struct lndstr *land);
|
|||
int doplane(s_char op, int arg, s_char *p, struct plnstr *plane);
|
||||
|
||||
|
||||
/*
|
||||
* format: give c <amt> <commod> <sect>
|
||||
*/
|
||||
int
|
||||
edit(void)
|
||||
{
|
||||
|
@ -170,8 +168,7 @@ edit(void)
|
|||
arg = atoi(ptr);
|
||||
} else
|
||||
return RET_SYN;
|
||||
}
|
||||
else if (arg_index == 3) {
|
||||
} else if (arg_index == 3) {
|
||||
if ((err = getin(&thing, &ptr, &arg, buf)) != RET_OK) {
|
||||
if (err == END) {
|
||||
switch (ewhat) {
|
||||
|
@ -205,7 +202,7 @@ edit(void)
|
|||
return err;
|
||||
break;
|
||||
case 'l':
|
||||
if ((err = doland(thing[0], arg, §)) != RET_OK)
|
||||
if ((err = doland(thing[0], arg, ptr, §)) != RET_OK)
|
||||
return err;
|
||||
if (!putsect(§))
|
||||
return RET_FAIL;
|
||||
|
@ -276,20 +273,27 @@ noise(struct sctstr *sptr, int public_amt, s_char *name, int old, int new)
|
|||
static void
|
||||
prsect(struct sctstr *sect)
|
||||
{
|
||||
pr("X coord <X>: %d\t", sect->sct_x);
|
||||
pr("Y coord <Y>: %d\n", sect->sct_y);
|
||||
pr("X dist coord: %d\t", sect->sct_dist_x);
|
||||
pr("Y dist coord: %d\n", sect->sct_dist_y);
|
||||
pr(" sect own oo eff mob min gld frt oil urn wrk lty che plg ptime fall avail\n");
|
||||
pr("things: o O e m i g f c u w l x p t F a\n");
|
||||
prxy("%4d,%-4d", sect->sct_x, sect->sct_y, player->cnum);
|
||||
pr(" %c%c %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d %4d %3d %5d %4d %5d\n", dchr[sect->sct_type].d_mnem, (sect->sct_newtype == sect->sct_type) ? ' ' : dchr[sect->sct_newtype].d_mnem, sect->sct_own, sect->sct_oldown, sect->sct_effic, sect->sct_mobil, sect->sct_min, sect->sct_gmin, sect->sct_fertil, sect->sct_oil, sect->sct_uran, sect->sct_work, sect->sct_loyal, getvar(V_CHE, (s_char *)sect, EF_SECTOR), getvar(V_PSTAGE, (s_char *)sect, EF_SECTOR), getvar(V_PTIME, (s_char *)sect, EF_SECTOR), getvar(V_FALLOUT, (s_char *)sect, EF_SECTOR), sect->sct_avail);
|
||||
pr("Location <L>: %s\t", xyas(sect->sct_x, sect->sct_y, player->cnum));
|
||||
pr("Distribution sector <D>: %s\n",
|
||||
xyas(sect->sct_dist_x, sect->sct_dist_y, player->cnum));
|
||||
pr("Designation <s>: %c\t New designation <S>: %c\n",
|
||||
dchr[sect->sct_type].d_mnem, dchr[sect->sct_newtype].d_mnem);
|
||||
pr("own oo eff mob min gld frt oil urn wrk lty che plg ptime fall avail\n");
|
||||
pr(" o O e m i g f c u w l x p t F a\n");
|
||||
pr("%3d %3d %3d %3d %3d %3d %3d %3d %3d %3d %3d %4d %3d %5d %4d %5d\n",
|
||||
sect->sct_own, sect->sct_oldown, sect->sct_effic, sect->sct_mobil,
|
||||
sect->sct_min, sect->sct_gmin, sect->sct_fertil, sect->sct_oil,
|
||||
sect->sct_uran, sect->sct_work, sect->sct_loyal,
|
||||
getvar(V_CHE, (s_char *)sect, EF_SECTOR),
|
||||
getvar(V_PSTAGE, (s_char *)sect, EF_SECTOR),
|
||||
getvar(V_PTIME, (s_char *)sect, EF_SECTOR),
|
||||
getvar(V_FALLOUT, (s_char *)sect, EF_SECTOR), sect->sct_avail);
|
||||
|
||||
pr(" Mines <M>: %d\n", getvar(V_MINE, (s_char *)sect, EF_SECTOR));
|
||||
pr(" Road %% <R>: %d\n", sect->sct_road);
|
||||
pr(" Rail %% <r>: %d\n", sect->sct_rail);
|
||||
pr(" Defense %% <d>: %d\n", sect->sct_defense);
|
||||
pr("Mines <M>: %d\t", getvar(V_MINE, (s_char *)sect, EF_SECTOR));
|
||||
pr("Coastal <C>: %d\n", sect->sct_coastal);
|
||||
pr("Road %% <R>: %d\t", sect->sct_road);
|
||||
pr("Rail %% <r>: %d\t", sect->sct_rail);
|
||||
pr("Defense %% <d>: %d\n", sect->sct_defense);
|
||||
}
|
||||
|
||||
|
||||
|
@ -479,10 +483,12 @@ getin(s_char **what, s_char **p, int *arg, s_char *buf)
|
|||
|
||||
|
||||
int
|
||||
doland(s_char op, int arg, struct sctstr *sect)
|
||||
doland(s_char op, int arg, s_char *p, struct sctstr *sect)
|
||||
{
|
||||
natid newown, oldown;
|
||||
coord newx, newy;
|
||||
int new, old;
|
||||
int des;
|
||||
switch (op) {
|
||||
case 'C':
|
||||
if (arg < 0)
|
||||
|
@ -612,11 +618,39 @@ doland(s_char op, int arg, struct sctstr *sect)
|
|||
putvar(V_MINE, arg, (s_char *)sect, EF_SECTOR);
|
||||
pr("Mines changed to %d\n", arg);
|
||||
break;
|
||||
case 'X':
|
||||
sect->sct_x = arg;
|
||||
case 'L':
|
||||
if (!sarg_xy(p, &newx, &newy))
|
||||
return RET_SYN;
|
||||
sect->sct_x = newx;
|
||||
sect->sct_y = newy;
|
||||
break;
|
||||
case 'Y':
|
||||
sect->sct_y = arg;
|
||||
case 'D':
|
||||
if (!sarg_xy(p, &newx, &newy))
|
||||
return RET_SYN;
|
||||
pr("Distribtion Location for sector %s changed from %s to %s\n",
|
||||
xyas(sect->sct_x, sect->sct_y, player->cnum),
|
||||
xyas(sect->sct_dist_x, sect->sct_dist_y, player->cnum),
|
||||
xyas(newx, newy, player->cnum));
|
||||
sect->sct_dist_x = newx;
|
||||
sect->sct_dist_y = newy;
|
||||
break;
|
||||
case 's':
|
||||
des = typematch(p, EF_SECTOR);
|
||||
if (des < 0)
|
||||
return RET_SYN;
|
||||
pr("Designation for sector %s changed from %c to %c\n",
|
||||
xyas(sect->sct_x, sect->sct_y, player->cnum),
|
||||
dchr[sect->sct_type].d_mnem, dchr[des].d_mnem);
|
||||
sect->sct_type = des;
|
||||
break;
|
||||
case 'S':
|
||||
des = typematch(p, EF_SECTOR);
|
||||
if (des < 0)
|
||||
return RET_SYN;
|
||||
pr("New Designation for sector %s changed from %c to %c\n",
|
||||
xyas(sect->sct_x, sect->sct_y, player->cnum),
|
||||
dchr[sect->sct_newtype].d_mnem, dchr[des].d_mnem);
|
||||
sect->sct_newtype = des;
|
||||
break;
|
||||
case 'R':
|
||||
if (arg > 100)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue