From: Mladen Turk Date: Wed, 29 Sep 2004 19:07:47 +0000 (+0000) Subject: Use apr_strftime instead our own format_byte_out function. X-Git-Tag: 2.1.1~189 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=084ca3d9eb7aab4e338b22122ab2b21b52fb27a9;p=thirdparty%2Fapache%2Fhttpd.git Use apr_strftime instead our own format_byte_out function. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@105346 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/modules/proxy/mod_proxy.c b/modules/proxy/mod_proxy.c index fb2375803e5..58bf73c8394 100644 --- a/modules/proxy/mod_proxy.c +++ b/modules/proxy/mod_proxy.c @@ -1671,25 +1671,6 @@ static int proxy_post_config(apr_pool_t *pconf, apr_pool_t *plog, return OK; } - -#define KBYTE 1024 -#define MBYTE 1048576L -#define GBYTE 1073741824L - -/* Format the number of bytes nicely */ -static void format_byte_out(request_rec *r, apr_off_t bytes) -{ - - if (bytes < (5 * KBYTE)) - ap_rprintf(r, "%d B", (int) bytes); - else if (bytes < (MBYTE / 2)) - ap_rprintf(r, "%.1f kB", (float) bytes / KBYTE); - else if (bytes < (GBYTE / 2)) - ap_rprintf(r, "%.1f MB", (float) bytes / MBYTE); - else - ap_rprintf(r, "%.1f GB", (float) bytes / GBYTE); -} - /* * proxy Extension to mod_status */ @@ -1725,7 +1706,7 @@ static int proxy_status_hook(request_rec *r, int flags) worker = (proxy_worker *)balancer->workers->elts; for (n = 0; n < balancer->workers->nelts; n++) { - + char fbuf[50]; ap_rvputs(r, "\n", worker->scheme, "", NULL); ap_rvputs(r, "", worker->hostname, "", NULL); if (worker->s->status & PROXY_WORKER_DISABLED) @@ -1740,9 +1721,9 @@ static int proxy_status_hook(request_rec *r, int flags) ap_rvputs(r, "", worker->s->redirect, NULL); ap_rprintf(r, "%d", worker->s->lbfactor); ap_rprintf(r, "%d", (int)(worker->s->elected)); - format_byte_out(r, worker->s->transfered); + ap_rputs(apr_strfsize(worker->s->transfered, fbuf), r); ap_rputs("", r); - format_byte_out(r, worker->s->readed); + ap_rputs(apr_strfsize(worker->s->readed, fbuf), r); ap_rputs("\n", r); /* TODO: Add the rest of dynamic worker data */ @@ -1783,13 +1764,13 @@ static void child_init(apr_pool_t *p, server_rec *s) /* Initialize worker's shared scoreboard data */ worker = (proxy_worker *)conf->workers->elts; for (i = 0; i < conf->workers->nelts; i++) { - ap_proxy_initialize_worker_share(conf, worker); + ap_proxy_initialize_worker_share(conf, worker, s); ap_proxy_initialize_worker(worker, s); worker++; } /* Initialize forward worker if defined */ if (conf->forward) { - ap_proxy_initialize_worker_share(conf, conf->forward); + ap_proxy_initialize_worker_share(conf, conf->forward, s); ap_proxy_initialize_worker(conf->forward, s); /* Do not disable worker in case of errors */ conf->forward->s->status |= PROXY_WORKER_IGNORE_ERRORS;