diff options
author | Sascha Schumann <sas@php.net> | 2000-06-23 16:46:04 +0000 |
---|---|---|
committer | Sascha Schumann <sas@php.net> | 2000-06-23 16:46:04 +0000 |
commit | 091dc3840d770ed3aaebea63f1af0fae06329fc1 (patch) | |
tree | 640d0ae45443f3a6b693a88dc4e2df1840c6c7b4 | |
parent | 940f58c2dec4f2f6479dee377b0f7d24eb21ffea (diff) | |
download | php-git-091dc3840d770ed3aaebea63f1af0fae06329fc1.tar.gz |
Move the incomplete class stuff into its own file, so that we can
make it easier accessible to WDDX.
-rw-r--r-- | ext/standard/Makefile.in | 2 | ||||
-rw-r--r-- | ext/standard/incomplete_class.c | 120 | ||||
-rw-r--r-- | ext/standard/php_incomplete_class.h | 62 | ||||
-rw-r--r-- | ext/standard/var.c | 119 |
4 files changed, 185 insertions, 118 deletions
diff --git a/ext/standard/Makefile.in b/ext/standard/Makefile.in index 69d18edc79..8af72fa317 100644 --- a/ext/standard/Makefile.in +++ b/ext/standard/Makefile.in @@ -7,7 +7,7 @@ LTLIBRARY_SOURCES=\ link.c mail.c math.c md5.c metaphone.c microtime.c pack.c pageinfo.c \ parsedate.c quot_print.c rand.c reg.c soundex.c string.c scanf.c \ syslog.c type.c uniqid.c url.c url_scanner.c var.c output.c assert.c \ - strnatcmp.c levenshtein.c + strnatcmp.c levenshtein.c incomplete_class.c include $(top_srcdir)/build/dynlib.mk diff --git a/ext/standard/incomplete_class.c b/ext/standard/incomplete_class.c new file mode 100644 index 0000000000..4fee312f47 --- /dev/null +++ b/ext/standard/incomplete_class.c @@ -0,0 +1,120 @@ +/* + +----------------------------------------------------------------------+ + | PHP version 4.0 | + +----------------------------------------------------------------------+ + | Copyright (c) 1997, 1998, 1999, 2000 The PHP Group | + +----------------------------------------------------------------------+ + | This source file is subject to version 2.02 of the PHP license, | + | that is bundled with this package in the file LICENSE, and is | + | available at through the world-wide-web at | + | http://www.php.net/license/2_02.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" + +#define INCOMPLETE_CLASS "__PHP_Incomplete_Class" +#define MAGIC_MEMBER "__PHP_Incomplete_Class_Name" + +static void incomplete_class_message(zend_property_reference *ref) +{ + char buf[1024]; + char *class_name; + + class_name = php_lookup_class_name(&ref->object, NULL, 0); + + if (!class_name) + class_name = estrdup("unknown"); + + snprintf(buf, 1023, INCOMPLETE_CLASS_MSG, class_name); + + efree(class_name); + + php_error(E_ERROR, buf); +} + +static void incomplete_class_call_func(INTERNAL_FUNCTION_PARAMETERS, zend_property_reference *property_reference) +{ + incomplete_class_message(property_reference); +} + +static int incomplete_class_set_property(zend_property_reference *property_reference, zval *value) +{ + incomplete_class_message(property_reference); + + /* does not reach this point */ + return (0); +} + +static zval incomplete_class_get_property(zend_property_reference *property_reference) +{ + zval foo; + + incomplete_class_message(property_reference); + + /* does not reach this point */ + return (foo); +} + +zend_class_entry *php_create_incomplete_class(BLS_D) +{ + zend_class_entry incomplete_class; + + INIT_OVERLOADED_CLASS_ENTRY(incomplete_class, INCOMPLETE_CLASS, NULL, + incomplete_class_call_func, + incomplete_class_get_property, + incomplete_class_set_property); + + BG(incomplete_class) = zend_register_internal_class(&incomplete_class); + + return (BG(incomplete_class)); +} + + +char *php_lookup_class_name(zval **object, size_t *nlen, zend_bool del) +{ + zval **val; + char *retval = NULL; + + if (zend_hash_find((*object)->value.obj.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)->value.obj.properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER)); + } + + return (retval); +} + +void php_store_class_name(zval **object, const char *name, size_t len) +{ + zval *val; + + 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((*object)->value.obj.properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER), &val, sizeof(val), NULL); +} diff --git a/ext/standard/php_incomplete_class.h b/ext/standard/php_incomplete_class.h new file mode 100644 index 0000000000..b3ebb42f16 --- /dev/null +++ b/ext/standard/php_incomplete_class.h @@ -0,0 +1,62 @@ +/* + +----------------------------------------------------------------------+ + | PHP version 4.0 | + +----------------------------------------------------------------------+ + | Copyright (c) 1997, 1998, 1999, 2000 The PHP Group | + +----------------------------------------------------------------------+ + | This source file is subject to version 2.02 of the PHP license, | + | that is bundled with this package in the file LICENSE, and is | + | available at through the world-wide-web at | + | http://www.php.net/license/2_02.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> | + +----------------------------------------------------------------------+ + */ + + +#ifndef PHP_INCOMPLETE_CLASS_H +#define PHP_INCOMPLETE_CLASS_H + +#define PHP_IC_ENTRY \ + BG(incomplete_class) + +#define PHP_IC_ENTRY_READ \ + (PHP_IC_ENTRY ? PHP_IC_ENTRY : php_create_incomplete_class(BLS_C)) + + +#define PHP_SET_CLASS_ATTRIBUTES() \ + if ((*struc)->value.obj.ce == BG(incomplete_class)) { \ + class_name = php_lookup_class_name(struc, &name_len, 1); \ + free_class_name = 1; \ + } else { \ + class_name = (*struc)->value.obj.ce->name; \ + name_len = (*struc)->value.obj.ce->name_length; \ + } + +#define PHP_CLEANUP_CLASS_ATTRIBUTES() \ + if (free_class_name) efree(class_name) + +#define PHP_CLASS_ATTRIBUTES \ + char *class_name; \ + size_t name_len; \ + zend_bool free_class_name = 0 \ + + + +#ifdef __cplusplus +extern "C" { +#endif + +zend_class_entry *php_create_incomplete_class(BLS_D); + +char *php_lookup_class_name(zval **object, size_t *nlen, zend_bool del); +void php_store_class_name(zval **object, const char *name, size_t len); + +#ifdef __cplusplus +}; +#endif + +#endif diff --git a/ext/standard/var.c b/ext/standard/var.c index 850a9f02bf..9760f86e22 100644 --- a/ext/standard/var.c +++ b/ext/standard/var.c @@ -31,6 +31,7 @@ #include "php_string.h" #include "php_var.h" #include "basic_functions.h" +#include "php_incomplete_class.h" #define COMMON ((*struc)->is_ref?"&":"") @@ -52,102 +53,6 @@ static int php_array_element_dump(zval **zv, int num_args, va_list args, zend_ha return 0; } -static char *php_lookup_class_name(zval **object, size_t *nlen, zend_bool del); - -#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" - -static void incomplete_class_message(zend_property_reference *ref) -{ - char buf[1024]; - char *class_name; - - class_name = php_lookup_class_name(&ref->object, NULL, 0); - - if (!class_name) - class_name = estrdup("unknown"); - - snprintf(buf, 1023, INCOMPLETE_CLASS_MSG, class_name); - - efree(class_name); - - php_error(E_ERROR, buf); -} - -static void incomplete_class_call_func(INTERNAL_FUNCTION_PARAMETERS, zend_property_reference *property_reference) -{ - incomplete_class_message(property_reference); -} - -static int incomplete_class_set_property(zend_property_reference *property_reference, zval *value) -{ - incomplete_class_message(property_reference); - - /* does not reach this point */ - return (0); -} - -static zval incomplete_class_get_property(zend_property_reference *property_reference) -{ - zval foo; - - incomplete_class_message(property_reference); - - /* does not reach this point */ - return (foo); -} - -#define INCOMPLETE_CLASS "__PHP_Incomplete_Class" - -static void php_create_incomplete_class(BLS_D) -{ - zend_class_entry incomplete_class; - - INIT_OVERLOADED_CLASS_ENTRY(incomplete_class, INCOMPLETE_CLASS, NULL, - incomplete_class_call_func, - incomplete_class_get_property, - incomplete_class_set_property); - - BG(incomplete_class) = zend_register_internal_class(&incomplete_class); -} - -#define MAGIC_MEMBER "__PHP_Incomplete_Class_Name" - -static char *php_lookup_class_name(zval **object, size_t *nlen, zend_bool del) -{ - zval **val; - char *retval = NULL; - - if (zend_hash_find((*object)->value.obj.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)->value.obj.properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER)); - } - - return (retval); -} - -static void php_store_class_name(zval **object, const char *name, size_t len) -{ - zval *val; - - 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((*object)->value.obj.properties, MAGIC_MEMBER, sizeof(MAGIC_MEMBER), &val, sizeof(val), NULL); -} - void php_var_dump(pval **struc, int level) { HashTable *myht; @@ -246,24 +151,6 @@ PHP_FUNCTION(var_dump) strcat(__p->value.str.val + __i, (S));\ } -#define PHP_SET_CLASS_ATTRIBUTES() \ - if ((*struc)->value.obj.ce == BG(incomplete_class)) { \ - class_name = php_lookup_class_name(struc, &name_len, 1); \ - free_class_name = 1; \ - } else { \ - class_name = (*struc)->value.obj.ce->name; \ - name_len = (*struc)->value.obj.ce->name_length; \ - } - -#define PHP_CLEANUP_CLASS_ATTRIBUTES() \ - if (free_class_name) efree(class_name) - -#define PHP_CLASS_ATTRIBUTES \ - char *class_name; \ - size_t name_len; \ - zend_bool free_class_name = 0 \ - - /* }}} */ /* {{{ php_var_serialize */ @@ -580,9 +467,7 @@ int php_var_unserialize(pval **rval, const char **p, const char *max) if (zend_hash_find(EG(class_table), class_name, i+1, (void **) &ce)==FAILURE) { incomplete_class = 1; - if (BG(incomplete_class) == NULL) - php_create_incomplete_class(BLS_C); - ce = BG(incomplete_class); + ce = PHP_IC_ENTRY_READ; } } else { /* old php 3.0 data 'o' */ ce = &zend_standard_class_def; |