mirror of
https://github.com/php/php-src.git
synced 2025-08-18 23:18:56 +02:00
ongoing development ...
This commit is contained in:
parent
207f26ae91
commit
c1fe9cd279
7 changed files with 268 additions and 66 deletions
|
@ -1,7 +1,11 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "../handler.h"
|
#include "../handler.h"
|
||||||
|
#include "../php_rpc.h"
|
||||||
|
|
||||||
RPC_REGISTER_HANDLERS(com);
|
RPC_REGISTER_HANDLERS(com)
|
||||||
|
|
||||||
|
RPC_FUNCTION_ENTRY_START(com)
|
||||||
|
RPC_FUNCTION_ENTRY_END()
|
||||||
|
|
||||||
RPC_INIT_FUNCTION(com) {
|
RPC_INIT_FUNCTION(com) {
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,13 +3,27 @@
|
||||||
|
|
||||||
#include "php.h"
|
#include "php.h"
|
||||||
|
|
||||||
#define RPC_HANDLER(layer) {#layer, layer##_handler_init, &layer##_object_handlers, &layer##_class_entry}
|
#define RPC_HANDLER(layer) {#layer, layer##_handler_init, &layer##_object_handlers, &layer##_class_entry, layer##_function_entry}
|
||||||
|
|
||||||
#define RPC_DECLARE_HANDLER(layer) void layer##_handler_init(); \
|
#define RPC_DECLARE_HANDLER(layer) void layer##_handler_init(); \
|
||||||
rpc_object_handlers layer##_object_handlers; \
|
rpc_object_handlers layer##_object_handlers; \
|
||||||
zend_class_entry layer##_class_entry;
|
zend_class_entry layer##_class_entry; \
|
||||||
|
function_entry layer##_function_entry[];
|
||||||
|
|
||||||
#define RPC_INIT_FUNCTION(layer) void layer##_handler_init()
|
#define RPC_INIT_FUNCTION(layer) void layer##_handler_init()
|
||||||
|
|
||||||
#define RPC_REGISTER_HANDLERS(layer) zend_class_entry layer##_class_entry; \
|
#define RPC_REGISTER_HANDLERS(layer) zend_class_entry layer##_class_entry; \
|
||||||
rpc_object_handlers layer##object_handlers;
|
rpc_object_handlers layer##_object_handlers; \
|
||||||
|
|
||||||
|
|
||||||
|
#define RPC_FUNCTION_ENTRY_START(layer) function_entry layer##_function_entry[] = { \
|
||||||
|
PHP_FALIAS(layer##_load, rpc_load, NULL) \
|
||||||
|
PHP_FALIAS(layer##_call, rpc_call, NULL) \
|
||||||
|
PHP_FALIAS(layer##_get, rpc_get, NULL) \
|
||||||
|
PHP_FALIAS(layer##_set, rpc_set, NULL)
|
||||||
|
|
||||||
|
#define RPC_FUNCTION_ENTRY_END() {NULL, NULL, NULL} \
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
typedef struct _rpc_object_handlers {
|
typedef struct _rpc_object_handlers {
|
||||||
|
@ -21,6 +35,7 @@ typedef struct _rpc_handler_entry {
|
||||||
void (*rpc_handler_init)();
|
void (*rpc_handler_init)();
|
||||||
rpc_object_handlers *handlers;
|
rpc_object_handlers *handlers;
|
||||||
zend_class_entry *ce;
|
zend_class_entry *ce;
|
||||||
|
function_entry *functions;
|
||||||
} rpc_handler_entry;
|
} rpc_handler_entry;
|
||||||
|
|
||||||
typedef struct _rpc_internal {
|
typedef struct _rpc_internal {
|
||||||
|
|
|
@ -20,10 +20,13 @@ PHP_MINIT_FUNCTION(rpc);
|
||||||
PHP_MSHUTDOWN_FUNCTION(rpc);
|
PHP_MSHUTDOWN_FUNCTION(rpc);
|
||||||
PHP_MINFO_FUNCTION(rpc);
|
PHP_MINFO_FUNCTION(rpc);
|
||||||
|
|
||||||
|
ZEND_FUNCTION(rpc_load);
|
||||||
|
ZEND_FUNCTION(rpc_call);
|
||||||
|
ZEND_FUNCTION(rpc_set);
|
||||||
|
ZEND_FUNCTION(rpc_get);
|
||||||
|
|
||||||
ZEND_BEGIN_MODULE_GLOBALS(rpc)
|
ZEND_BEGIN_MODULE_GLOBALS(rpc)
|
||||||
zend_object_handle handle;
|
int dummy;
|
||||||
HashTable *instance;
|
|
||||||
HashTable *handlers;
|
|
||||||
ZEND_END_MODULE_GLOBALS(rpc)
|
ZEND_END_MODULE_GLOBALS(rpc)
|
||||||
|
|
||||||
#ifdef ZTS
|
#ifdef ZTS
|
||||||
|
@ -32,4 +35,6 @@ ZEND_END_MODULE_GLOBALS(rpc)
|
||||||
#define RPC_G(v) (rpc_globals.v)
|
#define RPC_G(v) (rpc_globals.v)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define phpext_rpc_ptr &rpc_module_entry
|
||||||
|
|
||||||
#endif /* PHP_RPC_H */
|
#endif /* PHP_RPC_H */
|
222
ext/rpc/rpc.c
222
ext/rpc/rpc.c
|
@ -5,16 +5,18 @@
|
||||||
#include "php.h"
|
#include "php.h"
|
||||||
#include "php_ini.h"
|
#include "php_ini.h"
|
||||||
#include "ext/standard/info.h"
|
#include "ext/standard/info.h"
|
||||||
#include "php_rpc.h"
|
|
||||||
|
|
||||||
|
#include "php_rpc.h"
|
||||||
#include "rpc.h"
|
#include "rpc.h"
|
||||||
#include "layer.h"
|
#include "layer.h"
|
||||||
|
|
||||||
ZEND_DECLARE_MODULE_GLOBALS(rpc)
|
ZEND_DECLARE_MODULE_GLOBALS(rpc)
|
||||||
|
|
||||||
|
static int rpc_global_startup(void);
|
||||||
|
static int rpc_global_shutdown(void);
|
||||||
static void rpc_globals_ctor(zend_rpc_globals *rpc_globals TSRMLS_DC);
|
static void rpc_globals_ctor(zend_rpc_globals *rpc_globals TSRMLS_DC);
|
||||||
static void rpc_instance_dtor(void *pDest);
|
static void rpc_instance_dtor(void *pDest);
|
||||||
static void rpc_handlers_dtor(void *pDest);
|
static void rpc_export_functions(char *name, zend_class_entry *ce, function_entry functions[] TSRMLS_DC);
|
||||||
static zend_object_value rpc_create_object(zend_class_entry *class_type TSRMLS_DC);
|
static zend_object_value rpc_create_object(zend_class_entry *class_type TSRMLS_DC);
|
||||||
|
|
||||||
/* object handler */
|
/* object handler */
|
||||||
|
@ -38,8 +40,6 @@ static int rpc_get_classname(zval *object, char **class_name, zend_uint *class_n
|
||||||
static int rpc_compare(zval *object1, zval *object2 TSRMLS_DC);
|
static int rpc_compare(zval *object1, zval *object2 TSRMLS_DC);
|
||||||
/**/
|
/**/
|
||||||
|
|
||||||
ZEND_FUNCTION(CONSTRUCTOR);
|
|
||||||
|
|
||||||
static zend_object_handlers rpc_handlers = {
|
static zend_object_handlers rpc_handlers = {
|
||||||
rpc_add_ref,
|
rpc_add_ref,
|
||||||
rpc_del_ref,
|
rpc_del_ref,
|
||||||
|
@ -85,9 +85,13 @@ zend_module_entry rpc_module_entry = {
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
static HashTable *instance;
|
static HashTable *instance;
|
||||||
|
static HashTable *handlers;
|
||||||
|
|
||||||
|
static MUTEX_T mx_instance;
|
||||||
|
static unsigned long thread_count = 0;
|
||||||
|
|
||||||
#ifdef COMPILE_DL_RPC
|
#ifdef COMPILE_DL_RPC
|
||||||
ZEND_GET_MODULE(rpc)
|
ZEND_GET_MODULE(rpc);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* {{{ PHP_INI
|
/* {{{ PHP_INI
|
||||||
|
@ -97,42 +101,72 @@ PHP_INI_BEGIN()
|
||||||
PHP_INI_END()
|
PHP_INI_END()
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
|
/* still not sure if MINIT is really only once per server and not once per thread
|
||||||
|
* so i keep the init stuff here here
|
||||||
|
*/
|
||||||
|
static int rpc_global_startup(void)
|
||||||
|
{
|
||||||
|
mx_instance = tsrm_mutex_alloc();
|
||||||
|
|
||||||
|
handlers = (HashTable *) pemalloc(sizeof(HashTable), TRUE);
|
||||||
|
instance = (HashTable *) pemalloc(sizeof(HashTable), TRUE);
|
||||||
|
|
||||||
|
zend_hash_init(handlers, 0, NULL, NULL, TRUE);
|
||||||
|
zend_hash_init(instance, 0, NULL, rpc_instance_dtor, TRUE);
|
||||||
|
|
||||||
|
FOREACH_HANDLER {
|
||||||
|
HANDLER.rpc_handler_init();
|
||||||
|
|
||||||
|
/* create a class entry for every rpc handler */
|
||||||
|
INIT_OVERLOADED_CLASS_ENTRY((*(HANDLER.ce)),
|
||||||
|
HANDLER.name,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
HANDLER.ce->create_object = rpc_create_object;
|
||||||
|
|
||||||
|
/* load all available rpc handler into a hash */
|
||||||
|
zend_hash_add(handlers, HANDLER.name, strlen(HANDLER.name) + 1, &(HANDLER.handlers), sizeof(rpc_object_handlers *), NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
return SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* same as above for shutdown */
|
||||||
|
static int rpc_global_shutdown(void)
|
||||||
|
{
|
||||||
|
tsrm_mutex_free(mx_instance);
|
||||||
|
|
||||||
|
zend_hash_destroy(handlers);
|
||||||
|
zend_hash_destroy(instance);
|
||||||
|
|
||||||
|
return SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
static void rpc_globals_ctor(zend_rpc_globals *rpc_globals TSRMLS_DC)
|
static void rpc_globals_ctor(zend_rpc_globals *rpc_globals TSRMLS_DC)
|
||||||
{
|
{
|
||||||
RPC_G(handle) = 0;
|
|
||||||
|
|
||||||
RPC_G(handlers) = (HashTable *) pemalloc(sizeof(HashTable), TRUE);
|
|
||||||
RPC_G(instance) = (HashTable *) pemalloc(sizeof(HashTable), TRUE);
|
|
||||||
|
|
||||||
zend_hash_init(RPC_G(handlers), 0, NULL, NULL, TRUE);
|
|
||||||
zend_hash_init(RPC_G(instance), 0, NULL, rpc_instance_dtor, TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* {{{ PHP_MINIT_FUNCTION
|
/* {{{ PHP_MINIT_FUNCTION
|
||||||
*/
|
*/
|
||||||
PHP_MINIT_FUNCTION(rpc)
|
PHP_MINIT_FUNCTION(rpc)
|
||||||
{
|
{
|
||||||
int i;
|
/* GINIT */
|
||||||
|
if (thread_count++ == 0) {
|
||||||
|
rpc_global_startup();
|
||||||
|
}
|
||||||
|
|
||||||
|
FOREACH_HANDLER {
|
||||||
|
/* register classes and functions */
|
||||||
|
zend_register_internal_class(HANDLER.ce TSRMLS_CC);
|
||||||
|
zend_register_functions(HANDLER.functions, NULL, MODULE_PERSISTENT TSRMLS_CC);
|
||||||
|
}
|
||||||
|
|
||||||
ZEND_INIT_MODULE_GLOBALS(rpc, rpc_globals_ctor, NULL);
|
ZEND_INIT_MODULE_GLOBALS(rpc, rpc_globals_ctor, NULL);
|
||||||
REGISTER_INI_ENTRIES();
|
REGISTER_INI_ENTRIES();
|
||||||
|
|
||||||
for (i=0; i < (sizeof(handler_entries) / sizeof(rpc_handler_entry)); i++) {
|
|
||||||
handler_entries[i].rpc_handler_init();
|
|
||||||
|
|
||||||
INIT_OVERLOADED_CLASS_ENTRY((*(handler_entries[i].ce)),
|
|
||||||
handler_entries[i].name,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
handler_entries[i].ce->create_object = rpc_create_object;
|
|
||||||
|
|
||||||
zend_register_internal_class(handler_entries[i].ce TSRMLS_CC);
|
|
||||||
zend_hash_add(RPC_G(handlers), handler_entries[i].name, strlen(handler_entries[i].name), &(handler_entries[i].handlers), sizeof(rpc_object_handlers *), NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
@ -141,8 +175,10 @@ PHP_MINIT_FUNCTION(rpc)
|
||||||
*/
|
*/
|
||||||
PHP_MSHUTDOWN_FUNCTION(rpc)
|
PHP_MSHUTDOWN_FUNCTION(rpc)
|
||||||
{
|
{
|
||||||
zend_hash_destroy(RPC_G(handlers));
|
/* GSHUTDOWN */
|
||||||
zend_hash_destroy(RPC_G(instance));
|
if (--thread_count == 0) {
|
||||||
|
rpc_global_shutdown();
|
||||||
|
}
|
||||||
|
|
||||||
UNREGISTER_INI_ENTRIES();
|
UNREGISTER_INI_ENTRIES();
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
|
@ -167,7 +203,7 @@ static void rpc_instance_dtor(void *pDest)
|
||||||
|
|
||||||
intern = (rpc_internal **) pDest;
|
intern = (rpc_internal **) pDest;
|
||||||
|
|
||||||
/* destruct intern */
|
/* TODO: destruct intern */
|
||||||
}
|
}
|
||||||
|
|
||||||
static zend_object_value rpc_create_object(zend_class_entry *class_type TSRMLS_DC)
|
static zend_object_value rpc_create_object(zend_class_entry *class_type TSRMLS_DC)
|
||||||
|
@ -175,45 +211,56 @@ static zend_object_value rpc_create_object(zend_class_entry *class_type TSRMLS_D
|
||||||
zend_object_value *zov;
|
zend_object_value *zov;
|
||||||
rpc_internal *intern;
|
rpc_internal *intern;
|
||||||
|
|
||||||
|
/* set up the object value struct */
|
||||||
zov = (zend_object_value*) pemalloc(sizeof(zend_object_value), TRUE);
|
zov = (zend_object_value*) pemalloc(sizeof(zend_object_value), TRUE);
|
||||||
intern = (rpc_internal *) pemalloc(sizeof(rpc_internal), TRUE);
|
|
||||||
|
|
||||||
zov->handle = RPC_G(handle)++;
|
|
||||||
zov->handlers = &rpc_handlers;
|
zov->handlers = &rpc_handlers;
|
||||||
|
|
||||||
|
/* set up the internal representation of our rpc instance */
|
||||||
|
intern = (rpc_internal *) pemalloc(sizeof(rpc_internal), TRUE);
|
||||||
intern->ce = class_type;
|
intern->ce = class_type;
|
||||||
intern->refcount = 0;
|
intern->refcount = 0;
|
||||||
intern->data = NULL;
|
intern->data = NULL;
|
||||||
zend_hash_find(RPC_G(handlers), class_type->name, class_type->name_length, (void **) &(intern->handlers));
|
if (zend_hash_find(handlers, class_type->name, class_type->name_length + 1, (void **) &(intern->handlers)) == FAILURE) {
|
||||||
|
/* TODO: exception */
|
||||||
|
}
|
||||||
|
|
||||||
zend_hash_index_update_or_next_insert(RPC_G(instance), zov->handle, &intern, sizeof(rpc_internal *), NULL, HASH_ADD);
|
/* store the instance in a hash and set the key as handle, thus
|
||||||
|
* we can find it later easily
|
||||||
|
*/
|
||||||
|
tsrm_mutex_lock(mx_instance);
|
||||||
|
{
|
||||||
|
zov->handle = instance->nNextFreeElement;
|
||||||
|
zend_hash_next_index_insert(instance, &intern, sizeof(rpc_internal *), NULL);
|
||||||
|
}
|
||||||
|
tsrm_mutex_unlock(mx_instance);
|
||||||
|
|
||||||
return *zov;
|
return *zov;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**/
|
/* object handler */
|
||||||
|
|
||||||
static void rpc_add_ref(zval *object)
|
static void rpc_add_ref(zval *object)
|
||||||
{
|
{
|
||||||
ZVAL_ADDREF(object);
|
GET_INTERNAL(intern);
|
||||||
|
RPC_ADDREF(intern);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rpc_del_ref(zval *object)
|
static void rpc_del_ref(zval *object)
|
||||||
{
|
{
|
||||||
if (ZVAL_REFCOUNT(object) > 0) {
|
GET_INTERNAL(intern);
|
||||||
ZVAL_DELREF(object);
|
|
||||||
|
if (RPC_REFCOUNT(intern) > 0) {
|
||||||
|
RPC_DELREF(intern);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ZVAL_REFCOUNT(object) == 0) {
|
if (RPC_REFCOUNT(intern) == 0) {
|
||||||
rpc_delete(object);
|
rpc_instance_dtor(intern);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rpc_delete(zval *object)
|
static void rpc_delete(zval *object)
|
||||||
{
|
{
|
||||||
TSRMLS_FETCH();
|
|
||||||
GET_INTERNAL(intern);
|
GET_INTERNAL(intern);
|
||||||
|
|
||||||
rpc_instance_dtor(intern);
|
rpc_instance_dtor(intern);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -237,6 +284,7 @@ static zval* rpc_read(zval *object, zval *member, int type TSRMLS_DC)
|
||||||
static void rpc_write(zval *object, zval *member, zval *value TSRMLS_DC)
|
static void rpc_write(zval *object, zval *member, zval *value TSRMLS_DC)
|
||||||
{
|
{
|
||||||
// GET_INTERNAL(intern);
|
// GET_INTERNAL(intern);
|
||||||
|
/* FIXME */
|
||||||
}
|
}
|
||||||
|
|
||||||
static zval** rpc_get_property(zval *object, zval *member TSRMLS_DC)
|
static zval** rpc_get_property(zval *object, zval *member TSRMLS_DC)
|
||||||
|
@ -247,7 +295,7 @@ static zval** rpc_get_property(zval *object, zval *member TSRMLS_DC)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static zval **rpc_get_property_zval(zval *object, zval *member TSRMLS_DC)
|
static zval** rpc_get_property_zval(zval *object, zval *member TSRMLS_DC)
|
||||||
{
|
{
|
||||||
// GET_INTERNAL(intern);
|
// GET_INTERNAL(intern);
|
||||||
|
|
||||||
|
@ -266,6 +314,7 @@ static zval* rpc_get(zval *property TSRMLS_DC)
|
||||||
static void rpc_set(zval **property, zval *value TSRMLS_DC)
|
static void rpc_set(zval **property, zval *value TSRMLS_DC)
|
||||||
{
|
{
|
||||||
// GET_INTERNAL(intern);
|
// GET_INTERNAL(intern);
|
||||||
|
/* FIXME */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rpc_has_property(zval *object, zval *member, int check_empty TSRMLS_DC)
|
static int rpc_has_property(zval *object, zval *member, int check_empty TSRMLS_DC)
|
||||||
|
@ -279,6 +328,7 @@ static int rpc_has_property(zval *object, zval *member, int check_empty TSRMLS_D
|
||||||
static void rpc_unset_property(zval *object, zval *member TSRMLS_DC)
|
static void rpc_unset_property(zval *object, zval *member TSRMLS_DC)
|
||||||
{
|
{
|
||||||
// GET_INTERNAL(intern);
|
// GET_INTERNAL(intern);
|
||||||
|
/* FIXME */
|
||||||
}
|
}
|
||||||
|
|
||||||
static HashTable* rpc_get_properties(zval *object TSRMLS_DC)
|
static HashTable* rpc_get_properties(zval *object TSRMLS_DC)
|
||||||
|
@ -291,10 +341,18 @@ static HashTable* rpc_get_properties(zval *object TSRMLS_DC)
|
||||||
|
|
||||||
static union _zend_function* rpc_get_method(zval *object, char *method, int method_len TSRMLS_DC)
|
static union _zend_function* rpc_get_method(zval *object, char *method, int method_len TSRMLS_DC)
|
||||||
{
|
{
|
||||||
// GET_INTERNAL(intern);
|
zend_function *function;
|
||||||
|
|
||||||
|
function = (zend_function *) emalloc(sizeof(zend_function));
|
||||||
|
function->type = ZEND_OVERLOADED_FUNCTION;
|
||||||
|
function->common.arg_types = NULL;
|
||||||
|
function->common.function_name = method;
|
||||||
|
function->common.scope = NULL;
|
||||||
|
|
||||||
|
// GET_INTERNAL(intern);
|
||||||
|
|
||||||
/* FIXME */
|
/* FIXME */
|
||||||
return NULL;
|
return function;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rpc_call(char *method, INTERNAL_FUNCTION_PARAMETERS)
|
static int rpc_call(char *method, INTERNAL_FUNCTION_PARAMETERS)
|
||||||
|
@ -314,7 +372,8 @@ static union _zend_function* rpc_get_constructor(zval *object TSRMLS_DC)
|
||||||
|
|
||||||
rpc_ctor->type = ZEND_INTERNAL_FUNCTION;
|
rpc_ctor->type = ZEND_INTERNAL_FUNCTION;
|
||||||
rpc_ctor->scope = (*intern)->ce;
|
rpc_ctor->scope = (*intern)->ce;
|
||||||
rpc_ctor->handler = CONSTRUCTOR_FN;
|
rpc_ctor->arg_types = NULL;
|
||||||
|
rpc_ctor->handler = ZEND_FN(rpc_load);
|
||||||
|
|
||||||
return (zend_function *) rpc_ctor;
|
return (zend_function *) rpc_ctor;
|
||||||
}
|
}
|
||||||
|
@ -333,8 +392,71 @@ static int rpc_compare(zval *object1, zval *object2 TSRMLS_DC)
|
||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
ZEND_FUNCTION(CONSTRUCTOR)
|
/**/
|
||||||
|
|
||||||
|
/* constructor */
|
||||||
|
ZEND_FUNCTION(rpc_load)
|
||||||
{
|
{
|
||||||
|
zval *object = getThis();
|
||||||
|
rpc_internal **intern;
|
||||||
|
|
||||||
|
/* check if we were called as a constructor or as a function */
|
||||||
|
if (!object) {
|
||||||
|
/* we were called as a function so we have to figure out which rpc layer was requested
|
||||||
|
* and then we have to set up a zval containing the object
|
||||||
|
*/
|
||||||
|
|
||||||
|
char *key;
|
||||||
|
int key_len;
|
||||||
|
|
||||||
|
/* the name of the rpc layer is prepended to '_load' so lets strip everything after
|
||||||
|
* the first '_' away from the function name
|
||||||
|
*/
|
||||||
|
zend_class_entry *ce;
|
||||||
|
key = estrdup(get_active_function_name(TSRMLS_C));
|
||||||
|
key_len = strchr(key, '_') - key;
|
||||||
|
key[key_len] = '\0';
|
||||||
|
|
||||||
|
/* get the class entry for the requested rpc layer */
|
||||||
|
if (zend_hash_find(CG(class_table), key, key_len + 1, (void **) &ce) == FAILURE) {
|
||||||
|
/* TODO: exception here */
|
||||||
|
RETURN_FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set up a new zval container */
|
||||||
|
ALLOC_ZVAL(object);
|
||||||
|
INIT_PZVAL(object);
|
||||||
|
|
||||||
|
Z_TYPE_P(object) = IS_OBJECT;
|
||||||
|
ZVAL_REFCOUNT(object) = 1;
|
||||||
|
PZVAL_IS_REF(object) = 1;
|
||||||
|
|
||||||
|
/* create a new object */
|
||||||
|
object->value.obj = rpc_create_object(ce TSRMLS_CC);
|
||||||
|
|
||||||
|
return_value = object;
|
||||||
|
|
||||||
|
/* now everything is set up the same way as if we were called as a constructor */
|
||||||
|
}
|
||||||
|
|
||||||
|
GET_INTERNAL_EX(intern, object);
|
||||||
|
|
||||||
|
/* FIXME */
|
||||||
|
}
|
||||||
|
|
||||||
|
ZEND_FUNCTION(rpc_call)
|
||||||
|
{
|
||||||
|
/* FIXME */
|
||||||
|
}
|
||||||
|
|
||||||
|
ZEND_FUNCTION(rpc_set)
|
||||||
|
{
|
||||||
|
/* FIXME */
|
||||||
|
}
|
||||||
|
|
||||||
|
ZEND_FUNCTION(rpc_get)
|
||||||
|
{
|
||||||
|
/* FIXME */
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -45,7 +45,7 @@ RSC=rc.exe
|
||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MD /W3 /GX /O2 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
# ADD BASE CPP /nologo /MD /W3 /GX /O2 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
||||||
# ADD CPP /nologo /MD /W3 /GX /O2 /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "NDEBUG" /D ZEND_DEBUG=0 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
# ADD CPP /nologo /MD /W3 /GX /O2 /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "NDEBUG" /D ZEND_DEBUG=0 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "COMPILE_DL_RPC" /YX /FD /c
|
||||||
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x40d /d "NDEBUG"
|
# ADD BASE RSC /l 0x40d /d "NDEBUG"
|
||||||
|
@ -71,7 +71,7 @@ LINK32=link.exe
|
||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /GZ /c
|
# ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /GZ /c
|
||||||
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "_DEBUG" /D ZEND_DEBUG=1 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /FR /YX /FD /GZ /c
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "_DEBUG" /D ZEND_DEBUG=1 /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "COMPILE_DL_RPC" /FR /YX /FD /GZ /c
|
||||||
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x40d /d "_DEBUG"
|
# ADD BASE RSC /l 0x40d /d "_DEBUG"
|
||||||
|
@ -97,7 +97,7 @@ LINK32=link.exe
|
||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "_DEBUG" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /FR /YX /FD /GZ /c
|
# ADD BASE CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /D "_DEBUG" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /FR /YX /FD /GZ /c
|
||||||
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "_DEBUG" /D ZEND_DEBUG=1 /D "ZTS" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /FR /YX /FD /D /GZ /c
|
# ADD CPP /nologo /MDd /W3 /Gm /GX /ZI /Od /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "_DEBUG" /D ZEND_DEBUG=1 /D "ZTS" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "COMPILE_DL_RPC" /FR /YX /FD /D /GZ /c
|
||||||
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x40d /d "_DEBUG"
|
# ADD BASE RSC /l 0x40d /d "_DEBUG"
|
||||||
|
@ -123,7 +123,7 @@ LINK32=link.exe
|
||||||
# PROP Ignore_Export_Lib 0
|
# PROP Ignore_Export_Lib 0
|
||||||
# PROP Target_Dir ""
|
# PROP Target_Dir ""
|
||||||
# ADD BASE CPP /nologo /MD /W3 /GX /O2 /D "NDEBUG" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
# ADD BASE CPP /nologo /MD /W3 /GX /O2 /D "NDEBUG" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
||||||
# ADD CPP /nologo /MD /W3 /GX /O2 /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "NDEBUG" /D ZEND_DEBUG=0 /D "ZTS" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /YX /FD /c
|
# ADD CPP /nologo /MD /W3 /GX /O2 /I "..\.." /I "..\..\main" /I "..\..\Zend" /I "..\..\..\bindlib_w32" /I "..\..\TSRM" /D "NDEBUG" /D ZEND_DEBUG=0 /D "ZTS" /D "PHP_WIN32" /D "ZEND_WIN32" /D "WIN32" /D "_WINDOWS" /D "_MBCS" /D "_USRDLL" /D "COMPILE_DL_RPC" /YX /FD /c
|
||||||
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||||
# ADD BASE RSC /l 0x40d /d "NDEBUG"
|
# ADD BASE RSC /l 0x40d /d "NDEBUG"
|
||||||
|
@ -156,8 +156,48 @@ SOURCE=.\rpc.c
|
||||||
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\handler.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\layer.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\php_rpc.h
|
SOURCE=.\php_rpc.h
|
||||||
# End Source File
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\rpc.h
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "tests"
|
||||||
|
|
||||||
|
# PROP Default_Filter "*.php"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\tests\test1.php
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "layer"
|
||||||
|
|
||||||
|
# PROP Default_Filter ""
|
||||||
|
# Begin Group "com"
|
||||||
|
|
||||||
|
# PROP Default_Filter ""
|
||||||
|
# Begin Group "Source Files No. 1"
|
||||||
|
|
||||||
|
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\com\com.c
|
||||||
|
# End Source File
|
||||||
|
# End Group
|
||||||
|
# Begin Group "Header Files No. 1"
|
||||||
|
|
||||||
|
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||||
|
# End Group
|
||||||
|
# End Group
|
||||||
# End Group
|
# End Group
|
||||||
# End Target
|
# End Target
|
||||||
# End Project
|
# End Project
|
||||||
|
|
|
@ -1,11 +1,20 @@
|
||||||
#ifndef RPC_H
|
#ifndef RPC_H
|
||||||
#define RPC_H
|
#define RPC_H
|
||||||
|
|
||||||
#define CONSTRUCTOR __construct
|
#define FOREACH_HANDLER for (__handler_counter=0; __handler_counter < HANDLER_COUNT; __handler_counter++)
|
||||||
#define CONSTRUCTOR_FN ZEND_FN(__construct)
|
#define HANDLER handler_entries[__handler_counter]
|
||||||
|
#define HANDLER_COUNT (sizeof(handler_entries) / sizeof(rpc_handler_entry))
|
||||||
|
|
||||||
#define GET_INTERNAL(intern) GET_INTERNAL_EX(intern, object)
|
#define GET_INTERNAL(intern) rpc_internal **intern; \
|
||||||
#define GET_INTERNAL_EX(intern, object) rpc_internal **intern; \
|
GET_INTERNAL_EX(intern, object)
|
||||||
zend_hash_index_find(RPC_G(instance), object->value.obj.handle, (void **) &intern);
|
#define GET_INTERNAL_EX(intern, object) if (zend_hash_index_find(instance, object->value.obj.handle, (void **) &intern) == FAILURE) { \
|
||||||
|
/* TODO: exception */ \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define RPC_REFCOUNT(intern) ((*intern)->refcount)
|
||||||
|
#define RPC_ADDREF(intern) (++RPC_REFCOUNT(intern))
|
||||||
|
#define RPC_DELREF(intern) (--RPC_REFCOUNT(intern))
|
||||||
|
|
||||||
|
static int __handler_counter;
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -1,4 +1,11 @@
|
||||||
<?php
|
<?php
|
||||||
|
print "huhuhdsa";
|
||||||
|
|
||||||
$rpc = new com();
|
$rpc = new com();
|
||||||
|
$rpc->call();
|
||||||
delete $rpc;
|
delete $rpc;
|
||||||
|
|
||||||
|
$heh = com_load();
|
||||||
|
$heh->call;
|
||||||
|
delete $heh;
|
||||||
?>
|
?>
|
Loading…
Add table
Add a link
Reference in a new issue