123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389 |
- <?php
- // misc help functions and utilities
- function rand_str($len=32) {
- return substr(md5(uniqid(rand())), 0, $len);
- }
- // strip leading and trailing whitespace from each line in the string
- function strip_ws($txt) {
- $lines = explode("\n", $txt);
- $result = array();
- foreach ($lines as $line)
- if (trim($line))
- $result[] = trim($line);
- return trim(join("\n", $result));
- }
- // helper class for testing code that involves actions and filters
- // typical use:
- // $ma = new MockAction();
- // add_action('foo', array(&$ma, 'action'));
- class MockAction {
- var $events;
- var $debug;
- function MockAction($debug=0) {
- $this->reset();
- $this->debug = $debug;
- }
- function reset() {
- $this->events = array();
- }
- function current_filter() {
- if (is_callable('current_filter'))
- return current_filter();
- global $wp_actions;
- return end($wp_actions);
- }
- function action($arg) {
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('action' => __FUNCTION__, 'tag'=>$this->current_filter(), 'args'=>$args);
- return $arg;
- }
- function action2($arg) {
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('action' => __FUNCTION__, 'tag'=>$this->current_filter(), 'args'=>$args);
- return $arg;
- }
- function filter($arg) {
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('filter' => __FUNCTION__, 'tag'=>$this->current_filter(), 'args'=>$args);
- return $arg;
- }
- function filter2($arg) {
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('filter' => __FUNCTION__, 'tag'=>$this->current_filter(), 'args'=>$args);
- return $arg;
- }
- function filter_append($arg) {
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('filter' => __FUNCTION__, 'tag'=>$this->current_filter(), 'args'=>$args);
- return $arg . '_append';
- }
- function filterall($tag, $arg=NULL) {
- // this one doesn't return the result, so it's safe to use with the new 'all' filter
- if ($this->debug) dmp(__FUNCTION__, $this->current_filter());
- $args = func_get_args();
- $this->events[] = array('filter' => __FUNCTION__, 'tag'=>$tag, 'args'=>array_slice($args, 1));
- }
- // return a list of all the actions, tags and args
- function get_events() {
- return $this->events;
- }
- // return a count of the number of times the action was called since the last reset
- function get_call_count($tag='') {
- if ($tag) {
- $count = 0;
- foreach ($this->events as $e)
- if ($e['action'] == $tag)
- ++$count;
- return $count;
- }
- return count($this->events);
- }
- // return an array of the tags that triggered calls to this action
- function get_tags() {
- $out = array();
- foreach ($this->events as $e) {
- $out[] = $e['tag'];
- }
- return $out;
- }
- // return an array of args passed in calls to this action
- function get_args() {
- $out = array();
- foreach ($this->events as $e)
- $out[] = $e['args'];
- return $out;
- }
- }
- // convert valid xml to an array tree structure
- // kinda lame but it works with a default php 4 install
- class testXMLParser {
- var $xml;
- var $data = array();
- function testXMLParser($in) {
- $this->xml = xml_parser_create();
- xml_set_object($this->xml, $this);
- xml_parser_set_option($this->xml,XML_OPTION_CASE_FOLDING, 0);
- xml_set_element_handler($this->xml, array($this, 'startHandler'), array($this, 'endHandler'));
- xml_set_character_data_handler($this->xml, array($this, 'dataHandler'));
- $this->parse($in);
- }
- function parse($in) {
- $parse = xml_parse($this->xml, $in, sizeof($in));
- if (!$parse) {
- trigger_error(sprintf("XML error: %s at line %d",
- xml_error_string(xml_get_error_code($this->xml)),
- xml_get_current_line_number($this->xml)), E_USER_ERROR);
- xml_parser_free($this->xml);
- }
- return true;
- }
- function startHandler($parser, $name, $attributes) {
- $data['name'] = $name;
- if ($attributes) { $data['attributes'] = $attributes; }
- $this->data[] = $data;
- }
- function dataHandler($parser, $data) {
- $index = count($this->data) - 1;
- @$this->data[$index]['content'] .= $data;
- }
- function endHandler($parser, $name) {
- if (count($this->data) > 1) {
- $data = array_pop($this->data);
- $index = count($this->data) - 1;
- $this->data[$index]['child'][] = $data;
- }
- }
- }
- function xml_to_array($in) {
- $p = new testXMLParser($in);
- return $p->data;
- }
- function xml_find($tree /*, $el1, $el2, $el3, .. */) {
- $a = func_get_args();
- $a = array_slice($a, 1);
- $n = count($a);
- $out = array();
- if ($n < 1)
- return $out;
- for ($i=0; $i<count($tree); $i++) {
- # echo "checking '{$tree[$i][name]}' == '{$a[0]}'\n";
- # var_dump($tree[$i]['name'], $a[0]);
- if ($tree[$i]['name'] == $a[0]) {
- # echo "n == {$n}\n";
- if ($n == 1)
- $out[] = $tree[$i];
- else {
- $subtree =& $tree[$i]['child'];
- $call_args = array($subtree);
- $call_args = array_merge($call_args, array_slice($a, 1));
- $out = array_merge($out, call_user_func_array('xml_find', $call_args));
- }
- }
- }
- return $out;
- }
- function xml_join_atts($atts) {
- $a = array();
- foreach ($atts as $k=>$v)
- $a[] = $k.'="'.$v.'"';
- return join(' ', $a);
- }
- function xml_array_dumbdown(&$data) {
- $out = array();
- foreach (array_keys($data) as $i) {
- $name = $data[$i]['name'];
- if (!empty($data[$i]['attributes']))
- $name .= ' '.xml_join_atts($data[$i]['attributes']);
- if (!empty($data[$i]['child'])) {
- $out[$name][] = xml_array_dumbdown($data[$i]['child']);
- }
- else
- $out[$name] = $data[$i]['content'];
- }
- return $out;
- }
- function dmp() {
- $args = func_get_args();
- foreach ($args as $thing)
- echo (is_scalar($thing) ? strval($thing) : var_export($thing, true)), "\n";
- }
- function dmp_filter($a) {
- dmp($a);
- return $a;
- }
- function get_echo($callable, $args = array()) {
- ob_start();
- call_user_func_array($callable, $args);
- return ob_get_clean();
- }
- // recursively generate some quick assertEquals tests based on an array
- function gen_tests_array($name, $array) {
- $out = array();
- foreach ($array as $k=>$v) {
- if (is_numeric($k))
- $index = strval($k);
- else
- $index = "'".addcslashes($k, "\n\r\t'\\")."'";
- if (is_string($v)) {
- $out[] = '$this->assertEquals( \'' . addcslashes($v, "\n\r\t'\\") . '\', $'.$name.'['.$index.'] );';
- }
- elseif (is_numeric($v)) {
- $out[] = '$this->assertEquals( ' . $v . ', $'.$name.'['.$index.'] );';
- }
- elseif (is_array($v)) {
- $out[] = gen_tests_array("{$name}[{$index}]", $v);
- }
- }
- return join("\n", $out)."\n";
- }
- /**
- * Use to create objects by yourself
- */
- class MockClass {};
- /**
- * Drops all tables from the WordPress database
- */
- function drop_tables() {
- global $wpdb;
- $tables = $wpdb->get_col('SHOW TABLES;');
- foreach ($tables as $table)
- $wpdb->query("DROP TABLE IF EXISTS {$table}");
- }
- function print_backtrace() {
- $bt = debug_backtrace();
- echo "Backtrace:\n";
- $i = 0;
- foreach ($bt as $stack) {
- echo ++$i, ": ";
- if ( isset($stack['class']) )
- echo $stack['class'].'::';
- if ( isset($stack['function']) )
- echo $stack['function'].'() ';
- echo "line {$stack[line]} in {$stack[file]}\n";
- }
- echo "\n";
- }
- // mask out any input fields matching the given name
- function mask_input_value($in, $name='_wpnonce') {
- return preg_replace('@<input([^>]*) name="'.preg_quote($name).'"([^>]*) value="[^>]*" />@', '<input$1 name="'.preg_quote($name).'"$2 value="***" />', $in);
- }
- $GLOBALS['_wp_die_disabled'] = false;
- function _wp_die_handler( $message, $title = '', $args = array() ) {
- if ( !$GLOBALS['_wp_die_disabled'] ) {
- _default_wp_die_handler( $message, $title, $args );
- } else {
- //Ignore at our peril
- }
- }
- function _disable_wp_die() {
- $GLOBALS['_wp_die_disabled'] = true;
- }
- function _enable_wp_die() {
- $GLOBALS['_wp_die_disabled'] = false;
- }
- function _wp_die_handler_filter() {
- return '_wp_die_handler';
- }
- if ( !function_exists( 'str_getcsv' ) ) {
- function str_getcsv( $input, $delimiter = ',', $enclosure = '"', $escape = "\\" ) {
- $fp = fopen( 'php://temp/', 'r+' );
- fputs( $fp, $input );
- rewind( $fp );
- $data = fgetcsv( $fp, strlen( $input ), $delimiter, $enclosure );
- fclose( $fp );
- return $data;
- }
- }
- function _rmdir( $path ) {
- if ( in_array(basename( $path ), array( '.', '..' ) ) ) {
- return;
- } elseif ( is_file( $path ) ) {
- unlink( $path );
- } elseif ( is_dir( $path ) ) {
- foreach ( scandir( $path ) as $file )
- _rmdir( $path . '/' . $file );
- rmdir( $path );
- }
- }
- /**
- * Removes the post type and its taxonomy associations.
- */
- function _unregister_post_type( $cpt_name ) {
- unset( $GLOBALS['wp_post_types'][ $cpt_name ] );
- unset( $GLOBALS['_wp_post_type_features'][ $cpt_name ] );
- foreach ( $GLOBALS['wp_taxonomies'] as $taxonomy ) {
- if ( false !== $key = array_search( $cpt_name, $taxonomy->object_type ) ) {
- unset( $taxonomy->object_type[$key] );
- }
- }
- }
- function _unregister_taxonomy( $taxonomy_name ) {
- unset( $GLOBALS['wp_taxonomies'][$taxonomy_name] );
- }
- function _cleanup_query_vars() {
- // clean out globals to stop them polluting wp and wp_query
- foreach ( $GLOBALS['wp']->public_query_vars as $v )
- unset( $GLOBALS[$v] );
- foreach ( $GLOBALS['wp']->private_query_vars as $v )
- unset( $GLOBALS[$v] );
- foreach ( get_taxonomies( array() , 'objects' ) as $t ) {
- if ( ! empty( $t->query_var ) )
- $GLOBALS['wp']->add_query_var( $t->query_var );
- }
- foreach ( get_post_types( array() , 'objects' ) as $t ) {
- if ( ! empty( $t->query_var ) )
- $GLOBALS['wp']->add_query_var( $t->query_var );
- }
- }
- function _clean_term_filters() {
- remove_filter( 'get_terms', array( 'Featured_Content', 'hide_featured_term' ), 10, 2 );
- remove_filter( 'get_the_terms', array( 'Featured_Content', 'hide_the_featured_term' ), 10, 3 );
- }
|