From: Jim Jagielski Date: Sun, 8 Jan 2012 01:40:36 +0000 (+0000) Subject: Merge r1228766 from trunk: X-Git-Tag: 2.4.0~19 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2e984d793ced2d8d3c0bd0e9e123baba7030c636;p=apache Merge r1228766 from trunk: optimize this... Do strlen() ONLY if we need to check for overflow. Reviewed/backported by: jim git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/branches/2.4.x@1228767 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/modules/proxy/proxy_util.c b/modules/proxy/proxy_util.c index 2fa2d7e2f1..5821aa9300 100644 --- a/modules/proxy/proxy_util.c +++ b/modules/proxy/proxy_util.c @@ -81,15 +81,18 @@ APR_IMPLEMENT_OPTIONAL_HOOK_RUN_ALL(proxy, PROXY, int, create_req, PROXY_DECLARE(apr_status_t) ap_proxy_strncpy(char *dst, const char *src, apr_size_t dlen) { - if ((strlen(src)+1) > dlen) { - /* XXX: APR_ENOSPACE would be better */ - return APR_EGENERAL; - } - else { - /* XXX: Once slen and dlen are known, no excuse not to memcpy */ - apr_cpystrn(dst, src, dlen); + char *thenil; + apr_size_t thelen; + + thenil = apr_cpystrn(dst, src, dlen); + thelen = thenil - dst; + /* Assume the typical case is smaller copying into bigger + so we have a fast return */ + if ((thelen < dlen-1) || ((strlen(src)) == thelen)) { + return APR_SUCCESS; } - return APR_SUCCESS; + /* XXX: APR_ENOSPACE would be better */ + return APR_EGENERAL; } /* already called in the knowledge that the characters are hex digits */