diff options
Diffstat (limited to 'ext/standard/incomplete_class.c')
-rw-r--r-- | ext/standard/incomplete_class.c | 164 |
1 files changed, 0 insertions, 164 deletions
diff --git a/ext/standard/incomplete_class.c b/ext/standard/incomplete_class.c deleted file mode 100644 index e333173971..0000000000 --- a/ext/standard/incomplete_class.c +++ /dev/null @@ -1,164 +0,0 @@ -/* - +----------------------------------------------------------------------+ - | PHP Version 5 | - +----------------------------------------------------------------------+ - | Copyright (c) 1997-2004 The PHP Group | - +----------------------------------------------------------------------+ - | This source file is subject to version 3.0 of the PHP license, | - | that is bundled with this package in the file LICENSE, and is | - | available through the world-wide-web at the following url: | - | http://www.php.net/license/3_0.txt. | - | If you did not receive a copy of the PHP license and are unable to | - | obtain it through the world-wide-web, please send a note to | - | license@php.net so we can mail you a copy immediately. | - +----------------------------------------------------------------------+ - | Author: Sascha Schumann <sascha@schumann.cx> | - +----------------------------------------------------------------------+ - */ - - -/* $Id$ */ - -#include "php.h" -#include "basic_functions.h" -#include "php_incomplete_class.h" - -#define INCOMPLETE_CLASS_MSG \ - "The script tried to execute a method or " \ - "access a property of an incomplete object. " \ - "Please ensure that the class definition <b>%s</b> of the object " \ - "you are trying to operate on was loaded _before_ " \ - "the session was started" - - -/* {{{ incomplete_class_message - */ -static void incomplete_class_message(int error_type TSRMLS_DC) -{ - char buf[1024]; - char *class_name = NULL; - - if(EG(This)) { - class_name = php_lookup_class_name(EG(This), NULL, 0); - } - - if (!class_name) - class_name = estrdup("unknown"); - - snprintf(buf, sizeof(buf)-1, INCOMPLETE_CLASS_MSG, class_name); - - efree(class_name); - - php_error_docref(NULL TSRMLS_CC, error_type, "%s", buf); -} -/* }}} */ - -/* {{{ incomplete_class_call_func - */ -static void incomplete_class_call_func(INTERNAL_FUNCTION_PARAMETERS) -{ - incomplete_class_message(E_ERROR TSRMLS_CC); -} -/* }}} */ - -/* {{{ incomplete_class_set_property - */ -static void incomplete_class_set_property(INTERNAL_FUNCTION_PARAMETERS) -{ - incomplete_class_message(E_NOTICE TSRMLS_CC); -} -/* }}} */ - -/* {{{ incomplete_class_get_property - */ -static void incomplete_class_get_property(INTERNAL_FUNCTION_PARAMETERS) -{ - incomplete_class_message(E_NOTICE TSRMLS_CC); -} -/* }}} */ - -/* {{{ php_create_incomplete_class - */ -zend_internal_function incomplete_class_call_func_fe; -zend_internal_function incomplete_class_get_property_fe; -zend_internal_function incomplete_class_set_property_fe; - -static void php_incomplete_class_init_func(zend_internal_function *fe, void (*handler)(INTERNAL_FUNCTION_PARAMETERS)) { - fe->type = ZEND_INTERNAL_FUNCTION; - fe->handler = handler; - fe->function_name = NULL; - fe->scope = NULL; - fe->fn_flags = 0; - fe->prototype = NULL; - fe->num_args = 2; - fe->arg_info = NULL; - fe->pass_rest_by_reference = 0; -} - -zend_class_entry *php_create_incomplete_class(TSRMLS_D) -{ - zend_class_entry incomplete_class; - - php_incomplete_class_init_func(&incomplete_class_call_func_fe, incomplete_class_call_func); - php_incomplete_class_init_func(&incomplete_class_get_property_fe, incomplete_class_get_property); - php_incomplete_class_init_func(&incomplete_class_set_property_fe, incomplete_class_set_property); - - INIT_OVERLOADED_CLASS_ENTRY(incomplete_class, INCOMPLETE_CLASS, NULL, - (zend_function *)&incomplete_class_call_func_fe, - (zend_function *)&incomplete_class_get_property_fe, - (zend_function *)&incomplete_class_set_property_fe); - - return zend_register_internal_class(&incomplete_class TSRMLS_CC); -} -/* }}} */ - -/* {{{ php_lookup_class_name - */ -char *php_lookup_class_name(zval *object, size_t *nlen, zend_bool del) -{ - zval **val; - char *retval = NULL; - HashTable *object_properties; - TSRMLS_FETCH(); - - object_properties = Z_OBJPROP_P(object); - - if (zend_hash_find(object_properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER), (void **) &val) == SUCCESS) { - retval = estrndup(Z_STRVAL_PP(val), Z_STRLEN_PP(val)); - - if (nlen) - *nlen = Z_STRLEN_PP(val); - - if (del) - zend_hash_del(object_properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER)); - } - - return (retval); -} -/* }}} */ - -/* {{{ php_store_class_name - */ -void php_store_class_name(zval *object, const char *name, size_t len) -{ - zval *val; - TSRMLS_FETCH(); - - MAKE_STD_ZVAL(val); - - Z_TYPE_P(val) = IS_STRING; - Z_STRVAL_P(val) = estrndup(name, len); - Z_STRLEN_P(val) = len; - - zend_hash_update(Z_OBJPROP_P(object), MAGIC_MEMBER, sizeof(MAGIC_MEMBER), &val, sizeof(val), NULL); -} -/* }}} */ - -/* - * Local variables: - * tab-width: 4 - * c-basic-offset: 4 - * End: - * vim600: sw=4 ts=4 fdm=marker - * vim<600: sw=4 ts=4 - */ |