diff options
author | Dmitry Stogov <dmitry@zend.com> | 2018-03-05 11:51:58 +0300 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2018-03-05 11:51:58 +0300 |
commit | 6c035f53f143c065aa3befbdbacd30ce691cff2a (patch) | |
tree | 5f4b79e233f85bff2d53c34ab059f5b1504ba8a9 /Zend/zend_ini.c | |
parent | 10549ac62db3895bf2abf864d2834e3eacd6e72e (diff) | |
download | php-git-6c035f53f143c065aa3befbdbacd30ce691cff2a.tar.gz |
Separate duplicated code into a zend_ini_parse_bool() function.
Diffstat (limited to 'Zend/zend_ini.c')
-rw-r--r-- | Zend/zend_ini.c | 34 |
1 files changed, 13 insertions, 21 deletions
diff --git a/Zend/zend_ini.c b/Zend/zend_ini.c index c488eda649..70db810819 100644 --- a/Zend/zend_ini.c +++ b/Zend/zend_ini.c @@ -509,6 +509,17 @@ ZEND_API zend_string *zend_ini_get_value(zend_string *name) /* {{{ */ } /* }}} */ +ZEND_API zend_bool zend_ini_parse_bool(zend_string *str) +{ + if ((ZSTR_LEN(str) == 4 && strcasecmp(ZSTR_VAL(str), "true") == 0) + || (ZSTR_LEN(str) == 3 && strcasecmp(ZSTR_VAL(str), "yes") == 0) + || (ZSTR_LEN(str) == 2 && strcasecmp(ZSTR_VAL(str), "on") == 0)) { + return 1; + } else { + return atoi(ZSTR_VAL(str)) != 0; + } +} + #if TONY_20070307 static void zend_ini_displayer_cb(zend_ini_entry *ini_entry, int type) /* {{{ */ { @@ -563,15 +574,7 @@ ZEND_INI_DISP(zend_ini_boolean_displayer_cb) /* {{{ */ } if (tmp_value) { - if (ZSTR_LEN(tmp_value) == 4 && strcasecmp(ZSTR_VAL(tmp_value), "true") == 0) { - value = 1; - } else if (ZSTR_LEN(tmp_value) == 3 && strcasecmp(ZSTR_VAL(tmp_value), "yes") == 0) { - value = 1; - } else if (ZSTR_LEN(tmp_value) == 2 && strcasecmp(ZSTR_VAL(tmp_value), "on") == 0) { - value = 1; - } else { - value = atoi(ZSTR_VAL(tmp_value)); - } + value = zend_ini_parse_bool(tmp_value); } else { value = 0; } @@ -647,18 +650,7 @@ ZEND_API ZEND_INI_MH(OnUpdateBool) /* {{{ */ p = (zend_bool *) (base+(size_t) mh_arg1); - if (ZSTR_LEN(new_value) == 2 && strcasecmp("on", ZSTR_VAL(new_value)) == 0) { - *p = (zend_bool) 1; - } - else if (ZSTR_LEN(new_value) == 3 && strcasecmp("yes", ZSTR_VAL(new_value)) == 0) { - *p = (zend_bool) 1; - } - else if (ZSTR_LEN(new_value) == 4 && strcasecmp("true", ZSTR_VAL(new_value)) == 0) { - *p = (zend_bool) 1; - } - else { - *p = (zend_bool) atoi(ZSTR_VAL(new_value)); - } + *p = zend_ini_parse_bool(new_value); return SUCCESS; } /* }}} */ |