Menu Adam R Brown

WP hooks navigation: Home/browseActions indexFilters index

Source View: comment_feed_join

To save our bandwidth, we show only a snippet of code around each occurence of the hook. View complete file in SVN (without highlighting).

Understanding Source Code

The best way to understand what a hook does is to look at where it occurs in the source code.

Remember, this hook may occur in more than one file. Moreover, the hook's context may change from version to version.

Source View

This hook occurs 2 times in this file.

Line Code
2802                     $cwhere = "WHERE comment_approved = '1' $where";
2803                     $cgroupby = "$wpdb->comments.comment_id";
2804                } else { // Other non singular e.g. front
2805                     $cjoin = "JOIN $wpdb->posts ON ( $wpdb->comments.comment_post_ID = $wpdb->posts.ID )";
2806                     $cwhere = "WHERE post_status = 'publish' AND comment_approved = '1'";
2807                     $cgroupby = '';
2808                }
2809
2810                if ( !$q['suppress_filters'] ) {
2811                     $cjoin = apply_filters_ref_array('comment_feed_join', array( $cjoin, &$this ) );
2812                     $cwhere = apply_filters_ref_array('comment_feed_where', array( $cwhere, &$this ) );
2813                     $cgroupby = apply_filters_ref_array('comment_feed_groupby', array( $cgroupby, &$this ) );
2814                     $corderby = apply_filters_ref_array('comment_feed_orderby', array( 'comment_date_gmt DESC', &$this ) );
2815                     $climits = apply_filters_ref_array('comment_feed_limits', array( 'LIMIT ' . get_option('posts_per_rss'), &$this ) );
2816                }
2817                $cgroupby = ( ! empty( $cgroupby ) ) ? 'GROUP BY ' . $cgroupby : '';
2818                $corderby = ( ! empty( $corderby ) ) ? 'ORDER BY ' . $corderby : '';
2819
2820                $this->comments = (array) $wpdb->get_results("SELECT $distinct $wpdb->comments.* FROM $wpdb->comments $cjoin $cwhere $cgroupby $corderby $climits");
 
Line Code
2933           // Convert to WP_Post objects
2934           if ( $this->posts )
2935                $this->posts = array_map( 'get_post', $this->posts );
2936
2937           // Raw results filter. Prior to status checks.
2938           if ( !$q['suppress_filters'] )
2939                $this->posts = apply_filters_ref_array('posts_results', array( $this->posts, &$this ) );
2940
2941           if ( !empty($this->posts) && $this->is_comment_feed && $this->is_singular ) {
2942                $cjoin = apply_filters_ref_array('comment_feed_join', array( '', &$this ) );
2943                $cwhere = apply_filters_ref_array('comment_feed_where', array( "WHERE comment_post_ID = '{$this->posts[0]->ID}' AND comment_approved = '1'", &$this ) );
2944                $cgroupby = apply_filters_ref_array('comment_feed_groupby', array( '', &$this ) );
2945                $cgroupby = ( ! empty( $cgroupby ) ) ? 'GROUP BY ' . $cgroupby : '';
2946                $corderby = apply_filters_ref_array('comment_feed_orderby', array( 'comment_date_gmt DESC', &$this ) );
2947                $corderby = ( ! empty( $corderby ) ) ? 'ORDER BY ' . $corderby : '';
2948                $climits = apply_filters_ref_array('comment_feed_limits', array( 'LIMIT ' . get_option('posts_per_rss'), &$this ) );
2949                $comments_request = "SELECT $wpdb->comments.* FROM $wpdb->comments $cjoin $cwhere $cgroupby $corderby $climits";
2950                $this->comments = $wpdb->get_results($comments_request);
2951                $this->comment_count = count($this->comments);