subs: De-duplicate formatting in intelligence_report()
Every piece is formatted either with pr(), or with sprintf() for later sending with wu(). The output is actually identical. Format with sprintf() always, and then either pr() or wu() the results. While there, change the first parameter's type from int to natid. Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
This commit is contained in:
parent
61fc526b5d
commit
c8e5b4fc50
2 changed files with 15 additions and 37 deletions
|
@ -192,7 +192,7 @@ extern int lnd_take_casualty(int, struct ulist *, int);
|
|||
extern void lnd_submil(struct lndstr *, int);
|
||||
extern void lnd_takemob(struct emp_qelem *, double);
|
||||
extern int lnd_spyval(struct lndstr *);
|
||||
extern void intelligence_report(int, struct lndstr *, int, char *);
|
||||
extern void intelligence_report(natid, struct lndstr *, int, char *);
|
||||
extern void lnd_mar_stay_behind(struct emp_qelem *, natid);
|
||||
extern void lnd_mar_put(struct emp_qelem *, natid);
|
||||
extern void lnd_put(struct emp_qelem *);
|
||||
|
|
|
@ -341,33 +341,19 @@ lnd_spyval(struct lndstr *lp)
|
|||
}
|
||||
|
||||
void
|
||||
intelligence_report(int destination, struct lndstr *lp, int spy,
|
||||
intelligence_report(natid destination, struct lndstr *lp, int spy,
|
||||
char *mess)
|
||||
{
|
||||
int vis = lnd_vis(lp);
|
||||
char buf1[80], buf2[80], buf3[80];
|
||||
|
||||
if (destination == 0)
|
||||
if (!destination || !lp->lnd_own)
|
||||
return;
|
||||
|
||||
if (lp->lnd_own == 0)
|
||||
return;
|
||||
|
||||
memset(buf1, 0, sizeof(buf1));
|
||||
memset(buf2, 0, sizeof(buf2));
|
||||
memset(buf3, 0, sizeof(buf3));
|
||||
if (chance((spy + vis) / 10.0)) {
|
||||
if (destination == player->cnum)
|
||||
pr("%s %s", mess, prland(lp));
|
||||
else
|
||||
sprintf(buf1, "%s %s", mess, prland(lp));
|
||||
|
||||
if (chance((spy + vis) / 20.0)) {
|
||||
if (destination == player->cnum)
|
||||
pr(" (eff %d, mil %d",
|
||||
roundintby(lp->lnd_effic, 5),
|
||||
roundintby(lp->lnd_item[I_MILIT], 10));
|
||||
else
|
||||
sprintf(buf2, " (eff %d, mil %d",
|
||||
roundintby(lp->lnd_effic, 5),
|
||||
roundintby(lp->lnd_item[I_MILIT], 10));
|
||||
|
@ -376,25 +362,17 @@ intelligence_report(int destination, struct lndstr *lp, int spy,
|
|||
int t;
|
||||
t = lp->lnd_tech - 20 + roll(40);
|
||||
t = MAX(t, 0);
|
||||
if (destination == player->cnum)
|
||||
pr(", tech %d)\n", t);
|
||||
else
|
||||
sprintf(buf3, ", tech %d)\n", t);
|
||||
} else {
|
||||
if (destination == player->cnum)
|
||||
pr(")\n");
|
||||
else
|
||||
sprintf(buf3, ")\n");
|
||||
}
|
||||
} else {
|
||||
if (destination == player->cnum)
|
||||
pr("\n");
|
||||
else
|
||||
sprintf(buf2, "\n");
|
||||
buf3[0] = 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (destination != player->cnum) {
|
||||
if (destination == player->cnum)
|
||||
pr("%s%s%s", buf1, buf2, buf3);
|
||||
else
|
||||
wu(0, destination, "%s%s%s", buf1, buf2, buf3);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue