diff options
Diffstat (limited to 'wp-includes')
-rw-r--r-- | wp-includes/classes.php | 6 | ||||
-rw-r--r-- | wp-includes/comment.php | 2 | ||||
-rw-r--r-- | wp-includes/plugin.php | 32 | ||||
-rw-r--r-- | wp-includes/query.php | 6 | ||||
-rw-r--r-- | wp-includes/rewrite.php | 2 |
5 files changed, 38 insertions, 10 deletions
diff --git a/wp-includes/classes.php b/wp-includes/classes.php index 3c1db01..a23442c 100644 --- a/wp-includes/classes.php +++ b/wp-includes/classes.php @@ -228,7 +228,7 @@ class WP { $this->query_vars = apply_filters('request', $this->query_vars); - do_action('parse_request', array(&$this)); + do_action_ref_array('parse_request', array(&$this)); } function send_headers() { @@ -270,7 +270,7 @@ class WP { } } - do_action('send_headers', array(&$this)); + do_action_ref_array('send_headers', array(&$this)); } function build_query_string() { @@ -338,7 +338,7 @@ class WP { $this->query_posts(); $this->handle_404(); $this->register_globals(); - do_action('wp', array(&$this)); + do_action_ref_array('wp', array(&$this)); } function WP() { diff --git a/wp-includes/comment.php b/wp-includes/comment.php index 514197f..45fe0f8 100644 --- a/wp-includes/comment.php +++ b/wp-includes/comment.php @@ -695,7 +695,7 @@ function pingback($content, $post_ID) { endif; endforeach; - do_action('pre_ping', array(&$post_links, &$pung)); + do_action_ref_array('pre_ping', array(&$post_links, &$pung)); foreach ($post_links as $pagelinkedto){ debug_fwrite($log, "Processing -- $pagelinkedto\n"); diff --git a/wp-includes/plugin.php b/wp-includes/plugin.php index 1fe2c80..365a6f8 100644 --- a/wp-includes/plugin.php +++ b/wp-includes/plugin.php @@ -111,9 +111,37 @@ function do_action($tag, $arg = '') { merge_filters($tag); - if ( !isset($wp_filter[$tag]) ) { + if ( !isset($wp_filter[$tag]) ) return; + + foreach ($wp_filter[$tag] as $priority => $functions) { + if ( !is_null($functions) ) { + foreach($functions as $function) { + + $function_name = $function['function']; + $accepted_args = $function['accepted_args']; + + if ( $accepted_args > 0 ) + $the_args = array_slice($args, 0, $accepted_args); + elseif ( $accepted_args == 0 ) + $the_args = NULL; + else + $the_args = $args; + + call_user_func_array($function_name, $the_args); + } + } } +} + +function do_action_ref_array($tag, $args) { + global $wp_filter; + + merge_filters($tag); + + if ( !isset($wp_filter[$tag]) ) + return; + foreach ($wp_filter[$tag] as $priority => $functions) { if ( !is_null($functions) ) { foreach($functions as $function) { @@ -128,7 +156,7 @@ function do_action($tag, $arg = '') { else $the_args = $args; - $string = call_user_func_array($function_name, $the_args); + call_user_func_array($function_name, $the_args); } } } diff --git a/wp-includes/query.php b/wp-includes/query.php index 925eff5..689b27f 100644 --- a/wp-includes/query.php +++ b/wp-includes/query.php @@ -350,7 +350,7 @@ class WP_Query { if ('404' == $qv['error']) {
$this->is_404 = true;
if ( !empty($query) ) {
- do_action('parse_query', array(&$this));
+ do_action_ref_array('parse_query', array(&$this));
}
return;
}
@@ -498,7 +498,7 @@ class WP_Query { }
if ( !empty($query) ) {
- do_action('parse_query', array(&$this));
+ do_action_ref_array('parse_query', array(&$this));
}
}
@@ -526,7 +526,7 @@ class WP_Query { function &get_posts() {
global $wpdb, $pagenow, $user_ID;
- do_action('pre_get_posts', array(&$this));
+ do_action_ref_array('pre_get_posts', array(&$this));
// Shorthand.
$q = &$this->query_vars;
diff --git a/wp-includes/rewrite.php b/wp-includes/rewrite.php index 7865351..75445f8 100644 --- a/wp-includes/rewrite.php +++ b/wp-includes/rewrite.php @@ -735,7 +735,7 @@ class WP_Rewrite { // Put them together.
$this->rules = array_merge($robots_rewrite, $page_rewrite, $root_rewrite, $comments_rewrite, $search_rewrite, $category_rewrite, $author_rewrite, $date_rewrite, $post_rewrite, $this->extra_rules);
- do_action('generate_rewrite_rules', array(&$this));
+ do_action_ref_array('generate_rewrite_rules', array(&$this));
$this->rules = apply_filters('rewrite_rules_array', $this->rules);
return $this->rules;
|