diff options
author | SVN Migration <svn@php.net> | 2003-08-03 13:58:21 +0000 |
---|---|---|
committer | SVN Migration <svn@php.net> | 2003-08-03 13:58:21 +0000 |
commit | 1002acbac0e99cad57b4ed3b58f1bae0b51980f5 (patch) | |
tree | 1cae9d4f16bd5e88c6f5fb708c4b8872d49e9ca6 /ext/tidy | |
parent | f05452fbcdceac2d1d8176d2c1b69c741af54ae9 (diff) | |
download | php-git-BEFORE_ARG_INFO.tar.gz |
This commit was manufactured by cvs2svn to create tag 'BEFORE_ARG_INFO'.BEFORE_ARG_INFO
Diffstat (limited to 'ext/tidy')
-rw-r--r-- | ext/tidy/CREDITS | 2 | ||||
-rw-r--r-- | ext/tidy/README_TIDY | 154 | ||||
-rw-r--r-- | ext/tidy/TODO | 4 | ||||
-rw-r--r-- | ext/tidy/config.m4 | 35 | ||||
-rw-r--r-- | ext/tidy/examples/cleanhtml.php | 40 | ||||
-rw-r--r-- | ext/tidy/examples/dumpit.php | 94 | ||||
-rw-r--r-- | ext/tidy/examples/urlgrab.php | 63 | ||||
-rw-r--r-- | ext/tidy/package.xml | 55 | ||||
-rw-r--r-- | ext/tidy/php_tidy.h | 193 | ||||
-rw-r--r-- | ext/tidy/tests/001.phpt | 24 | ||||
-rw-r--r-- | ext/tidy/tests/002.phpt | 25 | ||||
-rw-r--r-- | ext/tidy/tests/003.phpt | 27 | ||||
-rw-r--r-- | ext/tidy/tests/004.phpt | 24 | ||||
-rw-r--r-- | ext/tidy/tests/005.html | 1 | ||||
-rw-r--r-- | ext/tidy/tests/005.phpt | 25 | ||||
-rw-r--r-- | ext/tidy/tests/006.phpt | 23 | ||||
-rw-r--r-- | ext/tidy/tests/007.phpt | 37 | ||||
-rw-r--r-- | ext/tidy/tidy.c | 1920 |
18 files changed, 0 insertions, 2746 deletions
diff --git a/ext/tidy/CREDITS b/ext/tidy/CREDITS deleted file mode 100644 index 5d590d14f6..0000000000 --- a/ext/tidy/CREDITS +++ /dev/null @@ -1,2 +0,0 @@ -Tidy -John Coggeshall
\ No newline at end of file diff --git a/ext/tidy/README_TIDY b/ext/tidy/README_TIDY deleted file mode 100644 index 9b15dcd102..0000000000 --- a/ext/tidy/README_TIDY +++ /dev/null @@ -1,154 +0,0 @@ - -README FOR ext/tidy by John Coggeshall <john@php.net> - -Tidy Version: 0.5b - -Tidy is an extension based on Libtidy (http://tidy.sf.net/) and allows a PHP developer -to clean, repair, and traverse HTML, XHTML, and XML documents -- including ones with -embedded scripting languages such as PHP or ASP within them using OO constructs. - -The Tidy extension has two separate APIs, one for general parsing, cleaning, and -repairing and another for document traversal. The general API is provided below: - - tidy_create() Initialize and return a tidy document resource - tidy_parse_file($tidy, $file) Parse the document stored in $file - tidy_parse_string($tidy, $str) Parse the string stored in $str - - tidy_clean_repair($tidy) Clean and repair the document - tidy_diagnose($tidy) Diagnose a parsed document - - tidy_setopt($tidy, $opt, $val) Set a configuration option $opt to $val - tidy_getopt($tidy, $opt) Retrieve a configuration option - - ** note: $opt is a string representing the option. Right now the only - source of these options is the LibTidy source.. eventually I'll document - them offically -- see the src/config.c file in the tidy source ** - - tidy_get_output($tidy) Return the cleaned tidy HTML as a string - tidy_get_error_buffer($tidy) Return a log of the errors and warnings - returned by tidy - - tidy_get_release() Return the Libtidy release date - tidy_get_status($tidy) Return the status of the document - tidy_get_html_ver($tidy) Return the major HTML version detected for - the document; - - tidy_is_xhtml($tidy) Determines if the document is XHTML - tidy_is_xml($tidy) Determines if the document is a generic XML - - tidy_error_count($tidy) Returns the number of errors in the document - tidy_warning_count($tidy) Returns the number of warnings in the document - tidy_access_count($tidy) Returns the number of accessibility-related - warnings in the document. - tidy_config_count($tidy) Returns the number of configuration errors found - - tidy_load_config($tidy, $file) Loads the specified configuration file - tidY_load_config_enc($tidy, - $file, - $enc) Loads the specified config file using the specified - character encoding - tidy_set_encoding($tidy, $enc) Sets the current character encoding for the document - tidy_save_config($tidy, $file) Saves the current config to $file - - -Beyond these general-purpose API functions, Tidy also supports the following -functions which are used to retrieve an object for document traversal: - - tidy_get_root($tidy) Returns an object starting at the root of the - document - tidy_get_head($tidy) Returns an object starting at the <HEAD> tag - tidy_get_html($tidy) Returns an object starting at the <HTML> tag - tidy_get_body($tidy) Returns an object starting at the <BODY> tag - -All Navigation of the specified document is done via the PHP5 object constructs. -There are two types of objects which Tidy can create. The first is TidyNode, which -represents HTML Tags, Text, and more (see the TidyNode_Type Constants). The second -is TidyAttr, which represents an attribute within an HTML tag (TidyNode). The -functionality of these objects is represented by the following schema: - -class TidyNode { - - public $name; // name of node (i.e. HEAD) - public $value; // value of node (everything between tags) - public $type; // type of node (text, php, asp, etc.) - public $id; // id of node (i.e. TIDY_TAG_HEAD) - - public $line; // line # of node in source - public $column; // column # of node in source - - public $html_ver; // HTML version (0,1,2,3,4) - - public $attribs; // an array of attributes (see TidyAttr) - public $children; // an array of child nodes - - function has_siblings(); // any sibling nodes? - function has_children(); // any child nodes? - function has_parent(); // have a parent? - - function is_comment(); // is node a comment? - function is_xhtml(); // is document XHTML? - function is_xml(); // is document generic XML (not HTML/XHTML) - function is_text(); // is node text? - function is_html(); // is node an HTML tag? - - function is_jste(); // is jste block? - function is_asp(); // is Microsoft ASP block? - function is_php(); // is PHP block? - - function next(); // returns next node - function prev(); // returns prev node - function parent(); // returns parent node - function child(); // returns first child node - - /* Searches for a particular attribute in the current node based - on node ID. If found returns a TidyAttr object for it */ - function get_attr_type($attr_id); - - /* - - NOT YET IMPLEMENTED - - Recursively traverses the tree from the current node and returns - an array of attributes matching the node ID/attr ID pair - - Useful for pulling out things like links: - foreach($body->fetch_attrs(TIDY_TAG_A, TIDY_ATTR_HREF) as $link) { - echo "Link : {$link->value}\n"; - } - */ - - function fetch_attrs($node_id, $attr_id); - - /* - - NOT YET IMPLEMENTED - - Recursively traverses the tree from the current node and returns - an array of nodes matching the node ID - - Useful for pulling out tables, etc (echos the HTML for every - <TABLE> block) - - foreach($body->fetch_nodes(TIDY_TAG_TABLE) as $table) { - - echo $table->value; - - } - */ - function fetch_nodes($node_id) -} - -class TidyAttr { - - public $name; // attribute name i.e. HREF - public $value; // attribute value - public $id; // attribute id i.e. TIDY_ATTR_HREF - - function next(); // returns next attribute in tag - function tag(); // returns the tag node associated with attribute -} - -Examples of using these objects to navigate the tree can be found in the examples/ -directory (I suggest looking at urlgrab.php and dumpit.php) - -E-mail thoughts, suggestions, patches, etc. to <john@php.net>
\ No newline at end of file diff --git a/ext/tidy/TODO b/ext/tidy/TODO deleted file mode 100644 index 19151b14d7..0000000000 --- a/ext/tidy/TODO +++ /dev/null @@ -1,4 +0,0 @@ -TODO - - - Implement fetch_attr(), fetch_node() methods - - Fix any memleaks (some may be purely ZE2 related)
\ No newline at end of file diff --git a/ext/tidy/config.m4 b/ext/tidy/config.m4 deleted file mode 100644 index 069b3ee6b4..0000000000 --- a/ext/tidy/config.m4 +++ /dev/null @@ -1,35 +0,0 @@ -dnl -dnl $Id$ -dnl - -PHP_ARG_WITH(tidy,for TIDY support, -[ --with-tidy[=DIR] Include TIDY support]) - -if test "$PHP_TIDY" != "no"; then - PHP_NEW_EXTENSION(tidy, tidy.c, $ext_shared) - if test "$PHP_TIDY" != "yes"; then - TIDY_SEARCH_DIRS=$PHP_TIDY - else - TIDY_SEARCH_DIRS="/usr/local /usr" - fi - for i in $TIDY_SEARCH_DIRS; do - if test -f $i/include/tidy/tidy.h; then - TIDY_DIR=$i - TIDY_INCDIR=$i/include/tidy - elif test -f $i/include/tidy.h; then - TIDY_DIR=$i - TIDY_INCDIR=$i/include - fi - done - - if test -z "$TIDY_DIR"; then - AC_MSG_ERROR(Cannot find libtidy) - fi - - TIDY_LIBDIR=$TIDY_DIR/lib - - AC_DEFINE(HAVE_TIDY,1,[ ]) - PHP_SUBST(TIDY_SHARED_LIBADD) - PHP_ADD_LIBRARY_WITH_PATH(tidy, $TIDY_LIBDIR, TIDY_SHARED_LIBADD) - PHP_ADD_INCLUDE($TIDY_INCDIR) -fi diff --git a/ext/tidy/examples/cleanhtml.php b/ext/tidy/examples/cleanhtml.php deleted file mode 100644 index c949a0cfc2..0000000000 --- a/ext/tidy/examples/cleanhtml.php +++ /dev/null @@ -1,40 +0,0 @@ -<?php - - /* - * cleanhtml.php - * - * A simple script to clean and repair HTML,XHTML,PHP,ASP,etc. documents - * if no file is provided, it reads from standard input. - * - * By: John Coggeshall <john@php.net> - * - * Usage: php cleanhtml.php [filename] - * - */ - - $tidy = tidy_create(); - - if(!isset($_SERVER['argv'][1])) { - $data = file_get_contents("php://stdin"); - tidy_parse_string($tidy, $data); - } else { - tidy_parse_file($tidy, $_SERVER['argv'][1]); - } - - tidy_clean_repair($tidy); - - if(tidy_warning_count($tidy) || - tidy_error_count($tidy)) { - - echo "\n\nThe following errors or warnings occured:\n"; - echo tidy_get_error_buffer($tidy); - echo "\n"; - } - - echo tidy_get_output($tidy); - -?> - - - -
\ No newline at end of file diff --git a/ext/tidy/examples/dumpit.php b/ext/tidy/examples/dumpit.php deleted file mode 100644 index 46d307d704..0000000000 --- a/ext/tidy/examples/dumpit.php +++ /dev/null @@ -1,94 +0,0 @@ -<?php - /* - * dumpit.php - * - * a command-line script which dumps the given HTML, PHP, ASP, XHTML, etc. - * file as it is represented in the document model. - * - * By: John Coggeshall <john@php.net> - * - * Usage; php dumpit.php <filename> - */ - - - $tidy = tidy_create(); - tidy_parse_file($tidy, $_SERVER['argv'][1]); - - /* Optionally you can do this here if you want to fix up the document */ - - /* tidy_clean_repair($tidy); */ - - $tree = tidy_get_root($tidy); - dump_tree($tree); - echo "\n"; - - function node_type($type) { - - switch($type) { - - case TIDY_NODETYPE_ROOT: return "Root Node"; - case TIDY_NODETYPE_DOCTYPE: return "DocType Node"; - case TIDY_NODETYPE_COMMENT: return "Comment Node"; - case TIDY_NODETYPE_PROCINS: return "ProcIns Node"; - case TIDY_NODETYPE_TEXT: return "Text Node"; - case TIDY_NODETYPE_START: return "Start Node"; - case TIDY_NODETYPE_END: return "End Node"; - case TIDY_NODETYPE_STARTEND: return "Start/End Node"; - case TIDY_NODETYPE_CDATA: return "CDATA Node"; - case TIDY_NODETYPE_SECTION: return "Section Node"; - case TIDY_NODETYPE_ASP: return "ASP Source Code Node"; - case TIDY_NODETYPE_PHP: return "PHP Source Code Node"; - case TIDY_NODETYPE_JSTE: return "JSTE Source Code"; - case TIDY_NODETYPE_XMLDECL: return "XML Declaration Node"; - default: return "Unknown Node"; - } - } - - function do_leaf($string, $indent) { - for($i = 0; $i < $indent; $i++) { - echo " "; - } - echo $string; - } - - function dump_tree($node, $indent = 0) { - if($node) { - /* Put something there if the node name is empty */ - $nodename = trim(strtoupper($node->name)); - $nodename = (empty($nodename)) ? "[EMPTY]" : $nodename; - - /* Generate the Node, and a pretty name for it */ - do_leaf(" + $nodename (".node_type($node->type).")\n", $indent); - - /* Check to see if this node is a text node. Text nodes are - generated by start/end tags and contain the text in between. - i.e. <B>foo</B> will create a text node with $node->value - equal to 'foo' */ - if($node->type == TIDY_NODETYPE_TEXT) { - do_leaf(" |\n", $indent); - do_leaf(" +---- Value: '{$node->value}'\n", $indent); - } - - /* Any attributes on this node? */ - if(count($node->attribs)) { - do_leaf(" |\n", $indent); - do_leaf(" +---- Attributes\n", $indent); - - /* Cycle through the attributes and display them and their values. */ - foreach($node->attribs as $attrib) { - do_leaf(" +--{$attrib->name}\n", $indent); - do_leaf(" | +-- Value: {$attrib->value}\n", $indent); - } - } - - /* Recurse along the children to generate the remaining nodes */ - if($node->has_children()) { - foreach($node->children as $child) { - dump_tree($child, $indent + 3); - } - } - } - } - - -?>
\ No newline at end of file diff --git a/ext/tidy/examples/urlgrab.php b/ext/tidy/examples/urlgrab.php deleted file mode 100644 index 63a2875a79..0000000000 --- a/ext/tidy/examples/urlgrab.php +++ /dev/null @@ -1,63 +0,0 @@ -<?php - - /* - * urlgrab.php - * - * A simple command-line utility to extract all of the URLS contained - * within <A HREF> tags from a document. - * - * By: John Coggeshall <john@php.net> - * - * Usage: php urlgrab.php <file> - * - */ - - /* Create a Tidy Resource */ - $tidy = tidy_create(); - - /* Parse the document */ - tidy_parse_file($tidy, $_SERVER['argv'][1]); - - /* Fix up the document */ - tidy_clean_repair($tidy); - - /* Get an object representing everything from the <HTML> tag in */ - $html = tidy_get_html($tidy); - - /* Traverse the document tree */ - print_r(get_links($html)); - - function get_links($node) { - $urls = array(); - - /* Check to see if we are on an <A> tag or not */ - if($node->id == TIDY_TAG_A) { - /* If we are, find the HREF attribute */ - $attrib = $node->get_attr_type(TIDY_ATTR_HREF); - if($attrib) { - /* Add the value of the HREF attrib to $urls */ - $urls[] = $attrib->value; - } - - } - - /* Are there any children? */ - if($node->has_children()) { - - /* Traverse down each child recursively */ - foreach($node->children as $child) { - - /* Append the results from recursion to $urls */ - foreach(get_links($child) as $url) { - - $urls[] = $url; - - } - - } - } - - return $urls; - } - -?>
\ No newline at end of file diff --git a/ext/tidy/package.xml b/ext/tidy/package.xml deleted file mode 100644 index e9458c1873..0000000000 --- a/ext/tidy/package.xml +++ /dev/null @@ -1,55 +0,0 @@ -<?xml version="1.0" encoding="ISO-8859-1" ?> -<!DOCTYPE package SYSTEM "../pear/package.dtd"> -<package> - <name>Tidy</name> - <summary>Tidy HTML Repairing and Parsing</summary> - <maintainers> - <maintainer> - <user>john</user> - <name>John Coggeshall</name> - <email>john@php.net</email> - <role>lead</role> - </maintainer> - </maintainers> - <description> -Tidy is a binding for the Tidy HTML clean and repair utility which -allows you to not only clean and otherwise manipluate HTML documents, -but also traverse the document tree using the Zend Engine 2 OO semantics. - - </description> - <license>PHP</license> - <release> - <state>stable</state> - <version>0.5</version> - <date>TBA</date> - <notes> - </notes> - <filelist> - <file role="src" name="config.m4"/> - <file role="src" name="tidy.c"/> - <file role="src" name="php_tidy.h"/> - - <file role="doc" name="CREDITS"/> - <file role="doc" name="README_TIDY"/> - <file role="doc" name="TODO"/> - <file role="doc" name="examples/cleanhtml.php"/> - <file role="doc" name="examples/dumpit.php"/> - <file role="doc" name="examples/urlgrab.php"/> - - <file role="test" name="tests/001.phpt"/> - <file role="test" name="tests/002.phpt"/> - <file role="test" name="tests/003.phpt"/> - <file role="test" name="tests/004.phpt"/> - <file role="test" name="tests/005.phpt"/> - <file role="test" name="tests/005.html"/> - <file role="test" name="tests/006.phpt"/> - <file role="test" name="tests/007.phpt"/> - </filelist> - <deps> - <dep type="php" rel="ge">5.0.0</dep> - </deps> - </release> -</package> -<!-- -vim:et:ts=1:sw=1 ---> diff --git a/ext/tidy/php_tidy.h b/ext/tidy/php_tidy.h deleted file mode 100644 index 42324e4a37..0000000000 --- a/ext/tidy/php_tidy.h +++ /dev/null @@ -1,193 +0,0 @@ -/* - +----------------------------------------------------------------------+ - | PHP Version 4 | - +----------------------------------------------------------------------+ - | Copyright (c) 1997-2003 The PHP Group | - +----------------------------------------------------------------------+ - | This source file is subject to version 3.0 of the PHP license, | - | that is bundled with this package in the file LICENSE, and is | - | available through the world-wide-web at the following url: | - | http://www.php.net/license/3_0.txt. | - | If you did not receive a copy of the PHP license and are unable to | - | obtain it through the world-wide-web, please send a note to | - | license@php.net so we can mail you a copy immediately. | - +----------------------------------------------------------------------+ - | Author: John Coggeshall <john@php.net> | - +----------------------------------------------------------------------+ -*/ - -/* $Id$ */ - -#ifndef PHP_TIDY_H -#define PHP_TIDY_H - -extern zend_module_entry tidy_module_entry; -#define phpext_tidy_ptr &tidy_module_entry - -#ifdef PHP_WIN32 -#define PHP_TIDY_API __declspec(dllexport) -#else -#define PHP_TIDY_API -#endif - -#ifdef ZTS -#include "TSRM.h" -#endif - -#include "tidyenum.h" -#include "tidy.h" -#include "buffio.h" - -#ifdef ZTS -#define TIDY_G(v) TSRMG(tidy_globals_id, zend_tidy_globals *, v) -#else -#define TIDY_G(v) (tidy_globals.v) -#endif - -#ifndef TRUE -#define TRUE 1 -#define FALSE 0 -#endif - -#define TIDY_RV_FALSE(__t) __t->type = IS_BOOL; __t->value.lval = FALSE -#define TIDY_RV_TRUE(__t) __t->type = IS_BOOL; __t->value.lval = TRUE - -#define TIDY_IS_TN_PROP(_p) zend_hash_exists(TIDY_G(tn_prop), #_p, strlen(#_p)) -#define TIDY_IS_TA_PROP(_p) zend_hash_exists(TIDY_G(ta_prop), #_p, strlen(#_p)) - -#define REMOVE_NEWLINE(_z) _z->value.str.val[_z->value.str.len-1] = '\0'; - -#define TIDY_TAG_CONST(tag) REGISTER_LONG_CONSTANT("TIDY_TAG_" #tag, TidyTag_##tag, CONST_CS | CONST_PERSISTENT) -#define TIDY_ATTR_CONST(attr) REGISTER_LONG_CONSTANT("TIDY_ATTR_" #attr, TidyAttr_##attr, CONST_CS | CONST_PERSISTENT) -#define TIDY_NODE_CONST(name, type) REGISTER_LONG_CONSTANT("TIDY_NODETYPE_" #name, TidyNode_##type, CONST_CS | CONST_PERSISTENT) - -#define PHP_IS_TIDYUNDEF 0 -#define PHP_IS_TIDYNODE 1 -#define PHP_IS_TIDYATTR 2 - - -struct _PHPTidyDoc { - - TidyDoc doc; - TidyBuffer *errbuf; - zend_bool parsed; -}; - -typedef struct _PHPTidyDoc PHPTidyDoc; -typedef struct _PHPTidyObj PHPTidyObj; - -struct _PHPTidyObj { - zend_object obj; - TidyNode node; - TidyAttr attr; - PHPTidyDoc *tdoc; - unsigned int type; - zval *obj_parent; - unsigned int refcount; -}; - - -PHP_MINIT_FUNCTION(tidy); -PHP_MSHUTDOWN_FUNCTION(tidy); -PHP_RINIT_FUNCTION(tidy); -PHP_RSHUTDOWN_FUNCTION(tidy); -PHP_MINFO_FUNCTION(tidy); - -PHP_FUNCTION(tidy_create); -PHP_FUNCTION(tidy_setopt); -PHP_FUNCTION(tidy_getopt); -PHP_FUNCTION(tidy_parse_string); -PHP_FUNCTION(tidy_parse_file); -PHP_FUNCTION(tidy_clean_repair); -PHP_FUNCTION(tidy_diagnose); -PHP_FUNCTION(tidy_get_output); -PHP_FUNCTION(tidy_get_error_buffer); -PHP_FUNCTION(tidy_get_release); -PHP_FUNCTION(tidy_get_status); -PHP_FUNCTION(tidy_get_html_ver); -PHP_FUNCTION(tidy_is_xhtml); -PHP_FUNCTION(tidy_is_xml); -PHP_FUNCTION(tidy_error_count); -PHP_FUNCTION(tidy_warning_count); -PHP_FUNCTION(tidy_access_count); -PHP_FUNCTION(tidy_config_count); -PHP_FUNCTION(tidy_load_config); -PHP_FUNCTION(tidy_load_config_enc); -PHP_FUNCTION(tidy_set_encoding); -PHP_FUNCTION(tidy_save_config); - -PHP_FUNCTION(tidy_get_root); -PHP_FUNCTION(tidy_get_html); -PHP_FUNCTION(tidy_get_head); -PHP_FUNCTION(tidy_get_body); - -static void php_tidy_obj_clone(void *, void ** TSRMLS_DC); -static void php_tidy_obj_dtor(void *, zend_object_handle TSRMLS_DC); - -zend_object_value php_tidy_create_obj(zend_class_entry * TSRMLS_DC); -static zend_object_value php_tidy_register_object(PHPTidyObj *intern TSRMLS_DC); - -static zval *_php_tidy_create_obj_zval(unsigned int objtype, - PHPTidyObj *parent, - void *data - TSRMLS_DC); -static void _php_tidy_create_obj(zval *return_value, - unsigned int objtype, - PHPTidyObj *parent, - void *data - TSRMLS_DC); -/* object handlers */ -static zval * tidy_property_read(zval *object, zval *member, zend_bool silent TSRMLS_DC); -static void tidy_property_write(zval *obj, zval *member, zval *value TSRMLS_DC); -static zval ** tidy_property_get_ptr(zval *obj, zval *member TSRMLS_DC); -static int tidy_property_exists(zval *object, zval *member, int check_empty TSRMLS_DC); -static void tidy_property_delete(zval *obj, zval *member TSRMLS_DC); -static HashTable * tidy_get_properties(zval *object TSRMLS_DC); -static union _zend_function * tidy_get_method(zval *obj, char *method, int method_len TSRMLS_DC); -static int tidy_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS); -static union _zend_function * tidy_get_constructor(zval *obj TSRMLS_DC); -static zend_class_entry * tidy_get_class_entry(zval *obj TSRMLS_DC); -static int tidy_get_class_name(zval *obj, char **class_name, zend_uint *name_len, int parent TSRMLS_DC); -static int tidy_objects_compare(zval *obj_one, zval *obj_two TSRMLS_DC); -static void tidy_object_cast(zval *readobj, zval *writeobj, int type, int should_free TSRMLS_DC); -static void tidy_write_dim(zval *object, zval *offset, zval *value TSRMLS_DC); -static void tidy_del_dim(zval *object, zval *offset TSRMLS_DC); -static zval *tidy_read_dim(zval *object, zval *offset TSRMLS_DC); - -zend_bool _php_tidy_attr_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS); -zend_bool _php_tidy_node_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS); -void _php_tidy_init_prop_hashtables(); - -/* resource dtor */ -void dtor_TidyDoc(zend_rsrc_list_entry * TSRMLS_DC); - -/* constant register helpers */ -void _php_tidy_register_nodetypes(INIT_FUNC_ARGS); -void _php_tidy_register_tags(INIT_FUNC_ARGS); -void _php_tidy_register_attributes(INIT_FUNC_ARGS); - -/* Callbacks for hooking Tidy Memory alloc into e*alloc */ -void * _php_tidy_mem_alloc(size_t size); -void * _php_tidy_mem_realloc(void *mem, size_t newsize); -void _php_tidy_mem_free(void *mem); -void _php_tidy_mem_panic(ctmbstr errmsg); - -ZEND_BEGIN_MODULE_GLOBALS(tidy) -ZEND_END_MODULE_GLOBALS(tidy) - - - - - - -#endif - - -/* - * Local variables: - * tab-width: 4 - * c-basic-offset: 4 - * End: - * vim600: noet sw=4 ts=4 fdm=marker - * vim<600: noet sw=4 ts=4 - */ diff --git a/ext/tidy/tests/001.phpt b/ext/tidy/tests/001.phpt deleted file mode 100644 index 4be56d0403..0000000000 --- a/ext/tidy/tests/001.phpt +++ /dev/null @@ -1,24 +0,0 @@ ---TEST-- -Check for tidy presence ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php -echo "tidy extension is available"; -/* - you can add regression tests for your extension here - - the output of your test code has to be equal to the - text in the --EXPECT-- section below for the tests - to pass, differences between the output and the - expected text are interpreted as failure - - see php4/README.TESTING for further information on - writing regression tests -*/ -?> ---EXPECT-- -tidy extension is available diff --git a/ext/tidy/tests/002.phpt b/ext/tidy/tests/002.phpt deleted file mode 100644 index b3fccffb3f..0000000000 --- a/ext/tidy/tests/002.phpt +++ /dev/null @@ -1,25 +0,0 @@ ---TEST-- -tidy_parse_string() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - - tidy_parse_string($tidy, "<HTML></HTML>"); - - echo tidy_get_output($tidy); - -?> ---EXPECT-- -<html> -<head> -<title></title> -</head> -<body> -</body> -</html>
\ No newline at end of file diff --git a/ext/tidy/tests/003.phpt b/ext/tidy/tests/003.phpt deleted file mode 100644 index fe0fefc688..0000000000 --- a/ext/tidy/tests/003.phpt +++ /dev/null @@ -1,27 +0,0 @@ ---TEST-- -tidy_clean_repair() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - - tidy_parse_string($tidy, "<HTML></HTML>"); - tidy_clean_repair($tidy); - - echo tidy_get_output($tidy); - -?> ---EXPECT-- -<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN"> -<html> -<head> -<title></title> -</head> -<body> -</body> -</html> diff --git a/ext/tidy/tests/004.phpt b/ext/tidy/tests/004.phpt deleted file mode 100644 index 930a2093c7..0000000000 --- a/ext/tidy/tests/004.phpt +++ /dev/null @@ -1,24 +0,0 @@ ---TEST-- -tidy_diagnose() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - - tidy_parse_string($tidy, "<HTML></HTML>"); - tidy_diagnose($tidy); - echo tidy_get_error_buffer($tidy); - -?> ---EXPECT-- - -line 1 column 1 - Warning: missing <!DOCTYPE> declaration -line 1 column 7 - Warning: discarding unexpected </html> -line 1 column 14 - Warning: inserting missing 'title' element -Info: Document content looks like HTML 3.2 -3 warnings, 0 errors were found!
\ No newline at end of file diff --git a/ext/tidy/tests/005.html b/ext/tidy/tests/005.html deleted file mode 100644 index 8c17451f91..0000000000 --- a/ext/tidy/tests/005.html +++ /dev/null @@ -1 +0,0 @@ -<HTML></HTML> diff --git a/ext/tidy/tests/005.phpt b/ext/tidy/tests/005.phpt deleted file mode 100644 index 828bc148ea..0000000000 --- a/ext/tidy/tests/005.phpt +++ /dev/null @@ -1,25 +0,0 @@ ---TEST-- -tidy_parse_file() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - - tidy_parse_file($tidy, "ext/tidy/tests/005.html"); - - echo tidy_get_output($tidy); - -?> ---EXPECT-- -<html> -<head> -<title></title> -</head> -<body> -</body> -</html>
\ No newline at end of file diff --git a/ext/tidy/tests/006.phpt b/ext/tidy/tests/006.phpt deleted file mode 100644 index 2ea27d38f4..0000000000 --- a/ext/tidy/tests/006.phpt +++ /dev/null @@ -1,23 +0,0 @@ ---TEST-- -Verbose tidy_get_error_buffer() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - - tidy_parse_string($tidy, "<HTML><asd asdf></HTML>"); - - echo tidy_get_error_buffer($tidy, true); - -?> ---EXPECT-- -line 1 column 1 - Warning: missing <!DOCTYPE> declaration -line 1 column 7 - Error: <asd> is not recognized! -line 1 column 7 - Warning: discarding unexpected <asd> -line 1 column 17 - Warning: discarding unexpected </html> -line 1 column 7 - Warning: inserting missing 'title' element
\ No newline at end of file diff --git a/ext/tidy/tests/007.phpt b/ext/tidy/tests/007.phpt deleted file mode 100644 index 7fcbb8f39c..0000000000 --- a/ext/tidy/tests/007.phpt +++ /dev/null @@ -1,37 +0,0 @@ ---TEST-- -Verbose tidy_setopt() / tidy_getopt() ---SKIPIF-- -<?php if (!extension_loaded("Tidy")) print "skip"; ?> ---POST-- ---GET-- ---INI-- ---FILE-- -<?php - - $tidy = tidy_create(); - echo "Current Value of 'tidy-mark': "; - var_dump(tidy_getopt($tidy, "tidy-mark")); - tidy_setopt($tidy, "tidy-mark", true); - echo "\nNew Value of 'tidy-mark': "; - var_dump(tidy_getopt($tidy, "tidy-mark")); - echo "Current Value of 'error-file': "; - var_dump(tidy_getopt($tidy, "error-file")); - tidy_setopt($tidy, "error-file", "foobar"); - echo "\nNew Value of 'error-file': "; - var_dump(tidy_getopt($tidy, "error-file")); - echo "Current Value of 'tab-size': "; - var_dump(tidy_getopt($tidy, "tab-size")); - tidy_setopt($tidy, "tab-size", 10); - echo "\nNew Value of 'tab-size': "; - var_dump(tidy_getopt($tidy, "tab-size")); -?> ---EXPECT-- -Current Value of 'tidy-mark': bool(false) - -New Value of 'tidy-mark': bool(true) -Current Value of 'error-file': string(0) "" - -New Value of 'error-file': string(6) "foobar" -Current Value of 'tab-size': int(8) - -New Value of 'tab-size': int(10)
\ No newline at end of file diff --git a/ext/tidy/tidy.c b/ext/tidy/tidy.c deleted file mode 100644 index b08a023d5f..0000000000 --- a/ext/tidy/tidy.c +++ /dev/null @@ -1,1920 +0,0 @@ -/* - +----------------------------------------------------------------------+ - | PHP Version 4 | - +----------------------------------------------------------------------+ - | Copyright (c) 1997-2003 The PHP Group | - +----------------------------------------------------------------------+ - | This source file is subject to version 3.0 of the PHP license, | - | that is bundled with this package in the file LICENSE, and is | - | available through the world-wide-web at the following url: | - | http://www.php.net/license/3_0.txt. | - | If you did not receive a copy of the PHP license and are unable to | - | obtain it through the world-wide-web, please send a note to | - | license@php.net so we can mail you a copy immediately. | - +----------------------------------------------------------------------+ - | Author: John Coggeshall <john@php.net> | - +----------------------------------------------------------------------+ -*/ - -/* $Id$ */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include "php.h" -#include "php_ini.h" -#include "ext/standard/info.h" -#include "php_tidy.h" -#include "Zend/zend_API.h" -#include "Zend/zend_hash.h" -#include "zend_objects_API.h" -#include "zend_objects.h" -#include "zend_operators.h" -#include "safe_mode.h" - -ZEND_DECLARE_MODULE_GLOBALS(tidy); - -static int le_tidydoc; -#define le_tidydoc_name "Tidy Document" - -zend_class_entry *php_tidy_ce; - -static zend_object_handlers php_tidy_object_handlers = { - ZEND_OBJECTS_STORE_HANDLERS, - tidy_property_read, - tidy_property_write, - tidy_read_dim, - tidy_write_dim, - tidy_property_get_ptr, - tidy_property_get_ptr, - NULL, - NULL, - tidy_property_exists, - tidy_property_delete, - tidy_del_dim, - tidy_get_properties, - tidy_get_method, - tidy_call_method, - tidy_get_constructor, - tidy_get_class_entry, - tidy_get_class_name, - tidy_objects_compare, - tidy_object_cast -}; - - -function_entry tidy_functions[] = { - PHP_FE(tidy_create, NULL) - PHP_FE(tidy_setopt, NULL) - PHP_FE(tidy_getopt, NULL) - PHP_FE(tidy_parse_string, NULL) - PHP_FE(tidy_parse_file, NULL) - PHP_FE(tidy_get_output, NULL) - PHP_FE(tidy_get_error_buffer, NULL) - PHP_FE(tidy_clean_repair, NULL) - PHP_FE(tidy_diagnose, NULL) - PHP_FE(tidy_get_release, NULL) - PHP_FE(tidy_get_status, NULL) - PHP_FE(tidy_get_html_ver, NULL) - PHP_FE(tidy_is_xhtml, NULL) - PHP_FE(tidy_is_xml, NULL) - PHP_FE(tidy_error_count, NULL) - PHP_FE(tidy_warning_count, NULL) - PHP_FE(tidy_access_count, NULL) - PHP_FE(tidy_config_count, NULL) - PHP_FE(tidy_load_config, NULL) - PHP_FE(tidy_load_config_enc, NULL) - PHP_FE(tidy_set_encoding, NULL) - PHP_FE(tidy_save_config, NULL) - PHP_FE(tidy_get_root, NULL) - PHP_FE(tidy_get_head, NULL) - PHP_FE(tidy_get_html, NULL) - PHP_FE(tidy_get_body, NULL) - {NULL, NULL, NULL} -}; - - -zend_module_entry tidy_module_entry = { -#if ZEND_MODULE_API_NO >= 20010901 - STANDARD_MODULE_HEADER, -#endif - "Tidy", - tidy_functions, - PHP_MINIT(tidy), - PHP_MSHUTDOWN(tidy), - NULL, - NULL, - PHP_MINFO(tidy), -#if ZEND_MODULE_API_NO >= 20010901 - "0.5b", -#endif - STANDARD_MODULE_PROPERTIES -}; - - -#ifdef COMPILE_DL_TIDY -ZEND_GET_MODULE(tidy) -#endif - -static inline PHPTidyObj *php_tidy_fetch_object(zval *object TSRMLS_DC) { - - return (PHPTidyObj *) zend_object_store_get_object(object TSRMLS_CC); -} - -void * _php_tidy_mem_alloc(size_t size) { - return emalloc(size); -} - -void * _php_tidy_mem_realloc(void *mem, size_t newsize) { - return erealloc(mem, newsize); -} - -void _php_tidy_mem_free(void *mem) { - efree(mem); -} - -void _php_tidy_mem_panic(ctmbstr errmsg) { - - php_error_docref(NULL TSRMLS_CC, E_ERROR, "Could not allocate memory for Tidy: %s", (char *)errmsg); -} - - -PHPTidyObj *php_tidy_new(TSRMLS_DC) { - - PHPTidyObj *intern; - - intern = emalloc(sizeof(PHPTidyObj)); - intern->obj.ce = php_tidy_ce; - intern->obj.in_get = 0; - intern->obj.in_set = 0; - intern->node = NULL; - intern->attr = NULL; - intern->type = PHP_IS_TIDYUNDEF; - intern->tdoc = NULL; - - intern->obj.properties = emalloc(sizeof(HashTable)); - zend_hash_init(intern->obj.properties, 0, NULL, ZVAL_PTR_DTOR, 0); - - return intern; - -} - -static zval *_php_tidy_create_obj_zval(unsigned int objtype, - PHPTidyObj *parent, - void *data - TSRMLS_DC) { - zval *return_value; - MAKE_STD_ZVAL(return_value); - ZVAL_NULL(return_value); - - _php_tidy_create_obj(return_value, objtype, parent, data TSRMLS_CC); - return return_value; -} - -static void _php_tidy_create_obj(zval *return_value, - unsigned int objtype, - PHPTidyObj *parent, - void *data - TSRMLS_DC) { - - PHPTidyObj *retobj; - - retobj = php_tidy_new(); - retobj->tdoc = parent->tdoc; - retobj->type = objtype; - retobj->refcount = 1; - parent->refcount++; - - switch(objtype) { - case PHP_IS_TIDYNODE: - retobj->node = (TidyNode)data; - break; - case PHP_IS_TIDYATTR: - retobj->node = parent->node; - retobj->attr = (TidyAttr)data; - break; - default: - retobj->node = NULL; - retobj->attr = NULL; - } - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(retobj TSRMLS_CC); - -} - -static zend_object_value php_tidy_register_object(PHPTidyObj *intern TSRMLS_DC) { - - zend_object_value retval; - - retval.handle = zend_objects_store_put(intern, - php_tidy_obj_dtor, - php_tidy_obj_clone TSRMLS_CC); - retval.handlers = (zend_object_handlers *) &php_tidy_object_handlers; - - return retval; -} - -void dtor_TidyDoc(zend_rsrc_list_entry *rsrc TSRMLS_DC) { - - PHPTidyDoc *tdoc = (PHPTidyDoc *)rsrc->ptr; - - if(tdoc->doc) { - tidyRelease(tdoc->doc); - } - if(tdoc->errbuf) { - tidyBufFree(tdoc->errbuf); - efree(tdoc->errbuf); - - } - - efree(tdoc); - -} - -static void php_tidy_obj_dtor(void *object, zend_object_handle handle TSRMLS_DC) { - - PHPTidyObj *o = (PHPTidyObj *)object; - - if(--o->refcount == 0) { - /* We don't free anything else here from - PHPTidyObj, they are all pointers - to internal TidyNode structs, which - get freed when the tidy resource is - destroied by TidyRelease() - */ - - zend_objects_destroy_object(&o->obj, handle TSRMLS_CC); - } - -} - -static void php_tidy_obj_clone(void *object, void **object_clone TSRMLS_DC) { - - PHPTidyObj *intern = (PHPTidyObj *) object; - PHPTidyObj **intern_clone = (PHPTidyObj **) object_clone; - - *intern_clone = emalloc(sizeof(PHPTidyObj)); - (*intern_clone)->obj.ce = intern->obj.ce; - (*intern_clone)->obj.in_get = 0; - (*intern_clone)->obj.in_set = 0; - ALLOC_HASHTABLE((*intern_clone)->obj.properties); - - /* memcopy these.. */ - memcpy((*intern_clone)->node, intern->node, sizeof(TidyNode)); - memcpy((*intern_clone)->attr, intern->attr, sizeof(TidyAttr)); - memcpy((*intern_clone)->tdoc, intern->tdoc, sizeof(PHPTidyDoc)); - (*intern_clone)->type = intern->type; - -} - -static void php_tidy_init_globals(zend_tidy_globals *tidy_globals) { - - /* No globals for now */ -} - -PHP_MINIT_FUNCTION(tidy) { - - zend_class_entry _tidy_entry; - - INIT_CLASS_ENTRY(_tidy_entry, "TidyObject", NULL); - php_tidy_ce = zend_register_internal_class(&_tidy_entry TSRMLS_CC); - - ZEND_INIT_MODULE_GLOBALS(tidy, php_tidy_init_globals, NULL); - le_tidydoc = zend_register_list_destructors_ex(dtor_TidyDoc, NULL, le_tidydoc_name, module_number); - - _php_tidy_register_tags(INIT_FUNC_ARGS_PASSTHRU); - _php_tidy_register_attributes(INIT_FUNC_ARGS_PASSTHRU); - _php_tidy_register_nodetypes(INIT_FUNC_ARGS_PASSTHRU); - - tidySetMallocCall(_php_tidy_mem_alloc); - tidySetReallocCall(_php_tidy_mem_realloc); - tidySetFreeCall(_php_tidy_mem_free); - tidySetPanicCall(_php_tidy_mem_panic); - - return SUCCESS; - -} - - -PHP_MSHUTDOWN_FUNCTION(tidy) { - - - return SUCCESS; - -} - - - -PHP_MINFO_FUNCTION(tidy) { - - php_info_print_table_start(); - php_info_print_table_header(2, "Tidy support", "enabled"); - php_info_print_table_row(2, "Tidy Build Date", (char *)tidyReleaseDate()); - php_info_print_table_end(); - -} - -/* {{{ proto resource tidy_create() - Initialize a new tidy document */ -PHP_FUNCTION(tidy_create) { - - PHPTidyDoc *tdoc; - tdoc = emalloc(sizeof(PHPTidyDoc)); - tdoc->doc = tidyCreate(); - tdoc->parsed = 0; - - tdoc->errbuf = emalloc(sizeof(TidyBuffer)); - tidyBufInit(tdoc->errbuf); - - if(tidySetErrorBuffer(tdoc->doc, tdoc->errbuf) != 0) - php_error_docref(NULL TSRMLS_CC, E_ERROR, "Could not set Tidy error buffer"); - - tidyOptSetBool(tdoc->doc, TidyForceOutput, yes); - tidyOptSetBool(tdoc->doc, TidyMark, no); - - ZEND_REGISTER_RESOURCE(return_value, tdoc, le_tidydoc); - -} -/* }}} */ - -/* {{{ proto void tidy_parse_string(resource tidy, string input) - Parse a document stored in a string */ -PHP_FUNCTION(tidy_parse_string) { - - char *input; - int input_len; - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &input, &input_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(tidyParseString(tdoc->doc, input) < 0) { - php_error_docref(NULL TSRMLS_CC, E_ERROR, "[Tidy error] %s", tdoc->errbuf->bp); - } - - tdoc->parsed = 1; - -} -/* }}} */ - -/* {{{ proto string tidy_get_error_buffer(resource tidy [, boolean detailed]) - Return warnings and errors which occured parsing the specified document*/ -PHP_FUNCTION(tidy_get_error_buffer) { - - zval *res; - PHPTidyDoc *tdoc; - zend_bool detailed; - - if((ZEND_NUM_ARGS() == 0) || (ZEND_NUM_ARGS() > 2)) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r|b", &res, &detailed) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - if(detailed) { - tidyErrorSummary(tdoc->doc); - } - - RETVAL_STRING(tdoc->errbuf->bp, 1); - - tidyBufClear(tdoc->errbuf); - -} -/* }}} */ - -/* {{{ proto string tidy_get_output(resource tidy) - Return a string representing the parsed tidy markup */ -PHP_FUNCTION(tidy_get_output) { - - zval *res; - PHPTidyDoc *tdoc; - TidyBuffer output = {0}; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - tidySaveBuffer( tdoc->doc, &output ); - - RETVAL_STRING(output.bp, 1); - - tidyBufFree(&output); - -} -/* }}} */ - -/* {{{ proto boolean tidy_parse_file(resource tidy, string file) - Parse markup in file or URI */ -PHP_FUNCTION(tidy_parse_file) { - - - char *inputfile; - int input_len; - zval *res; - PHPTidyDoc *tdoc; - php_stream *stream; - char *contents; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &inputfile, &input_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - stream = php_stream_open_wrapper(inputfile, "rb", - ENFORCE_SAFE_MODE | REPORT_ERRORS, - NULL); - - if(!stream) { - RETURN_FALSE; - } - - if (php_stream_copy_to_mem(stream, &contents, PHP_STREAM_COPY_ALL, 0) > 0) { - - if(tidyParseString(tdoc->doc, contents) < 0) { - php_error_docref(NULL TSRMLS_CC, E_ERROR, "[Tidy error] %s", tdoc->errbuf->bp); - } - tdoc->parsed = TRUE; - efree(contents); - } - - php_stream_close(stream); - - RETURN_TRUE; -} -/* }}} */ - -/* {{{ proto boolean tidy_clean_repair(resource tidy) - Execute configured cleanup and repair operations on parsed markup */ -PHP_FUNCTION(tidy_clean_repair) { - - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - if(tidyCleanAndRepair(tdoc->doc) >= 0) RETURN_TRUE; - - RETURN_FALSE; - -} -/* }}} */ - -/* {{{ proto boolean tidy_diagnose(resource tidy) - Run configured diagnostics on parsed and repaired markup. */ -PHP_FUNCTION(tidy_diagnose) { - - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - if(tidyRunDiagnostics(tdoc->doc) >= 0) RETURN_TRUE; - - RETURN_FALSE; -} - -/* }}} */ - -/* {{{ proto string tidy_get_release() - Get release date (version) for Tidy library */ -PHP_FUNCTION(tidy_get_release) { - - RETURN_STRING((char *)tidyReleaseDate(), 1); -} -/* }}} */ - -/* {{{ proto int tidy_get_status(resource tidy) - Get status of specfied document. */ -PHP_FUNCTION(tidy_get_status) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - RETURN_LONG(tidyStatus(tdoc->doc)); - -} -/* }}} */ - -/* {{{ proto int tidy_get_html_ver(resource tidy) - Get the Detected HTML version for the specified document. */ -PHP_FUNCTION(tidy_get_html_ver) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - - RETURN_LONG(tidyDetectedHtmlVersion(tdoc->doc)); -} -/* }}} */ - -/* {{{ proto boolean tidy_is_xhtml(resource tidy) - Indicates if the document is a XHTML document. */ -PHP_FUNCTION(tidy_is_xhtml) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - RETURN_BOOL(tidyDetectedXhtml(tdoc->doc)); - -} -/* }}} */ - -/* {{{ proto boolean tidy_is_xhtml(resource tidy) - Indicates if the document is a generic (non HTML/XHTML) XML document. */ -PHP_FUNCTION(tidy_is_xml) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - RETURN_BOOL(tidyDetectedGenericXml(tdoc->doc)); -} -/* }}} */ - -/* {{{ proto int tidy_error_count(resource tidy) - Returns the Number of Tidy errors encountered for specified document. */ -PHP_FUNCTION(tidy_error_count) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - RETURN_LONG(tidyErrorCount(tdoc->doc)); -} -/* }}} */ - -/* {{{ proto int tidy_warning_count(resource tidy) - Returns the Number of Tidy warnings encountered for specified document. */ -PHP_FUNCTION(tidy_warning_count) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - RETURN_LONG(tidyWarningCount(tdoc->doc)); -} -/* }}} */ - -/* {{{ proto int tidy_access_count(resource tidy) - Returns the Number of Tidy accessibility warnings encountered for specified document. */ -PHP_FUNCTION(tidy_access_count) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - RETURN_LONG(tidyAccessWarningCount(tdoc->doc)); - -} -/* }}} */ - -/* {{{ proto int tidy_config_count(resource tidy) - Returns the Number of Tidy configuration errors encountered for specified document. */ -PHP_FUNCTION(tidy_config_count) { - zval *res; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - - RETURN_LONG(tidyConfigErrorCount(tdoc->doc)); - -} -/* }}} */ - -/* {{{ proto void tidy_load_config(resource tidy, string filename) - Load an ASCII Tidy configuration file */ -PHP_FUNCTION(tidy_load_config) { - zval *res; - char *filename; - int filename_len; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &filename, &filename_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - if(tidyLoadConfig(tdoc->doc, filename) < 0) { - php_error_docref(NULL TSRMLS_CC, E_ERROR, "Could not load configuration file '%s'", filename); - } - -} -/* }}} */ - -/* {{{ proto void tidy_load_config(resource tidy, string filename, string encoding) - Load an ASCII Tidy configuration file with the specified encoding */ -PHP_FUNCTION(tidy_load_config_enc) { - zval *res; - char *filename; - char *encoding; - int enc_len, file_len; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rss", &res, &filename, &file_len, &encoding, &enc_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - if(tidyLoadConfigEnc(tdoc->doc, filename, encoding) < 0) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Could not load configuration file '%s' using encoding '%s'", filename, encoding); - RETURN_FALSE; - } - - RETURN_TRUE; -} -/* }}} */ - -/* {{{ proto boolean tidy_set_encoding(resource tidy, string encoding) - Set the input/output character encoding for parsing markup. - Values include: ascii, latin1, raw, utf8, iso2022, mac, win1252, utf16le, - utf16be, utf16, big5 and shiftjis. */ -PHP_FUNCTION(tidy_set_encoding) { - zval *res; - char *encoding; - int enc_len; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &encoding, &enc_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - if(tidySetCharEncoding(tdoc->doc, encoding) < 0) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Could not set encoding '%s'", encoding); - RETURN_FALSE; - } - - RETURN_TRUE; -} -/* }}} */ - -/* {{{ proto boolean tidy_save_config(resource tidy, string filename) - Save current settings to named file. Only non-default values are written. */ -PHP_FUNCTION(tidy_save_config) { - zval *res; - char *filename; - int file_len; - PHPTidyDoc *tdoc; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &filename, &file_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - if(tidyOptSaveFile(tdoc->doc, filename) < 0) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Could not write tidy configuration file '%s'", filename); - RETURN_FALSE; - } - - RETURN_TRUE; -} -/* }}} */ - -/* {{{ proto boolean tidy_setopt(resource tidy, string option, mixed newvalue) - Updates the configuration settings for the specified tidy document. */ -PHP_FUNCTION(tidy_setopt) { - - zval *res, *value; - char *optname; - int optname_len; - PHPTidyDoc *tdoc; - TidyOption opt; - - - if(ZEND_NUM_ARGS() != 3) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rsz", &res, &optname, &optname_len, &value) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->doc) { - php_error_docref(NULL TSRMLS_CC,E_ERROR, "Invalid Tidy Resource Specified"); - RETURN_FALSE; - } - - opt = tidyGetOptionByName(tdoc->doc, optname); - if(!opt) { - php_error_docref(NULL TSRMLS_CC,E_WARNING, "Unknown Tidy Configuration Option '%s'", optname); - RETURN_FALSE; - } - - switch(tidyOptGetType(opt)) { - - case TidyString: - if(tidyOptSetValue(tdoc->doc, tidyOptGetId(opt), Z_STRVAL_P(value))) { - RETURN_TRUE; - } - break; - - case TidyInteger: - if(tidyOptSetInt(tdoc->doc, tidyOptGetId(opt), Z_LVAL_P(value))) { - RETURN_TRUE; - } - break; - - case TidyBoolean: - if(tidyOptSetBool(tdoc->doc, tidyOptGetId(opt), Z_LVAL_P(value))) { - RETURN_TRUE; - } - break; - - default: - - php_error_docref(NULL TSRMLS_CC,E_WARNING, "Unable to determine type of Tidy configuration constant to set"); - - } - RETURN_FALSE; -} -/* }}} */ - -/* {{{ proto mixed tidy_getopt(resource tidy, string option) - Returns the value of the specified configuration option for the tidy document. */ -PHP_FUNCTION(tidy_getopt) { - - zval *res; - char *optname, *strval; - int optname_len; - PHPTidyDoc *tdoc; - TidyOption opt; - - if(ZEND_NUM_ARGS() != 2) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "rs", &res, &optname, &optname_len) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->doc) { - php_error_docref(NULL TSRMLS_CC,E_ERROR, "Invalid Tidy Resource Specified"); - RETURN_FALSE; - } - - opt = tidyGetOptionByName(tdoc->doc, optname); - if(!opt) { - php_error_docref(NULL TSRMLS_CC,E_WARNING, "Unknown Tidy Configuration Option '%s'", optname); - RETURN_FALSE; - } - - switch(tidyOptGetType(opt)) { - - case TidyString: - strval = (char *)tidyOptGetValue(tdoc->doc, tidyOptGetId(opt)); - - if(strval) { - RETURN_STRING(strval, 0); - } else { - RETURN_EMPTY_STRING(); - } - - break; - case TidyInteger: - RETURN_LONG(tidyOptGetInt(tdoc->doc, tidyOptGetId(opt))) - break; - case TidyBoolean: - - if(tidyOptGetBool(tdoc->doc, tidyOptGetId(opt))) { - RETURN_TRUE; - } - - break; - - default: - - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Unable to determine type of Tidy configuration constant to get"); - - } - - RETURN_FALSE; - -} -/* }}} */ - -/* {{{ proto TidyNode tidy_get_root(resource tidy) - Returns a TidyNode Object representing the root of the tidy parse tree */ -PHP_FUNCTION(tidy_get_root) { - - zval *res; - PHPTidyDoc *tdoc; - PHPTidyObj *obj; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - obj = php_tidy_new(); - obj->node = tidyGetRoot(tdoc->doc); - obj->tdoc = tdoc; - obj->attr = NULL; - obj->type = PHP_IS_TIDYNODE; - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(obj TSRMLS_CC); - -} -/* }}} */ - -/* {{{ proto TidyNode tidy_get_html(resource tidy) - Returns a TidyNode Object starting from the <HTML> tag of the tidy parse tree */ -PHP_FUNCTION(tidy_get_html) { - - zval *res; - PHPTidyDoc *tdoc; - PHPTidyObj *obj; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - obj = php_tidy_new(); - obj->node = tidyGetHtml(tdoc->doc); - obj->tdoc = tdoc; - obj->attr = NULL; - obj->type = PHP_IS_TIDYNODE; - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(obj TSRMLS_CC); - -} -/* }}} */ - -/* {{{ proto TidyNode tidy_get_head(resource tidy) - Returns a TidyNode Object starting from the <HEAD> tag of the tidy parse tree */ -PHP_FUNCTION(tidy_get_head) { - - zval *res; - PHPTidyDoc *tdoc; - PHPTidyObj *obj; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - obj = php_tidy_new(); - obj->node = tidyGetHead(tdoc->doc); - obj->tdoc = tdoc; - obj->attr = NULL; - obj->type = PHP_IS_TIDYNODE; - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(obj TSRMLS_CC); - -} -/* }}} */ - -/* {{{ proto TidyNode tidy_get_body(resource tidy) - Returns a TidyNode Object starting from the <BODY> tag of the tidy parse tree */ -PHP_FUNCTION(tidy_get_body) { - - zval *res; - PHPTidyDoc *tdoc; - PHPTidyObj *obj; - - if(ZEND_NUM_ARGS() != 1) { - WRONG_PARAM_COUNT; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "r", &res) == FAILURE) { - return; - } - - ZEND_FETCH_RESOURCE(tdoc, PHPTidyDoc *, &res, -1, le_tidydoc_name, le_tidydoc); - - if(!tdoc->parsed) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "A document must be parsed before executing this function."); - RETURN_FALSE; - } - - obj = php_tidy_new(); - obj->node = tidyGetBody(tdoc->doc); - obj->tdoc = tdoc; - obj->attr = NULL; - obj->type = PHP_IS_TIDYNODE; - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(obj TSRMLS_CC); - -} -/* }}} */ - -static void tidy_property_delete(zval *obj, zval *member TSRMLS_DC) {} -static void tidy_property_write(zval *obj, zval *member, zval *value TSRMLS_DC) {} -static void tidy_object_cast(zval *readobj, zval *writeobj, int type, int should_free TSRMLS_DC) {} -static union _zend_function * tidy_get_constructor(zval *obj TSRMLS_DC) { return NULL; } -static void tidy_write_dim(zval *object, zval *offset, zval *value TSRMLS_DC) {} -static void tidy_del_dim(zval *object, zval *offset TSRMLS_DC) {} -static zval *tidy_read_dim(zval *object, zval *offset TSRMLS_DC) { - - return EG(uninitialized_zval_ptr); -} - -static zend_class_entry * tidy_get_class_entry(zval *obj TSRMLS_DC) { - - return php_tidy_ce; -} - - -static zval ** tidy_property_get_ptr(zval *obj, zval *member TSRMLS_DC) { - zval **p_ptr; - zval *p; - - /* How to fix this memleak? */ - p_ptr = emalloc(sizeof(zval **)); - - p = tidy_property_read(obj, member, 0 TSRMLS_CC); - - *p_ptr = p; - - return p_ptr; - -} - -static zval * tidy_property_read(zval *object, zval *member, zend_bool silent TSRMLS_DC) { - - PHPTidyObj *obj = php_tidy_fetch_object(object); - zval *return_value, *temp; - TidyBuffer buf; - TidyNode tempnode; - TidyAttr tempattr; - char *temp_str; - - char *name = Z_STRVAL_P(member); - - MAKE_STD_ZVAL(return_value); - ZVAL_NULL(return_value); - - /* Seems to me the engine expects to simply recieve a pointer to - an already-existing zval, not for one to be created and returned.. - - Thus, it doesn't feel compelled to free the return value once it's - done with it... this seems to compell it appropiately. */ - return_value->refcount--; - - switch(obj->type) { - - case PHP_IS_TIDYNODE: - - if(!strcmp(name, "name")) { - temp_str = (char *)tidyNodeGetName(obj->node); - if(temp_str) { - ZVAL_STRING(return_value, temp_str, 1); - } - - } else if(!strcmp(name, "value")) { - - memset(&buf, 0, sizeof(buf)); - tidyNodeGetText(obj->tdoc->doc, obj->node, &buf); - ZVAL_STRING(return_value, (char *)buf.bp, 1); - - /* The buffer adds a newline at the end of the string */ - REMOVE_NEWLINE(return_value); - - tidyBufFree(&buf); - - } else if(!strcmp(name, "type")) { - - ZVAL_LONG(return_value, tidyNodeGetType(obj->node)); - - } else if(!strcmp(name, "id")) { - - if(tidyNodeGetName(obj->node)) { - ZVAL_LONG(return_value, tidyNodeGetId(obj->node)); - } - - } else if(!strcmp(name, "attribs")) { - - array_init(return_value); - - tempattr = tidyAttrFirst(obj->node); - - if(tempattr) { - - temp = _php_tidy_create_obj_zval(PHP_IS_TIDYATTR, obj, tempattr TSRMLS_CC); - temp->refcount--; - add_next_index_zval(return_value, temp); - - while((tempattr = tidyAttrNext(tempattr))) { - - temp = _php_tidy_create_obj_zval(PHP_IS_TIDYATTR, obj, tempattr TSRMLS_CC); - add_next_index_zval(return_value, temp); - - } - } - - } else if(!strcmp(name, "children")) { - - array_init(return_value); - tempnode = tidyGetChild(obj->node); - if(tempnode) { - - temp = _php_tidy_create_obj_zval(PHP_IS_TIDYNODE, obj, tempnode TSRMLS_CC); - add_next_index_zval(return_value, temp); - - while((tempnode = tidyGetNext(tempnode))) { - - temp = _php_tidy_create_obj_zval(PHP_IS_TIDYNODE, obj, tempnode TSRMLS_CC); - temp->refcount--; - add_next_index_zval(return_value, temp); - - } - } - - } else if(!strcmp(name, "line")) { - ZVAL_LONG(return_value, tidyNodeLine(obj->node)); - } else if(!strcmp(name, "column")) { - ZVAL_LONG(return_value, tidyNodeColumn(obj->node)); - } else if(!strcmp(name, "html_ver")) { - ZVAL_LONG(return_value, tidyDetectedHtmlVersion(obj->tdoc->doc)); - } - - break; - case PHP_IS_TIDYATTR: - - if(!strcmp(name, "name")) { - temp_str = (char *)tidyAttrName(obj->attr); - if(temp_str) { - ZVAL_STRING(return_value, temp_str , 1); - } - } else if(!strcmp(name, "value")) { - temp_str = (char *)tidyAttrValue(obj->attr); - if(temp_str) { - ZVAL_STRING(return_value, temp_str , 1); - efree(temp_str); - } - } else if(!strcmp(name, "id")) { - ZVAL_LONG(return_value, tidyAttrGetId(obj->attr)); - } - - break; - default: - php_error_docref(NULL TSRMLS_CC,E_ERROR, "Undefined Tidy object type."); - break; - } - - return return_value; - -} - -static int tidy_property_exists(zval *object, zval *member, int check_empty TSRMLS_DC) { - - return TRUE; -} - -static HashTable * tidy_get_properties(zval *object TSRMLS_DC) { - - zend_object *zobj; - zobj = zend_objects_get_address(object TSRMLS_CC); - return zobj->properties; - -} - -static union _zend_function * tidy_get_method(zval *obj, char *method, int method_len TSRMLS_DC) { - - zend_internal_function *f; - - f = emalloc(sizeof(zend_internal_function)); - f->type = ZEND_OVERLOADED_FUNCTION; - f->arg_types = NULL; - f->scope = php_tidy_ce; - f->fn_flags = 0; - - /* How to fix this memleak? */ - f->function_name = estrndup(method, method_len); - - return (union _zend_function *) f; -} - -zend_bool _php_tidy_node_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS) { - - PHPTidyObj *obj = php_tidy_fetch_object(getThis()); - PHPTidyObj *newobj; - TidyNode tempnode; - TidyAttr tempattr; - - int param; - - if(strstr(method, "has_")) { - - if(!strcmp(method, "has_siblings")) { - - if(tidyGetNext(obj->node) || tidyGetPrev(obj->node)) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "has_children")) { - - if(tidyGetChild(obj->node)) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "has_parent")) { - - if(tidyGetParent(obj->node)) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } - - } else if(strstr(method, "is_")) { - - if(!strcmp(method, "is_comment")) { - - if(tidyNodeGetType(obj->node) == TidyNode_Comment) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_xhtml")) { - - if(tidyDetectedXhtml(obj->tdoc->doc)) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_xml")) { - - if(tidyDetectedGenericXml(obj->tdoc->doc)) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_text")) { - - if(tidyNodeGetType(obj->node) == TidyNode_Text) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_jste")) { - - if(tidyNodeGetType(obj->node) == TidyNode_Jste) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_asp")) { - - if(tidyNodeGetType(obj->node) == TidyNode_Asp) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_php")) { - - if(tidyNodeGetType(obj->node) == TidyNode_Php) { - TIDY_RV_TRUE(return_value); - } else { - TIDY_RV_FALSE(return_value); - } - - } else if(!strcmp(method, "is_html")) { - - switch(tidyNodeGetType(obj->node)) { - - case TidyNode_Start: - case TidyNode_End: - case TidyNode_StartEnd: - TIDY_RV_TRUE(return_value); - break; - default: - TIDY_RV_FALSE(return_value); - break; - } - - } - - } else { - - if(!strcmp(method, "next")) { - - tempnode = tidyGetNext(obj->node); - if(tempnode) { - _php_tidy_create_obj(return_value, - PHP_IS_TIDYNODE, - obj, - tempnode TSRMLS_CC); - } - - } else if(!strcmp(method, "prev")) { - - tempnode = tidyGetPrev(obj->node); - if(tempnode) { - _php_tidy_create_obj(return_value, - PHP_IS_TIDYNODE, - obj, - tempnode TSRMLS_CC); - } - - } else if(!strcmp(method, "parent")) { - - tempnode = tidyGetParent(obj->node); - if(tempnode) { - _php_tidy_create_obj(return_value, - PHP_IS_TIDYNODE, - obj, - tempnode TSRMLS_CC); - } - - } else if(!strcmp(method, "child")) { - - tempnode = tidyGetChild(obj->node); - if(tempnode) { - _php_tidy_create_obj(return_value, - PHP_IS_TIDYNODE, - obj, - tempnode TSRMLS_CC); - } - - } else if(!strcmp(method, "get_attr_type")) { - - if(ZEND_NUM_ARGS() != 1) { - zend_wrong_param_count(TSRMLS_CC); - return TRUE; - } - - if(zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, - "l", ¶m) == FAILURE) { - return FALSE; - } - - - newobj = php_tidy_new(); - newobj->tdoc = obj->tdoc; - - for(tempattr = tidyAttrFirst(obj->node); - tempattr; - tempattr = tidyAttrNext(tempattr)) { - - if(tidyAttrGetId(tempattr) == param) { - - newobj->attr = tempattr; - newobj->type = PHP_IS_TIDYATTR; - obj->refcount++; - - return_value->type = IS_OBJECT; - return_value->value.obj = php_tidy_register_object(newobj TSRMLS_CC); - - break; - - } - - } - - } else { - - return FALSE; - - } - } - - return TRUE; - -} - -zend_bool _php_tidy_attr_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS) { - - PHPTidyObj *obj = php_tidy_fetch_object(getThis()); - TidyAttr tempattr; - - if(!strcmp(method, "next")) { - - tempattr = tidyAttrNext(obj->attr); - - if(tempattr) { - _php_tidy_create_obj(return_value, PHP_IS_TIDYATTR, obj, tempattr TSRMLS_CC); - } else { - - TIDY_RV_FALSE(return_value); - - } - - } else if(!strcmp(method, "tag")) { - _php_tidy_create_obj(return_value, PHP_IS_TIDYNODE, obj, obj->node TSRMLS_CC); - } else { - return FALSE; - } - - return TRUE; -} - -static int tidy_call_method(char *method, INTERNAL_FUNCTION_PARAMETERS) { - - PHPTidyObj *obj = php_tidy_fetch_object(getThis()); - - switch(obj->type) { - - case PHP_IS_TIDYNODE: - return _php_tidy_node_call_method(method, INTERNAL_FUNCTION_PARAM_PASSTHRU); - break; - case PHP_IS_TIDYATTR: - return _php_tidy_attr_call_method(method, INTERNAL_FUNCTION_PARAM_PASSTHRU); - break; - default: - php_error_docref(NULL TSRMLS_CC, E_ERROR, "Undefined Tidy object type."); - break; - } - - return FALSE; -} - -static int tidy_get_class_name(zval *obj, char **class_name, zend_uint *name_len, int parent TSRMLS_DC) { - - PHPTidyObj *object = php_tidy_fetch_object(obj); - - switch(object->type) { - - case PHP_IS_TIDYNODE: - - *class_name = estrdup("Tidy_Node"); - *name_len = sizeof("Tidy_Node"); - - break; - case PHP_IS_TIDYATTR: - - *class_name = estrdup("Tidy_Attribute"); - *name_len = sizeof("Tidy_Attribute"); - - break; - default: - - *class_name = estrdup("Tidy_Unknown"); - *name_len = sizeof("Tidy_Unknown"); - break; - } - - return TRUE; -} - -static int tidy_objects_compare(zval *obj_one, zval *obj_two TSRMLS_DC) { - - PHPTidyObj *obj1, *obj2; - - obj1 = php_tidy_fetch_object(obj_one); - obj2 = php_tidy_fetch_object(obj_two); - - if( (obj1->tdoc == obj2->tdoc) && - (obj1->node == obj2->node) && - (obj1->attr == obj2->attr) && - (obj1->type == obj2->type)) { - - return TRUE; - - } - - return FALSE; - -} - - -void _php_tidy_register_nodetypes(INIT_FUNC_ARGS) { - - TIDY_NODE_CONST(ROOT, Root); - TIDY_NODE_CONST(DOCTYPE, DocType); - TIDY_NODE_CONST(COMMENT, Comment); - TIDY_NODE_CONST(PROCINS, ProcIns); - TIDY_NODE_CONST(TEXT, Text); - TIDY_NODE_CONST(START, Start); - TIDY_NODE_CONST(END, End); - TIDY_NODE_CONST(STARTEND, StartEnd); - TIDY_NODE_CONST(CDATA, CDATA); - TIDY_NODE_CONST(SECTION, Section); - TIDY_NODE_CONST(ASP, Asp); - TIDY_NODE_CONST(JSTE, Jste); - TIDY_NODE_CONST(PHP, Php); - TIDY_NODE_CONST(XMLDECL, XmlDecl); - -} - -void _php_tidy_register_tags(INIT_FUNC_ARGS) { - - TIDY_TAG_CONST(UNKNOWN); - TIDY_TAG_CONST(A); - TIDY_TAG_CONST(ABBR); - TIDY_TAG_CONST(ACRONYM); - TIDY_TAG_CONST(ADDRESS); - TIDY_TAG_CONST(ALIGN); - TIDY_TAG_CONST(APPLET); - TIDY_TAG_CONST(AREA); - TIDY_TAG_CONST(B); - TIDY_TAG_CONST(BASE); - TIDY_TAG_CONST(BASEFONT); - TIDY_TAG_CONST(BDO); - TIDY_TAG_CONST(BGSOUND); - TIDY_TAG_CONST(BIG); - TIDY_TAG_CONST(BLINK); - TIDY_TAG_CONST(BLOCKQUOTE); - TIDY_TAG_CONST(BODY); - TIDY_TAG_CONST(BR); - TIDY_TAG_CONST(BUTTON); - TIDY_TAG_CONST(CAPTION); - TIDY_TAG_CONST(CENTER); - TIDY_TAG_CONST(CITE); - TIDY_TAG_CONST(CODE); - TIDY_TAG_CONST(COL); - TIDY_TAG_CONST(COLGROUP); - TIDY_TAG_CONST(COMMENT); - TIDY_TAG_CONST(DD); - TIDY_TAG_CONST(DEL); - TIDY_TAG_CONST(DFN); - TIDY_TAG_CONST(DIR); - TIDY_TAG_CONST(DIV); - TIDY_TAG_CONST(DL); - TIDY_TAG_CONST(DT); - TIDY_TAG_CONST(EM); - TIDY_TAG_CONST(EMBED); - TIDY_TAG_CONST(FIELDSET); - TIDY_TAG_CONST(FONT); - TIDY_TAG_CONST(FORM); - TIDY_TAG_CONST(FRAME); - TIDY_TAG_CONST(FRAMESET); - TIDY_TAG_CONST(H1); - TIDY_TAG_CONST(H2); - TIDY_TAG_CONST(H3); - TIDY_TAG_CONST(H4); - TIDY_TAG_CONST(H5); - TIDY_TAG_CONST(H6); - TIDY_TAG_CONST(HEAD); - TIDY_TAG_CONST(HR); - TIDY_TAG_CONST(HTML); - TIDY_TAG_CONST(I); - TIDY_TAG_CONST(IFRAME); - TIDY_TAG_CONST(ILAYER); - TIDY_TAG_CONST(IMG); - TIDY_TAG_CONST(INPUT); - TIDY_TAG_CONST(INS); - TIDY_TAG_CONST(ISINDEX); - TIDY_TAG_CONST(KBD); - TIDY_TAG_CONST(KEYGEN); - TIDY_TAG_CONST(LABEL); - TIDY_TAG_CONST(LAYER); - TIDY_TAG_CONST(LEGEND); - TIDY_TAG_CONST(LI); - TIDY_TAG_CONST(LINK); - TIDY_TAG_CONST(LISTING); - TIDY_TAG_CONST(MAP); - TIDY_TAG_CONST(MARQUEE); - TIDY_TAG_CONST(MENU); - TIDY_TAG_CONST(META); - TIDY_TAG_CONST(MULTICOL); - TIDY_TAG_CONST(NOBR); - TIDY_TAG_CONST(NOEMBED); - TIDY_TAG_CONST(NOFRAMES); - TIDY_TAG_CONST(NOLAYER); - TIDY_TAG_CONST(NOSAVE); - TIDY_TAG_CONST(NOSCRIPT); - TIDY_TAG_CONST(OBJECT); - TIDY_TAG_CONST(OL); - TIDY_TAG_CONST(OPTGROUP); - TIDY_TAG_CONST(OPTION); - TIDY_TAG_CONST(P); - TIDY_TAG_CONST(PARAM); - TIDY_TAG_CONST(PLAINTEXT); - TIDY_TAG_CONST(PRE); - TIDY_TAG_CONST(Q); - TIDY_TAG_CONST(RB); - TIDY_TAG_CONST(RBC); - TIDY_TAG_CONST(RP); - TIDY_TAG_CONST(RT); - TIDY_TAG_CONST(RTC); - TIDY_TAG_CONST(RUBY); - TIDY_TAG_CONST(S); - TIDY_TAG_CONST(SAMP); - TIDY_TAG_CONST(SCRIPT); - TIDY_TAG_CONST(SELECT); - TIDY_TAG_CONST(SERVER); - TIDY_TAG_CONST(SERVLET); - TIDY_TAG_CONST(SMALL); - TIDY_TAG_CONST(SPACER); - TIDY_TAG_CONST(SPAN); - TIDY_TAG_CONST(STRIKE); - TIDY_TAG_CONST(STRONG); - TIDY_TAG_CONST(STYLE); - TIDY_TAG_CONST(SUB); - TIDY_TAG_CONST(SUP); - TIDY_TAG_CONST(TABLE); - TIDY_TAG_CONST(TBODY); - TIDY_TAG_CONST(TD); - TIDY_TAG_CONST(TEXTAREA); - TIDY_TAG_CONST(TFOOT); - TIDY_TAG_CONST(TH); - TIDY_TAG_CONST(THEAD); - TIDY_TAG_CONST(TITLE); - TIDY_TAG_CONST(TR); - TIDY_TAG_CONST(TT); - TIDY_TAG_CONST(U); - TIDY_TAG_CONST(UL); - TIDY_TAG_CONST(VAR); - TIDY_TAG_CONST(WBR); - TIDY_TAG_CONST(XMP); - -} - -void _php_tidy_register_attributes(INIT_FUNC_ARGS) { - - TIDY_ATTR_CONST(UNKNOWN); - TIDY_ATTR_CONST(ABBR); - TIDY_ATTR_CONST(ACCEPT); - TIDY_ATTR_CONST(ACCEPT_CHARSET); - TIDY_ATTR_CONST(ACCESSKEY); - TIDY_ATTR_CONST(ACTION); - TIDY_ATTR_CONST(ADD_DATE); - TIDY_ATTR_CONST(ALIGN); - TIDY_ATTR_CONST(ALINK); - TIDY_ATTR_CONST(ALT); - TIDY_ATTR_CONST(ARCHIVE); - TIDY_ATTR_CONST(AXIS); - TIDY_ATTR_CONST(BACKGROUND); - TIDY_ATTR_CONST(BGCOLOR); - TIDY_ATTR_CONST(BGPROPERTIES); - TIDY_ATTR_CONST(BORDER); - TIDY_ATTR_CONST(BORDERCOLOR); - TIDY_ATTR_CONST(BOTTOMMARGIN); - TIDY_ATTR_CONST(CELLPADDING); - TIDY_ATTR_CONST(CELLSPACING); - TIDY_ATTR_CONST(CHAR); - TIDY_ATTR_CONST(CHAROFF); - TIDY_ATTR_CONST(CHARSET); - TIDY_ATTR_CONST(CHECKED); - TIDY_ATTR_CONST(CITE); - TIDY_ATTR_CONST(CLASS); - TIDY_ATTR_CONST(CLASSID); - TIDY_ATTR_CONST(CLEAR); - TIDY_ATTR_CONST(CODE); - TIDY_ATTR_CONST(CODEBASE); - TIDY_ATTR_CONST(CODETYPE); - TIDY_ATTR_CONST(COLOR); - TIDY_ATTR_CONST(COLS); - TIDY_ATTR_CONST(COLSPAN); - TIDY_ATTR_CONST(COMPACT); - TIDY_ATTR_CONST(CONTENT); - TIDY_ATTR_CONST(COORDS); - TIDY_ATTR_CONST(DATA); - TIDY_ATTR_CONST(DATAFLD); - //TIDY_ATTR_CONST(DATAFORMATSAS); - TIDY_ATTR_CONST(DATAPAGESIZE); - TIDY_ATTR_CONST(DATASRC); - TIDY_ATTR_CONST(DATETIME); - TIDY_ATTR_CONST(DECLARE); - TIDY_ATTR_CONST(DEFER); - TIDY_ATTR_CONST(DIR); - TIDY_ATTR_CONST(DISABLED); - TIDY_ATTR_CONST(ENCODING); - TIDY_ATTR_CONST(ENCTYPE); - TIDY_ATTR_CONST(FACE); - TIDY_ATTR_CONST(FOR); - TIDY_ATTR_CONST(FRAME); - TIDY_ATTR_CONST(FRAMEBORDER); - TIDY_ATTR_CONST(FRAMESPACING); - TIDY_ATTR_CONST(GRIDX); - TIDY_ATTR_CONST(GRIDY); - TIDY_ATTR_CONST(HEADERS); - TIDY_ATTR_CONST(HEIGHT); - TIDY_ATTR_CONST(HREF); - TIDY_ATTR_CONST(HREFLANG); - TIDY_ATTR_CONST(HSPACE); - TIDY_ATTR_CONST(HTTP_EQUIV); - TIDY_ATTR_CONST(ID); - TIDY_ATTR_CONST(ISMAP); - TIDY_ATTR_CONST(LABEL); - TIDY_ATTR_CONST(LANG); - TIDY_ATTR_CONST(LANGUAGE); - TIDY_ATTR_CONST(LAST_MODIFIED); - TIDY_ATTR_CONST(LAST_VISIT); - TIDY_ATTR_CONST(LEFTMARGIN); - TIDY_ATTR_CONST(LINK); - TIDY_ATTR_CONST(LONGDESC); - TIDY_ATTR_CONST(LOWSRC); - TIDY_ATTR_CONST(MARGINHEIGHT); - TIDY_ATTR_CONST(MARGINWIDTH); - TIDY_ATTR_CONST(MAXLENGTH); - TIDY_ATTR_CONST(MEDIA); - TIDY_ATTR_CONST(METHOD); - TIDY_ATTR_CONST(MULTIPLE); - TIDY_ATTR_CONST(NAME); - TIDY_ATTR_CONST(NOHREF); - TIDY_ATTR_CONST(NORESIZE); - TIDY_ATTR_CONST(NOSHADE); - TIDY_ATTR_CONST(NOWRAP); - TIDY_ATTR_CONST(OBJECT); - TIDY_ATTR_CONST(OnAFTERUPDATE); - TIDY_ATTR_CONST(OnBEFOREUNLOAD); - TIDY_ATTR_CONST(OnBEFOREUPDATE); - TIDY_ATTR_CONST(OnBLUR); - TIDY_ATTR_CONST(OnCHANGE); - TIDY_ATTR_CONST(OnCLICK); - TIDY_ATTR_CONST(OnDATAAVAILABLE); - TIDY_ATTR_CONST(OnDATASETCHANGED); - TIDY_ATTR_CONST(OnDATASETCOMPLETE); - TIDY_ATTR_CONST(OnDBLCLICK); - TIDY_ATTR_CONST(OnERRORUPDATE); - TIDY_ATTR_CONST(OnFOCUS); - TIDY_ATTR_CONST(OnKEYDOWN); - TIDY_ATTR_CONST(OnKEYPRESS); - TIDY_ATTR_CONST(OnKEYUP); - TIDY_ATTR_CONST(OnLOAD); - TIDY_ATTR_CONST(OnMOUSEDOWN); - TIDY_ATTR_CONST(OnMOUSEMOVE); - TIDY_ATTR_CONST(OnMOUSEOUT); - TIDY_ATTR_CONST(OnMOUSEOVER); - TIDY_ATTR_CONST(OnMOUSEUP); - TIDY_ATTR_CONST(OnRESET); - TIDY_ATTR_CONST(OnROWENTER); - TIDY_ATTR_CONST(OnROWEXIT); - TIDY_ATTR_CONST(OnSELECT); - TIDY_ATTR_CONST(OnSUBMIT); - TIDY_ATTR_CONST(OnUNLOAD); - TIDY_ATTR_CONST(PROFILE); - TIDY_ATTR_CONST(PROMPT); - TIDY_ATTR_CONST(RBSPAN); - TIDY_ATTR_CONST(READONLY); - TIDY_ATTR_CONST(REL); - TIDY_ATTR_CONST(REV); - TIDY_ATTR_CONST(RIGHTMARGIN); - TIDY_ATTR_CONST(ROWS); - TIDY_ATTR_CONST(ROWSPAN); - TIDY_ATTR_CONST(RULES); - TIDY_ATTR_CONST(SCHEME); - TIDY_ATTR_CONST(SCOPE); - TIDY_ATTR_CONST(SCROLLING); - TIDY_ATTR_CONST(SELECTED); - TIDY_ATTR_CONST(SHAPE); - TIDY_ATTR_CONST(SHOWGRID); - TIDY_ATTR_CONST(SHOWGRIDX); - TIDY_ATTR_CONST(SHOWGRIDY); - TIDY_ATTR_CONST(SIZE); - TIDY_ATTR_CONST(SPAN); - TIDY_ATTR_CONST(SRC); - TIDY_ATTR_CONST(STANDBY); - TIDY_ATTR_CONST(START); - TIDY_ATTR_CONST(STYLE); - TIDY_ATTR_CONST(SUMMARY); - TIDY_ATTR_CONST(TABINDEX); - TIDY_ATTR_CONST(TARGET); - TIDY_ATTR_CONST(TEXT); - TIDY_ATTR_CONST(TITLE); - TIDY_ATTR_CONST(TOPMARGIN); - TIDY_ATTR_CONST(TYPE); - TIDY_ATTR_CONST(USEMAP); - TIDY_ATTR_CONST(VALIGN); - TIDY_ATTR_CONST(VALUE); - TIDY_ATTR_CONST(VALUETYPE); - TIDY_ATTR_CONST(VERSION); - TIDY_ATTR_CONST(VLINK); - TIDY_ATTR_CONST(VSPACE); - TIDY_ATTR_CONST(WIDTH); - TIDY_ATTR_CONST(WRAP); - TIDY_ATTR_CONST(XML_LANG); - TIDY_ATTR_CONST(XML_SPACE); - TIDY_ATTR_CONST(XMLNS); - -} |