in flood_report_relative_times.c [46:83]
apr_status_t relative_times_process_stats(report_t *report, int verified, request_t *req, response_t *resp, flood_timer_t *timer)
{
#define FLOOD_PRINT_BUF 256
apr_size_t buflen;
char buf[FLOOD_PRINT_BUF];
relative_report_t *rr = (relative_report_t*)report;
buflen = apr_snprintf(buf, FLOOD_PRINT_BUF,
"%" APR_INT64_T_FMT " %" APR_INT64_T_FMT
" %" APR_INT64_T_FMT " %" APR_INT64_T_FMT " %" APR_INT64_T_FMT,
timer->begin,
timer->connect - timer->begin,
timer->write - timer->begin,
timer->read - timer->begin,
timer->close - timer->begin);
switch (verified)
{
case FLOOD_VALID:
apr_snprintf(buf+buflen, FLOOD_PRINT_BUF-buflen, " OK ");
break;
case FLOOD_INVALID:
apr_snprintf(buf+buflen, FLOOD_PRINT_BUF-buflen, " FAIL ");
break;
default:
apr_snprintf(buf+buflen, FLOOD_PRINT_BUF-buflen, " %d ", verified);
}
#if APR_HAS_THREADS
apr_thread_mutex_lock(rr->config->mutex);
apr_file_printf(local_stdout, "%s %pT %s\n", buf, apr_os_thread_current(), req->uri);
apr_thread_mutex_unlock(rr->config->mutex);
#else
apr_file_printf(local_stdout, "%s %d %s\n", buf, getpid(), req->uri);
#endif
return APR_SUCCESS;
}