pollita         Fri Jun 13 18:25:29 2003 EDT

  Modified files:              
    /php4/ext/standard  user_filters.c 
  Log:
  User Filters don't need to register a resource list for streams.
  That functionality is already exported by the streams API.
  
  
Index: php4/ext/standard/user_filters.c
diff -u php4/ext/standard/user_filters.c:1.17 php4/ext/standard/user_filters.c:1.18
--- php4/ext/standard/user_filters.c:1.17       Tue Jun 10 16:03:39 2003
+++ php4/ext/standard/user_filters.c    Fri Jun 13 18:25:29 2003
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
 */
 
-/* $Id: user_filters.c,v 1.17 2003/06/10 20:03:39 imajes Exp $ */
+/* $Id: user_filters.c,v 1.18 2003/06/13 22:25:29 pollita Exp $ */
 
 #include "php.h"
 #include "php_globals.h"
@@ -28,7 +28,6 @@
 #define PHP_STREAM_BRIGADE_RES_NAME    "userfilter.bucket brigade"
 #define PHP_STREAM_BUCKET_RES_NAME "userfilter.bucket"
 #define PHP_STREAM_FILTER_RES_NAME "userfilter.filter"
-#define PHP_STREAM_RES_NAME "userfilter.stream"
 
 struct php_user_filter_data {
        zend_class_entry *ce;
@@ -40,7 +39,6 @@
 static int le_userfilters;
 static int le_bucket_brigade;
 static int le_bucket;
-static int le_stream;
 
 #define GET_FILTER_FROM_OBJ()  { \
        zval **tmp; \
@@ -82,9 +80,10 @@
                return FAILURE;
        }
 
+       /* Filters will dispose of their brigades */
        le_bucket_brigade = zend_register_list_destructors_ex(NULL, NULL, 
PHP_STREAM_BRIGADE_RES_NAME, module_number);
+       /* Brigades will dispose of their buckets */
        le_bucket = zend_register_list_destructors_ex(NULL, NULL, 
PHP_STREAM_BUCKET_RES_NAME, module_number);
-       le_stream = zend_register_list_destructors_ex(NULL, NULL, PHP_STREAM_RES_NAME, 
module_number);
        
        if (le_bucket_brigade == FAILURE) {
                return FAILURE;
@@ -149,7 +148,7 @@
        if (FAILURE == zend_hash_find(Z_OBJPROP_P(obj), "stream", sizeof("stream"), 
(void**)&zstream)) {
                /* Give the userfilter class a hook back to the stream */
                ALLOC_INIT_ZVAL(zstream);
-               ZEND_REGISTER_RESOURCE(zstream, stream, le_stream);
+               php_stream_to_zval(stream, zstream);
                add_property_zval(obj, "stream", zstream);
                /* add_property_zval increments the refcount which is unwanted here */
                zval_ptr_dtor(&zstream);
@@ -402,7 +401,7 @@
                RETURN_FALSE;
        }
 
-       ZEND_FETCH_RESOURCE(stream, php_stream *, &zstream, -1, PHP_STREAM_RES_NAME, 
le_stream);
+       php_stream_from_zval(stream, &zstream);
 
        if (!(pbuffer = pemalloc(buffer_len, php_stream_is_persistent(stream)))) {
                RETURN_FALSE;



-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to