summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHarald Radi <phanto@php.net>2002-06-09 14:52:50 +0000
committerHarald Radi <phanto@php.net>2002-06-09 14:52:50 +0000
commit30e1541595cc1fb3ba9ed1db0dd54a6b4ac6ecd7 (patch)
tree5a3710a9889cdc010175e738d598ff393e12c8f7
parentc55e855fdd5c78d5cea74202e7c770edf7a7df24 (diff)
downloadphp-git-30e1541595cc1fb3ba9ed1db0dd54a6b4ac6ecd7.tar.gz
reflect the new abstraction changes in the demo layer
-rw-r--r--ext/rpc/com/com.c61
1 files changed, 39 insertions, 22 deletions
diff --git a/ext/rpc/com/com.c b/ext/rpc/com/com.c
index 11f4d4930b..0b51925ed7 100644
--- a/ext/rpc/com/com.c
+++ b/ext/rpc/com/com.c
@@ -1,45 +1,55 @@
#include "com.h"
/* protos */
-static int com_hash(char *, zend_uint, char **, zend_uint *, int, char *, int);
-static int com_ctor(char *, zend_uint, void **, int , zval ***);
+static int com_hash(rpc_string, rpc_string *, int, char *, int);
+static int com_name(rpc_string, rpc_string *, int);
+static int com_ctor(rpc_string, void **, int , zval ***);
static int com_dtor(void **);
-static int com_call(char *, zend_uint, void **, zval **, int, zval ***);
-static int com_get(char *, zend_uint, zval *, void **);
-static int com_set(char *, zend_uint, zval *, void **);
+static int com_call(rpc_string, void **, zval **, int, zval ***);
+static int com_get(rpc_string, zval *, void **);
+static int com_set(rpc_string, zval *, void **);
static int com_compare(void **, void **);
-static int com_get_classname(char **, zend_uint *, void **);
-static int com_has_property(char *, zend_uint, void **);
-static int com_unset_property(char *, zend_uint, void **);
+static int com_has_property(rpc_string, void **);
+static int com_unset_property(rpc_string, void **);
static int com_get_properties(HashTable **, void **);
/* register rpc callback function */
RPC_REGISTER_HANDLERS_START(com)
-POOL,
+TRUE, /* poolable */
HASH_AS_INT_WITH_SIGNATURE,
com_hash,
+com_name,
com_ctor,
com_dtor,
com_call,
com_get,
com_set,
com_compare,
-com_get_classname,
com_has_property,
com_unset_property,
com_get_properties
RPC_REGISTER_HANDLERS_END()
+/* register ini settings */
+RPC_INI_START(com)
+PHP_INI_ENTRY_EX("com.allow_dcom", "0", PHP_INI_SYSTEM, NULL, php_ini_boolean_displayer_cb)
+PHP_INI_ENTRY_EX("com.autoregister_typelib", "0", PHP_INI_SYSTEM, NULL, php_ini_boolean_displayer_cb)
+PHP_INI_ENTRY_EX("com.autoregister_verbose", "0", PHP_INI_SYSTEM, NULL, php_ini_boolean_displayer_cb)
+PHP_INI_ENTRY_EX("com.autoregister_casesensitive", "1", PHP_INI_SYSTEM, NULL, php_ini_boolean_displayer_cb)
+RPC_INI_END()
+
/* register userspace functions */
RPC_FUNCTION_ENTRY_START(com)
ZEND_FALIAS(com_invoke, rpc_call, NULL)
ZEND_FE(com_addref, NULL)
+ ZEND_FE(com_release, NULL)
RPC_FUNCTION_ENTRY_END()
/* register class methods */
RPC_METHOD_ENTRY_START(com)
ZEND_FALIAS(addref, com_addref, NULL)
+ ZEND_FALIAS(release, com_release, NULL)
RPC_METHOD_ENTRY_END()
/* init function that is called before the class is registered
@@ -51,55 +61,58 @@ RPC_INIT_FUNCTION(com)
/* rpc handler functions */
-static int com_hash(char *name, zend_uint name_len, char **hash, zend_uint *hash_len, int num_args, char *arg_types, int type)
+static int com_hash(rpc_string name, rpc_string *hash, int num_args, char *arg_types, int type)
{
- *hash = strdup(name);
- *hash_len = name_len;
+ hash->str = strdup(name.str);
+ hash->len = name.len;
return SUCCESS;
}
-static int com_ctor(char *class_name, zend_uint class_name_len, void **data, int num_args, zval **args[])
+static int com_name(rpc_string hash, rpc_string *name, int type)
{
+ name->str = strdup(hash.str);
+ name->len = hash.len;
+
return SUCCESS;
}
-static int com_dtor(void **data)
+static int com_ctor(rpc_string class_name, void **data, int num_args, zval **args[])
{
return SUCCESS;
}
-static int com_call(char *method_name, zend_uint method_name_len, void **data, zval **return_value, int num_args, zval **args[])
+static int com_dtor(void **data)
{
return SUCCESS;
}
-static int com_get(char *property_name, zend_uint property_name_len, zval *return_value, void **data)
+static int com_call(rpc_string method_name, void **data, zval **return_value, int num_args, zval **args[])
{
return SUCCESS;
}
-static int com_set(char *property_name, zend_uint property_name_len, zval *value, void **data)
+static int com_get(rpc_string property_name, zval *return_value, void **data)
{
return SUCCESS;
}
-static int com_compare(void **data1, void **data2)
+static int com_set(rpc_string property_name, zval *value, void **data)
{
return SUCCESS;
}
-static int com_get_classname(char **class_name, zend_uint *class_name_length, void **data)
+static int com_compare(void **data1, void **data2)
{
return SUCCESS;
}
-static int com_has_property(char *property_name, zend_uint property_name_length, void **data)
+static int com_has_property(rpc_string property_name, void **data)
{
return SUCCESS;
}
-static int com_unset_property(char *property_name, zend_uint property_name_length, void **data)
+static int com_unset_property(rpc_string property_name, void **data)
{
return SUCCESS;
}
@@ -112,4 +125,8 @@ static int com_get_properties(HashTable **properties, void **data)
/* custom functions */
ZEND_FUNCTION(com_addref)
{
+}
+
+ZEND_FUNCTION(com_release)
+{
} \ No newline at end of file