From f9fb4c48b124ddbd5b80dd20484232151741dff5 Mon Sep 17 00:00:00 2001 From: Ruediger Pluem Date: Fri, 28 Jun 2019 08:50:31 +0000 Subject: * Replace apr_psprintf with apr_pstrcat where the format strings only contain %s to improve efficiency. Leave out error messages as they are not on a crtical code path and error message become less readable when taking out the format specifiers. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1862270 13f79535-47bb-0310-9956-ffa450edef68 --- modules/dav/fs/dbm.c | 20 +++++++++++-------- modules/dav/fs/repos.c | 10 ++++++---- modules/dav/main/mod_dav.c | 44 +++++++++++++++++++++-------------------- modules/dav/main/props.c | 16 +++++++-------- modules/dav/main/std_liveprop.c | 8 ++++---- modules/dav/main/util.c | 4 ++-- 6 files changed, 55 insertions(+), 47 deletions(-) (limited to 'modules/dav') diff --git a/modules/dav/fs/dbm.c b/modules/dav/fs/dbm.c index 821168e887..0d12831f02 100644 --- a/modules/dav/fs/dbm.c +++ b/modules/dav/fs/dbm.c @@ -355,29 +355,33 @@ static void dav_append_prop(apr_pool_t *pool, /* the property is an empty value */ if (*name == ':') { /* "no namespace" case */ - s = apr_psprintf(pool, "<%s/>" DEBUG_CR, name+1); + s = apr_pstrcat(pool, "<", name+1, "/>" DEBUG_CR, NULL); } else { - s = apr_psprintf(pool, "" DEBUG_CR, name); + s = apr_pstrcat(pool, "" DEBUG_CR, NULL); } } else if (*lang != '\0') { if (*name == ':') { /* "no namespace" case */ - s = apr_psprintf(pool, "<%s xml:lang=\"%s\">%s" DEBUG_CR, - name+1, lang, value, name+1); + s = apr_pstrcat(pool, "<", name+1, " xml:lang=\"", + lang, "\">", value, "" DEBUG_CR, + NULL); } else { - s = apr_psprintf(pool, "%s" DEBUG_CR, - name, lang, value, name); + s = apr_pstrcat(pool, "", value, "" DEBUG_CR, + NULL); } } else if (*name == ':') { /* "no namespace" case */ - s = apr_psprintf(pool, "<%s>%s" DEBUG_CR, name+1, value, name+1); + s = apr_pstrcat(pool, "<", name+1, ">", value, "" + DEBUG_CR, NULL); } else { - s = apr_psprintf(pool, "%s" DEBUG_CR, name, value, name); + s = apr_pstrcat(pool, "", value, "" + DEBUG_CR, NULL); } apr_text_append(pool, phdr, s); diff --git a/modules/dav/fs/repos.c b/modules/dav/fs/repos.c index 6a5ff765f8..335b22f7ae 100644 --- a/modules/dav/fs/repos.c +++ b/modules/dav/fs/repos.c @@ -2002,10 +2002,12 @@ static dav_prop_insert dav_fs_insert_prop(const dav_resource *resource, } else { /* assert: what == DAV_PROP_INSERT_SUPPORTED */ - s = apr_psprintf(p, - "" DEBUG_CR, - info->name, dav_fs_namespace_uris[info->ns]); + s = apr_pstrcat(p, + "name, + "\" D:namespace=\"", + dav_fs_namespace_uris[info->ns], + "\"/>" DEBUG_CR, NULL); } apr_text_append(p, phdr, s); diff --git a/modules/dav/main/mod_dav.c b/modules/dav/main/mod_dav.c index 7fb8b5878c..8534352fcd 100644 --- a/modules/dav/main/mod_dav.c +++ b/modules/dav/main/mod_dav.c @@ -669,8 +669,8 @@ static int dav_created(request_rec *r, const char *locn, const char *what, /* Apache doesn't allow us to set a variable body for HTTP_CREATED, so * we must manufacture the entire response. */ - body = apr_psprintf(r->pool, "%s %s has been created.", - what, ap_escape_html(r->pool, locn)); + body = apr_pstrcat(r->pool, what, " ", ap_escape_html(r->pool, locn), + " has been created.", NULL); return dav_error_response(r, HTTP_CREATED, body); } @@ -1355,10 +1355,10 @@ static dav_error *dav_gen_supported_methods(request_rec *r, if (elts[i].key == NULL) continue; - s = apr_psprintf(r->pool, - "" - DEBUG_CR, - elts[i].key); + s = apr_pstrcat(r->pool, + "" DEBUG_CR, NULL); apr_text_append(r->pool, body, s); } } @@ -1384,10 +1384,9 @@ static dav_error *dav_gen_supported_methods(request_rec *r, /* see if method is supported */ if (apr_table_get(methods, name) != NULL) { - s = apr_psprintf(r->pool, - "" - DEBUG_CR, - name); + s = apr_pstrcat(r->pool, + "" DEBUG_CR, NULL); apr_text_append(r->pool, body, s); } } @@ -1519,10 +1518,12 @@ static dav_error *dav_gen_supported_reports(request_rec *r, for (rp = reports; rp->nmspace != NULL; ++rp) { /* Note: we presume reports->namespace is * properly XML/URL quoted */ - s = apr_psprintf(r->pool, - "" DEBUG_CR, - rp->name, rp->nmspace); + s = apr_pstrcat(r->pool, + "name, + "\" D:namespace=\"", + rp->nmspace, + "\"/>" DEBUG_CR, NULL); apr_text_append(r->pool, body, s); } } @@ -1560,12 +1561,13 @@ static dav_error *dav_gen_supported_reports(request_rec *r, /* Note: we presume reports->nmspace is * properly XML/URL quoted */ - s = apr_psprintf(r->pool, - "" - DEBUG_CR, - rp->name, rp->nmspace); + s = apr_pstrcat(r->pool, + "name, + "\" D:namespace=\"", + rp->nmspace, + "\"/>" DEBUG_CR, NULL); apr_text_append(r->pool, body, s); break; } @@ -2742,7 +2744,7 @@ static int dav_method_copymove(request_rec *r, int is_move) const char *nscp_path = apr_table_get(r->headers_in, "New-uri"); if (nscp_host != NULL && nscp_path != NULL) - dest = apr_psprintf(r->pool, "http://%s%s", nscp_host, nscp_path); + dest = apr_pstrcat(r->pool, "http://", nscp_host, nscp_path, NULL); } if (dest == NULL) { /* This supplies additional information for the default message. */ diff --git a/modules/dav/main/props.c b/modules/dav/main/props.c index 793c40a87f..6965edccc0 100644 --- a/modules/dav/main/props.c +++ b/modules/dav/main/props.c @@ -421,18 +421,18 @@ static dav_error * dav_insert_coreprop(dav_propdb *propdb, /* use D: prefix to refer to the DAV: namespace URI, * and let the namespace attribute default to "DAV:" */ - s = apr_psprintf(propdb->p, - "" DEBUG_CR, - name); + s = apr_pstrcat(propdb->p, + "" DEBUG_CR, NULL); } else if (what == DAV_PROP_INSERT_VALUE && *value != '\0') { /* use D: prefix to refer to the DAV: namespace URI */ - s = apr_psprintf(propdb->p, "%s" DEBUG_CR, - name, value, name); + s = apr_pstrcat(propdb->p, "", value, "" DEBUG_CR, NULL); } else { /* use D: prefix to refer to the DAV: namespace URI */ - s = apr_psprintf(propdb->p, "" DEBUG_CR, name); + s = apr_pstrcat(propdb->p, "" DEBUG_CR, NULL); } apr_text_append(propdb->p, phdr, s); @@ -473,11 +473,11 @@ static void dav_output_prop_name(apr_pool_t *pool, const char *s; if (*name->ns == '\0') - s = apr_psprintf(pool, "<%s/>" DEBUG_CR, name->name); + s = apr_pstrcat(pool, "<", name->name, "/>" DEBUG_CR, NULL); else { const char *prefix = dav_xmlns_add_uri(xi, name->ns); - s = apr_psprintf(pool, "<%s:%s/>" DEBUG_CR, prefix, name->name); + s = apr_pstrcat(pool, "<", prefix, ":", name->name, "/>" DEBUG_CR, NULL); } apr_text_append(pool, phdr, s); diff --git a/modules/dav/main/std_liveprop.c b/modules/dav/main/std_liveprop.c index e760c655b5..cb46b65607 100644 --- a/modules/dav/main/std_liveprop.c +++ b/modules/dav/main/std_liveprop.c @@ -154,10 +154,10 @@ static dav_prop_insert dav_core_insert_prop(const dav_resource *resource, /* assert: info != NULL && info->name != NULL */ if (what == DAV_PROP_INSERT_SUPPORTED) { - s = apr_psprintf(p, - "" DEBUG_CR, - info->name, dav_core_namespace_uris[info->ns]); + s = apr_pstrcat(p, + "name, + "\" D:namespace=\"", dav_core_namespace_uris[info->ns], + "\"/>" DEBUG_CR, NULL); } else if (what == DAV_PROP_INSERT_VALUE && *value != '\0') { s = apr_psprintf(p, "%s" DEBUG_CR, diff --git a/modules/dav/main/util.c b/modules/dav/main/util.c index a09419e56f..f131a486aa 100644 --- a/modules/dav/main/util.c +++ b/modules/dav/main/util.c @@ -470,8 +470,8 @@ DAV_DECLARE(void) dav_xmlns_generate(dav_xmlns_info *xi, apr_hash_this(hi, &prefix, NULL, &uri); - s = apr_psprintf(xi->pool, " xmlns:%s=\"%s\"", - (const char *)prefix, (const char *)uri); + s = apr_pstrcat(xi->pool, " xmlns:", (const char *)prefix, "=\"", + (const char *)uri, "\"", NULL); apr_text_append(xi->pool, phdr, s); } } -- cgit v1.2.3