Add include param to get_posts(), get_categories(), get_pages(), and get_bookmarks(). Props MichaelH. fixes #2562
git-svn-id: http://svn.automattic.com/wordpress/trunk@3655 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
b5b8986bca
commit
4ce7df114d
|
@ -1446,24 +1446,58 @@ function get_page_uri($page_id) {
|
||||||
|
|
||||||
function get_posts($args) {
|
function get_posts($args) {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
|
if ( is_array($args) )
|
||||||
|
$r = &$args;
|
||||||
|
else
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
if ( !isset($r['numberposts']) )
|
parse_str($args, $r);
|
||||||
$r['numberposts'] = 5;
|
|
||||||
if ( !isset($r['offset']) )
|
$defaults = array('numberposts' => 5, 'offset' => 0, 'category' => '',
|
||||||
$r['offset'] = 0;
|
'orderby' => 'post_date', 'order' => 'DESC', 'include' => '', 'exclude' => '');
|
||||||
if ( !isset($r['category']) )
|
$r = array_merge($defaults, $r);
|
||||||
$r['category'] = '';
|
extract($r);
|
||||||
if ( !isset($r['orderby']) )
|
|
||||||
$r['orderby'] = 'post_date';
|
$inclusions = '';
|
||||||
if ( !isset($r['order']) )
|
if ( !empty($include) ) {
|
||||||
$r['order'] = 'DESC';
|
$offset = 0; //ignore offset, category, and exclude params if using include
|
||||||
|
$category = '';
|
||||||
|
$exclude = '';
|
||||||
|
$incposts = preg_split('/[\s,]+/',$include);
|
||||||
|
$numberposts = count($incposts); // only the number of posts included
|
||||||
|
if ( count($incposts) ) {
|
||||||
|
foreach ( $incposts as $incpost ) {
|
||||||
|
if (empty($inclusions))
|
||||||
|
$inclusions = ' AND ( ID = ' . intval($incpost) . ' ';
|
||||||
|
else
|
||||||
|
$inclusions .= ' OR ID = ' . intval($incpost) . ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!empty($inclusions))
|
||||||
|
$inclusions .= ')';
|
||||||
|
|
||||||
|
$exclusions = '';
|
||||||
|
if ( !empty($exclude) ) {
|
||||||
|
$exposts = preg_split('/[\s,]+/',$exclude);
|
||||||
|
if ( count($exposts) ) {
|
||||||
|
foreach ( $exposts as $expost ) {
|
||||||
|
if (empty($exclusions))
|
||||||
|
$exclusions = ' AND ( ID <> ' . intval($expost) . ' ';
|
||||||
|
else
|
||||||
|
$exclusions .= ' AND ID <> ' . intval($expost) . ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!empty($exclusions))
|
||||||
|
$exclusions .= ')';
|
||||||
|
|
||||||
$posts = $wpdb->get_results(
|
$posts = $wpdb->get_results(
|
||||||
"SELECT DISTINCT * FROM $wpdb->posts " .
|
"SELECT DISTINCT * FROM $wpdb->posts " .
|
||||||
( empty( $r['category'] ) ? "" : ", $wpdb->post2cat " ) .
|
( empty( $category ) ? "" : ", $wpdb->post2cat " ) .
|
||||||
" WHERE (post_type = 'post' AND post_status = 'publish') ".
|
" WHERE (post_type = 'post' AND post_status = 'publish') $exclusions $inclusions " .
|
||||||
( empty( $r['category'] ) ? "" : "AND $wpdb->posts.ID = $wpdb->post2cat.post_id AND $wpdb->post2cat.category_id = " . $r['category']. " " ) .
|
( empty( $category ) ? "" : "AND $wpdb->posts.ID = $wpdb->post2cat.post_id AND $wpdb->post2cat.category_id = " . $category. " " ) .
|
||||||
" GROUP BY $wpdb->posts.ID ORDER BY " . $r['orderby'] . " " . $r['order'] . " LIMIT " . $r['offset'] . ',' . $r['numberposts'] );
|
" GROUP BY $wpdb->posts.ID ORDER BY " . $orderby . " " . $order . " LIMIT " . $offset . ',' . $numberposts );
|
||||||
|
|
||||||
update_post_caches($posts);
|
update_post_caches($posts);
|
||||||
|
|
||||||
|
|
|
@ -283,19 +283,42 @@ function get_bookmarks($args = '') {
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
|
||||||
$defaults = array('orderby' => 'name', 'order' => 'ASC', 'limit' => -1, 'category' => -1,
|
$defaults = array('orderby' => 'name', 'order' => 'ASC', 'limit' => -1, 'category' => -1,
|
||||||
'category_name' => '', 'hide_invisible' => 1, 'show_updated' => 0);
|
'category_name' => '', 'hide_invisible' => 1, 'show_updated' => 0, 'include' => '', 'exclude' => '');
|
||||||
$r = array_merge($defaults, $r);
|
$r = array_merge($defaults, $r);
|
||||||
extract($r);
|
extract($r);
|
||||||
|
|
||||||
|
$inclusions = '';
|
||||||
|
if ( !empty($include) ) {
|
||||||
|
$exclude = ''; //ignore exclude, category, and category_name params if using include
|
||||||
|
$category = -1;
|
||||||
|
$category_name = '';
|
||||||
|
$inclinks = preg_split('/[\s,]+/',$include);
|
||||||
|
if ( count($inclinks) ) {
|
||||||
|
foreach ( $inclinks as $inclink ) {
|
||||||
|
if (empty($inclusions))
|
||||||
|
$inclusions = ' AND ( link_id = ' . intval($inclink) . ' ';
|
||||||
|
else
|
||||||
|
$inclusions .= ' OR link_id = ' . intval($inclink) . ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!empty($inclusions))
|
||||||
|
$inclusions .= ')';
|
||||||
|
|
||||||
$exclusions = '';
|
$exclusions = '';
|
||||||
if ( !empty($exclude) ) {
|
if ( !empty($exclude) ) {
|
||||||
$exlinks = preg_split('/[\s,]+/',$r['exclude']);
|
$exlinks = preg_split('/[\s,]+/',$exclude);
|
||||||
if ( count($exlinks) ) {
|
if ( count($exlinks) ) {
|
||||||
foreach ( $exlinks as $exlink ) {
|
foreach ( $exlinks as $exlink ) {
|
||||||
|
if (empty($exclusions))
|
||||||
|
$exclusions = ' AND ( link_id <> ' . intval($exlink) . ' ';
|
||||||
|
else
|
||||||
$exclusions .= ' AND link_id <> ' . intval($exlink) . ' ';
|
$exclusions .= ' AND link_id <> ' . intval($exlink) . ' ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!empty($exclusions))
|
||||||
|
$exclusions .= ')';
|
||||||
|
|
||||||
if ( ! empty($category_name) ) {
|
if ( ! empty($category_name) ) {
|
||||||
if ( $cat_id = $wpdb->get_var("SELECT cat_ID FROM $wpdb->categories WHERE cat_name='$category_name' LIMIT 1") )
|
if ( $cat_id = $wpdb->get_var("SELECT cat_ID FROM $wpdb->categories WHERE cat_name='$category_name' LIMIT 1") )
|
||||||
|
@ -320,7 +343,7 @@ function get_bookmarks($args = '') {
|
||||||
$get_updated = ", UNIX_TIMESTAMP(link_updated) AS link_updated_f ";
|
$get_updated = ", UNIX_TIMESTAMP(link_updated) AS link_updated_f ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$orderby = strtolower($r['orderby']);
|
$orderby = strtolower($orderby);
|
||||||
$length = '';
|
$length = '';
|
||||||
switch ($orderby) {
|
switch ($orderby) {
|
||||||
case 'length':
|
case 'length':
|
||||||
|
@ -341,6 +364,7 @@ function get_bookmarks($args = '') {
|
||||||
$visible = "AND link_visible = 'Y'";
|
$visible = "AND link_visible = 'Y'";
|
||||||
|
|
||||||
$query = "SELECT * $length $recently_updated_test $get_updated FROM $wpdb->links $join WHERE 1=1 $visible $category_query";
|
$query = "SELECT * $length $recently_updated_test $get_updated FROM $wpdb->links $join WHERE 1=1 $visible $category_query";
|
||||||
|
$query .= " $exclusions $inclusions";
|
||||||
$query .= " ORDER BY $orderby $order";
|
$query .= " ORDER BY $orderby $order";
|
||||||
if ($limit != -1)
|
if ($limit != -1)
|
||||||
$query .= " LIMIT $limit";
|
$query .= " LIMIT $limit";
|
||||||
|
|
|
@ -376,28 +376,49 @@ function &get_categories($args = '') {
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
|
||||||
$defaults = array('type' => 'post', 'child_of' => 0, 'orderby' => 'name', 'order' => 'ASC',
|
$defaults = array('type' => 'post', 'child_of' => 0, 'orderby' => 'name', 'order' => 'ASC',
|
||||||
'hide_empty' => true, 'include_last_update_time' => false, 'hierarchical' => 1);
|
'hide_empty' => true, 'include_last_update_time' => false, 'hierarchical' => 1, $exclude => '', $include => '');
|
||||||
$r = array_merge($defaults, $r);
|
$r = array_merge($defaults, $r);
|
||||||
$r['orderby'] = "cat_" . $r['orderby'];
|
$r['orderby'] = "cat_" . $r['orderby']; // restricts order by to cat_ID and cat_name fields
|
||||||
extract($r);
|
extract($r);
|
||||||
|
|
||||||
$exclusions = '';
|
|
||||||
$having = '';
|
|
||||||
$where = 'cat_ID > 0';
|
$where = 'cat_ID > 0';
|
||||||
|
$inclusions = '';
|
||||||
|
if ( !empty($include) ) {
|
||||||
|
$child_of = 0; //ignore child_of and exclude params if using include
|
||||||
|
$exclude = '';
|
||||||
|
$incategories = preg_split('/[\s,]+/',$include);
|
||||||
|
if ( count($incategories) ) {
|
||||||
|
foreach ( $incategories as $incat ) {
|
||||||
|
if (empty($inclusions))
|
||||||
|
$inclusions = ' AND ( cat_ID = ' . intval($incat) . ' ';
|
||||||
|
else
|
||||||
|
$inclusions .= ' OR cat_ID = ' . intval($incat) . ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!empty($inclusions))
|
||||||
|
$inclusions .= ')';
|
||||||
|
$where .= $inclusions;
|
||||||
|
|
||||||
$exclusions = '';
|
$exclusions = '';
|
||||||
if ( !empty($exclude) ) {
|
if ( !empty($exclude) ) {
|
||||||
$excategories = preg_split('/[\s,]+/',$exclude);
|
$excategories = preg_split('/[\s,]+/',$exclude);
|
||||||
if ( count($excategories) ) {
|
if ( count($excategories) ) {
|
||||||
foreach ( $excategories as $excat ) {
|
foreach ( $excategories as $excat ) {
|
||||||
|
if (empty($exclusions))
|
||||||
|
$exclusions = ' AND ( cat_ID <> ' . intval($excat) . ' ';
|
||||||
|
else
|
||||||
$exclusions .= ' AND cat_ID <> ' . intval($excat) . ' ';
|
$exclusions .= ' AND cat_ID <> ' . intval($excat) . ' ';
|
||||||
// TODO: Exclude children of excluded cats?
|
// TODO: Exclude children of excluded cats? Note: children are getting excluded
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!empty($exclusions))
|
||||||
|
$exclusions .= ')';
|
||||||
$exclusions = apply_filters('list_cats_exclusions', $exclusions );
|
$exclusions = apply_filters('list_cats_exclusions', $exclusions );
|
||||||
$where .= $exclusions;
|
$where .= $exclusions;
|
||||||
|
|
||||||
|
$having = '';
|
||||||
if ( $hide_empty ) {
|
if ( $hide_empty ) {
|
||||||
if ( 'link' == $type )
|
if ( 'link' == $type )
|
||||||
$having = 'HAVING link_count > 0';
|
$having = 'HAVING link_count > 0';
|
||||||
|
|
|
@ -306,24 +306,47 @@ function &get_pages($args = '') {
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
|
||||||
$defaults = array('child_of' => 0, 'sort_order' => 'ASC', 'sort_column' => 'post_title',
|
$defaults = array('child_of' => 0, 'sort_order' => 'ASC', 'sort_column' => 'post_title',
|
||||||
'hierarchical' => 1);
|
'hierarchical' => 1, $exclude => '', $include => '');
|
||||||
$r = array_merge($defaults, $r);
|
$r = array_merge($defaults, $r);
|
||||||
|
extract($r);
|
||||||
|
|
||||||
|
$inclusions = '';
|
||||||
|
if ( !empty($include) ) {
|
||||||
|
$child_of = 0; //ignore child_of and exclude params if using include
|
||||||
|
$exclude = '';
|
||||||
|
$incpages = preg_split('/[\s,]+/',$include);
|
||||||
|
if ( count($incpages) ) {
|
||||||
|
foreach ( $incpages as $incpage ) {
|
||||||
|
if (empty($inclusions))
|
||||||
|
$inclusions = ' AND ( ID = ' . intval($incpage) . ' ';
|
||||||
|
else
|
||||||
|
$inclusions .= ' OR ID = ' . intval($incpage) . ' ';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!empty($inclusions))
|
||||||
|
$inclusions .= ')';
|
||||||
|
|
||||||
$exclusions = '';
|
$exclusions = '';
|
||||||
if ( !empty($r['exclude']) ) {
|
if ( !empty($exclude) ) {
|
||||||
$expages = preg_split('/[\s,]+/',$r['exclude']);
|
$expages = preg_split('/[\s,]+/',$exclude);
|
||||||
if ( count($expages) ) {
|
if ( count($expages) ) {
|
||||||
foreach ( $expages as $expage ) {
|
foreach ( $expages as $expage ) {
|
||||||
|
if (empty($exclusions))
|
||||||
|
$exclusions = ' AND ( ID <> ' . intval($expage) . ' ';
|
||||||
|
else
|
||||||
$exclusions .= ' AND ID <> ' . intval($expage) . ' ';
|
$exclusions .= ' AND ID <> ' . intval($expage) . ' ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!empty($exclusions))
|
||||||
|
$exclusions .= ')';
|
||||||
|
|
||||||
$pages = $wpdb->get_results("SELECT * " .
|
$pages = $wpdb->get_results("SELECT * " .
|
||||||
"FROM $wpdb->posts " .
|
"FROM $wpdb->posts " .
|
||||||
"WHERE post_type = 'page' AND post_status = 'publish' " .
|
"WHERE post_type = 'page' AND post_status = 'publish' " .
|
||||||
"$exclusions " .
|
"$exclusions $inclusions" .
|
||||||
"ORDER BY " . $r['sort_column'] . " " . $r['sort_order']);
|
"ORDER BY " . $sort_column . " " . $sort_order);
|
||||||
|
|
||||||
if ( empty($pages) )
|
if ( empty($pages) )
|
||||||
return array();
|
return array();
|
||||||
|
@ -331,8 +354,8 @@ function &get_pages($args = '') {
|
||||||
// Update cache.
|
// Update cache.
|
||||||
update_page_cache($pages);
|
update_page_cache($pages);
|
||||||
|
|
||||||
if ( $r['child_of'] || $r['hierarchical'] )
|
if ( $child_of || $hierarchical )
|
||||||
$pages = & get_page_children($r['child_of'], $pages);
|
$pages = & get_page_children($child_of, $pages);
|
||||||
|
|
||||||
return $pages;
|
return $pages;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue