From: Marcus Boerger Date: Mon, 26 May 2003 20:45:22 +0000 (+0000) Subject: Add pseudo constant __METHOD__ to easily report namespace::class::method. X-Git-Tag: RELEASE_1_0_2~576 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=955460a3190352341a598103dcfa5591c8a4cb6a;p=php Add pseudo constant __METHOD__ to easily report namespace::class::method. # This is especially good for tests. Since it does not draw away from the # real issues and nicely reports what is needed to identify a method. --- diff --git a/Zend/zend_language_scanner.l b/Zend/zend_language_scanner.l index ee1060cb55..436d9aa08c 100644 --- a/Zend/zend_language_scanner.l +++ b/Zend/zend_language_scanner.l @@ -998,6 +998,35 @@ NAMESPACE_NAME ({LABEL}":")+{LABEL} return T_FUNC_C; } +"__METHOD__" { + char *namespace_name = CG(active_namespace)->name; + char *class_name = CG(active_class_entry) ? CG(active_class_entry)->name : NULL; + char *func_name = CG(active_op_array)->function_name; + size_t len = 1; + + if (namespace_name) { + len += strlen(namespace_name) + 2; + } + if (class_name) { + len += strlen(class_name) + 2; + } + if (func_name) { + len += strlen(func_name); + } + + zendlval->value.str.val = emalloc(len); + zendlval->value.str.len = sprintf(zendlval->value.str.val, "%s%s%s%s%s", + namespace_name ? namespace_name : "", + namespace_name && (class_name || func_name) ? "::" : "", + class_name ? class_name : "", + class_name && func_name ? "::" : "", + func_name ? func_name : "" + ); + zendlval->value.str.len = strlen(zendlval->value.str.val); + zendlval->type = IS_STRING; + return T_CLASS_C; +} + "__LINE__" { zendlval->value.lval = CG(zend_lineno); zendlval->type = IS_LONG;