summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXinchen Hui <laruence@gmail.com>2016-05-07 00:07:04 -0700
committerXinchen Hui <laruence@gmail.com>2016-05-07 00:08:15 -0700
commit29079f263e38ebf76e2ddbd308e001639eb9e3bf (patch)
treea027f8730f40567a5f284659cad8b5cd40e4b2e1
parentf7439afedaaa4ec15e1940efaa280089714d54cf (diff)
downloadphp-git-29079f263e38ebf76e2ddbd308e001639eb9e3bf.tar.gz
Strlen cleanup (additions for previous one fix)
Probably compilers will do similar optimization
-rw-r--r--Zend/zend_object_handlers.c5
-rw-r--r--Zend/zend_strtod.c4
2 files changed, 5 insertions, 4 deletions
diff --git a/Zend/zend_object_handlers.c b/Zend/zend_object_handlers.c
index 9abe3875ef..ba3e84bf7d 100644
--- a/Zend/zend_object_handlers.c
+++ b/Zend/zend_object_handlers.c
@@ -1068,6 +1068,7 @@ ZEND_API int zend_check_protected(zend_class_entry *ce, zend_class_entry *scope)
ZEND_API zend_function *zend_get_call_trampoline_func(zend_class_entry *ce, zend_string *method_name, int is_static) /* {{{ */
{
+ size_t mname_len;
zend_op_array *func;
zend_function *fbc = is_static ? ce->__callstatic : ce->__call;
@@ -1100,8 +1101,8 @@ ZEND_API zend_function *zend_get_call_trampoline_func(zend_class_entry *ce, zend
//??? keep compatibility for "\0" characters
//??? see: Zend/tests/bug46238.phpt
- if (UNEXPECTED(strlen(ZSTR_VAL(method_name)) != ZSTR_LEN(method_name))) {
- func->function_name = zend_string_init(ZSTR_VAL(method_name), strlen(ZSTR_VAL(method_name)), 0);
+ if (UNEXPECTED((mname_len = strlen(ZSTR_VAL(method_name))) != ZSTR_LEN(method_name))) {
+ func->function_name = zend_string_init(ZSTR_VAL(method_name), mname_len, 0);
} else {
func->function_name = zend_string_copy(method_name);
}
diff --git a/Zend/zend_strtod.c b/Zend/zend_strtod.c
index 8a0863261b..889a31685c 100644
--- a/Zend/zend_strtod.c
+++ b/Zend/zend_strtod.c
@@ -4456,7 +4456,7 @@ ZEND_API double zend_oct_strtod(const char *str, const char **endptr)
double value = 0;
int any = 0;
- if (strlen(str) < 1) {
+ if (str[0] == '\0') {
if (endptr != NULL) {
*endptr = str;
}
@@ -4491,7 +4491,7 @@ ZEND_API double zend_bin_strtod(const char *str, const char **endptr)
double value = 0;
int any = 0;
- if (strlen(str) < 2) {
+ if (str[0] == '\0' || str[1] == '\0') {
if (endptr != NULL) {
*endptr = str;
}