]> granicus.if.org Git - php/commitdiff
Fix bug #67392: token_name() does not return name for T_POW and T_POW_EQUAL token
authorFerenc Kovacs <tyrael@php.net>
Sat, 7 Jun 2014 13:27:54 +0000 (15:27 +0200)
committerFerenc Kovacs <tyrael@php.net>
Sat, 7 Jun 2014 13:27:54 +0000 (15:27 +0200)
NEWS
ext/tokenizer/tests/bug67395.phpt [new file with mode: 0644]
ext/tokenizer/tokenizer_data.c

diff --git a/NEWS b/NEWS
index 3a1290f6dae8806145d9f55701f248aa46491779..a930dd6936f05c1da23f10e64e074ca5898ccd39 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -7,6 +7,10 @@ PHP                                                                        NEWS
     (Remi) (CVE-2014-3981)
   . Fixed bug #67392 (dtrace breaks argument unpack). (Nikita)
 
+- Tokenizer:
+  . Fixed bug #67395 (token_name() does not return name for T_POW and T_POW_EQUAL
+    token). (Ferenc)
+
 05 Jun 2014, PHP 5.6.0 Beta 4
 
 - Core:
diff --git a/ext/tokenizer/tests/bug67395.phpt b/ext/tokenizer/tests/bug67395.phpt
new file mode 100644 (file)
index 0000000..c9b7f30
--- /dev/null
@@ -0,0 +1,15 @@
+--TEST--
+Bug 67395: token_name() does not return name for T_POW and T_POW_EQUAL token
+--FILE--
+<?php
+
+$powToken = token_get_all('<?php **')[1][0];
+var_dump(token_name($powToken));
+
+$powEqualToken = token_get_all('<?php **=')[1][0];
+var_dump(token_name($powEqualToken));
+
+?>
+--EXPECT--
+string(5) "T_POW"
+string(11) "T_POW_EQUAL"
index dc48f040f1c563348caf0a67dc8ed67683ee5a8d..5a01bde573bb1c9d93abbdc55668dddfa4d8d540 100644 (file)
@@ -160,6 +160,8 @@ void tokenizer_register_constants(INIT_FUNC_ARGS) {
        REGISTER_LONG_CONSTANT("T_NS_SEPARATOR", T_NS_SEPARATOR, CONST_CS | CONST_PERSISTENT);
        REGISTER_LONG_CONSTANT("T_ELLIPSIS", T_ELLIPSIS, CONST_CS | CONST_PERSISTENT);
        REGISTER_LONG_CONSTANT("T_DOUBLE_COLON", T_PAAMAYIM_NEKUDOTAYIM, CONST_CS | CONST_PERSISTENT);
+       REGISTER_LONG_CONSTANT("T_POW", T_POW, CONST_CS | CONST_PERSISTENT);
+       REGISTER_LONG_CONSTANT("T_POW_EQUAL", T_POW_EQUAL, CONST_CS | CONST_PERSISTENT);
 }
 
 char *get_token_type_name(int token_type)
@@ -296,6 +298,8 @@ char *get_token_type_name(int token_type)
                case T_DIR: return "T_DIR";
                case T_NS_SEPARATOR: return "T_NS_SEPARATOR";
                case T_ELLIPSIS: return "T_ELLIPSIS";
+               case T_POW: return "T_POW";
+               case T_POW_EQUAL: return "T_POW_EQUAL";
 
        }
        return "UNKNOWN";