summaryrefslogtreecommitdiff
path: root/ext/dotnet/dotnet.cpp
diff options
context:
space:
mode:
authorHarald Radi <phanto@php.net>2001-05-02 21:52:12 +0000
committerHarald Radi <phanto@php.net>2001-05-02 21:52:12 +0000
commit7361fa13fca5a7312e7afb2ba97ea4bdc7a310c2 (patch)
treebdea2444c06eda1091fa8fd172bdf878342fc48e /ext/dotnet/dotnet.cpp
parente6e43743c5c9a4a38ff64db9a5c1a80760984c1f (diff)
downloadphp-git-7361fa13fca5a7312e7afb2ba97ea4bdc7a310c2.tar.gz
adapted because of the changes in the com module
Diffstat (limited to 'ext/dotnet/dotnet.cpp')
-rw-r--r--ext/dotnet/dotnet.cpp21
1 files changed, 12 insertions, 9 deletions
diff --git a/ext/dotnet/dotnet.cpp b/ext/dotnet/dotnet.cpp
index fc9e2ef678..0e65bfe630 100644
--- a/ext/dotnet/dotnet.cpp
+++ b/ext/dotnet/dotnet.cpp
@@ -16,7 +16,6 @@
+----------------------------------------------------------------------+
*/
-
/*
* This module implements support for Microsoft .Net components.
*/
@@ -38,11 +37,11 @@ extern "C" { /* this should be included in the includes itself !! */
#include "php.h"
#include "ext/standard/info.h"
-#include "../com/conversion.h"
-#include "../com/php_COM.h"
}
+#include "../com/conversion.h"
+#include "../com/php_COM.h"
#include "Mscoree.h"
#include "mscorlib.h"
@@ -76,7 +75,7 @@ HRESULT dotnet_init() {
return ERROR_SUCCESS;
}
-HRESULT dotnet_create(OLECHAR *assembly, OLECHAR *datatype, struct IDispatch **object) {
+HRESULT dotnet_create(OLECHAR *assembly, OLECHAR *datatype, i_dispatch *object) {
HRESULT hr;
_ObjectHandle *pHandle;
@@ -89,7 +88,7 @@ HRESULT dotnet_create(OLECHAR *assembly, OLECHAR *datatype, struct IDispatch **o
pHandle->Release();
if (FAILED(hr)) return hr;
- *object = unwrapped.pdispVal;
+ php_COM_set(object, unwrapped.pdispVal, TRUE);
return ERROR_SUCCESS;
}
@@ -109,7 +108,7 @@ PHP_FUNCTION(DOTNET_load)
HRESULT hr;
pval *assembly_name, *datatype_name;
OLECHAR *assembly, *datatype;
- IDispatch FAR *i_dispatch = NULL;
+ i_dispatch *obj;
if (ZEND_NUM_ARGS() != 2) WRONG_PARAM_COUNT;
@@ -123,8 +122,10 @@ PHP_FUNCTION(DOTNET_load)
convert_to_string(datatype_name);
datatype = php_char_to_OLECHAR(datatype_name->value.str.val, datatype_name->value.str.len, codepage);
+ obj = (i_dispatch *) emalloc(sizeof(i_dispatch));
+
/* obtain IDispatch */
- hr=dotnet_create(assembly, datatype, &i_dispatch);
+ hr=dotnet_create(assembly, datatype, obj);
efree(assembly);
efree(datatype);
if (FAILED(hr)) {
@@ -132,14 +133,16 @@ PHP_FUNCTION(DOTNET_load)
error_message = php_COM_error_message(hr);
php_error(E_WARNING,"Error obtaining .Net class for %s in assembly %s: %s",datatype_name->value.str.val,assembly_name->value.str.val,error_message);
LocalFree(error_message);
+ efree(obj);
RETURN_FALSE;
}
- if (!i_dispatch) {
+ if (!obj->i.dispatch) {
php_error(E_WARNING,"Unable to locate %s in assembly %s",datatype_name->value.str.val,assembly_name->value.str.val);
+ efree(obj);
RETURN_FALSE;
}
- RETURN_LONG(zend_list_insert(i_dispatch,php_COM_get_le_idispatch()));
+ RETURN_LONG(zend_list_insert(obj, php_COM_get_le_idispatch()));
}
/* }}} */