phanto          Wed Oct  2 08:53:51 2002 EDT

  Modified files:              
    /php4/ext/com       COM.c 
  Log:
  fixes bugs #19156 and #19544
  
  
Index: php4/ext/com/COM.c
diff -u php4/ext/com/COM.c:1.86 php4/ext/com/COM.c:1.87
--- php4/ext/com/COM.c:1.86     Mon Aug 26 09:36:35 2002
+++ php4/ext/com/COM.c  Wed Oct  2 08:53:51 2002
@@ -18,7 +18,7 @@
    |         Wez Furlong <[EMAIL PROTECTED]>                           |
    +----------------------------------------------------------------------+
  */
-/* $Id: COM.c,v 1.86 2002/08/26 13:36:35 wez Exp $ */
+/* $Id: COM.c,v 1.87 2002/10/02 12:53:51 phanto Exp $ */
 /*
  * This module implements support for COM components that support the IDispatch
  * interface.  Both local (COM) and remote (DCOM) components can be accessed.
@@ -291,11 +291,9 @@
        if (C_HASENUM(obj) = SUCCEEDED(C_DISPATCH_VT(obj)->Invoke(C_DISPATCH(obj), 
DISPID_NEWENUM, &IID_NULL, LOCALE_SYSTEM_DEFAULT,
                                                                                       
                                   DISPATCH_METHOD|DISPATCH_PROPERTYGET, &dispparams, 
var_result, NULL, NULL))) {
                if (V_VT(var_result) == VT_UNKNOWN) {
-                       V_UNKNOWN(var_result)->lpVtbl->AddRef(V_UNKNOWN(var_result));
                        C_HASENUM(obj) = 
SUCCEEDED(V_UNKNOWN(var_result)->lpVtbl->QueryInterface(V_UNKNOWN(var_result), 
&IID_IEnumVARIANT,
                                                                                       
                                                                                  
(void**)&C_ENUMVARIANT(obj)));
                } else if (V_VT(var_result) == VT_DISPATCH) {
-                       V_DISPATCH(var_result)->lpVtbl->AddRef(V_DISPATCH(var_result));
                        C_HASENUM(obj) = 
SUCCEEDED(V_DISPATCH(var_result)->lpVtbl->QueryInterface(V_DISPATCH(var_result), 
&IID_IEnumVARIANT,
                                                                                       
                                                                                   
(void**)&C_ENUMVARIANT(obj)));
                }
@@ -1872,6 +1870,7 @@
                switch (Z_TYPE_P(overloaded_property)) {
                        case OE_IS_ARRAY:
                                if (do_COM_offget(var_result, obj, 
&overloaded_property->element, FALSE TSRMLS_CC) == FAILURE) {
+                                       pval_destructor(&overloaded_property->element);
                                        FREE_VARIANT(var_result);
                                        FREE_COM(obj_prop);
 
@@ -1881,6 +1880,7 @@
 
                        case OE_IS_OBJECT:
                                if (do_COM_propget(var_result, obj, 
&overloaded_property->element, FALSE TSRMLS_CC) == FAILURE) {
+                                       pval_destructor(&overloaded_property->element);
                                        FREE_VARIANT(var_result);
                                        FREE_COM(obj_prop);
 
@@ -1888,21 +1888,24 @@
                                }
                                break;
 
-                       case OE_IS_METHOD: {
-                                       FREE_VARIANT(var_result);
-                                       if (obj != obj_prop) {
-                                               FREE_COM(obj_prop);
+                       case OE_IS_METHOD:
+                               pval_destructor(&overloaded_property->element);
+                               FREE_VARIANT(var_result);
 
-                                               return_value = *object;
-                                               ZVAL_ADDREF(&return_value);
-                                       } else {
-                                               RETVAL_COM(obj);
-                                       }
-                                       return return_value;
+                               if (obj != obj_prop) {
+                                       FREE_COM(obj_prop);
+
+                                       return_value = *object;
+                                       ZVAL_ADDREF(&return_value);
+                               } else {
+                                       RETVAL_COM(obj);
                                }
-                               break;
+
+                               return return_value;
                }
 
+               pval_destructor(&overloaded_property->element);
+
                if (V_VT(var_result) == VT_DISPATCH) {
                        if (V_DISPATCH(var_result) == NULL) {
                                FREE_VARIANT(var_result);
@@ -1920,8 +1923,6 @@
                        FREE_COM(obj_prop);
                        obj_prop = NULL;
                }
-
-               pval_destructor(&overloaded_property->element);
        }
 
        if (obj_prop != NULL) {



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

Reply via email to