Mike filter suppression. Props DD32. see #7326

git-svn-id: http://svn.automattic.com/wordpress/trunk@8773 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2008-08-29 18:33:04 +00:00
parent e1226189ad
commit e1ebd0e10a

View File

@ -778,7 +778,7 @@ class WP_Query {
if ( !empty($qv['post_status']) ) if ( !empty($qv['post_status']) )
$qv['post_status'] = preg_replace('|[^a-z0-9_,-]|', '', $qv['post_status']); $qv['post_status'] = preg_replace('|[^a-z0-9_,-]|', '', $qv['post_status']);
if ( $this->is_posts_page && !$qv['withcomments'] ) if ( $this->is_posts_page && ( ! isset($qv['withcomments']) || ! $qv['withcomments'] ) )
$this->is_comment_feed = false; $this->is_comment_feed = false;
$this->is_singular = $this->is_single || $this->is_page || $this->is_attachment; $this->is_singular = $this->is_single || $this->is_page || $this->is_attachment;
@ -832,7 +832,9 @@ class WP_Query {
$join = ''; $join = '';
$search = ''; $search = '';
$groupby = ''; $groupby = '';
$fields = "$wpdb->posts.*";
$post_status_join = false; $post_status_join = false;
$page = 1;
if ( !isset($q['caller_get_posts']) ) if ( !isset($q['caller_get_posts']) )
$q['caller_get_posts'] = false; $q['caller_get_posts'] = false;
@ -1432,15 +1434,17 @@ class WP_Query {
$where = "AND 0"; $where = "AND 0";
} }
$orderby = $q['orderby'];
// Apply post-paging filters on where and join. Only plugins that // Apply post-paging filters on where and join. Only plugins that
// manipulate paging queries should use these hooks. // manipulate paging queries should use these hooks.
if ( !$q['suppress_filters'] ) { if ( !$q['suppress_filters'] ) {
$where = apply_filters('posts_where_paged', $where); $where = apply_filters('posts_where_paged', $where);
$groupby = apply_filters('posts_groupby', $groupby); $groupby = apply_filters('posts_groupby', $groupby);
$join = apply_filters('posts_join_paged', $join); $join = apply_filters('posts_join_paged', $join);
$orderby = apply_filters('posts_orderby', $q['orderby']); $orderby = apply_filters('posts_orderby', $orderby);
$distinct = apply_filters('posts_distinct', $distinct); $distinct = apply_filters('posts_distinct', $distinct);
$fields = apply_filters('posts_fields', "$wpdb->posts.*"); $fields = apply_filters('posts_fields', $fields);
$limits = apply_filters( 'post_limits', $limits ); $limits = apply_filters( 'post_limits', $limits );
} }
@ -1466,9 +1470,9 @@ class WP_Query {
if ( !empty($limits) ) if ( !empty($limits) )
$found_rows = 'SQL_CALC_FOUND_ROWS'; $found_rows = 'SQL_CALC_FOUND_ROWS';
$request = " SELECT $found_rows $distinct $fields FROM $wpdb->posts $join WHERE 1=1 $where $groupby $orderby $limits"; $this->request = " SELECT $found_rows $distinct $fields FROM $wpdb->posts $join WHERE 1=1 $where $groupby $orderby $limits";
if ( !$q['suppress_filters'] ) if ( !$q['suppress_filters'] )
$this->request = apply_filters('posts_request', $request); $this->request = apply_filters('posts_request', $this->request);
$this->posts = $wpdb->get_results($this->request); $this->posts = $wpdb->get_results($this->request);
// Raw results filter. Prior to status checks. // Raw results filter. Prior to status checks.