]> granicus.if.org Git - php/commitdiff
"better" "fix" for #29392.
authorWez Furlong <wez@php.net>
Tue, 27 Jul 2004 22:17:00 +0000 (22:17 +0000)
committerWez Furlong <wez@php.net>
Tue, 27 Jul 2004 22:17:00 +0000 (22:17 +0000)
This fixes the crash; the sample script:

$c = new COM('ADODB.Connection');
echo $c;

still does not work because the engine tries to call $c->__toString() and the
ADODB object *might* implement that method, but doesn't know until you open the
connection.

ext/com_dotnet/com_handlers.c

index d18a5a952c65c48fb5b094c6e77ff5bfd2207b3f..cee0b41017598466f28be8fca638bfc50ab682b2 100644 (file)
@@ -286,11 +286,19 @@ static void function_dtor(void *pDest)
        }
 }
 
+static PHP_FUNCTION(com_method_handler)
+{
+       Z_OBJ_HANDLER_P(getThis(), call_method)(
+                       ((zend_internal_function*)EG(function_state_ptr)->function)->function_name,
+                       INTERNAL_FUNCTION_PARAM_PASSTHRU);
+}
+
 static union _zend_function *com_method_get(zval *object, char *name, int len TSRMLS_DC)
 {
        zend_internal_function f, *fptr = NULL;
        php_com_dotnet_object *obj;
        union _zend_function *func;
+       DISPID dummy;
 
        obj = CDNO_FETCH(object);
 
@@ -298,6 +306,10 @@ static union _zend_function *com_method_get(zval *object, char *name, int len TS
                return NULL;
        }
 
+       if (FAILED(php_com_get_id_of_name(obj, name, len, &dummy TSRMLS_CC))) {
+               return NULL;
+       }
+
        /* check cache */
        if (obj->method_cache == NULL || FAILURE == zend_hash_find(obj->method_cache, name, len, (void**)&fptr)) {
                f.type = ZEND_OVERLOADED_FUNCTION;
@@ -306,6 +318,7 @@ static union _zend_function *com_method_get(zval *object, char *name, int len TS
                f.scope = obj->ce;
                f.fn_flags = 0;
                f.function_name = estrndup(name, len);
+               f.handler = PHP_FN(com_method_handler);
 
                fptr = &f;
                
@@ -350,8 +363,6 @@ static union _zend_function *com_method_get(zval *object, char *name, int len TS
                                                        break;
 
                                                case DESCKIND_NONE:
-                                               //default:
-                                               //      fptr = NULL;
                                                        break;
                                        }
                                        if (TI) {