}
static void notice_processed_counts(Counts *counts, int completed,
- InputFile *ipf, const char *what) {
+ InputFile *ipf_xtra, const char *what) {
#define RCI_NOTHING(x) /* nothing */
#define RCI_TRIPLE_FMT(x) " " #x "=" RCI_TRIPLE_FMT_BASE
-#define RCI_TRIPLE_VALS(x) ,RCI_TRIPLE_VALS_BASE(ipf->counts.results, [RC_##x])
+#define RCI_TRIPLE_VALS(x) , RCI_TRIPLE_VALS_BASE(counts->results, [RC_##x])
-#define CNT(art,rc) (ipf->counts.results[art_##art][RC_##rc])
+#define CNT(art,rc) (counts->results[art_##art][RC_##rc])
+
+ assert(!completed || ipf_xtra);
char *inprog= completed
? xasprintf("%s","") /* GCC produces a stupid warning for printf("") ! */
- : xasprintf(" inprogress=%ld", ipf->inprogress);
- char *autodefer= ipf && ipf->autodefer >= 0
- ? xasprintf(" autodeferred=%ld", ipf->autodefer)
+ : xasprintf(" inprogress=%ld", ipf_xtra->inprogress);
+ char *autodefer= ipf_xtra && ipf_xtra->autodefer >= 0
+ ? xasprintf(" autodeferred=%ld", ipf_xtra->autodefer)
: xasprintf("%s","");
info("%s %s read=%d (+bl=%d,+err=%d)%s%s"
RESULT_COUNTS(RCI_NOTHING, RCI_TRIPLE_FMT)
,
completed?"completed":"processed", what,
- ipf->counts.events[read_ok], ipf->counts.events[read_blank],
- ipf->counts.events[read_err],
- inprog, autodefer, ipf->counts.events[nooffer_missing],
+ counts->events[read_ok], counts->events[read_blank],
+ counts->events[read_err],
+ inprog, autodefer, counts->events[nooffer_missing],
CNT(Unchecked,sent) + CNT(Unsolicited,sent)
, CNT(Unchecked,sent), CNT(Unsolicited,sent),
CNT(Wanted,accepted) + CNT(Unsolicited,accepted)
RESULT_COUNTS(RCI_NOTHING, RCI_TRIPLE_VALS)
);
- memset(&ipf->counts, 0, sizeof(ipf->counts));
+ memset(&counts, 0, sizeof(*counts));
free(inprog);
free(autodefer);