From d693d6b2cbb28496302efbfc3b58f7599d8c71ca Mon Sep 17 00:00:00 2001 From: Uwe Steinmann Date: Wed, 1 Mar 2000 21:16:24 +0000 Subject: [PATCH] - started to implement overload class for xml node --- ext/domxml/domxml.c | 126 ++++++++++++++++++++++++++++++++++++++++++++ tests/testdom | 7 ++- 2 files changed, 132 insertions(+), 1 deletion(-) diff --git a/ext/domxml/domxml.c b/ext/domxml/domxml.c index 020146d3f5..71bd292e89 100644 --- a/ext/domxml/domxml.c +++ b/ext/domxml/domxml.c @@ -144,6 +144,132 @@ PHP_MINIT_FUNCTION(domxml) return SUCCESS; } +#ifdef 0 +/* {{{ Node Class */ +pval domxmlnode_class_get_property(zend_property_reference *property_reference) +{ + pval result; + zend_overloaded_element *overloaded_property; + zend_llist_element *element; + + + printf("Reading a property from a OverloadedTestClass object:\n"); + + for (element=property_reference->elements_list.head; element; element=element->next) { + overloaded_property = (zend_overloaded_element *) element->data; + switch (overloaded_property->type) { + case OE_IS_ARRAY: + printf("Array offset: "); + break; + case OE_IS_OBJECT: + printf("Object property: "); + break; + } + switch (overloaded_property->element.type) { + case IS_LONG: + printf("%ld (numeric)\n", overloaded_property->element.value.lval); + break; + case IS_STRING: + printf("'%s'\n", overloaded_property->element.value.str.val); + break; + } + pval_destructor(&overloaded_property->element); + } + + result.value.str.val = estrndup("testing", 7); + result.value.str.len = 7; + result.type = IS_STRING; + return result; +} + + +int domxmlnode_class_set_property(zend_property_reference *property_reference, pval *value) +{ + zend_overloaded_element *overloaded_property; + zend_llist_element *element; + + printf("Writing to a property from a OverloadedTestClass object:\n"); + printf("Writing '"); + zend_print_variable(value); + printf("'\n"); + + for (element=property_reference->elements_list.head; element; element=element->next) { + overloaded_property = (zend_overloaded_element *) element->data; + switch (overloaded_property->type) { + case OE_IS_ARRAY: + printf("Array offset: "); + break; + case OE_IS_OBJECT: + printf("Object property: "); + break; + } + switch (overloaded_property->element.type) { + case IS_LONG: + printf("%ld (numeric)\n", overloaded_property->element.value.lval); + break; + case IS_STRING: + printf("'%s'\n", overloaded_property->element.value.str.val); + break; + } + pval_destructor(&overloaded_property->element); + } + + return 0; +} + +void domxmlnode_class_call_function(INTERNAL_FUNCTION_PARAMETERS, zend_property_reference *property_reference) +{ + zend_overloaded_element *overloaded_property; + zend_llist_element *element; + + + printf("Invoking a method on OverloadedTestClass object:\n"); + + for (element=property_reference->elements_list.head; element; element=element->next) { + overloaded_property = (zend_overloaded_element *) element->data; + switch (overloaded_property->type) { + case OE_IS_ARRAY: + printf("Array offset: "); + break; + case OE_IS_OBJECT: + printf("Object property: "); + break; + case OE_IS_METHOD: + printf("Overloaded method: "); + } + switch (overloaded_property->element.type) { + case IS_LONG: + printf("%ld (numeric)\n", overloaded_property->element.value.lval); + break; + case IS_STRING: + printf("'%s'\n", overloaded_property->element.value.str.val); + break; + } + pval_destructor(&overloaded_property->element); + } + + printf("%d arguments\n", ARG_COUNT(ht)); + return_value->value.str.val = estrndup("testing", 7); + return_value->value.str.len = 7; + return_value->type = IS_STRING; +} + + +void domxmlnode_class_startup() +{ + zend_class_entry domxmlnode_class_entry; + + INIT_OVERLOADED_CLASS_ENTRY(dcomxmlnode_class_entry, "Dom Node", + php_domxmlnode_class_functions, + domxmlnode_class_call_function, + domxmlnode_class_get_property, + domxmlnode_class_set_property); + + register_internal_class(&domxmlnode_class_entry); +} +/* }}} */ +#endif + PHP_MINFO_FUNCTION(domxml) { PUTS("DOM/XML support active (compiled with libxml "); diff --git a/tests/testdom b/tests/testdom index bfd4ae3998..53aa75c657 100644 --- a/tests/testdom +++ b/tests/testdom @@ -46,6 +46,7 @@ $xmlstr = " ]> + Title &sp; @@ -66,7 +67,10 @@ $xmlstr = " by using the methods of the xmlnode object */ echo "Test 1: accessing single nodes from php\n"; -$dom = xmldoc($xmlstr); +if(!$dom = xmldoc($xmlstr)) { + echo "Error while parsing the document\n"; + exit; +} echo "XML Version: ".$dom->version."\n"; $dtd = $dom->dtd(); $rootnode = $dom->root(); @@ -75,6 +79,7 @@ output_node($rootnode); /* This one creates a dom tree made of php objects */ echo "Test 2: creating a tree with php objects\n"; $dom = xmltree($xmlstr); +$dom->root->name = "section"; var_dump($dom); echo $dom->root->name; echo "\n"; -- 2.40.0