]> granicus.if.org Git - php/commitdiff
Fixed bug #75049 (spl_autoload_unregister can't handle spl_autoload_functions results)
authorXinchen Hui <laruence@gmail.com>
Wed, 9 Aug 2017 03:28:53 +0000 (11:28 +0800)
committerXinchen Hui <laruence@gmail.com>
Wed, 9 Aug 2017 03:28:53 +0000 (11:28 +0800)
NEWS
ext/spl/php_spl.c
ext/spl/tests/bug75049.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index 7ff084990188b97d5a08eec35c6f89035d024ccc..a1f33f209d871b34316922b2572b019d66fa62cc 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -46,6 +46,8 @@ PHP                                                                        NEWS
     (Laruence)
 
 - SPL:
+  . Fixed bug #75049 (spl_autoload_unregister can't handle
+    spl_autoload_functions results). (Laruence)
   . Fixed bug #74669 (Unserialize ArrayIterator broken). (Andrew Nester)
   . Fixed bug #75015 (Crash in recursive iterator destructors). (Julien)
 
index b8e10a563c868d91609b778d64b361f516b51f96..28a4fae00de1b6e7b4b09ed7c016faf94c6cc7a5 100644 (file)
@@ -536,8 +536,14 @@ PHP_FUNCTION(spl_autoload_register)
                        ZSTR_VAL(lc_name)[ZSTR_LEN(lc_name)] = '\0';
                } else {
                        ZVAL_UNDEF(&alfi.closure);
-                       lc_name = zend_string_alloc(ZSTR_LEN(func_name), 0);
-                       zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name), ZSTR_LEN(func_name));
+                       /* Skip leading \ */
+                       if (ZSTR_VAL(func_name)[0] == '\\') {
+                               lc_name = zend_string_alloc(ZSTR_LEN(func_name) - 1, 0);
+                               zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name) + 1, ZSTR_LEN(func_name) - 1);
+                       } else {
+                               lc_name = zend_string_alloc(ZSTR_LEN(func_name), 0);
+                               zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name), ZSTR_LEN(func_name));
+                       }
                }
                zend_string_release(func_name);
 
@@ -655,8 +661,14 @@ PHP_FUNCTION(spl_autoload_unregister)
                memcpy(ZSTR_VAL(lc_name) + ZSTR_LEN(func_name), &Z_OBJ_HANDLE_P(zcallable), sizeof(uint32_t));
                ZSTR_VAL(lc_name)[ZSTR_LEN(lc_name)] = '\0';
        } else {
-               lc_name = zend_string_alloc(ZSTR_LEN(func_name), 0);
-               zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name), ZSTR_LEN(func_name));
+               /* Skip leading \ */
+               if (ZSTR_VAL(func_name)[0] == '\\') {
+                       lc_name = zend_string_alloc(ZSTR_LEN(func_name) - 1, 0);
+                       zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name) + 1, ZSTR_LEN(func_name) - 1);
+               } else {
+                       lc_name = zend_string_alloc(ZSTR_LEN(func_name), 0);
+                       zend_str_tolower_copy(ZSTR_VAL(lc_name), ZSTR_VAL(func_name), ZSTR_LEN(func_name));
+               }
        }
        zend_string_release(func_name);
 
diff --git a/ext/spl/tests/bug75049.phpt b/ext/spl/tests/bug75049.phpt
new file mode 100644 (file)
index 0000000..2f03a3b
--- /dev/null
@@ -0,0 +1,16 @@
+--TEST--
+Bug #75049 (spl_autoload_unregister can't handle spl_autoload_functions results)
+--FILE--
+<?php
+class Auto { public static function loader() {}}
+$autoloader = '\Auto::loader';
+
+echo (int)spl_autoload_register($autoloader);
+echo (int)spl_autoload_unregister($autoloader);
+echo (int)spl_autoload_register($autoloader);
+foreach (spl_autoload_functions() as $loader) {
+       echo (int)spl_autoload_unregister($loader);
+}
+echo (int)count(spl_autoload_functions());
+--EXPECTF--
+11110