php-src/Zend/zend_variables.c

244 lines
5.8 KiB
C
Raw Normal View History

1999-04-07 18:10:10 +00:00
/*
+----------------------------------------------------------------------+
| Zend Engine |
+----------------------------------------------------------------------+
2013-01-01 08:28:54 +00:00
| Copyright (c) 1998-2013 Zend Technologies Ltd. (http://www.zend.com) |
1999-04-07 18:10:10 +00:00
+----------------------------------------------------------------------+
2001-12-11 15:16:21 +00:00
| This source file is subject to version 2.00 of the Zend license, |
1999-07-16 14:58:16 +00:00
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
2001-12-11 15:16:21 +00:00
| http://www.zend.com/license/2_00.txt. |
1999-07-16 14:58:16 +00:00
| If you did not receive a copy of the Zend license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@zend.com so we can mail you a copy immediately. |
1999-04-07 18:10:10 +00:00
+----------------------------------------------------------------------+
| Authors: Andi Gutmans <andi@zend.com> |
| Zeev Suraski <zeev@zend.com> |
+----------------------------------------------------------------------+
*/
/* $Id$ */
1999-07-16 14:58:16 +00:00
1999-04-07 18:10:10 +00:00
#include <stdio.h>
#include "zend.h"
#include "zend_API.h"
#include "zend_globals.h"
#include "zend_constants.h"
#include "zend_list.h"
ZEND_API void _zval_dtor_func(zval *zvalue ZEND_FILE_LINE_DC)
1999-04-07 18:10:10 +00:00
{
2007-09-28 19:52:53 +00:00
switch (Z_TYPE_P(zvalue) & IS_CONSTANT_TYPE_MASK) {
1999-04-07 18:10:10 +00:00
case IS_STRING:
case IS_CONSTANT:
CHECK_ZVAL_STRING_REL(zvalue);
1999-08-27 19:17:19 +00:00
STR_FREE_REL(zvalue->value.str.val);
1999-04-07 18:10:10 +00:00
break;
case IS_ARRAY:
case IS_CONSTANT_ARRAY: {
TSRMLS_FETCH();
1999-04-07 18:10:10 +00:00
if (zvalue->value.ht && (zvalue->value.ht != &EG(symbol_table))) {
2012-10-18 12:10:35 +00:00
/* break possible cycles */
Z_TYPE_P(zvalue) = IS_NULL;
zend_hash_destroy(zvalue->value.ht);
FREE_HASHTABLE(zvalue->value.ht);
1999-04-07 18:10:10 +00:00
}
}
break;
1999-07-10 11:45:23 +00:00
case IS_OBJECT:
2002-03-15 16:26:17 +00:00
{
TSRMLS_FETCH();
Z_OBJ_HT_P(zvalue)->del_ref(zvalue TSRMLS_CC);
}
1999-04-07 18:10:10 +00:00
break;
2002-03-15 16:26:17 +00:00
case IS_RESOURCE:
{
2001-07-30 04:54:16 +00:00
TSRMLS_FETCH();
/* destroy resource */
zend_list_delete(zvalue->value.lval);
}
1999-04-07 18:10:10 +00:00
break;
case IS_LONG:
case IS_DOUBLE:
case IS_BOOL:
2000-01-04 13:22:58 +00:00
case IS_NULL:
1999-04-07 18:10:10 +00:00
default:
return;
1999-04-07 18:10:10 +00:00
break;
}
}
ZEND_API void _zval_internal_dtor(zval *zvalue ZEND_FILE_LINE_DC)
{
2007-09-28 19:52:53 +00:00
switch (Z_TYPE_P(zvalue) & IS_CONSTANT_TYPE_MASK) {
case IS_STRING:
case IS_CONSTANT:
CHECK_ZVAL_STRING_REL(zvalue);
str_free(zvalue->value.str.val);
break;
case IS_ARRAY:
case IS_CONSTANT_ARRAY:
case IS_OBJECT:
case IS_RESOURCE:
zend_error(E_CORE_ERROR, "Internal zval's can't be arrays, objects or resources");
break;
case IS_LONG:
case IS_DOUBLE:
case IS_BOOL:
case IS_NULL:
default:
break;
}
}
2000-04-21 14:45:10 +00:00
ZEND_API void zval_add_ref(zval **p)
1999-04-07 18:10:10 +00:00
{
Z_ADDREF_PP(p);
1999-04-07 18:10:10 +00:00
}
ZEND_API void _zval_copy_ctor_func(zval *zvalue ZEND_FILE_LINE_DC)
1999-04-07 18:10:10 +00:00
{
2007-09-28 19:52:53 +00:00
switch (Z_TYPE_P(zvalue) & IS_CONSTANT_TYPE_MASK) {
2001-07-30 04:54:16 +00:00
case IS_RESOURCE: {
TSRMLS_FETCH();
zend_list_addref(zvalue->value.lval);
}
1999-04-07 18:10:10 +00:00
break;
case IS_BOOL:
case IS_LONG:
2000-01-04 13:22:58 +00:00
case IS_NULL:
1999-04-07 18:10:10 +00:00
break;
case IS_CONSTANT:
1999-04-07 18:10:10 +00:00
case IS_STRING:
CHECK_ZVAL_STRING_REL(zvalue);
if (!IS_INTERNED(zvalue->value.str.val)) {
zvalue->value.str.val = (char *) estrndup_rel(zvalue->value.str.val, zvalue->value.str.len);
}
1999-04-07 18:10:10 +00:00
break;
case IS_ARRAY:
case IS_CONSTANT_ARRAY: {
1999-04-07 18:10:10 +00:00
zval *tmp;
HashTable *original_ht = zvalue->value.ht;
HashTable *tmp_ht = NULL;
TSRMLS_FETCH();
1999-04-07 18:10:10 +00:00
if (zvalue->value.ht == &EG(symbol_table)) {
return; /* do nothing */
1999-04-07 18:10:10 +00:00
}
ALLOC_HASHTABLE_REL(tmp_ht);
zend_hash_init(tmp_ht, zend_hash_num_elements(original_ht), NULL, ZVAL_PTR_DTOR, 0);
zend_hash_copy(tmp_ht, original_ht, (copy_ctor_func_t) zval_add_ref, (void *) &tmp, sizeof(zval *));
zvalue->value.ht = tmp_ht;
1999-04-07 18:10:10 +00:00
}
break;
case IS_OBJECT:
2002-03-15 16:26:17 +00:00
{
TSRMLS_FETCH();
Z_OBJ_HT_P(zvalue)->add_ref(zvalue TSRMLS_CC);
2002-03-15 16:26:17 +00:00
}
1999-04-07 18:10:10 +00:00
break;
}
}
ZEND_API int zend_print_variable(zval *var)
{
return zend_print_zval(var, 0);
}
ZEND_API void _zval_dtor_wrapper(zval *zvalue)
1999-08-27 19:17:19 +00:00
{
TSRMLS_FETCH();
GC_REMOVE_ZVAL_FROM_BUFFER(zvalue);
zval_dtor(zvalue);
1999-08-27 19:17:19 +00:00
}
#if ZEND_DEBUG
ZEND_API void _zval_copy_ctor_wrapper(zval *zvalue)
{
zval_copy_ctor(zvalue);
}
ZEND_API void _zval_internal_dtor_wrapper(zval *zvalue)
{
zval_internal_dtor(zvalue);
}
1999-08-27 19:17:19 +00:00
ZEND_API void _zval_ptr_dtor_wrapper(zval **zval_ptr)
1999-08-27 19:17:19 +00:00
{
zval_ptr_dtor(zval_ptr);
1999-08-27 19:17:19 +00:00
}
ZEND_API void _zval_internal_ptr_dtor_wrapper(zval **zval_ptr)
{
zval_internal_ptr_dtor(zval_ptr);
}
1999-08-27 19:17:19 +00:00
#endif
ZEND_API int zval_copy_static_var(zval **p TSRMLS_DC, int num_args, va_list args, zend_hash_key *key) /* {{{ */
{
HashTable *target = va_arg(args, HashTable*);
zend_bool is_ref;
zval *tmp;
if (Z_TYPE_PP(p) & (IS_LEXICAL_VAR|IS_LEXICAL_REF)) {
is_ref = Z_TYPE_PP(p) & IS_LEXICAL_REF;
if (!EG(active_symbol_table)) {
zend_rebuild_symbol_table(TSRMLS_C);
}
if (zend_hash_quick_find(EG(active_symbol_table), key->arKey, key->nKeyLength, key->h, (void **) &p) == FAILURE) {
if (is_ref) {
ALLOC_INIT_ZVAL(tmp);
Z_SET_ISREF_P(tmp);
zend_hash_quick_add(EG(active_symbol_table), key->arKey, key->nKeyLength, key->h, &tmp, sizeof(zval*), (void**)&p);
} else {
tmp = EG(uninitialized_zval_ptr);
zend_error(E_NOTICE,"Undefined variable: %s", key->arKey);
}
} else {
if (is_ref) {
SEPARATE_ZVAL_TO_MAKE_IS_REF(p);
tmp = *p;
} else if (Z_ISREF_PP(p)) {
ALLOC_INIT_ZVAL(tmp);
ZVAL_COPY_VALUE(tmp, *p);
zval_copy_ctor(tmp);
Z_SET_REFCOUNT_P(tmp, 0);
Z_UNSET_ISREF_P(tmp);
} else {
tmp = *p;
}
}
} else {
tmp = *p;
}
if (zend_hash_quick_add(target, key->arKey, key->nKeyLength, key->h, &tmp, sizeof(zval*), NULL) == SUCCESS) {
Z_ADDREF_P(tmp);
}
return ZEND_HASH_APPLY_KEEP;
}
/* }}} */
1999-04-07 18:10:10 +00:00
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* indent-tabs-mode: t
1999-04-07 18:10:10 +00:00
* End:
*/