diff options
Diffstat (limited to 'ext/xmlwriter/php_xmlwriter.c')
| -rw-r--r-- | ext/xmlwriter/php_xmlwriter.c | 1049 |
1 files changed, 223 insertions, 826 deletions
diff --git a/ext/xmlwriter/php_xmlwriter.c b/ext/xmlwriter/php_xmlwriter.c index 2fa4e32854..be14a1220e 100644 --- a/ext/xmlwriter/php_xmlwriter.c +++ b/ext/xmlwriter/php_xmlwriter.c @@ -27,6 +27,7 @@ #include "ext/standard/info.h" #include "php_xmlwriter.h" #include "ext/standard/php_string.h" +#include "xmlwriter_arginfo.h" static PHP_FUNCTION(xmlwriter_set_indent); static PHP_FUNCTION(xmlwriter_set_indent_string); @@ -73,35 +74,15 @@ static PHP_FUNCTION(xmlwriter_flush); static zend_class_entry *xmlwriter_class_entry_ce; -static void xmlwriter_free_resource_ptr(xmlwriter_object *intern); -static void xmlwriter_dtor(zend_resource *rsrc); - typedef int (*xmlwriter_read_one_char_t)(xmlTextWriterPtr writer, const xmlChar *content); typedef int (*xmlwriter_read_int_t)(xmlTextWriterPtr writer); -/* {{{ xmlwriter_object_free_storage */ -static void xmlwriter_free_resource_ptr(xmlwriter_object *intern) -{ - if (intern) { - if (intern->ptr) { - xmlFreeTextWriter(intern->ptr); - intern->ptr = NULL; - } - if (intern->output) { - xmlBufferFree(intern->output); - intern->output = NULL; - } - efree(intern); - } -} -/* }}} */ - /* {{{ XMLWRITER_FROM_OBJECT */ -#define XMLWRITER_FROM_OBJECT(intern, object) \ +#define XMLWRITER_FROM_OBJECT(ptr, object) \ { \ ze_xmlwriter_object *obj = Z_XMLWRITER_P(object); \ - intern = obj->xmlwriter_ptr; \ - if (!intern) { \ + ptr = obj->ptr; \ + if (!ptr) { \ php_error_docref(NULL, E_WARNING, "Invalid or uninitialized XMLWriter object"); \ RETURN_FALSE; \ } \ @@ -117,10 +98,14 @@ static void xmlwriter_object_free_storage(zend_object *object) if (!intern) { return; } - if (intern->xmlwriter_ptr) { - xmlwriter_free_resource_ptr(intern->xmlwriter_ptr); + if (intern->ptr) { + xmlFreeTextWriter(intern->ptr); + intern->ptr = NULL; + } + if (intern->output) { + xmlBufferFree(intern->output); + intern->output = NULL; } - intern->xmlwriter_ptr = NULL; zend_object_std_dtor(&intern->std); } /* }}} */ @@ -146,351 +131,47 @@ static zend_object *xmlwriter_object_new(zend_class_entry *class_type) RETURN_FALSE; \ } \ -/* {{{ arginfo */ -ZEND_BEGIN_ARG_INFO(arginfo_xmlwriter_void, 0) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_resource, 0, 0, 1) - ZEND_ARG_INFO(0, xmlwriter) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_open_uri, 0, 0, 1) - ZEND_ARG_INFO(0, uri) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_set_indent, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, indent) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_set_indent, 0, 0, 1) - ZEND_ARG_INFO(0, indent) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_set_indent_string, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, indentString) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_set_indent_string, 0, 0, 1) - ZEND_ARG_INFO(0, indentString) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_attribute, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_attribute, 0, 0, 1) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_attribute_ns, 0, 0, 4) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_attribute_ns, 0, 0, 3) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_attribute_ns, 0, 0, 5) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_attribute_ns, 0, 0, 4) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_attribute, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, value) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_attribute, 0, 0, 2) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, value) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_element, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_element, 0, 0, 1) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_element_ns, 0, 0, 4) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_element_ns, 0, 0, 3) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_element, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_element, 0, 0, 1) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_element_ns, 0, 0, 4) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_element_ns, 0, 0, 3) - ZEND_ARG_INFO(0, prefix) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, uri) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_pi, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, target) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_pi, 0, 0, 1) - ZEND_ARG_INFO(0, target) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_pi, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, target) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_pi, 0, 0, 2) - ZEND_ARG_INFO(0, target) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_cdata, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_cdata, 0, 0, 1) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_text, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_text, 0, 0, 1) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_raw, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_raw, 0, 0, 1) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_document, 0, 0, 1) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, version) - ZEND_ARG_INFO(0, encoding) - ZEND_ARG_INFO(0, standalone) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_document, 0, 0, 0) - ZEND_ARG_INFO(0, version) - ZEND_ARG_INFO(0, encoding) - ZEND_ARG_INFO(0, standalone) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_comment, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_comment, 0, 0, 1) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_dtd, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, qualifiedName) - ZEND_ARG_INFO(0, publicId) - ZEND_ARG_INFO(0, systemId) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_dtd, 0, 0, 1) - ZEND_ARG_INFO(0, qualifiedName) - ZEND_ARG_INFO(0, publicId) - ZEND_ARG_INFO(0, systemId) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_dtd, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, publicId) - ZEND_ARG_INFO(0, systemId) - ZEND_ARG_INFO(0, subset) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_dtd, 0, 0, 1) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, publicId) - ZEND_ARG_INFO(0, systemId) - ZEND_ARG_INFO(0, subset) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_dtd_element, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, qualifiedName) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_dtd_element, 0, 0, 1) - ZEND_ARG_INFO(0, qualifiedName) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_dtd_element, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_dtd_element, 0, 0, 2) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_dtd_attlist, 0, 0, 2) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_dtd_attlist, 0, 0, 1) - ZEND_ARG_INFO(0, name) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_dtd_attlist, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_dtd_attlist, 0, 0, 2) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_start_dtd_entity, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, isparam) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_start_dtd_entity, 0, 0, 2) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, isparam) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_write_dtd_entity, 0, 0, 3) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_write_dtd_entity, 0, 0, 2) - ZEND_ARG_INFO(0, name) - ZEND_ARG_INFO(0, content) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_output_memory, 0, 0, 1) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, flush) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_output_memory, 0, 0, 0) - ZEND_ARG_INFO(0, flush) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_flush, 0, 0, 1) - ZEND_ARG_INFO(0, xmlwriter) - ZEND_ARG_INFO(0, empty) -ZEND_END_ARG_INFO() - -ZEND_BEGIN_ARG_INFO_EX(arginfo_xmlwriter_method_flush, 0, 0, 0) - ZEND_ARG_INFO(0, empty) -ZEND_END_ARG_INFO() -/* }}} */ - /* {{{ xmlwriter_functions */ static const zend_function_entry xmlwriter_functions[] = { PHP_FE(xmlwriter_open_uri, arginfo_xmlwriter_open_uri) - PHP_FE(xmlwriter_open_memory, arginfo_xmlwriter_void) + PHP_FE(xmlwriter_open_memory, arginfo_xmlwriter_open_memory) PHP_FE(xmlwriter_set_indent, arginfo_xmlwriter_set_indent) PHP_FE(xmlwriter_set_indent_string, arginfo_xmlwriter_set_indent_string) - PHP_FE(xmlwriter_start_comment, arginfo_xmlwriter_resource) - PHP_FE(xmlwriter_end_comment, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_start_comment, arginfo_xmlwriter_start_comment) + PHP_FE(xmlwriter_end_comment, arginfo_xmlwriter_end_comment) PHP_FE(xmlwriter_start_attribute, arginfo_xmlwriter_start_attribute) - PHP_FE(xmlwriter_end_attribute, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_attribute, arginfo_xmlwriter_end_attribute) PHP_FE(xmlwriter_write_attribute, arginfo_xmlwriter_write_attribute) PHP_FE(xmlwriter_start_attribute_ns,arginfo_xmlwriter_start_attribute_ns) PHP_FE(xmlwriter_write_attribute_ns,arginfo_xmlwriter_write_attribute_ns) PHP_FE(xmlwriter_start_element, arginfo_xmlwriter_start_element) - PHP_FE(xmlwriter_end_element, arginfo_xmlwriter_resource) - PHP_FE(xmlwriter_full_end_element, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_element, arginfo_xmlwriter_end_element) + PHP_FE(xmlwriter_full_end_element, arginfo_xmlwriter_full_end_element) PHP_FE(xmlwriter_start_element_ns, arginfo_xmlwriter_start_element_ns) PHP_FE(xmlwriter_write_element, arginfo_xmlwriter_write_element) PHP_FE(xmlwriter_write_element_ns, arginfo_xmlwriter_write_element_ns) PHP_FE(xmlwriter_start_pi, arginfo_xmlwriter_start_pi) - PHP_FE(xmlwriter_end_pi, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_pi, arginfo_xmlwriter_end_pi) PHP_FE(xmlwriter_write_pi, arginfo_xmlwriter_write_pi) - PHP_FE(xmlwriter_start_cdata, arginfo_xmlwriter_resource) - PHP_FE(xmlwriter_end_cdata, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_start_cdata, arginfo_xmlwriter_start_cdata) + PHP_FE(xmlwriter_end_cdata, arginfo_xmlwriter_end_cdata) PHP_FE(xmlwriter_write_cdata, arginfo_xmlwriter_write_cdata) PHP_FE(xmlwriter_text, arginfo_xmlwriter_text) PHP_FE(xmlwriter_write_raw, arginfo_xmlwriter_write_raw) PHP_FE(xmlwriter_start_document, arginfo_xmlwriter_start_document) - PHP_FE(xmlwriter_end_document, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_document, arginfo_xmlwriter_end_document) PHP_FE(xmlwriter_write_comment, arginfo_xmlwriter_write_comment) PHP_FE(xmlwriter_start_dtd, arginfo_xmlwriter_start_dtd) - PHP_FE(xmlwriter_end_dtd, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_dtd, arginfo_xmlwriter_end_dtd) PHP_FE(xmlwriter_write_dtd, arginfo_xmlwriter_write_dtd) PHP_FE(xmlwriter_start_dtd_element, arginfo_xmlwriter_start_dtd_element) - PHP_FE(xmlwriter_end_dtd_element, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_dtd_element, arginfo_xmlwriter_end_dtd_element) PHP_FE(xmlwriter_write_dtd_element, arginfo_xmlwriter_write_dtd_element) PHP_FE(xmlwriter_start_dtd_attlist, arginfo_xmlwriter_start_dtd_attlist) - PHP_FE(xmlwriter_end_dtd_attlist, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_dtd_attlist, arginfo_xmlwriter_end_dtd_attlist) PHP_FE(xmlwriter_write_dtd_attlist, arginfo_xmlwriter_write_dtd_attlist) PHP_FE(xmlwriter_start_dtd_entity, arginfo_xmlwriter_start_dtd_entity) - PHP_FE(xmlwriter_end_dtd_entity, arginfo_xmlwriter_resource) + PHP_FE(xmlwriter_end_dtd_entity, arginfo_xmlwriter_end_dtd_entity) PHP_FE(xmlwriter_write_dtd_entity, arginfo_xmlwriter_write_dtd_entity) PHP_FE(xmlwriter_output_memory, arginfo_xmlwriter_output_memory) PHP_FE(xmlwriter_flush, arginfo_xmlwriter_flush) @@ -500,48 +181,48 @@ static const zend_function_entry xmlwriter_functions[] = { /* {{{ xmlwriter_class_functions */ static const zend_function_entry xmlwriter_class_functions[] = { - PHP_ME_MAPPING(openUri, xmlwriter_open_uri, arginfo_xmlwriter_open_uri, 0) - PHP_ME_MAPPING(openMemory, xmlwriter_open_memory, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(setIndent, xmlwriter_set_indent, arginfo_xmlwriter_method_set_indent, 0) - PHP_ME_MAPPING(setIndentString, xmlwriter_set_indent_string, arginfo_xmlwriter_method_set_indent_string, 0) - PHP_ME_MAPPING(startComment, xmlwriter_start_comment, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(endComment, xmlwriter_end_comment, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(startAttribute, xmlwriter_start_attribute, arginfo_xmlwriter_method_start_attribute, 0) - PHP_ME_MAPPING(endAttribute, xmlwriter_end_attribute, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeAttribute, xmlwriter_write_attribute, arginfo_xmlwriter_method_write_attribute, 0) - PHP_ME_MAPPING(startAttributeNs, xmlwriter_start_attribute_ns,arginfo_xmlwriter_method_start_attribute_ns, 0) - PHP_ME_MAPPING(writeAttributeNs, xmlwriter_write_attribute_ns,arginfo_xmlwriter_method_write_attribute_ns, 0) - PHP_ME_MAPPING(startElement, xmlwriter_start_element, arginfo_xmlwriter_method_start_element, 0) - PHP_ME_MAPPING(endElement, xmlwriter_end_element, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(fullEndElement, xmlwriter_full_end_element, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(startElementNs, xmlwriter_start_element_ns, arginfo_xmlwriter_method_start_element_ns, 0) - PHP_ME_MAPPING(writeElement, xmlwriter_write_element, arginfo_xmlwriter_method_write_element, 0) - PHP_ME_MAPPING(writeElementNs, xmlwriter_write_element_ns, arginfo_xmlwriter_method_write_element_ns, 0) - PHP_ME_MAPPING(startPi, xmlwriter_start_pi, arginfo_xmlwriter_method_start_pi, 0) - PHP_ME_MAPPING(endPi, xmlwriter_end_pi, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writePi, xmlwriter_write_pi, arginfo_xmlwriter_method_write_pi, 0) - PHP_ME_MAPPING(startCdata, xmlwriter_start_cdata, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(endCdata, xmlwriter_end_cdata, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeCdata, xmlwriter_write_cdata, arginfo_xmlwriter_method_write_cdata, 0) - PHP_ME_MAPPING(text, xmlwriter_text, arginfo_xmlwriter_method_text, 0) - PHP_ME_MAPPING(writeRaw, xmlwriter_write_raw, arginfo_xmlwriter_method_write_raw, 0) - PHP_ME_MAPPING(startDocument, xmlwriter_start_document, arginfo_xmlwriter_method_start_document, 0) - PHP_ME_MAPPING(endDocument, xmlwriter_end_document, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeComment, xmlwriter_write_comment, arginfo_xmlwriter_method_write_comment, 0) - PHP_ME_MAPPING(startDtd, xmlwriter_start_dtd, arginfo_xmlwriter_method_start_dtd, 0) - PHP_ME_MAPPING(endDtd, xmlwriter_end_dtd, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeDtd, xmlwriter_write_dtd, arginfo_xmlwriter_method_write_dtd, 0) - PHP_ME_MAPPING(startDtdElement, xmlwriter_start_dtd_element,arginfo_xmlwriter_method_start_dtd_element, 0) - PHP_ME_MAPPING(endDtdElement, xmlwriter_end_dtd_element, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeDtdElement, xmlwriter_write_dtd_element, arginfo_xmlwriter_method_write_dtd_element, 0) - PHP_ME_MAPPING(startDtdAttlist, xmlwriter_start_dtd_attlist, arginfo_xmlwriter_method_start_dtd_attlist, 0) - PHP_ME_MAPPING(endDtdAttlist, xmlwriter_end_dtd_attlist, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeDtdAttlist, xmlwriter_write_dtd_attlist, arginfo_xmlwriter_method_write_dtd_attlist, 0) - PHP_ME_MAPPING(startDtdEntity, xmlwriter_start_dtd_entity, arginfo_xmlwriter_method_start_dtd_entity, 0) - PHP_ME_MAPPING(endDtdEntity, xmlwriter_end_dtd_entity, arginfo_xmlwriter_void, 0) - PHP_ME_MAPPING(writeDtdEntity, xmlwriter_write_dtd_entity, arginfo_xmlwriter_method_write_dtd_entity, 0) - PHP_ME_MAPPING(outputMemory, xmlwriter_output_memory, arginfo_xmlwriter_method_output_memory, 0) - PHP_ME_MAPPING(flush, xmlwriter_flush, arginfo_xmlwriter_method_flush, 0) + PHP_ME_MAPPING(openUri, xmlwriter_open_uri, arginfo_class_XMLWriter_openUri, 0) + PHP_ME_MAPPING(openMemory, xmlwriter_open_memory, arginfo_class_XMLWriter_openMemory, 0) + PHP_ME_MAPPING(setIndent, xmlwriter_set_indent, arginfo_class_XMLWriter_setIndent, 0) + PHP_ME_MAPPING(setIndentString, xmlwriter_set_indent_string, arginfo_class_XMLWriter_setIdentString, 0) + PHP_ME_MAPPING(startComment, xmlwriter_start_comment, arginfo_class_XMLWriter_startComment, 0) + PHP_ME_MAPPING(endComment, xmlwriter_end_comment, arginfo_class_XMLWriter_endComment, 0) + PHP_ME_MAPPING(startAttribute, xmlwriter_start_attribute, arginfo_class_XMLWriter_startAttribute, 0) + PHP_ME_MAPPING(endAttribute, xmlwriter_end_attribute, arginfo_class_XMLWriter_endAttribute, 0) + PHP_ME_MAPPING(writeAttribute, xmlwriter_write_attribute, arginfo_class_XMLWriter_writeAttribute, 0) + PHP_ME_MAPPING(startAttributeNs, xmlwriter_start_attribute_ns,arginfo_class_XMLWriter_startAttributeNs, 0) + PHP_ME_MAPPING(writeAttributeNs, xmlwriter_write_attribute_ns,arginfo_class_XMLWriter_writeAttributeNs, 0) + PHP_ME_MAPPING(startElement, xmlwriter_start_element, arginfo_class_XMLWriter_startElement, 0) + PHP_ME_MAPPING(endElement, xmlwriter_end_element, arginfo_class_XMLWriter_endElement, 0) + PHP_ME_MAPPING(fullEndElement, xmlwriter_full_end_element, arginfo_class_XMLWriter_fullEndElement, 0) + PHP_ME_MAPPING(startElementNs, xmlwriter_start_element_ns, arginfo_class_XMLWriter_startElementNs, 0) + PHP_ME_MAPPING(writeElement, xmlwriter_write_element, arginfo_class_XMLWriter_writeElement, 0) + PHP_ME_MAPPING(writeElementNs, xmlwriter_write_element_ns, arginfo_class_XMLWriter_writeElementNs, 0) + PHP_ME_MAPPING(startPi, xmlwriter_start_pi, arginfo_class_XMLWriter_startPi, 0) + PHP_ME_MAPPING(endPi, xmlwriter_end_pi, arginfo_class_XMLWriter_endPi, 0) + PHP_ME_MAPPING(writePi, xmlwriter_write_pi, arginfo_class_XMLWriter_writePi, 0) + PHP_ME_MAPPING(startCdata, xmlwriter_start_cdata, arginfo_class_XMLWriter_startCdata, 0) + PHP_ME_MAPPING(endCdata, xmlwriter_end_cdata, arginfo_class_XMLWriter_endCdata, 0) + PHP_ME_MAPPING(writeCdata, xmlwriter_write_cdata, arginfo_class_XMLWriter_writeCdata, 0) + PHP_ME_MAPPING(text, xmlwriter_text, arginfo_class_XMLWriter_text, 0) + PHP_ME_MAPPING(writeRaw, xmlwriter_write_raw, arginfo_class_XMLWriter_writeRaw, 0) + PHP_ME_MAPPING(startDocument, xmlwriter_start_document, arginfo_class_XMLWriter_startDocument, 0) + PHP_ME_MAPPING(endDocument, xmlwriter_end_document, arginfo_class_XMLWriter_endDocument, 0) + PHP_ME_MAPPING(writeComment, xmlwriter_write_comment, arginfo_class_XMLWriter_writeComment, 0) + PHP_ME_MAPPING(startDtd, xmlwriter_start_dtd, arginfo_class_XMLWriter_startDtd, 0) + PHP_ME_MAPPING(endDtd, xmlwriter_end_dtd, arginfo_class_XMLWriter_endDtd, 0) + PHP_ME_MAPPING(writeDtd, xmlwriter_write_dtd, arginfo_class_XMLWriter_writeDtd, 0) + PHP_ME_MAPPING(startDtdElement, xmlwriter_start_dtd_element,arginfo_class_XMLWriter_startDtdElement, 0) + PHP_ME_MAPPING(endDtdElement, xmlwriter_end_dtd_element, arginfo_class_XMLWriter_endDtdElement, 0) + PHP_ME_MAPPING(writeDtdElement, xmlwriter_write_dtd_element, arginfo_class_XMLWriter_writeDtdElement, 0) + PHP_ME_MAPPING(startDtdAttlist, xmlwriter_start_dtd_attlist, arginfo_class_XMLWriter_startDtdAttlist, 0) + PHP_ME_MAPPING(endDtdAttlist, xmlwriter_end_dtd_attlist, arginfo_class_XMLWriter_endDtdAttlist, 0) + PHP_ME_MAPPING(writeDtdAttlist, xmlwriter_write_dtd_attlist, arginfo_class_XMLWriter_writeDtdAttlist, 0) + PHP_ME_MAPPING(startDtdEntity, xmlwriter_start_dtd_entity, arginfo_class_XMLWriter_startDtdEntity, 0) + PHP_ME_MAPPING(endDtdEntity, xmlwriter_end_dtd_entity, arginfo_class_XMLWriter_endDtdEntity, 0) + PHP_ME_MAPPING(writeDtdEntity, xmlwriter_write_dtd_entity, arginfo_class_XMLWriter_writeDtdEntity, 0) + PHP_ME_MAPPING(outputMemory, xmlwriter_output_memory, arginfo_class_XMLWriter_outputMemory, 0) + PHP_ME_MAPPING(flush, xmlwriter_flush, arginfo_class_XMLWriter_flush, 0) PHP_FE_END }; /* }}} */ @@ -550,8 +231,6 @@ static const zend_function_entry xmlwriter_class_functions[] = { static PHP_MINIT_FUNCTION(xmlwriter); static PHP_MSHUTDOWN_FUNCTION(xmlwriter); static PHP_MINFO_FUNCTION(xmlwriter); - -static int le_xmlwriter; /* }}} */ /* _xmlwriter_get_valid_file_path should be made a @@ -654,47 +333,23 @@ static void xmlwriter_objects_clone(void *object, void **object_clone) } }}} */ -/* {{{ xmlwriter_dtor */ -static void xmlwriter_dtor(zend_resource *rsrc) { - xmlwriter_object *intern; - - intern = (xmlwriter_object *) rsrc->ptr; - xmlwriter_free_resource_ptr(intern); -} -/* }}} */ - static void php_xmlwriter_string_arg(INTERNAL_FUNCTION_PARAMETERS, xmlwriter_read_one_char_t internal_function, char *err_string) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name; size_t name_len; int retval; + zval *self; - zval *self = getThis(); - - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s", &name, &name_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs", &pind, &name, &name_len) == FAILURE) { - return; - } - - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os", &self, xmlwriter_class_entry_ce, &name, &name_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); if (err_string != NULL) { XMLW_NAME_CHK(err_string); } - ptr = intern->ptr; - if (ptr) { retval = internal_function(ptr, (xmlChar *) name); if (retval != -1) { @@ -707,27 +362,14 @@ static void php_xmlwriter_string_arg(INTERNAL_FUNCTION_PARAMETERS, xmlwriter_rea static void php_xmlwriter_end(INTERNAL_FUNCTION_PARAMETERS, xmlwriter_read_int_t internal_function) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; int retval; - zval *self = getThis(); + zval *self; - if (self) { - XMLWRITER_FROM_OBJECT(intern, self); - if (zend_parse_parameters_none() == FAILURE) { - return; - } - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "r", &pind) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "O", &self, xmlwriter_class_entry_ce) == FAILURE) { + return; } - - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = internal_function(ptr); @@ -739,34 +381,20 @@ static void php_xmlwriter_end(INTERNAL_FUNCTION_PARAMETERS, xmlwriter_read_int_t RETURN_FALSE; } -/* {{{ proto bool xmlwriter_set_indent(resource xmlwriter, bool indent) +/* {{{ proto bool xmlwriter_set_indent(XMLWriter xmlwriter, bool indent) Toggle indentation on/off - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_set_indent) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; int retval; zend_bool indent; + zval *self; - zval *self = getThis(); - - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "b", &indent) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rb", &pind, &indent) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Ob", &self, xmlwriter_class_entry_ce, &indent) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); - - ptr = intern->ptr; if (ptr) { retval = xmlTextWriterSetIndent(ptr, indent); if (retval == 0) { @@ -778,7 +406,7 @@ static PHP_FUNCTION(xmlwriter_set_indent) } /* }}} */ -/* {{{ proto bool xmlwriter_set_indent_string(resource xmlwriter, string indentString) +/* {{{ proto bool xmlwriter_set_indent_string(XMLWriter xmlwriter, string indentString) Set string used for indenting - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_set_indent_string) { @@ -786,7 +414,7 @@ static PHP_FUNCTION(xmlwriter_set_indent_string) } /* }}} */ -/* {{{ proto bool xmlwriter_start_attribute(resource xmlwriter, string name) +/* {{{ proto bool xmlwriter_start_attribute(XMLWriter xmlwriter, string name) Create start attribute - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_attribute) { @@ -794,7 +422,7 @@ static PHP_FUNCTION(xmlwriter_start_attribute) } /* }}} */ -/* {{{ proto bool xmlwriter_end_attribute(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_attribute(XMLWriter xmlwriter) End attribute - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_attribute) { @@ -802,38 +430,24 @@ static PHP_FUNCTION(xmlwriter_end_attribute) } /* }}} */ -/* {{{ proto bool xmlwriter_start_attribute_ns(resource xmlwriter, string prefix, string name, string uri) +/* {{{ proto bool xmlwriter_start_attribute_ns(XMLWriter xmlwriter, string prefix, string name, string uri) Create start namespaced attribute - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_attribute_ns) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *prefix, *uri; size_t name_len, prefix_len, uri_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "sss!", - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rsss!", &pind, - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Osss!", &self, xmlwriter_class_entry_ce, + &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Attribute Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterStartAttributeNS(ptr, (xmlChar *)prefix, (xmlChar *)name, (xmlChar *)uri); if (retval != -1) { @@ -845,38 +459,24 @@ static PHP_FUNCTION(xmlwriter_start_attribute_ns) } /* }}} */ -/* {{{ proto bool xmlwriter_write_attribute(resource xmlwriter, string name, string content) +/* {{{ proto bool xmlwriter_write_attribute(XMLWriter xmlwriter, string name, string content) Write full attribute - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_attribute) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content; size_t name_len, content_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ss", - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rss", &pind, - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Oss", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Attribute Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWriteAttribute(ptr, (xmlChar *)name, (xmlChar *)content); if (retval != -1) { @@ -888,39 +488,24 @@ static PHP_FUNCTION(xmlwriter_write_attribute) } /* }}} */ -/* {{{ proto bool xmlwriter_write_attribute_ns(resource xmlwriter, string prefix, string name, string uri, string content) +/* {{{ proto bool xmlwriter_write_attribute_ns(XMLWriter xmlwriter, string prefix, string name, string uri, string content) Write full namespaced attribute - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_attribute_ns) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *prefix, *uri, *content; size_t name_len, prefix_len, uri_len, content_len; int retval; + zval *self; - zval *self = getThis(); - - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "sss!s", - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rsss!s", &pind, - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Osss!s", &self, xmlwriter_class_entry_ce, + &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Attribute Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWriteAttributeNS(ptr, (xmlChar *)prefix, (xmlChar *)name, (xmlChar *)uri, (xmlChar *)content); if (retval != -1) { @@ -932,7 +517,7 @@ static PHP_FUNCTION(xmlwriter_write_attribute_ns) } /* }}} */ -/* {{{ proto bool xmlwriter_start_element(resource xmlwriter, string name) +/* {{{ proto bool xmlwriter_start_element(XMLWriter xmlwriter, string name) Create start element tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_element) { @@ -940,38 +525,24 @@ static PHP_FUNCTION(xmlwriter_start_element) } /* }}} */ -/* {{{ proto bool xmlwriter_start_element_ns(resource xmlwriter, string prefix, string name, string uri) +/* {{{ proto bool xmlwriter_start_element_ns(XMLWriter xmlwriter, string prefix, string name, string uri) Create start namespaced element tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_element_ns) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *prefix, *uri; size_t name_len, prefix_len, uri_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s!ss!", - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs!ss!", &pind, - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os!ss!", &self, xmlwriter_class_entry_ce, + &prefix, &prefix_len, &name, &name_len, &uri, &uri_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterStartElementNS(ptr, (xmlChar *)prefix, (xmlChar *)name, (xmlChar *)uri); if (retval != -1) { @@ -984,7 +555,7 @@ static PHP_FUNCTION(xmlwriter_start_element_ns) } /* }}} */ -/* {{{ proto bool xmlwriter_end_element(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_element(XMLWriter xmlwriter) End current element - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_element) { @@ -992,7 +563,7 @@ static PHP_FUNCTION(xmlwriter_end_element) } /* }}} */ -/* {{{ proto bool xmlwriter_full_end_element(resource xmlwriter) +/* {{{ proto bool xmlwriter_full_end_element(XMLWriter xmlwriter) End current element - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_full_end_element) { @@ -1000,38 +571,24 @@ static PHP_FUNCTION(xmlwriter_full_end_element) } /* }}} */ -/* {{{ proto bool xmlwriter_write_element(resource xmlwriter, string name[, string content]) +/* {{{ proto bool xmlwriter_write_element(XMLWriter xmlwriter, string name[, string content]) Write full element tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_element) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content = NULL; size_t name_len, content_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s|s!", - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs|s!", &pind, - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os|s!", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { if (!content) { retval = xmlTextWriterStartElement(ptr, (xmlChar *)name); @@ -1054,38 +611,24 @@ static PHP_FUNCTION(xmlwriter_write_element) } /* }}} */ -/* {{{ proto bool xmlwriter_write_element_ns(resource xmlwriter, string prefix, string name, string uri[, string content]) +/* {{{ proto bool xmlwriter_write_element_ns(XMLWriter xmlwriter, string prefix, string name, string uri[, string content]) Write full namesapced element tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_element_ns) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *prefix, *uri, *content = NULL; size_t name_len, prefix_len, uri_len, content_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s!ss!|s!", - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs!ss!|s!", &pind, - &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os!ss!|s!", &self, xmlwriter_class_entry_ce, + &prefix, &prefix_len, &name, &name_len, &uri, &uri_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { if (!content) { retval = xmlTextWriterStartElementNS(ptr,(xmlChar *)prefix, (xmlChar *)name, (xmlChar *)uri); @@ -1108,7 +651,7 @@ static PHP_FUNCTION(xmlwriter_write_element_ns) } /* }}} */ -/* {{{ proto bool xmlwriter_start_pi(resource xmlwriter, string target) +/* {{{ proto bool xmlwriter_start_pi(XMLWriter xmlwriter, string target) Create start PI tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_pi) { @@ -1116,7 +659,7 @@ static PHP_FUNCTION(xmlwriter_start_pi) } /* }}} */ -/* {{{ proto bool xmlwriter_end_pi(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_pi(XMLWriter xmlwriter) End current PI - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_pi) { @@ -1124,39 +667,24 @@ static PHP_FUNCTION(xmlwriter_end_pi) } /* }}} */ -/* {{{ proto bool xmlwriter_write_pi(resource xmlwriter, string target, string content) +/* {{{ proto bool xmlwriter_write_pi(XMLWriter xmlwriter, string target, string content) Write full PI tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_pi) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content; size_t name_len, content_len; int retval; + zval *self; - zval *self = getThis(); - - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ss", - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rss", &pind, - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Oss", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid PI Target"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWritePI(ptr, (xmlChar *)name, (xmlChar *)content); if (retval != -1) { @@ -1168,31 +696,18 @@ static PHP_FUNCTION(xmlwriter_write_pi) } /* }}} */ -/* {{{ proto bool xmlwriter_start_cdata(resource xmlwriter) +/* {{{ proto bool xmlwriter_start_cdata(XMLWriter xmlwriter) Create start CDATA tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_cdata) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters_none() == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "r", &pind) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "O", &self, xmlwriter_class_entry_ce) == FAILURE) { + return; } - - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = xmlTextWriterStartCDATA(ptr); @@ -1205,7 +720,7 @@ static PHP_FUNCTION(xmlwriter_start_cdata) } /* }}} */ -/* {{{ proto bool xmlwriter_end_cdata(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_cdata(XMLWriter xmlwriter) End current CDATA - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_cdata) { @@ -1213,7 +728,7 @@ static PHP_FUNCTION(xmlwriter_end_cdata) } /* }}} */ -/* {{{ proto bool xmlwriter_write_cdata(resource xmlwriter, string content) +/* {{{ proto bool xmlwriter_write_cdata(XMLWriter xmlwriter, string content) Write full CDATA tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_cdata) { @@ -1221,7 +736,7 @@ static PHP_FUNCTION(xmlwriter_write_cdata) } /* }}} */ -/* {{{ proto bool xmlwriter_write_raw(resource xmlwriter, string content) +/* {{{ proto bool xmlwriter_write_raw(XMLWriter xmlwriter, string content) Write text - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_raw) { @@ -1229,7 +744,7 @@ static PHP_FUNCTION(xmlwriter_write_raw) } /* }}} */ -/* {{{ proto bool xmlwriter_text(resource xmlwriter, string content) +/* {{{ proto bool xmlwriter_text(XMLWriter xmlwriter, string content) Write text - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_text) { @@ -1237,31 +752,18 @@ static PHP_FUNCTION(xmlwriter_text) } /* }}} */ -/* {{{ proto bool xmlwriter_start_comment(resource xmlwriter) +/* {{{ proto bool xmlwriter_start_comment(XMLWriter xmlwriter) Create start comment - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_comment) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters_none() == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "r", &pind) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "O", &self, xmlwriter_class_entry_ce) == FAILURE) { + return; } - - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = xmlTextWriterStartComment(ptr); @@ -1274,7 +776,7 @@ static PHP_FUNCTION(xmlwriter_start_comment) } /* }}} */ -/* {{{ proto bool xmlwriter_end_comment(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_comment(XMLWriter xmlwriter) Create end comment - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_comment) { @@ -1282,7 +784,7 @@ static PHP_FUNCTION(xmlwriter_end_comment) } /* }}} */ -/* {{{ proto bool xmlwriter_write_comment(resource xmlwriter, string content) +/* {{{ proto bool xmlwriter_write_comment(XMLWriter xmlwriter, string content) Write full comment tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_comment) { @@ -1290,34 +792,20 @@ static PHP_FUNCTION(xmlwriter_write_comment) } /* }}} */ -/* {{{ proto bool xmlwriter_start_document(resource xmlwriter, string version, string encoding, string standalone) +/* {{{ proto bool xmlwriter_start_document(XMLWriter xmlwriter, string version, string encoding, string standalone) Create document tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_document) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *version = NULL, *enc = NULL, *alone = NULL; size_t version_len, enc_len, alone_len; int retval; + zval *self; - zval *self = getThis(); - - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "|s!s!s!", &version, &version_len, &enc, &enc_len, &alone, &alone_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "r|s!s!s!", &pind, &version, &version_len, &enc, &enc_len, &alone, &alone_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "O|s!s!s!", &self, xmlwriter_class_entry_ce, &version, &version_len, &enc, &enc_len, &alone, &alone_len) == FAILURE) { + return; } - - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = xmlTextWriterStartDocument(ptr, version, enc, alone); @@ -1330,7 +818,7 @@ static PHP_FUNCTION(xmlwriter_start_document) } /* }}} */ -/* {{{ proto bool xmlwriter_end_document(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_document(XMLWriter xmlwriter) End current document - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_document) { @@ -1338,33 +826,20 @@ static PHP_FUNCTION(xmlwriter_end_document) } /* }}} */ -/* {{{ proto bool xmlwriter_start_dtd(resource xmlwriter, string name, string pubid, string sysid) +/* {{{ proto bool xmlwriter_start_dtd(XMLWriter xmlwriter, string name, string pubid, string sysid) Create start DTD tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_dtd) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *pubid = NULL, *sysid = NULL; size_t name_len, pubid_len, sysid_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s|s!s!", &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len) == FAILURE) { - return; - } - - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs|s!s!", &pind, &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os|s!s!", &self, xmlwriter_class_entry_ce, &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len) == FAILURE) { + return; } - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = xmlTextWriterStartDTD(ptr, (xmlChar *)name, (xmlChar *)pubid, (xmlChar *)sysid); @@ -1377,7 +852,7 @@ static PHP_FUNCTION(xmlwriter_start_dtd) } /* }}} */ -/* {{{ proto bool xmlwriter_end_dtd(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_dtd(XMLWriter xmlwriter) End current DTD - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_dtd) { @@ -1385,35 +860,20 @@ static PHP_FUNCTION(xmlwriter_end_dtd) } /* }}} */ -/* {{{ proto bool xmlwriter_write_dtd(resource xmlwriter, string name, string pubid, string sysid, string subset) +/* {{{ proto bool xmlwriter_write_dtd(XMLWriter xmlwriter, string name, string pubid, string sysid, string subset) Write full DTD tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_dtd) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *pubid = NULL, *sysid = NULL, *subset = NULL; size_t name_len, pubid_len, sysid_len, subset_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "s|s!s!s!", &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len, &subset, &subset_len) == FAILURE) { - return; - } - - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rs|s!s!s!", &pind, &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len, &subset, &subset_len) == FAILURE) { - return; - } - - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Os|s!s!s!", &self, xmlwriter_class_entry_ce, &name, &name_len, &pubid, &pubid_len, &sysid, &sysid_len, &subset, &subset_len) == FAILURE) { + return; } - - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { retval = xmlTextWriterWriteDTD(ptr, (xmlChar *)name, (xmlChar *)pubid, (xmlChar *)sysid, (xmlChar *)subset); @@ -1426,7 +886,7 @@ static PHP_FUNCTION(xmlwriter_write_dtd) } /* }}} */ -/* {{{ proto bool xmlwriter_start_dtd_element(resource xmlwriter, string name) +/* {{{ proto bool xmlwriter_start_dtd_element(XMLWriter xmlwriter, string name) Create start DTD element - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_dtd_element) { @@ -1434,7 +894,7 @@ static PHP_FUNCTION(xmlwriter_start_dtd_element) } /* }}} */ -/* {{{ proto bool xmlwriter_end_dtd_element(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_dtd_element(XMLWriter xmlwriter) End current DTD element - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_dtd_element) { @@ -1442,37 +902,24 @@ static PHP_FUNCTION(xmlwriter_end_dtd_element) } /* }}} */ -/* {{{ proto bool xmlwriter_write_dtd_element(resource xmlwriter, string name, string content) +/* {{{ proto bool xmlwriter_write_dtd_element(XMLWriter xmlwriter, string name, string content) Write full DTD element tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_dtd_element) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content; size_t name_len, content_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ss", &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rss", &pind, - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Oss", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWriteDTDElement(ptr, (xmlChar *)name, (xmlChar *)content); if (retval != -1) { @@ -1484,7 +931,7 @@ static PHP_FUNCTION(xmlwriter_write_dtd_element) } /* }}} */ -/* {{{ proto bool xmlwriter_start_dtd_attlist(resource xmlwriter, string name) +/* {{{ proto bool xmlwriter_start_dtd_attlist(XMLWriter xmlwriter, string name) Create start DTD AttList - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_dtd_attlist) { @@ -1492,7 +939,7 @@ static PHP_FUNCTION(xmlwriter_start_dtd_attlist) } /* }}} */ -/* {{{ proto bool xmlwriter_end_dtd_attlist(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_dtd_attlist(XMLWriter xmlwriter) End current DTD AttList - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_dtd_attlist) { @@ -1500,38 +947,24 @@ static PHP_FUNCTION(xmlwriter_end_dtd_attlist) } /* }}} */ -/* {{{ proto bool xmlwriter_write_dtd_attlist(resource xmlwriter, string name, string content) +/* {{{ proto bool xmlwriter_write_dtd_attlist(XMLWriter xmlwriter, string name, string content) Write full DTD AttList tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_dtd_attlist) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content; size_t name_len, content_len; int retval; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ss", - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rss", &pind, - &name, &name_len, &content, &content_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Oss", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWriteDTDAttlist(ptr, (xmlChar *)name, (xmlChar *)content); if (retval != -1) { @@ -1543,37 +976,24 @@ static PHP_FUNCTION(xmlwriter_write_dtd_attlist) } /* }}} */ -/* {{{ proto bool xmlwriter_start_dtd_entity(resource xmlwriter, string name, bool isparam) +/* {{{ proto bool xmlwriter_start_dtd_entity(XMLWriter xmlwriter, string name, bool isparam) Create start DTD Entity - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_start_dtd_entity) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name; size_t name_len; int retval; zend_bool isparm; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "sb", &name, &name_len, &isparm) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rsb", &pind, &name, &name_len, &isparm) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Osb", &self, xmlwriter_class_entry_ce, &name, &name_len, &isparm) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Attribute Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterStartDTDEntity(ptr, isparm, (xmlChar *)name); if (retval != -1) { @@ -1585,7 +1005,7 @@ static PHP_FUNCTION(xmlwriter_start_dtd_entity) } /* }}} */ -/* {{{ proto bool xmlwriter_end_dtd_entity(resource xmlwriter) +/* {{{ proto bool xmlwriter_end_dtd_entity(XMLWriter xmlwriter) End current DTD Entity - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_end_dtd_entity) { @@ -1593,12 +1013,10 @@ static PHP_FUNCTION(xmlwriter_end_dtd_entity) } /* }}} */ -/* {{{ proto bool xmlwriter_write_dtd_entity(resource xmlwriter, string name, string content [, bool pe [, string pubid [, string sysid [, string ndataid]]]]) +/* {{{ proto bool xmlwriter_write_dtd_entity(XMLWriter xmlwriter, string name, string content [, bool pe [, string pubid [, string sysid [, string ndataid]]]]) Write full DTD Entity tag - returns FALSE on error */ static PHP_FUNCTION(xmlwriter_write_dtd_entity) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *name, *content; size_t name_len, content_len; @@ -1607,30 +1025,17 @@ static PHP_FUNCTION(xmlwriter_write_dtd_entity) char *pubid = NULL, *sysid = NULL, *ndataid = NULL; zend_bool pe = 0; size_t pubid_len, sysid_len, ndataid_len; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "ss|bsss", - &name, &name_len, &content, &content_len, &pe, &pubid, &pubid_len, - &sysid, &sysid_len, &ndataid, &ndataid_len) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "rss|bsss", &pind, - &name, &name_len, &content, &content_len, &pe, &pubid, &pubid_len, - &sysid, &sysid_len, &ndataid, &ndataid_len) == FAILURE) { - return; - } - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "Oss|bsss", &self, xmlwriter_class_entry_ce, + &name, &name_len, &content, &content_len, &pe, &pubid, &pubid_len, + &sysid, &sysid_len, &ndataid, &ndataid_len) == FAILURE) { + return; } + XMLWRITER_FROM_OBJECT(ptr, self); XMLW_NAME_CHK("Invalid Element Name"); - ptr = intern->ptr; - if (ptr) { retval = xmlTextWriterWriteDTDEntity(ptr, pe, (xmlChar *)name, (xmlChar *)pubid, (xmlChar *)sysid, (xmlChar *)ndataid, (xmlChar *)content); if (retval != -1) { @@ -1642,12 +1047,11 @@ static PHP_FUNCTION(xmlwriter_write_dtd_entity) } /* }}} */ -/* {{{ proto resource xmlwriter_open_uri(string source) +/* {{{ proto XMLWriter xmlwriter_open_uri(string source) Create new xmlwriter using source uri for output */ static PHP_FUNCTION(xmlwriter_open_uri) { char *valid_file = NULL; - xmlwriter_object *intern; xmlTextWriterPtr ptr; char *source; char resolved_path[MAXPATHLEN + 1]; @@ -1681,26 +1085,29 @@ static PHP_FUNCTION(xmlwriter_open_uri) RETURN_FALSE; } - intern = emalloc(sizeof(xmlwriter_object)); - intern->ptr = ptr; - intern->output = NULL; if (self) { - if (ze_obj->xmlwriter_ptr) { - xmlwriter_free_resource_ptr(ze_obj->xmlwriter_ptr); + if (ze_obj->ptr) { + xmlFreeTextWriter(ze_obj->ptr); + } + if (ze_obj->output) { + xmlBufferFree(ze_obj->output); } - ze_obj->xmlwriter_ptr = intern; + ze_obj->ptr = ptr; + ze_obj->output = NULL; RETURN_TRUE; } else { - RETURN_RES(zend_register_resource(intern, le_xmlwriter)); + ze_obj = php_xmlwriter_fetch_object(xmlwriter_object_new(xmlwriter_class_entry_ce)); + ze_obj->ptr = ptr; + ze_obj->output = NULL; + RETURN_OBJ(&ze_obj->std); } } /* }}} */ -/* {{{ proto resource xmlwriter_open_memory() +/* {{{ proto XMLWriter xmlwriter_open_memory() Create new xmlwriter using memory for string output */ static PHP_FUNCTION(xmlwriter_open_memory) { - xmlwriter_object *intern; xmlTextWriterPtr ptr; xmlBufferPtr buffer; zval *self = getThis(); @@ -1728,17 +1135,21 @@ static PHP_FUNCTION(xmlwriter_open_memory) RETURN_FALSE; } - intern = emalloc(sizeof(xmlwriter_object)); - intern->ptr = ptr; - intern->output = buffer; if (self) { - if (ze_obj->xmlwriter_ptr) { - xmlwriter_free_resource_ptr(ze_obj->xmlwriter_ptr); + if (ze_obj->ptr) { + xmlFreeTextWriter(ze_obj->ptr); + } + if (ze_obj->output) { + xmlBufferFree(ze_obj->output); } - ze_obj->xmlwriter_ptr = intern; + ze_obj->ptr = ptr; + ze_obj->output = buffer; RETURN_TRUE; } else { - RETURN_RES(zend_register_resource(intern, le_xmlwriter)); + ze_obj = php_xmlwriter_fetch_object(xmlwriter_object_new(xmlwriter_class_entry_ce)); + ze_obj->ptr = ptr; + ze_obj->output = buffer; + RETURN_OBJ(&ze_obj->std); } } @@ -1746,32 +1157,19 @@ static PHP_FUNCTION(xmlwriter_open_memory) /* {{{ php_xmlwriter_flush */ static void php_xmlwriter_flush(INTERNAL_FUNCTION_PARAMETERS, int force_string) { - zval *pind; - xmlwriter_object *intern; xmlTextWriterPtr ptr; xmlBufferPtr buffer; zend_bool empty = 1; int output_bytes; - zval *self = getThis(); + zval *self; - if (self) { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "|b", &empty) == FAILURE) { - return; - } - XMLWRITER_FROM_OBJECT(intern, self); - } else { - if (zend_parse_parameters(ZEND_NUM_ARGS(), "r|b", &pind, &empty) == FAILURE) { - return; - } - - if ((intern = (xmlwriter_object *)zend_fetch_resource(Z_RES_P(pind), "XMLWriter", le_xmlwriter)) == NULL) { - RETURN_FALSE; - } + if (zend_parse_method_parameters(ZEND_NUM_ARGS(), getThis(), "O|b", &self, xmlwriter_class_entry_ce, &empty) == FAILURE) { + return; } - ptr = intern->ptr; + XMLWRITER_FROM_OBJECT(ptr, self); if (ptr) { - buffer = intern->output; + buffer = Z_XMLWRITER_P(self)->output; if (force_string == 1 && buffer == NULL) { RETURN_EMPTY_STRING(); } @@ -1791,7 +1189,7 @@ static void php_xmlwriter_flush(INTERNAL_FUNCTION_PARAMETERS, int force_string) } /* }}} */ -/* {{{ proto string xmlwriter_output_memory(resource xmlwriter [,bool flush]) +/* {{{ proto string xmlwriter_output_memory(XMLWriter xmlwriter [,bool flush]) Output current buffer as string */ static PHP_FUNCTION(xmlwriter_output_memory) { @@ -1799,7 +1197,7 @@ static PHP_FUNCTION(xmlwriter_output_memory) } /* }}} */ -/* {{{ proto mixed xmlwriter_flush(resource xmlwriter [,bool empty]) +/* {{{ proto mixed xmlwriter_flush(XMLWriter xmlwriter [,bool empty]) Output current buffer */ static PHP_FUNCTION(xmlwriter_flush) { @@ -1812,7 +1210,6 @@ static PHP_FUNCTION(xmlwriter_flush) static PHP_MINIT_FUNCTION(xmlwriter) { zend_class_entry ce; - le_xmlwriter = zend_register_list_destructors_ex(xmlwriter_dtor, NULL, "xmlwriter", module_number); memcpy(&xmlwriter_object_handlers, &std_object_handlers, sizeof(zend_object_handlers)); xmlwriter_object_handlers.offset = XtOffsetOf(ze_xmlwriter_object, std); |
