diff options
| author | Andi Gutmans <andi@php.net> | 2001-12-28 16:36:04 +0000 |
|---|---|---|
| committer | Andi Gutmans <andi@php.net> | 2001-12-28 16:36:04 +0000 |
| commit | ae1a702501b7410048555d9b0537326fed760186 (patch) | |
| tree | afa0c522530fbf67f34e803e3c9d4db12118a855 /Zend/zend_compile.c | |
| parent | b14f6cf79fb6857de1e32f0956a80a01d13ebd25 (diff) | |
| download | php-git-ae1a702501b7410048555d9b0537326fed760186.tar.gz | |
- Fix some case insensitivity stuff in respect to classes
Diffstat (limited to 'Zend/zend_compile.c')
| -rw-r--r-- | Zend/zend_compile.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c index 676cac10ec..13ffd01944 100644 --- a/Zend/zend_compile.c +++ b/Zend/zend_compile.c @@ -986,7 +986,7 @@ void do_fetch_class(znode *result, znode *class_entry, znode *class_name TSRMLS_ } -void do_fetch_class_name(znode *result, znode *class_name_entry, znode *class_name TSRMLS_DC) +void do_fetch_class_name(znode *result, znode *class_name_entry, znode *class_name, zend_bool case_sensitive TSRMLS_DC) { zend_uint length; @@ -995,7 +995,9 @@ void do_fetch_class_name(znode *result, znode *class_name_entry, znode *class_na } else { *result = *class_name_entry; } - + if (!case_sensitive) { + zend_str_tolower(class_name->u.constant.value.str.val, class_name->u.constant.value.str.len); + } length = 1 + result->u.constant.value.str.len + class_name->u.constant.value.str.len; result->u.constant.value.str.val = erealloc(result->u.constant.value.str.val, length+1); memcpy(&result->u.constant.value.str.val[result->u.constant.value.str.len], ":", sizeof(":")-1); @@ -2061,7 +2063,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_container, znode *con switch (mode) { case ZEND_CT: if (constant_container) { - do_fetch_class_name(NULL, constant_container, constant_name TSRMLS_CC); + do_fetch_class_name(NULL, constant_container, constant_name, 1 TSRMLS_CC); *result = *constant_container; } else { *result = *constant_name; |
