X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=missing.c;h=65851bef9dd24d6571ffed3c666dec0230de2dae;hp=bbc4b3ac3b8787114f546b0bbfeaa5a78d4c578b;hb=ad5f896b03adaa073134a00108a9cdf00720673a;hpb=781c90c0447166dd52ef881ae15751fa466c32fb diff --git a/missing.c b/missing.c index bbc4b3a..65851be 100644 --- a/missing.c +++ b/missing.c @@ -1,16 +1,28 @@ +/* + +--------------------------------------------------------------------+ + | PECL :: http | + +--------------------------------------------------------------------+ + | Redistribution and use in source and binary forms, with or without | + | modification, are permitted provided that the conditions mentioned | + | in the accompanying LICENSE file are met. | + +--------------------------------------------------------------------+ + | Copyright (c) 2004-2010, Michael Wallner | + +--------------------------------------------------------------------+ +*/ + +/* $Id$ */ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif #include "php.h" #include "missing.h" +#ifdef WONKY int zend_declare_property_double(zend_class_entry *ce, char *name, int name_length, double value, int access_type TSRMLS_DC) { - zval *property; - - if (ce->type & ZEND_INTERNAL_CLASS) { - property = malloc(sizeof(zval)); - } else { - ALLOC_ZVAL(property); - } + zval *property = pemalloc(sizeof(zval), ce->type & ZEND_INTERNAL_CLASS); INIT_PZVAL(property); ZVAL_DOUBLE(property, value); return zend_declare_property(ce, name, name_length, property, access_type TSRMLS_CC); @@ -18,15 +30,39 @@ int zend_declare_property_double(zend_class_entry *ce, char *name, int name_leng void zend_update_property_double(zend_class_entry *scope, zval *object, char *name, int name_length, double value TSRMLS_DC) { - zval *tmp; + zval *tmp = ecalloc(1, sizeof(zval)); + ZVAL_DOUBLE(tmp, value); + zend_update_property(scope, object, name, name_length, tmp TSRMLS_CC); +} +int zend_declare_property_bool(zend_class_entry *ce, char *name, int name_length, long value, int access_type TSRMLS_DC) +{ + zval *property = pemalloc(sizeof(zval), ce->type & ZEND_INTERNAL_CLASS); + INIT_PZVAL(property); + ZVAL_BOOL(property, value); + return zend_declare_property(ce, name, name_length, property, access_type TSRMLS_CC); +} + +void zend_update_property_bool(zend_class_entry *scope, zval *object, char *name, int name_length, long value TSRMLS_DC) +{ + zval *tmp = ecalloc(1, sizeof(zval)); + ZVAL_BOOL(tmp, value); + zend_update_property(scope, object, name, name_length, tmp TSRMLS_CC); +} + +void zend_update_property_stringl(zend_class_entry *scope, zval *object, char *name, int name_length, char *value, int value_len TSRMLS_DC) +{ + zval *tmp; + ALLOC_ZVAL(tmp); tmp->is_ref = 0; tmp->refcount = 0; - ZVAL_DOUBLE(tmp, value); + ZVAL_STRINGL(tmp, value, value_len, 1); zend_update_property(scope, object, name, name_length, tmp TSRMLS_CC); } +#endif + /* * Local variables: * tab-width: 4