2006-03-12 20:44:32 -05:00
< ? php
/*
* The Big Query .
*/
2006-11-19 02:56:05 -05:00
2006-03-12 20:44:32 -05:00
function get_query_var ( $var ) {
global $wp_query ;
return $wp_query -> get ( $var );
}
2007-02-24 02:33:29 -05:00
function set_query_var ( $var , $value ) {
global $wp_query ;
return $wp_query -> set ( $var , $value );
}
2006-03-12 20:44:32 -05:00
function & query_posts ( $query ) {
2006-11-09 01:50:58 -05:00
unset ( $GLOBALS [ 'wp_query' ]);
$GLOBALS [ 'wp_query' ] =& new WP_Query ();
return $GLOBALS [ 'wp_query' ] -> query ( $query );
2006-03-12 20:44:32 -05:00
}
2007-08-20 18:55:43 -04:00
function wp_reset_query () {
unset ( $GLOBALS [ 'wp_query' ]);
$GLOBALS [ 'wp_query' ] =& $GLOBALS [ 'wp_the_query' ];
}
2006-03-12 20:44:32 -05:00
/*
* Query type checks .
*/
function is_admin () {
global $wp_query ;
2007-03-07 00:29:15 -05:00
return ( $wp_query -> is_admin || ( strpos ( $_SERVER [ 'REQUEST_URI' ], 'wp-admin/' ) !== false ));
2006-03-12 20:44:32 -05:00
}
function is_archive () {
global $wp_query ;
return $wp_query -> is_archive ;
}
function is_attachment () {
global $wp_query ;
return $wp_query -> is_attachment ;
}
function is_author ( $author = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_author )
return false ;
if ( empty ( $author ) )
return true ;
$author_obj = $wp_query -> get_queried_object ();
if ( $author == $author_obj -> ID )
return true ;
elseif ( $author == $author_obj -> nickname )
return true ;
elseif ( $author == $author_obj -> user_nicename )
return true ;
return false ;
}
function is_category ( $category = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_category )
return false ;
if ( empty ( $category ) )
return true ;
$cat_obj = $wp_query -> get_queried_object ();
2007-05-23 14:59:12 -04:00
if ( $category == $cat_obj -> term_id )
2006-03-12 20:44:32 -05:00
return true ;
2007-05-23 14:59:12 -04:00
else if ( $category == $cat_obj -> name )
2006-03-12 20:44:32 -05:00
return true ;
2007-05-23 14:59:12 -04:00
elseif ( $category == $cat_obj -> slug )
2006-03-12 20:44:32 -05:00
return true ;
return false ;
}
2007-03-31 02:16:12 -04:00
function is_tag ( $slug = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_tag )
return false ;
if ( empty ( $slug ) )
return true ;
2007-05-22 23:57:20 -04:00
$tag_obj = $wp_query -> get_queried_object ();
if ( $slug == $tag_obj -> slug )
2007-03-31 02:16:12 -04:00
return true ;
return false ;
}
2006-03-12 20:44:32 -05:00
function is_comments_popup () {
global $wp_query ;
return $wp_query -> is_comments_popup ;
}
function is_date () {
global $wp_query ;
return $wp_query -> is_date ;
}
function is_day () {
global $wp_query ;
return $wp_query -> is_day ;
}
function is_feed () {
global $wp_query ;
return $wp_query -> is_feed ;
}
function is_home () {
global $wp_query ;
return $wp_query -> is_home ;
}
function is_month () {
global $wp_query ;
return $wp_query -> is_month ;
}
function is_page ( $page = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_page )
return false ;
if ( empty ( $page ) )
return true ;
$page_obj = $wp_query -> get_queried_object ();
if ( $page == $page_obj -> ID )
return true ;
elseif ( $page == $page_obj -> post_title )
return true ;
else if ( $page == $page_obj -> post_name )
return true ;
return false ;
}
function is_paged () {
global $wp_query ;
return $wp_query -> is_paged ;
}
function is_plugin_page () {
global $plugin_page ;
if ( isset ( $plugin_page ) )
return true ;
return false ;
}
function is_preview () {
global $wp_query ;
return $wp_query -> is_preview ;
}
2006-05-22 18:06:06 -04:00
function is_robots () {
global $wp_query ;
return $wp_query -> is_robots ;
}
2006-03-12 20:44:32 -05:00
function is_search () {
global $wp_query ;
return $wp_query -> is_search ;
}
function is_single ( $post = '' ) {
global $wp_query ;
if ( ! $wp_query -> is_single )
return false ;
if ( empty ( $post ) )
return true ;
$post_obj = $wp_query -> get_queried_object ();
if ( $post == $post_obj -> ID )
return true ;
elseif ( $post == $post_obj -> post_title )
return true ;
elseif ( $post == $post_obj -> post_name )
return true ;
return false ;
}
2006-08-29 23:33:39 -04:00
function is_singular () {
global $wp_query ;
2007-02-27 10:24:54 -05:00
return $wp_query -> is_singular ;
2006-08-29 23:33:39 -04:00
}
2006-03-12 20:44:32 -05:00
function is_time () {
global $wp_query ;
return $wp_query -> is_time ;
}
function is_trackback () {
global $wp_query ;
return $wp_query -> is_trackback ;
}
function is_year () {
global $wp_query ;
return $wp_query -> is_year ;
}
function is_404 () {
global $wp_query ;
return $wp_query -> is_404 ;
}
/*
* The Loop . Post loop control .
*/
2006-11-19 02:56:05 -05:00
2006-03-12 20:44:32 -05:00
function have_posts () {
global $wp_query ;
return $wp_query -> have_posts ();
}
function in_the_loop () {
global $wp_query ;
return $wp_query -> in_the_loop ;
}
function rewind_posts () {
global $wp_query ;
return $wp_query -> rewind_posts ();
}
function the_post () {
global $wp_query ;
$wp_query -> the_post ();
}
2007-02-24 02:33:29 -05:00
/*
* Comments loop .
*/
function have_comments () {
global $wp_query ;
return $wp_query -> have_comments ();
}
function the_comment () {
global $wp_query ;
return $wp_query -> the_comment ();
}
2006-03-12 20:44:32 -05:00
/*
* WP_Query
*/
class WP_Query {
var $query ;
2006-10-22 21:34:00 -04:00
var $query_vars = array ();
2006-03-12 20:44:32 -05:00
var $queried_object ;
var $queried_object_id ;
var $request ;
var $posts ;
var $post_count = 0 ;
var $current_post = - 1 ;
var $in_the_loop = false ;
var $post ;
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
var $comments ;
var $comment_count = 0 ;
var $current_comment = - 1 ;
var $comment ;
2006-03-12 20:44:32 -05:00
2006-11-08 16:22:35 -05:00
var $found_posts = 0 ;
var $max_num_pages = 0 ;
2006-03-12 20:44:32 -05:00
var $is_single = false ;
var $is_preview = false ;
var $is_page = false ;
var $is_archive = false ;
var $is_date = false ;
var $is_year = false ;
var $is_month = false ;
var $is_day = false ;
var $is_time = false ;
var $is_author = false ;
var $is_category = false ;
2007-03-31 02:16:12 -04:00
var $is_tag = false ;
2006-03-12 20:44:32 -05:00
var $is_search = false ;
var $is_feed = false ;
2007-02-24 02:33:29 -05:00
var $is_comment_feed = false ;
2006-03-12 20:44:32 -05:00
var $is_trackback = false ;
var $is_home = false ;
var $is_404 = false ;
var $is_comments_popup = false ;
var $is_admin = false ;
var $is_attachment = false ;
2006-08-29 23:33:39 -04:00
var $is_singular = false ;
2006-05-22 18:06:06 -04:00
var $is_robots = false ;
2006-07-19 22:05:25 -04:00
var $is_posts_page = false ;
2006-03-12 20:44:32 -05:00
function init_query_flags () {
$this -> is_single = false ;
$this -> is_page = false ;
$this -> is_archive = false ;
$this -> is_date = false ;
$this -> is_year = false ;
$this -> is_month = false ;
$this -> is_day = false ;
$this -> is_time = false ;
$this -> is_author = false ;
$this -> is_category = false ;
2007-03-31 02:16:12 -04:00
$this -> is_tag = false ;
2006-03-12 20:44:32 -05:00
$this -> is_search = false ;
$this -> is_feed = false ;
2007-02-24 02:33:29 -05:00
$this -> is_comment_feed = false ;
2006-03-12 20:44:32 -05:00
$this -> is_trackback = false ;
$this -> is_home = false ;
$this -> is_404 = false ;
$this -> is_paged = false ;
$this -> is_admin = false ;
$this -> is_attachment = false ;
2006-08-29 23:33:39 -04:00
$this -> is_singular = false ;
2006-05-22 18:06:06 -04:00
$this -> is_robots = false ;
2006-07-19 22:05:25 -04:00
$this -> is_posts_page = false ;
2006-03-12 20:44:32 -05:00
}
function init () {
unset ( $this -> posts );
unset ( $this -> query );
2006-10-22 21:34:00 -04:00
$this -> query_vars = array ();
2006-03-12 20:44:32 -05:00
unset ( $this -> queried_object );
unset ( $this -> queried_object_id );
$this -> post_count = 0 ;
$this -> current_post = - 1 ;
$this -> in_the_loop = false ;
$this -> init_query_flags ();
}
// Reparse the query vars.
function parse_query_vars () {
$this -> parse_query ( '' );
}
2007-02-27 10:24:54 -05:00
2006-09-21 17:05:38 -04:00
function fill_query_vars ( $array ) {
$keys = array (
'error'
, 'm'
, 'p'
, 'subpost'
, 'subpost_id'
, 'attachment'
, 'attachment_id'
, 'name'
, 'hour'
, 'static'
, 'pagename'
, 'page_id'
, 'second'
, 'minute'
, 'hour'
, 'day'
, 'monthnum'
, 'year'
, 'w'
, 'category_name'
2007-03-31 02:16:12 -04:00
, 'tag'
2006-09-21 17:05:38 -04:00
, 'author_name'
, 'feed'
, 'tb'
, 'paged'
, 'comments_popup'
, 'preview'
);
foreach ( $keys as $key ) {
if ( ! isset ( $array [ $key ]))
$array [ $key ] = '' ;
}
2007-02-27 10:24:54 -05:00
2007-08-15 18:08:51 -04:00
$array_keys = array ( 'category__in' , 'category__not_in' , 'category__and' );
foreach ( $array_keys as $key ) {
if ( ! isset ( $array [ $key ]))
$array [ $key ] = array ();
}
2006-09-21 17:05:38 -04:00
return $array ;
}
2006-03-12 20:44:32 -05:00
// Parse a query string and set query type booleans.
function parse_query ( $query ) {
if ( ! empty ( $query ) || ! isset ( $this -> query ) ) {
$this -> init ();
2006-08-30 00:02:12 -04:00
if ( is_array ( $query ) )
2007-03-08 23:05:28 -05:00
$this -> query_vars = $query ;
2006-08-30 00:02:12 -04:00
else
2007-03-08 23:05:28 -05:00
parse_str ( $query , $this -> query_vars );
2006-03-12 20:44:32 -05:00
$this -> query = $query ;
}
2007-02-27 10:24:54 -05:00
2007-03-08 23:05:28 -05:00
$this -> query_vars = $this -> fill_query_vars ( $this -> query_vars );
$qv = & $this -> query_vars ;
2007-02-27 10:24:54 -05:00
2006-05-22 18:06:06 -04:00
if ( ! empty ( $qv [ 'robots' ]) ) {
$this -> is_robots = true ;
return ;
}
2006-03-12 20:44:32 -05:00
if ( '404' == $qv [ 'error' ]) {
$this -> is_404 = true ;
if ( ! empty ( $query ) ) {
2006-09-12 13:45:23 -04:00
do_action_ref_array ( 'parse_query' , array ( & $this ));
2006-03-12 20:44:32 -05:00
}
return ;
}
$qv [ 'p' ] = ( int ) $qv [ 'p' ];
2007-03-08 23:05:28 -05:00
$qv [ 'page_id' ] = ( int ) $qv [ 'page_id' ];
$qv [ 'year' ] = ( int ) $qv [ 'year' ];
$qv [ 'monthnum' ] = ( int ) $qv [ 'monthnum' ];
$qv [ 'day' ] = ( int ) $qv [ 'day' ];
$qv [ 'w' ] = ( int ) $qv [ 'w' ];
$qv [ 'm' ] = ( int ) $qv [ 'm' ];
2007-08-04 12:30:27 -04:00
if ( '' !== $qv [ 'hour' ] ) $qv [ 'hour' ] = ( int ) $qv [ 'hour' ];
if ( '' !== $qv [ 'minute' ] ) $qv [ 'minute' ] = ( int ) $qv [ 'minute' ];
if ( '' !== $qv [ 'second' ] ) $qv [ 'second' ] = ( int ) $qv [ 'second' ];
2006-03-12 20:44:32 -05:00
// Compat. Map subpost to attachment.
if ( '' != $qv [ 'subpost' ] )
$qv [ 'attachment' ] = $qv [ 'subpost' ];
if ( '' != $qv [ 'subpost_id' ] )
$qv [ 'attachment_id' ] = $qv [ 'subpost_id' ];
2007-03-08 23:05:28 -05:00
$qv [ 'attachment_id' ] = ( int ) $qv [ 'attachment_id' ];
2007-06-13 22:25:30 -04:00
2007-03-08 23:05:28 -05:00
if ( ( '' != $qv [ 'attachment' ]) || ! empty ( $qv [ 'attachment_id' ]) ) {
2006-03-12 20:44:32 -05:00
$this -> is_single = true ;
$this -> is_attachment = true ;
2007-03-08 23:05:28 -05:00
} elseif ( '' != $qv [ 'name' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_single = true ;
} elseif ( $qv [ 'p' ] ) {
$this -> is_single = true ;
2007-08-04 12:30:27 -04:00
} elseif ( ( '' !== $qv [ 'hour' ]) && ( '' !== $qv [ 'minute' ]) && ( '' !== $qv [ 'second' ]) && ( '' != $qv [ 'year' ]) && ( '' != $qv [ 'monthnum' ]) && ( '' != $qv [ 'day' ]) ) {
2006-11-19 02:56:05 -05:00
// If year, month, day, hour, minute, and second are set, a single
// post is being queried.
2006-03-12 20:44:32 -05:00
$this -> is_single = true ;
2007-03-08 23:05:28 -05:00
} elseif ( '' != $qv [ 'static' ] || '' != $qv [ 'pagename' ] || ! empty ( $qv [ 'page_id' ]) ) {
2006-03-12 20:44:32 -05:00
$this -> is_page = true ;
$this -> is_single = false ;
2007-03-08 23:05:28 -05:00
} elseif ( ! empty ( $qv [ 's' ]) ) {
2006-03-12 20:44:32 -05:00
$this -> is_search = true ;
} else {
// Look for archive queries. Dates, categories, authors.
2007-08-04 12:30:27 -04:00
if ( '' !== $qv [ 'second' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_time = true ;
$this -> is_date = true ;
}
2007-08-04 12:30:27 -04:00
if ( '' !== $qv [ 'minute' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_time = true ;
$this -> is_date = true ;
}
2007-08-04 12:30:27 -04:00
if ( '' !== $qv [ 'hour' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_time = true ;
$this -> is_date = true ;
}
2007-03-08 23:05:28 -05:00
if ( $qv [ 'day' ] ) {
2006-03-12 20:44:32 -05:00
if ( ! $this -> is_date ) {
$this -> is_day = true ;
$this -> is_date = true ;
}
}
2007-03-08 23:05:28 -05:00
if ( $qv [ 'monthnum' ] ) {
2006-03-12 20:44:32 -05:00
if ( ! $this -> is_date ) {
$this -> is_month = true ;
$this -> is_date = true ;
}
}
2007-03-08 23:05:28 -05:00
if ( $qv [ 'year' ] ) {
2006-03-12 20:44:32 -05:00
if ( ! $this -> is_date ) {
$this -> is_year = true ;
$this -> is_date = true ;
}
}
2007-03-08 23:05:28 -05:00
if ( $qv [ 'm' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_date = true ;
if ( strlen ( $qv [ 'm' ]) > 9 ) {
$this -> is_time = true ;
} else if ( strlen ( $qv [ 'm' ]) > 7 ) {
$this -> is_day = true ;
} else if ( strlen ( $qv [ 'm' ]) > 5 ) {
$this -> is_month = true ;
} else {
$this -> is_year = true ;
}
}
if ( '' != $qv [ 'w' ]) {
$this -> is_date = true ;
}
2007-03-08 23:05:28 -05:00
if ( empty ( $qv [ 'cat' ]) || ( $qv [ 'cat' ] == '0' ) ) {
2006-03-12 20:44:32 -05:00
$this -> is_category = false ;
} else {
2007-03-07 00:29:15 -05:00
if ( strpos ( $qv [ 'cat' ], '-' ) !== false ) {
2006-03-12 20:44:32 -05:00
$this -> is_category = false ;
} else {
$this -> is_category = true ;
}
}
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'category_name' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_category = true ;
}
2006-11-19 02:56:05 -05:00
2007-08-15 18:08:51 -04:00
if ( ! is_array ( $qv [ 'category__in' ]) || empty ( $qv [ 'category__in' ]) ) {
$qv [ 'category__in' ] = array ();
} else {
$qv [ 'category__in' ] = array_map ( 'intval' , $qv [ 'category__in' ]);
$this -> is_category = true ;
}
if ( ! is_array ( $qv [ 'category___not_in' ]) || empty ( $qv [ 'category__not_in' ]) ) {
$qv [ 'category__not_in' ] = array ();
} else {
$qv [ 'category__not_in' ] = array_map ( 'intval' , $qv [ 'category__not_in' ]);
}
if ( ! is_array ( $qv [ 'category__and' ]) || empty ( $qv [ 'category__and' ]) ) {
$qv [ 'category__and' ] = array ();
} else {
$qv [ 'category__and' ] = array_map ( 'intval' , $qv [ 'category__and' ]);
$this -> is_category = true ;
}
2007-03-31 02:16:12 -04:00
if ( '' != $qv [ 'tag' ] )
$this -> is_tag = true ;
2007-03-08 23:05:28 -05:00
if ( empty ( $qv [ 'author' ]) || ( $qv [ 'author' ] == '0' ) ) {
2006-03-12 20:44:32 -05:00
$this -> is_author = false ;
} else {
$this -> is_author = true ;
}
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'author_name' ] ) {
2006-03-12 20:44:32 -05:00
$this -> is_author = true ;
}
2007-03-31 02:16:12 -04:00
if ( ( $this -> is_date || $this -> is_author || $this -> is_category || $this -> is_tag ) )
2006-03-12 20:44:32 -05:00
$this -> is_archive = true ;
}
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'feed' ] )
2006-03-12 20:44:32 -05:00
$this -> is_feed = true ;
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'tb' ] )
2006-03-12 20:44:32 -05:00
$this -> is_trackback = true ;
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'paged' ] )
2006-03-12 20:44:32 -05:00
$this -> is_paged = true ;
2007-03-08 23:05:28 -05:00
if ( '' != $qv [ 'comments_popup' ] )
2006-03-12 20:44:32 -05:00
$this -> is_comments_popup = true ;
2007-03-08 23:05:28 -05:00
// if we're previewing inside the write screen
if ( '' != $qv [ 'preview' ])
2006-03-12 20:44:32 -05:00
$this -> is_preview = true ;
2007-03-08 23:05:28 -05:00
if ( strpos ( $_SERVER [ 'PHP_SELF' ], 'wp-admin/' ) !== false )
2006-03-12 20:44:32 -05:00
$this -> is_admin = true ;
2007-02-24 02:33:29 -05:00
if ( false !== strpos ( $qv [ 'feed' ], 'comments-' ) ) {
2007-03-08 23:05:28 -05:00
$qv [ 'feed' ] = str_replace ( 'comments-' , '' , $qv [ 'feed' ]);
2007-02-24 02:33:29 -05:00
$qv [ 'withcomments' ] = 1 ;
}
2007-02-28 00:22:29 -05:00
$this -> is_singular = $this -> is_single || $this -> is_page || $this -> is_attachment ;
if ( $this -> is_feed && ( ! empty ( $qv [ 'withcomments' ]) || ( empty ( $qv [ 'withoutcomments' ]) && $this -> is_singular ) ) )
2007-02-24 02:33:29 -05:00
$this -> is_comment_feed = true ;
2007-03-08 23:05:28 -05:00
if ( ! ( $this -> is_singular || $this -> is_archive || $this -> is_search || $this -> is_feed || $this -> is_trackback || $this -> is_404 || $this -> is_admin || $this -> is_comments_popup ) )
2006-03-12 20:44:32 -05:00
$this -> is_home = true ;
2007-02-28 00:22:29 -05:00
// Correct is_* for page_on_front and page_for_posts
if ( $this -> is_home && ( empty ( $this -> query ) || $qv [ 'preview' ] == 'true' ) && 'page' == get_option ( 'show_on_front' ) && get_option ( 'page_on_front' ) ) {
$this -> is_page = true ;
$this -> is_home = false ;
2007-03-08 23:05:28 -05:00
$qv [ 'page_id' ] = get_option ( 'page_on_front' );
2007-02-28 00:22:29 -05:00
}
if ( '' != $qv [ 'pagename' ] ) {
$this -> queried_object =& get_page_by_path ( $qv [ 'pagename' ]);
if ( ! empty ( $this -> queried_object ) )
2007-03-22 20:59:21 -04:00
$this -> queried_object_id = ( int ) $this -> queried_object -> ID ;
2007-02-28 00:22:29 -05:00
else
unset ( $this -> queried_object );
if ( 'page' == get_option ( 'show_on_front' ) && isset ( $this -> queried_object_id ) && $this -> queried_object_id == get_option ( 'page_for_posts' ) ) {
$this -> is_page = false ;
$this -> is_home = true ;
$this -> is_posts_page = true ;
}
}
2007-03-08 23:05:28 -05:00
if ( $qv [ 'page_id' ] ) {
2007-02-28 00:22:29 -05:00
if ( 'page' == get_option ( 'show_on_front' ) && $qv [ 'page_id' ] == get_option ( 'page_for_posts' ) ) {
$this -> is_page = false ;
$this -> is_home = true ;
$this -> is_posts_page = true ;
}
}
if ( $this -> is_posts_page && ! $qv [ 'withcomments' ] )
$this -> is_comment_feed = false ;
$this -> is_singular = $this -> is_single || $this -> is_page || $this -> is_attachment ;
// Done correcting is_* for page_on_front and page_for_posts
2007-03-08 23:05:28 -05:00
if ( ! empty ( $query ) )
2006-09-12 13:45:23 -04:00
do_action_ref_array ( 'parse_query' , array ( & $this ));
2006-03-12 20:44:32 -05:00
}
function set_404 () {
2006-08-15 01:03:14 -04:00
$is_feed = $this -> is_feed ;
2006-03-12 20:44:32 -05:00
$this -> init_query_flags ();
$this -> is_404 = true ;
2006-08-15 01:03:14 -04:00
$this -> is_feed = $is_feed ;
2006-03-12 20:44:32 -05:00
}
function get ( $query_var ) {
if ( isset ( $this -> query_vars [ $query_var ])) {
return $this -> query_vars [ $query_var ];
}
return '' ;
}
function set ( $query_var , $value ) {
$this -> query_vars [ $query_var ] = $value ;
}
function & get_posts () {
global $wpdb , $pagenow , $user_ID ;
2006-09-12 13:45:23 -04:00
do_action_ref_array ( 'pre_get_posts' , array ( & $this ));
2006-03-12 20:44:32 -05:00
// Shorthand.
$q = & $this -> query_vars ;
2007-02-27 10:24:54 -05:00
2006-09-21 17:05:38 -04:00
$q = $this -> fill_query_vars ( $q );
2006-03-12 20:44:32 -05:00
// First let's clear some variables
2006-05-07 22:16:24 -04:00
$distinct = '' ;
2006-03-12 20:44:32 -05:00
$whichcat = '' ;
$whichauthor = '' ;
$whichpage = '' ;
$result = '' ;
$where = '' ;
$limits = '' ;
$join = '' ;
2006-09-21 17:05:38 -04:00
$search = '' ;
2006-11-07 18:43:59 -05:00
$groupby = '' ;
2006-03-12 20:44:32 -05:00
if ( ! isset ( $q [ 'post_type' ]) )
$q [ 'post_type' ] = 'post' ;
$post_type = $q [ 'post_type' ];
if ( ! isset ( $q [ 'posts_per_page' ]) || $q [ 'posts_per_page' ] == 0 )
2006-08-30 17:46:31 -04:00
$q [ 'posts_per_page' ] = get_option ( 'posts_per_page' );
2006-03-12 20:44:32 -05:00
if ( isset ( $q [ 'showposts' ]) && $q [ 'showposts' ] ) {
$q [ 'showposts' ] = ( int ) $q [ 'showposts' ];
$q [ 'posts_per_page' ] = $q [ 'showposts' ];
}
if ( ( isset ( $q [ 'posts_per_archive_page' ]) && $q [ 'posts_per_archive_page' ] != 0 ) && ( $this -> is_archive || $this -> is_search ) )
$q [ 'posts_per_page' ] = $q [ 'posts_per_archive_page' ];
if ( ! isset ( $q [ 'nopaging' ]) ) {
if ( $q [ 'posts_per_page' ] == - 1 ) {
$q [ 'nopaging' ] = true ;
} else {
$q [ 'nopaging' ] = false ;
}
}
if ( $this -> is_feed ) {
2006-08-30 17:46:31 -04:00
$q [ 'posts_per_page' ] = get_option ( 'posts_per_rss' );
2006-12-06 18:14:37 -05:00
$q [ 'nopaging' ] = false ;
2006-03-12 20:44:32 -05:00
}
2006-08-24 18:33:16 -04:00
$q [ 'posts_per_page' ] = ( int ) $q [ 'posts_per_page' ];
if ( $q [ 'posts_per_page' ] < - 1 )
$q [ 'posts_per_page' ] = abs ( $q [ 'posts_per_page' ]);
else if ( $q [ 'posts_per_page' ] == 0 )
$q [ 'posts_per_page' ] = 1 ;
2006-03-12 20:44:32 -05:00
2006-06-21 23:39:23 -04:00
if ( $this -> is_home && ( empty ( $this -> query ) || $q [ 'preview' ] == 'true' ) && ( 'page' == get_option ( 'show_on_front' ) ) && get_option ( 'page_on_front' ) ) {
2006-03-12 20:44:32 -05:00
$this -> is_page = true ;
$this -> is_home = false ;
$q [ 'page_id' ] = get_option ( 'page_on_front' );
}
if ( isset ( $q [ 'page' ])) {
$q [ 'page' ] = trim ( $q [ 'page' ], '/' );
$q [ 'page' ] = ( int ) $q [ 'page' ];
2006-07-04 15:58:11 -04:00
$q [ 'page' ] = abs ( $q [ 'page' ]);
2006-03-12 20:44:32 -05:00
}
2006-08-30 17:46:31 -04:00
$add_hours = intval ( get_option ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_option ( 'gmt_offset' ) - $add_hours ));
2006-03-12 20:44:32 -05:00
$wp_posts_post_date_field = " post_date " ; // "DATE_ADD(post_date, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE)";
// If a month is specified in the querystring, load that month
2007-03-08 23:05:28 -05:00
if ( $q [ 'm' ] ) {
2006-03-12 20:44:32 -05:00
$q [ 'm' ] = '' . preg_replace ( '|[^0-9]|' , '' , $q [ 'm' ]);
$where .= ' AND YEAR(post_date)=' . substr ( $q [ 'm' ], 0 , 4 );
if ( strlen ( $q [ 'm' ]) > 5 )
$where .= ' AND MONTH(post_date)=' . substr ( $q [ 'm' ], 4 , 2 );
if ( strlen ( $q [ 'm' ]) > 7 )
$where .= ' AND DAYOFMONTH(post_date)=' . substr ( $q [ 'm' ], 6 , 2 );
if ( strlen ( $q [ 'm' ]) > 9 )
$where .= ' AND HOUR(post_date)=' . substr ( $q [ 'm' ], 8 , 2 );
if ( strlen ( $q [ 'm' ]) > 11 )
$where .= ' AND MINUTE(post_date)=' . substr ( $q [ 'm' ], 10 , 2 );
if ( strlen ( $q [ 'm' ]) > 13 )
$where .= ' AND SECOND(post_date)=' . substr ( $q [ 'm' ], 12 , 2 );
}
2007-08-04 12:30:27 -04:00
if ( '' !== $q [ 'hour' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND HOUR(post_date)=' " . $q [ 'hour' ] . " ' " ;
2007-08-04 12:30:27 -04:00
if ( '' !== $q [ 'minute' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND MINUTE(post_date)=' " . $q [ 'minute' ] . " ' " ;
2007-08-04 12:30:27 -04:00
if ( '' !== $q [ 'second' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND SECOND(post_date)=' " . $q [ 'second' ] . " ' " ;
2007-03-08 23:05:28 -05:00
if ( $q [ 'year' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND YEAR(post_date)=' " . $q [ 'year' ] . " ' " ;
2007-03-08 23:05:28 -05:00
if ( $q [ 'monthnum' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND MONTH(post_date)=' " . $q [ 'monthnum' ] . " ' " ;
2007-03-08 23:05:28 -05:00
if ( $q [ 'day' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND DAYOFMONTH(post_date)=' " . $q [ 'day' ] . " ' " ;
if ( '' != $q [ 'name' ]) {
$q [ 'name' ] = sanitize_title ( $q [ 'name' ]);
$where .= " AND post_name = ' " . $q [ 'name' ] . " ' " ;
} else if ( '' != $q [ 'pagename' ]) {
2007-02-28 00:22:29 -05:00
if ( isset ( $this -> queried_object_id ) )
$reqpage = $this -> queried_object_id ;
else {
$reqpage = get_page_by_path ( $q [ 'pagename' ]);
if ( ! empty ( $reqpage ) )
$reqpage = $reqpage -> ID ;
else
$reqpage = 0 ;
}
2006-03-12 20:44:32 -05:00
2007-02-28 00:22:29 -05:00
if ( ( 'page' != get_option ( 'show_on_front' ) ) || ( $reqpage != get_option ( 'page_for_posts' ) ) ) {
2006-03-12 20:44:32 -05:00
$q [ 'pagename' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'pagename' ])));
$page_paths = '/' . trim ( $q [ 'pagename' ], '/' );
$q [ 'pagename' ] = sanitize_title ( basename ( $page_paths ));
$q [ 'name' ] = $q [ 'pagename' ];
$where .= " AND (ID = ' $reqpage ') " ;
}
} elseif ( '' != $q [ 'attachment' ]) {
$q [ 'attachment' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'attachment' ])));
$attach_paths = '/' . trim ( $q [ 'attachment' ], '/' );
$q [ 'attachment' ] = sanitize_title ( basename ( $attach_paths ));
$q [ 'name' ] = $q [ 'attachment' ];
$where .= " AND post_name = ' " . $q [ 'attachment' ] . " ' " ;
}
2007-03-08 23:05:28 -05:00
if ( $q [ 'w' ] )
2006-03-12 20:44:32 -05:00
$where .= " AND WEEK(post_date, 1)=' " . $q [ 'w' ] . " ' " ;
if ( intval ( $q [ 'comments_popup' ]) )
$q [ 'p' ] = intval ( $q [ 'comments_popup' ]);
2007-03-08 23:05:28 -05:00
// If an attachment is requested by number, let it supercede any post number.
if ( $q [ 'attachment_id' ] )
$q [ 'p' ] = $q [ 'attachment_id' ];
2006-03-12 20:44:32 -05:00
// If a post number is specified, load that post
2007-03-08 23:05:28 -05:00
if ( $q [ 'p' ] )
2006-03-12 20:44:32 -05:00
$where = ' AND ID = ' . $q [ 'p' ];
2007-03-08 23:05:28 -05:00
if ( $q [ 'page_id' ] ) {
2007-02-28 00:22:29 -05:00
if ( ( 'page' != get_option ( 'show_on_front' ) ) || ( $q [ 'page_id' ] != get_option ( 'page_for_posts' ) ) ) {
2006-03-12 20:44:32 -05:00
$q [ 'p' ] = $q [ 'page_id' ];
2007-03-08 23:05:28 -05:00
$where = ' AND ID = ' . $q [ 'page_id' ];
2006-03-12 20:44:32 -05:00
}
}
// If a search pattern is specified, load the posts that match
2007-03-08 23:05:28 -05:00
if ( ! empty ( $q [ 's' ]) ) {
2006-10-26 23:47:43 -04:00
// added slashes screw with quote grouping when done early, so done later
$q [ 's' ] = stripslashes ( $q [ 's' ]);
if ( $q [ 'sentence' ]) {
$q [ 'search_terms' ] = array ( $q [ 's' ]);
2006-03-12 20:44:32 -05:00
}
2006-10-26 23:47:43 -04:00
else {
preg_match_all ( '/".*?("|$)|((?<=[\\s",+])|^)[^\\s",+]+/' , $q [ s ], $matches );
$q [ 'search_terms' ] = array_map ( create_function ( '$a' , 'return trim($a, "\\"\'\\n\\r ");' ), $matches [ 0 ]);
}
$n = ( $q [ 'exact' ]) ? '' : '%' ;
$searchand = '' ;
foreach (( array ) $q [ 'search_terms' ] as $term ) {
$term = addslashes_gpc ( $term );
$search .= " { $searchand } ((post_title LIKE ' { $n } { $term } { $n } ') OR (post_content LIKE ' { $n } { $term } { $n } ')) " ;
$searchand = ' AND ' ;
2006-03-12 20:44:32 -05:00
}
2006-10-26 23:47:43 -04:00
$term = addslashes_gpc ( $q [ 's' ]);
2007-02-21 20:54:28 -05:00
if ( ! $q [ 'sentence' ] && count ( $q [ 'search_terms' ]) > 1 && $q [ 'search_terms' ][ 0 ] != $q [ 's' ] )
$search .= " OR (post_title LIKE ' { $n } { $term } { $n } ') OR (post_content LIKE ' { $n } { $term } { $n } ') " ;
if ( ! empty ( $search ) )
$search = " AND ( { $search } ) " ;
2006-03-12 20:44:32 -05:00
}
// Category stuff
2007-03-08 23:05:28 -05:00
if ( empty ( $q [ 'cat' ]) || ( $q [ 'cat' ] == '0' ) ||
2006-03-12 20:44:32 -05:00
// Bypass cat checks if fetching specific posts
2007-03-08 23:05:28 -05:00
$this -> is_singular ) {
$whichcat = '' ;
2006-03-12 20:44:32 -05:00
} else {
$q [ 'cat' ] = '' . urldecode ( $q [ 'cat' ]) . '' ;
$q [ 'cat' ] = addslashes_gpc ( $q [ 'cat' ]);
$cat_array = preg_split ( '/[,\s]+/' , $q [ 'cat' ]);
2006-05-07 22:16:24 -04:00
foreach ( $cat_array as $cat ) {
2006-06-01 03:42:46 -04:00
$cat = intval ( $cat );
2007-05-29 17:27:49 -04:00
$in = ( $cat > 0 );
$cat = abs ( $cat );
if ( $in ) {
2007-08-15 18:08:51 -04:00
$q [ 'category__in' ][] = $cat ;
$q [ 'category__in' ] = array_merge ( $q [ 'category__in' ], get_term_children ( $cat , 'category' ));
2007-05-29 17:27:49 -04:00
} else {
2007-08-15 18:08:51 -04:00
$q [ 'category__not_in' ][] = $cat ;
$q [ 'category__not_in' ] = array_merge ( $q [ 'category__not_in' ], get_term_children ( $cat , 'category' ));
2007-05-29 17:27:49 -04:00
}
2006-03-12 20:44:32 -05:00
}
2007-08-15 18:08:51 -04:00
}
if ( ! empty ( $q [ 'category__in' ]) || ! empty ( $q [ 'category__not_in' ]) || ! empty ( $q [ 'category__and' ]) ) {
$groupby = " { $wpdb -> posts } .ID " ;
}
if ( ! empty ( $q [ 'category__in' ]) ) {
$join = " LEFT JOIN $wpdb->term_relationships ON ( $wpdb->posts .ID = $wpdb->term_relationships .object_id) LEFT JOIN $wpdb->term_taxonomy ON ( $wpdb->term_relationships .term_taxonomy_id = $wpdb->term_taxonomy .term_taxonomy_id) " ;
$whichcat .= " AND $wpdb->term_taxonomy .taxonomy = 'category' " ;
$include_cats = " ' " . implode ( " ', ' " , $q [ 'category__in' ]) . " ' " ;
$whichcat .= " AND $wpdb->term_taxonomy .term_id IN ( $include_cats ) " ;
}
if ( ! empty ( $q [ 'category__not_in' ]) ) {
$ids = get_objects_in_term ( $q [ 'category__not_in' ], 'category' );
if ( is_array ( $ids ) && count ( $ids > 0 ) ) {
$out_posts = " ' " . implode ( " ', ' " , $ids ) . " ' " ;
$whichcat .= " AND $wpdb->posts .ID NOT IN ( $out_posts ) " ;
2007-05-29 17:27:49 -04:00
}
2007-08-15 18:08:51 -04:00
}
2007-05-29 17:27:49 -04:00
2007-08-15 18:08:51 -04:00
if ( ! empty ( $q [ 'category__and' ]) ) {
$count = 0 ;
foreach ( $q [ 'category__and' ] as $category_and ) {
$join .= " LEFT JOIN $wpdb->term_relationships AS tr $count ON ( $wpdb->posts .ID = tr $count .object_id) LEFT JOIN $wpdb->term_taxonomy AS tt $count ON (tr $count .term_taxonomy_id = tt $count .term_taxonomy_id) " ;
$whichcat .= " AND tt $count .term_id = ' $category_and ' " ;
$count ++ ;
2006-06-19 13:14:54 -04:00
}
2006-03-12 20:44:32 -05:00
}
2007-03-31 02:16:12 -04:00
if ( '' != $q [ 'tag' ] ) {
2007-05-22 23:57:20 -04:00
$reqtag = is_term ( $q [ 'tag' ], 'post_tag' );
if ( ! empty ( $reqtag ) )
$reqtag = $reqtag [ 'term_id' ];
2007-03-31 02:16:12 -04:00
else
2007-05-22 23:57:20 -04:00
$reqtag = 0 ;
2007-03-31 02:16:12 -04:00
2007-05-22 23:57:20 -04:00
$q [ 'tag_id' ] = $reqtag ;
$join = " LEFT JOIN $wpdb->term_relationships ON ( $wpdb->posts .ID = $wpdb->term_relationships .object_id) LEFT JOIN $wpdb->term_taxonomy ON ( $wpdb->term_relationships .term_taxonomy_id = $wpdb->term_taxonomy .term_taxonomy_id) " ;
$whichcat = " AND $wpdb->term_taxonomy .term_id IN ( { $q [ 'tag_id' ] } ) AND $wpdb->term_taxonomy .taxonomy = 'post_tag' " ;
2007-03-31 02:16:12 -04:00
$groupby = " { $wpdb -> posts } .ID " ;
}
2006-08-30 12:40:17 -04:00
// Category stuff for nice URLs
2007-03-08 23:05:28 -05:00
if ( '' != $q [ 'category_name' ] ) {
2006-03-12 20:44:32 -05:00
$reqcat = get_category_by_path ( $q [ 'category_name' ]);
$q [ 'category_name' ] = str_replace ( '%2F' , '/' , urlencode ( urldecode ( $q [ 'category_name' ])));
$cat_paths = '/' . trim ( $q [ 'category_name' ], '/' );
$q [ 'category_name' ] = sanitize_title ( basename ( $cat_paths ));
$cat_paths = '/' . trim ( urldecode ( $q [ 'category_name' ]), '/' );
$q [ 'category_name' ] = sanitize_title ( basename ( $cat_paths ));
$cat_paths = explode ( '/' , $cat_paths );
2006-12-09 01:35:22 -05:00
$cat_path = '' ;
foreach ( ( array ) $cat_paths as $pathdir )
$cat_path .= ( $pathdir != '' ? '/' : '' ) . sanitize_title ( $pathdir );
2006-03-12 20:44:32 -05:00
//if we don't match the entire hierarchy fallback on just matching the nicename
if ( empty ( $reqcat ) )
$reqcat = get_category_by_path ( $q [ 'category_name' ], false );
if ( ! empty ( $reqcat ) )
2007-05-23 14:59:12 -04:00
$reqcat = $reqcat -> term_id ;
2006-03-12 20:44:32 -05:00
else
$reqcat = 0 ;
$q [ 'cat' ] = $reqcat ;
2006-11-19 02:56:05 -05:00
2007-05-23 14:59:12 -04:00
$join = " LEFT JOIN $wpdb->term_relationships ON ( $wpdb->posts .ID = $wpdb->term_relationships .object_id) LEFT JOIN $wpdb->term_taxonomy ON ( $wpdb->term_relationships .term_taxonomy_id = $wpdb->term_taxonomy .term_taxonomy_id) " ;
$whichcat = " AND $wpdb->term_taxonomy .taxonomy = 'category' " ;
2007-06-06 12:13:12 -04:00
$in_cats = array ( $q [ 'cat' ]);
$in_cats = array_merge ( $in_cats , get_term_children ( $q [ 'cat' ], 'category' ));
$in_cats = " ' " . implode ( " ', ' " , $in_cats ) . " ' " ;
$whichcat .= " AND $wpdb->term_taxonomy .term_id IN ( $in_cats ) " ;
2006-11-07 18:43:59 -05:00
$groupby = " { $wpdb -> posts } .ID " ;
2006-03-12 20:44:32 -05:00
}
// Author/user stuff
2007-03-08 23:05:28 -05:00
if ( empty ( $q [ 'author' ]) || ( $q [ 'author' ] == '0' ) ) {
2006-03-12 20:44:32 -05:00
$whichauthor = '' ;
} else {
$q [ 'author' ] = '' . urldecode ( $q [ 'author' ]) . '' ;
$q [ 'author' ] = addslashes_gpc ( $q [ 'author' ]);
2007-03-07 00:29:15 -05:00
if ( strpos ( $q [ 'author' ], '-' ) !== false ) {
2006-03-12 20:44:32 -05:00
$eq = '!=' ;
$andor = 'AND' ;
$q [ 'author' ] = explode ( '-' , $q [ 'author' ]);
$q [ 'author' ] = '' . intval ( $q [ 'author' ][ 1 ]);
} else {
$eq = '=' ;
$andor = 'OR' ;
}
$author_array = preg_split ( '/[,\s]+/' , $q [ 'author' ]);
$whichauthor .= ' AND (post_author ' . $eq . ' ' . intval ( $author_array [ 0 ]);
for ( $i = 1 ; $i < ( count ( $author_array )); $i = $i + 1 ) {
$whichauthor .= ' ' . $andor . ' post_author ' . $eq . ' ' . intval ( $author_array [ $i ]);
}
$whichauthor .= ')' ;
}
2006-08-30 12:40:17 -04:00
// Author stuff for nice URLs
2006-03-12 20:44:32 -05:00
if ( '' != $q [ 'author_name' ]) {
2007-03-07 00:29:15 -05:00
if ( strpos ( $q [ 'author_name' ], '/' ) !== false ) {
2006-03-12 20:44:32 -05:00
$q [ 'author_name' ] = explode ( '/' , $q [ 'author_name' ]);
if ( $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 1 ]) {
$q [ 'author_name' ] = $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 1 ]; #no trailing slash
} else {
$q [ 'author_name' ] = $q [ 'author_name' ][ count ( $q [ 'author_name' ]) - 2 ]; #there was a trailling slash
}
}
$q [ 'author_name' ] = sanitize_title ( $q [ 'author_name' ]);
$q [ 'author' ] = $wpdb -> get_var ( " SELECT ID FROM $wpdb->users WHERE user_nicename=' " . $q [ 'author_name' ] . " ' " );
$whichauthor .= ' AND (post_author = ' . intval ( $q [ 'author' ]) . ')' ;
}
$where .= $search . $whichcat . $whichauthor ;
2007-03-08 23:05:28 -05:00
if ( empty ( $q [ 'order' ]) || (( strtoupper ( $q [ 'order' ]) != 'ASC' ) && ( strtoupper ( $q [ 'order' ]) != 'DESC' )) )
$q [ 'order' ] = 'DESC' ;
2006-03-12 20:44:32 -05:00
// Order by
2007-03-08 23:05:28 -05:00
if ( empty ( $q [ 'orderby' ]) ) {
2006-03-12 20:44:32 -05:00
$q [ 'orderby' ] = 'post_date ' . $q [ 'order' ];
} else {
// Used to filter values
$allowed_keys = array ( 'author' , 'date' , 'category' , 'title' , 'modified' , 'menu_order' );
$q [ 'orderby' ] = urldecode ( $q [ 'orderby' ]);
$q [ 'orderby' ] = addslashes_gpc ( $q [ 'orderby' ]);
$orderby_array = explode ( ' ' , $q [ 'orderby' ]);
if ( empty ( $orderby_array ) )
$orderby_array [] = $q [ 'orderby' ];
$q [ 'orderby' ] = '' ;
for ( $i = 0 ; $i < count ( $orderby_array ); $i ++ ) {
// Only allow certain values for safety
$orderby = $orderby_array [ $i ];
if ( 'menu_order' != $orderby )
$orderby = 'post_' . $orderby ;
if ( in_array ( $orderby_array [ $i ], $allowed_keys ) )
$q [ 'orderby' ] .= (( $i == 0 ) ? '' : ',' ) . " $orderby { $q [ 'order' ] } " ;
}
if ( empty ( $q [ 'orderby' ]) )
$q [ 'orderby' ] = 'post_date ' . $q [ 'order' ];
}
if ( $this -> is_attachment ) {
2007-05-28 14:34:06 -04:00
$where .= " AND post_type = 'attachment' " ;
2006-03-12 20:44:32 -05:00
} elseif ( $this -> is_page ) {
2007-05-28 14:34:06 -04:00
$where .= " AND post_type = 'page' " ;
2006-03-12 20:44:32 -05:00
} elseif ( $this -> is_single ) {
2007-05-28 14:34:06 -04:00
$where .= " AND post_type = 'post' " ;
2006-03-12 20:44:32 -05:00
} else {
2007-05-28 14:34:06 -04:00
$where .= " AND post_type = ' $post_type ' " ;
}
if ( isset ( $q [ 'post_status' ]) && '' != $q [ 'post_status' ] ) {
$q_status = explode ( ',' , $q [ 'post_status' ]);
$r_status = array ();
if ( in_array ( 'draft' , $q_status ) )
$r_status [] = " post_status = 'draft' " ;
2007-06-14 12:24:28 -04:00
if ( in_array ( 'pending' , $q_status ) )
$r_status [] = " post_status = 'pending' " ;
2007-05-28 14:34:06 -04:00
if ( in_array ( 'future' , $q_status ) )
$r_status [] = " post_status = 'future' " ;
if ( in_array ( 'inherit' , $q_status ) )
$r_status [] = " post_status = 'inherit' " ;
if ( in_array ( 'private' , $q_status ) )
$r_status [] = " post_status = 'private' " ;
if ( in_array ( 'publish' , $q_status ) )
$r_status [] = " post_status = 'publish' " ;
if ( ! empty ( $r_status ) )
$where .= " AND ( " . join ( ' OR ' , $r_status ) . " ) " ;
} elseif ( ! $this -> is_singular ) {
$where .= " AND (post_status = 'publish' " ;
2006-03-12 20:44:32 -05:00
2006-06-22 15:44:36 -04:00
if ( is_admin () )
2007-06-14 12:24:28 -04:00
$where .= " OR post_status = 'future' OR post_status = 'draft' OR post_status = 'pending' " ;
2007-06-13 22:25:30 -04:00
2007-05-28 16:39:24 -04:00
if ( is_user_logged_in () ) {
$where .= current_user_can ( " read_private_ { $post_type } s " ) ? " OR post_status = 'private' " : " OR post_author = $user_ID AND post_status = 'private' " ;
}
2006-05-11 19:13:35 -04:00
2007-05-28 14:34:06 -04:00
$where .= ')' ;
2006-03-12 20:44:32 -05:00
}
// Apply filters on where and join prior to paging so that any
// manipulations to them are reflected in the paging by day queries.
$where = apply_filters ( 'posts_where' , $where );
$join = apply_filters ( 'posts_join' , $join );
// Paging
2007-03-08 23:05:28 -05:00
if ( empty ( $q [ 'nopaging' ]) && ! $this -> is_singular ) {
2006-07-04 15:58:11 -04:00
$page = abs ( intval ( $q [ 'paged' ]));
2006-03-12 20:44:32 -05:00
if ( empty ( $page )) {
$page = 1 ;
}
2006-11-08 16:22:35 -05:00
if ( empty ( $q [ 'offset' ]) ) {
$pgstrt = '' ;
$pgstrt = ( intval ( $page ) - 1 ) * $q [ 'posts_per_page' ] . ', ' ;
$limits = 'LIMIT ' . $pgstrt . $q [ 'posts_per_page' ];
} else { // we're ignoring $page and using 'offset'
$q [ 'offset' ] = abs ( intval ( $q [ 'offset' ]));
$pgstrt = $q [ 'offset' ] . ', ' ;
$limits = 'LIMIT ' . $pgstrt . $q [ 'posts_per_page' ];
2006-03-12 20:44:32 -05:00
}
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
// Comments feeds
if ( $this -> is_comment_feed && ( $this -> is_archive || $this -> is_search || ! $this -> is_singular ) ) {
if ( $this -> is_archive || $this -> is_search ) {
$cjoin = " LEFT JOIN $wpdb->posts ON ( $wpdb->comments .comment_post_ID = $wpdb->posts .ID) $join " ;
$cwhere = " WHERE comment_approved = '1' $where " ;
$cgroupby = " GROUP BY $wpdb->comments .comment_id " ;
} else { // Other non singular e.g. front
$cjoin = " LEFT JOIN $wpdb->posts ON ( $wpdb->comments .comment_post_ID = $wpdb->posts .ID ) " ;
$cwhere = " WHERE post_status = 'publish' AND comment_approved = '1' " ;
$cgroupby = '' ;
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
$cjoin = apply_filters ( 'comment_feed_join' , $cjoin );
$cwhere = apply_filters ( 'comment_feed_where' , $cwhere );
$cgroupby = apply_filters ( 'comment_feed_groupby' , $cgroupby );
2007-02-27 10:24:54 -05:00
2007-04-18 22:53:19 -04:00
$this -> comments = ( array ) $wpdb -> get_results ( " SELECT $distinct $wpdb->comments .* FROM $wpdb->comments $cjoin $cwhere $cgroupby ORDER BY comment_date_gmt DESC LIMIT " . get_option ( 'posts_per_rss' ));
2007-02-24 02:33:29 -05:00
$this -> comment_count = count ( $this -> comments );
$post_ids = array ();
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
foreach ( $this -> comments as $comment )
$post_ids [] = ( int ) $comment -> comment_post_ID ;
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
$post_ids = join ( ',' , $post_ids );
$join = '' ;
if ( $post_ids )
$where = " AND $wpdb->posts .ID IN ( $post_ids ) " ;
else
$where = " AND 0 " ;
}
2006-03-12 20:44:32 -05:00
// Apply post-paging filters on where and join. Only plugins that
2007-08-22 14:03:26 -04:00
// manipulate paging queries should use these hooks.
// Announce current selection parameters. For use by caching plugins.
do_action ( 'posts_selection' , $where . $groupby . $q [ 'orderby' ] . $limits . $join );
2006-03-12 20:44:32 -05:00
$where = apply_filters ( 'posts_where_paged' , $where );
$groupby = apply_filters ( 'posts_groupby' , $groupby );
2006-04-01 19:33:10 -05:00
if ( ! empty ( $groupby ) )
$groupby = 'GROUP BY ' . $groupby ;
2006-03-12 20:44:32 -05:00
$join = apply_filters ( 'posts_join_paged' , $join );
2006-05-07 22:16:24 -04:00
$orderby = apply_filters ( 'posts_orderby' , $q [ 'orderby' ]);
2007-08-22 14:03:26 -04:00
if ( ! empty ( $orderby ) )
$orderby = 'ORDER BY ' . $orderby ;
2006-05-07 22:16:24 -04:00
$distinct = apply_filters ( 'posts_distinct' , $distinct );
$fields = apply_filters ( 'posts_fields' , " $wpdb->posts .* " );
2006-12-01 05:15:15 -05:00
$limits = apply_filters ( 'post_limits' , $limits );
2006-11-08 04:13:11 -05:00
$found_rows = '' ;
if ( ! empty ( $limits ) )
$found_rows = 'SQL_CALC_FOUND_ROWS' ;
2006-12-01 05:15:15 -05:00
2007-08-22 14:03:26 -04:00
$request = " SELECT $found_rows $distinct $fields FROM $wpdb->posts $join WHERE 1=1 $where $groupby $orderby $limits " ;
2006-03-12 20:44:32 -05:00
$this -> request = apply_filters ( 'posts_request' , $request );
$this -> posts = $wpdb -> get_results ( $this -> request );
2007-08-22 14:03:26 -04:00
// Raw results filter. Prior to status checks.
$this -> posts = apply_filters ( 'posts_results' , $this -> posts );
2007-02-24 02:33:29 -05:00
if ( $this -> is_comment_feed && $this -> is_singular ) {
$cjoin = apply_filters ( 'comment_feed_join' , '' );
$cwhere = apply_filters ( 'comment_feed_where' , " WHERE comment_post_ID = { $this -> posts [ 0 ] -> ID } AND comment_approved = '1' " );
2007-04-18 22:53:19 -04:00
$comments_request = " SELECT $wpdb->comments .* FROM $wpdb->comments $cjoin $cwhere ORDER BY comment_date_gmt DESC LIMIT " . get_option ( 'posts_per_rss' );
2007-02-24 02:33:29 -05:00
$this -> comments = $wpdb -> get_results ( $comments_request );
$this -> comment_count = count ( $this -> comments );
}
2007-02-27 10:24:54 -05:00
2006-11-08 04:13:11 -05:00
if ( ! empty ( $limits ) ) {
2006-12-01 05:15:15 -05:00
$found_posts_query = apply_filters ( 'found_posts_query' , 'SELECT FOUND_ROWS()' );
$this -> found_posts = $wpdb -> get_var ( $found_posts_query );
$this -> found_posts = apply_filters ( 'found_posts' , $this -> found_posts );
2006-11-18 19:58:15 -05:00
$this -> max_num_pages = ceil ( $this -> found_posts / $q [ 'posts_per_page' ]);
2006-11-08 04:13:11 -05:00
}
2007-02-27 10:24:54 -05:00
2006-03-12 20:44:32 -05:00
// Check post status to determine if post should be displayed.
if ( ! empty ( $this -> posts ) && ( $this -> is_single || $this -> is_page ) ) {
$status = get_post_status ( $this -> posts [ 0 ]);
//$type = get_post_type($this->posts[0]);
if ( ( 'publish' != $status ) ) {
if ( ! is_user_logged_in () ) {
// User must be logged in to view unpublished posts.
$this -> posts = array ();
} else {
2007-06-14 12:24:28 -04:00
if ( in_array ( $status , array ( 'draft' , 'pending' )) ) {
2006-03-12 20:44:32 -05:00
// User must have edit permissions on the draft to preview.
if ( ! current_user_can ( 'edit_post' , $this -> posts [ 0 ] -> ID )) {
$this -> posts = array ();
} else {
$this -> is_preview = true ;
$this -> posts [ 0 ] -> post_date = current_time ( 'mysql' );
}
} else if ( 'future' == $status ) {
$this -> is_preview = true ;
if ( ! current_user_can ( 'edit_post' , $this -> posts [ 0 ] -> ID )) {
$this -> posts = array ( );
}
} else {
if ( ! current_user_can ( 'read_post' , $this -> posts [ 0 ] -> ID ))
$this -> posts = array ();
}
}
}
}
2006-11-23 10:38:22 -05:00
$this -> posts = apply_filters ( 'the_posts' , $this -> posts );
2006-03-12 20:44:32 -05:00
update_post_caches ( $this -> posts );
$this -> post_count = count ( $this -> posts );
if ( $this -> post_count > 0 ) {
$this -> post = $this -> posts [ 0 ];
}
return $this -> posts ;
}
function next_post () {
2006-11-19 02:56:05 -05:00
2006-03-12 20:44:32 -05:00
$this -> current_post ++ ;
$this -> post = $this -> posts [ $this -> current_post ];
return $this -> post ;
}
function the_post () {
global $post ;
$this -> in_the_loop = true ;
$post = $this -> next_post ();
setup_postdata ( $post );
if ( $this -> current_post == 0 ) // loop has just started
do_action ( 'loop_start' );
}
function have_posts () {
if ( $this -> current_post + 1 < $this -> post_count ) {
return true ;
} elseif ( $this -> current_post + 1 == $this -> post_count ) {
do_action ( 'loop_end' );
// Do some cleaning up after the loop
$this -> rewind_posts ();
}
$this -> in_the_loop = false ;
return false ;
}
function rewind_posts () {
$this -> current_post = - 1 ;
if ( $this -> post_count > 0 ) {
$this -> post = $this -> posts [ 0 ];
}
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
function next_comment () {
$this -> current_comment ++ ;
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
$this -> comment = $this -> comments [ $this -> current_comment ];
return $this -> comment ;
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
function the_comment () {
global $comment ;
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
$comment = $this -> next_comment ();
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
if ( $this -> current_comment == 0 ) {
do_action ( 'comment_loop_start' );
}
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
function have_comments () {
if ( $this -> current_comment + 1 < $this -> comment_count ) {
return true ;
} elseif ( $this -> current_comment + 1 == $this -> comment_count ) {
$this -> rewind_comments ();
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
return false ;
}
2007-02-27 10:24:54 -05:00
2007-02-24 02:33:29 -05:00
function rewind_comments () {
$this -> current_comment = - 1 ;
if ( $this -> comment_count > 0 ) {
$this -> comment = $this -> comments [ 0 ];
}
}
2006-11-19 02:56:05 -05:00
2006-03-12 20:44:32 -05:00
function & query ( $query ) {
$this -> parse_query ( $query );
return $this -> get_posts ();
}
function get_queried_object () {
if ( isset ( $this -> queried_object )) {
return $this -> queried_object ;
}
$this -> queried_object = NULL ;
$this -> queried_object_id = 0 ;
if ( $this -> is_category ) {
$cat = $this -> get ( 'cat' );
$category = & get_category ( $cat );
$this -> queried_object = & $category ;
2007-03-22 20:59:21 -04:00
$this -> queried_object_id = ( int ) $cat ;
2007-08-21 14:39:45 -04:00
} else if ( $this -> is_tag ) {
$tag_id = $this -> get ( 'tag_id' );
$tag = & get_term ( $tag_id , 'post_tag' );
$this -> queried_object = & $tag ;
$this -> queried_object_id = ( int ) $tag_id ;
2006-07-19 22:05:25 -04:00
} else if ( $this -> is_posts_page ) {
$this -> queried_object = & get_page ( get_option ( 'page_for_posts' ));
2007-03-22 20:59:21 -04:00
$this -> queried_object_id = ( int ) $this -> queried_object -> ID ;
2006-03-12 20:44:32 -05:00
} else if ( $this -> is_single ) {
$this -> queried_object = $this -> post ;
2007-03-22 20:59:21 -04:00
$this -> queried_object_id = ( int ) $this -> post -> ID ;
2006-03-12 20:44:32 -05:00
} else if ( $this -> is_page ) {
$this -> queried_object = $this -> post ;
2007-03-22 20:59:21 -04:00
$this -> queried_object_id = ( int ) $this -> post -> ID ;
2006-03-12 20:44:32 -05:00
} else if ( $this -> is_author ) {
2007-03-22 20:59:21 -04:00
$author_id = ( int ) $this -> get ( 'author' );
2006-03-12 20:44:32 -05:00
$author = get_userdata ( $author_id );
$this -> queried_object = $author ;
$this -> queried_object_id = $author_id ;
}
return $this -> queried_object ;
}
function get_queried_object_id () {
$this -> get_queried_object ();
if ( isset ( $this -> queried_object_id )) {
return $this -> queried_object_id ;
}
return 0 ;
}
function WP_Query ( $query = '' ) {
if ( ! empty ( $query )) {
$this -> query ( $query );
}
}
}
2006-11-30 03:48:56 -05:00
// Redirect old slugs
function wp_old_slug_redirect () {
global $wp_query ;
if ( is_404 () && '' != $wp_query -> query_vars [ 'name' ] ) :
global $wpdb ;
$query = " SELECT post_id FROM $wpdb->postmeta , $wpdb->posts WHERE ID = post_id AND meta_key = '_wp_old_slug' AND meta_value=' " . $wp_query -> query_vars [ 'name' ] . " ' " ;
// if year, monthnum, or day have been specified, make our query more precise
// just in case there are multiple identical _wp_old_slug values
if ( '' != $wp_query -> query_vars [ 'year' ] )
$query .= " AND YEAR(post_date) = ' { $wp_query -> query_vars [ 'year' ] } ' " ;
if ( '' != $wp_query -> query_vars [ 'monthnum' ] )
$query .= " AND MONTH(post_date) = ' { $wp_query -> query_vars [ 'monthnum' ] } ' " ;
if ( '' != $wp_query -> query_vars [ 'day' ] )
$query .= " AND DAYOFMONTH(post_date) = ' { $wp_query -> query_vars [ 'day' ] } ' " ;
$id = ( int ) $wpdb -> get_var ( $query );
if ( ! $id )
return ;
$link = get_permalink ( $id );
if ( ! $link )
return ;
wp_redirect ( $link , '301' ); // Permanent redirect
exit ;
endif ;
}
2006-06-07 22:22:16 -04:00
//
// Private helper functions
//
// Setup global post data.
function setup_postdata ( $post ) {
global $id , $postdata , $authordata , $day , $page , $pages , $multipage , $more , $numpages , $wp_query ;
global $pagenow ;
2007-03-22 20:59:21 -04:00
$id = ( int ) $post -> ID ;
2006-06-07 22:22:16 -04:00
$authordata = get_userdata ( $post -> post_author );
$day = mysql2date ( 'd.m.y' , $post -> post_date );
$currentmonth = mysql2date ( 'm' , $post -> post_date );
$numpages = 1 ;
$page = get_query_var ( 'page' );
if ( ! $page )
$page = 1 ;
if ( is_single () || is_page () )
$more = 1 ;
$content = $post -> post_content ;
if ( preg_match ( '/<!--nextpage-->/' , $content ) ) {
if ( $page > 1 )
$more = 1 ;
$multipage = 1 ;
$content = str_replace ( " \n <!--nextpage--> \n " , '<!--nextpage-->' , $content );
$content = str_replace ( " \n <!--nextpage--> " , '<!--nextpage-->' , $content );
$content = str_replace ( " <!--nextpage--> \n " , '<!--nextpage-->' , $content );
$pages = explode ( '<!--nextpage-->' , $content );
$numpages = count ( $pages );
} else {
$pages [ 0 ] = $post -> post_content ;
$multipage = 0 ;
}
return true ;
}
2007-08-21 14:39:45 -04:00
?>