Cacheing cleanup. Introduce get_post() and get_category(). http://mosquito.wordpress.org/view.php?id=1157
git-svn-id: http://svn.automattic.com/wordpress/trunk@2478 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
8682ab7007
commit
8f9c24ef7a
|
@ -169,7 +169,7 @@ $query_string = apply_filters('query_string', $query_string);
|
||||||
update_category_cache();
|
update_category_cache();
|
||||||
|
|
||||||
// Call query posts to do the work.
|
// Call query posts to do the work.
|
||||||
$posts = query_posts($query_string);
|
$posts = & query_posts($query_string);
|
||||||
|
|
||||||
// Extract updated query vars back into global namespace.
|
// Extract updated query vars back into global namespace.
|
||||||
extract($wp_query->query_vars);
|
extract($wp_query->query_vars);
|
||||||
|
|
|
@ -217,7 +217,7 @@ class WP_Query {
|
||||||
$this->query_vars[$query_var] = $value;
|
$this->query_vars[$query_var] = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_posts() {
|
function &get_posts() {
|
||||||
global $wpdb, $pagenow, $request, $user_ID;
|
global $wpdb, $pagenow, $request, $user_ID;
|
||||||
|
|
||||||
// Shorthand.
|
// Shorthand.
|
||||||
|
@ -595,7 +595,7 @@ class WP_Query {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function query($query) {
|
function &query($query) {
|
||||||
$this->parse_query($query);
|
$this->parse_query($query);
|
||||||
return $this->get_posts();
|
return $this->get_posts();
|
||||||
}
|
}
|
||||||
|
@ -609,11 +609,9 @@ class WP_Query {
|
||||||
$this->queried_object_id = 0;
|
$this->queried_object_id = 0;
|
||||||
|
|
||||||
if ($this->is_category) {
|
if ($this->is_category) {
|
||||||
global $cache_categories;
|
$category = &get_category($this->get('cat'));
|
||||||
if (isset($cache_categories[$this->get('cat')])) {
|
$this->queried_object = &$category;
|
||||||
$this->queried_object = $cache_categories[$this->get('cat')];
|
|
||||||
$this->queried_object_id = $this->get('cat');
|
$this->queried_object_id = $this->get('cat');
|
||||||
}
|
|
||||||
} else if ($this->is_single) {
|
} else if ($this->is_single) {
|
||||||
$this->queried_object = $this->post;
|
$this->queried_object = $this->post;
|
||||||
$this->queried_object_id = $this->post->ID;
|
$this->queried_object_id = $this->post->ID;
|
||||||
|
|
|
@ -538,16 +538,67 @@ function get_postdata($postid) {
|
||||||
return $postdata;
|
return $postdata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retrieves post data given a post ID or post object.
|
||||||
|
// Handles post caching.
|
||||||
|
function &get_post(&$post, $output = OBJECT) {
|
||||||
|
global $post_cache, $wpdb;
|
||||||
|
|
||||||
|
if ( empty($post) ) {
|
||||||
|
if ( isset($GLOBALS['post']) )
|
||||||
|
$post = & $GLOBALS['post'];
|
||||||
|
else
|
||||||
|
$post = null;
|
||||||
|
} elseif (is_object($post) ) {
|
||||||
|
if (! isset($post_cache[$post->ID]))
|
||||||
|
$post_cache[$post->ID] = &$post;
|
||||||
|
$post = & $post_cache[$post->ID];
|
||||||
|
} else {
|
||||||
|
if ( isset($GLOBALS['post']) && ($post == $GLOBALS['post']->ID) )
|
||||||
|
$post = & $GLOBALS['post'];
|
||||||
|
elseif (isset($post_cache[$post]))
|
||||||
|
$post = & $post_cache[$post];
|
||||||
|
else {
|
||||||
|
$query = "SELECT * FROM $wpdb->posts WHERE ID=$post";
|
||||||
|
$post_cache[$post] = & $wpdb->get_row($query);
|
||||||
|
$post = & $post_cache[$post];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( $output == OBJECT ) {
|
||||||
|
return $post;
|
||||||
|
} elseif ( $output == ARRAY_A ) {
|
||||||
|
return get_object_vars($post);
|
||||||
|
} elseif ( $output == ARRAY_N ) {
|
||||||
|
return array_values(get_object_vars($post));
|
||||||
|
} else {
|
||||||
|
return $post;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieves category data given a category ID or category object.
|
||||||
|
// The category cache is fully populated by the blog header, so we don't
|
||||||
|
// have to worry with managing it here.
|
||||||
|
function &get_category(&$category, $output = OBJECT) {
|
||||||
|
global $cache_categories;
|
||||||
|
if (is_object($category))
|
||||||
|
$category = & $cache_categories[$category->cat_ID];
|
||||||
|
else
|
||||||
|
$category = & $cache_categories[$category];
|
||||||
|
|
||||||
|
if ( $output == OBJECT ) {
|
||||||
|
return $category;
|
||||||
|
} elseif ( $output == ARRAY_A ) {
|
||||||
|
return get_object_vars($category);
|
||||||
|
} elseif ( $output == ARRAY_N ) {
|
||||||
|
return array_values(get_object_vars($category));
|
||||||
|
} else {
|
||||||
|
return $category;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function get_catname($cat_ID) {
|
function get_catname($cat_ID) {
|
||||||
global $cache_catnames, $wpdb;
|
$category = &get_category($cat_ID);
|
||||||
if ( !$cache_catnames ) {
|
return $category->cat_name;
|
||||||
$results = $wpdb->get_results("SELECT * FROM $wpdb->categories") or die('Oops, couldn\'t query the db for categories.');
|
|
||||||
foreach ($results as $post) {
|
|
||||||
$cache_catnames[$post->cat_ID] = $post->cat_name;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$cat_name = $cache_catnames[$cat_ID];
|
|
||||||
return $cat_name;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function gzip_compression() {
|
function gzip_compression() {
|
||||||
|
@ -995,16 +1046,7 @@ function remove_action($tag, $function_to_remove, $priority = 10, $accepted_args
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_page_uri($page_id) {
|
function get_page_uri($page_id) {
|
||||||
global $wpdb, $cache_pages;
|
$page = get_post($page_id);
|
||||||
|
|
||||||
$dates = ",UNIX_TIMESTAMP(post_modified) AS time_modified";
|
|
||||||
$dates .= ",UNIX_TIMESTAMP(post_date) AS time_created";
|
|
||||||
|
|
||||||
if (!isset($cache_pages[$page_id])) {
|
|
||||||
$cache_pages[$page_id] = $wpdb->get_row("SELECT ID, post_title, post_name, post_parent $dates FROM $wpdb->posts WHERE ID = '$page_id'");
|
|
||||||
}
|
|
||||||
|
|
||||||
$page = $cache_pages[$page_id];
|
|
||||||
$uri = urldecode($page->post_name);
|
$uri = urldecode($page->post_name);
|
||||||
|
|
||||||
// A page cannot be it's own parent.
|
// A page cannot be it's own parent.
|
||||||
|
@ -1013,12 +1055,7 @@ function get_page_uri($page_id) {
|
||||||
}
|
}
|
||||||
|
|
||||||
while ($page->post_parent != 0) {
|
while ($page->post_parent != 0) {
|
||||||
if (isset($cache_pages[$page->post_parent])) {
|
$page = get_post($page->post_parent);
|
||||||
$page = $cache_pages[$page->post_parent];
|
|
||||||
} else {
|
|
||||||
$page = $wpdb->get_row("SELECT ID, post_title, post_name, post_parent $dates FROM $wpdb->posts WHERE ID = '$page->post_parent'");
|
|
||||||
$cache_pages[$page->ID] = $page;
|
|
||||||
}
|
|
||||||
$uri = urldecode($page->post_name) . "/" . $uri;
|
$uri = urldecode($page->post_name) . "/" . $uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1049,13 +1086,44 @@ function get_posts($args) {
|
||||||
return $posts;
|
return $posts;
|
||||||
}
|
}
|
||||||
|
|
||||||
function query_posts($query) {
|
function &query_posts($query) {
|
||||||
global $wp_query;
|
global $wp_query;
|
||||||
return $wp_query->query($query);
|
return $wp_query->query($query);
|
||||||
}
|
}
|
||||||
|
|
||||||
function update_post_caches($posts) {
|
function update_post_cache(&$posts) {
|
||||||
global $category_cache, $comment_count_cache, $post_meta_cache;
|
global $post_cache;
|
||||||
|
|
||||||
|
if ( !$posts )
|
||||||
|
return;
|
||||||
|
|
||||||
|
for ($i = 0; $i < count($posts); $i++) {
|
||||||
|
$post_cache[$posts[$i]->ID] = &$posts[$i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_post_category_cache($post_ids) {
|
||||||
|
global $wpdb, $category_cache, $cache_categories;
|
||||||
|
|
||||||
|
if (empty($post_ids))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (is_array($post_ids))
|
||||||
|
$post_ids = implode(',', $post_ids);
|
||||||
|
|
||||||
|
$dogs = $wpdb->get_results("SELECT DISTINCT
|
||||||
|
post_id, category_id FROM $wpdb->categories, $wpdb->post2cat
|
||||||
|
WHERE category_id = cat_ID AND post_id IN ($post_ids)");
|
||||||
|
|
||||||
|
if ( !empty($dogs) ) {
|
||||||
|
foreach ($dogs as $catt) {
|
||||||
|
$category_cache[$catt->post_id][$catt->category_id] = &$cache_categories[$catt->category_id];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_post_caches(&$posts) {
|
||||||
|
global $post_cache, $category_cache, $comment_count_cache, $post_meta_cache;
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
// No point in doing all this work if we didn't match any posts.
|
// No point in doing all this work if we didn't match any posts.
|
||||||
|
@ -1063,20 +1131,14 @@ function update_post_caches($posts) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Get the categories for all the posts
|
// Get the categories for all the posts
|
||||||
foreach ($posts as $post)
|
for ($i = 0; $i < count($posts); $i++) {
|
||||||
$post_id_list[] = $post->ID;
|
$post_id_list[] = $posts[$i]->ID;
|
||||||
|
$post_cache[$posts[$i]->ID] = &$posts[$i];
|
||||||
|
}
|
||||||
|
|
||||||
$post_id_list = implode(',', $post_id_list);
|
$post_id_list = implode(',', $post_id_list);
|
||||||
|
|
||||||
$dogs = $wpdb->get_results("SELECT DISTINCT
|
update_post_category_cache($post_id_list);
|
||||||
post_id, category_id, cat_name, category_nicename, category_description, category_parent
|
|
||||||
FROM $wpdb->categories, $wpdb->post2cat
|
|
||||||
WHERE category_id = cat_ID AND post_id IN ($post_id_list)");
|
|
||||||
|
|
||||||
if ( !empty($dogs) ) {
|
|
||||||
foreach ($dogs as $catt) {
|
|
||||||
$category_cache[$catt->post_id][$catt->category_id] = $catt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Do the same for comment numbers
|
// Do the same for comment numbers
|
||||||
$comment_counts = $wpdb->get_results("SELECT ID, COUNT( comment_ID ) AS ccount
|
$comment_counts = $wpdb->get_results("SELECT ID, COUNT( comment_ID ) AS ccount
|
||||||
|
@ -1114,9 +1176,11 @@ function update_post_caches($posts) {
|
||||||
function update_category_cache() {
|
function update_category_cache() {
|
||||||
global $cache_categories, $wpdb;
|
global $cache_categories, $wpdb;
|
||||||
$dogs = $wpdb->get_results("SELECT * FROM $wpdb->categories");
|
$dogs = $wpdb->get_results("SELECT * FROM $wpdb->categories");
|
||||||
foreach ($dogs as $catt)
|
foreach ($dogs as $catt) {
|
||||||
|
$catt->category_id = $catt->cat_ID; // Alias.
|
||||||
$cache_categories[$catt->cat_ID] = $catt;
|
$cache_categories[$catt->cat_ID] = $catt;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function update_user_cache() {
|
function update_user_cache() {
|
||||||
global $cache_userdata, $wpdb;
|
global $cache_userdata, $wpdb;
|
||||||
|
|
|
@ -1,20 +1,15 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
function get_the_category($id = false) {
|
function get_the_category($id = false) {
|
||||||
global $post, $wpdb, $category_cache;
|
global $post, $category_cache;
|
||||||
|
|
||||||
if ( !$id )
|
if ( !$id )
|
||||||
$id = $post->ID;
|
$id = $post->ID;
|
||||||
|
|
||||||
if ( $category_cache[$id] ) {
|
if ( ! isset($category_cache[$id]) )
|
||||||
|
update_post_category_cache($id);
|
||||||
|
|
||||||
$categories = $category_cache[$id];
|
$categories = $category_cache[$id];
|
||||||
} else {
|
|
||||||
$categories = $wpdb->get_results("
|
|
||||||
SELECT category_id, cat_name, category_nicename, category_description, category_parent
|
|
||||||
FROM $wpdb->categories, $wpdb->post2cat
|
|
||||||
WHERE $wpdb->post2cat.category_id = cat_ID AND $wpdb->post2cat.post_id = '$id'
|
|
||||||
");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($categories))
|
if (!empty($categories))
|
||||||
sort($categories);
|
sort($categories);
|
||||||
|
@ -25,19 +20,17 @@ function get_the_category($id = false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_category_link($category_id) {
|
function get_category_link($category_id) {
|
||||||
global $wpdb, $wp_rewrite, $querystring_start, $querystring_equal, $cache_categories;
|
global $wp_rewrite;
|
||||||
$catlink = $wp_rewrite->get_category_permastruct();
|
$catlink = $wp_rewrite->get_category_permastruct();
|
||||||
|
|
||||||
if ( empty($catlink) ) {
|
if ( empty($catlink) ) {
|
||||||
$file = get_settings('home') . '/' . get_settings('blogfilename');
|
$file = get_settings('home') . '/' . get_settings('blogfilename');
|
||||||
$catlink = $file . '?cat=' . $category_id;
|
$catlink = $file . '?cat=' . $category_id;
|
||||||
} else {
|
} else {
|
||||||
if ($cache_categories[$category_id]->category_nicename)
|
$category = &get_category($category_id);
|
||||||
$category_nicename = $cache_categories[$category_id]->category_nicename;
|
$category_nicename = $category->category_nicename;
|
||||||
else
|
|
||||||
$category_nicename = $wpdb->get_var('SELECT category_nicename FROM ' . $wpdb->categories . ' WHERE cat_ID=' . $category_id);
|
|
||||||
|
|
||||||
if ($parent = $cache_categories[$category_id]->category_parent)
|
if ($parent = $category->category_parent)
|
||||||
$category_nicename = get_category_parents($parent, false, '/', true) . $category_nicename . '/';
|
$category_nicename = get_category_parents($parent, false, '/', true) . $category_nicename . '/';
|
||||||
|
|
||||||
$catlink = str_replace('%category%', $category_nicename, $catlink);
|
$catlink = str_replace('%category%', $category_nicename, $catlink);
|
||||||
|
@ -108,20 +101,13 @@ function the_category($separator = '', $parents='') {
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_the_category_by_ID($cat_ID) {
|
function get_the_category_by_ID($cat_ID) {
|
||||||
global $cache_categories, $wpdb;
|
$category = &get_category($cat_ID);
|
||||||
if ( !$cache_categories[$cat_ID] ) {
|
return $category->cat_name;
|
||||||
$cat_name = $wpdb->get_var("SELECT cat_name FROM $wpdb->categories WHERE cat_ID = '$cat_ID'");
|
|
||||||
$cache_categories[$cat_ID]->cat_name = $cat_name;
|
|
||||||
} else {
|
|
||||||
$cat_name = $cache_categories[$cat_ID]->cat_name;
|
|
||||||
}
|
|
||||||
return($cat_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_category_parents($id, $link = FALSE, $separator = '/', $nicename = FALSE){
|
function get_category_parents($id, $link = FALSE, $separator = '/', $nicename = FALSE){
|
||||||
global $cache_categories;
|
|
||||||
$chain = '';
|
$chain = '';
|
||||||
$parent = $cache_categories[$id];
|
$parent = &get_category($id);
|
||||||
if ($nicename) {
|
if ($nicename) {
|
||||||
$name = $parent->category_nicename;
|
$name = $parent->category_nicename;
|
||||||
} else {
|
} else {
|
||||||
|
@ -175,11 +161,10 @@ function the_category_head($before='', $after='') {
|
||||||
}
|
}
|
||||||
|
|
||||||
function category_description($category = 0) {
|
function category_description($category = 0) {
|
||||||
global $cat, $wpdb, $cache_categories;
|
global $cat;
|
||||||
if (!$category) $category = $cat;
|
if (!$category) $category = $cat;
|
||||||
$category_description = $cache_categories[$category]->category_description;
|
$category = & get_category($category);
|
||||||
$category_description = apply_filters('category_description', $category_description, $category);
|
return apply_filters('category_description', $category->category_description, $category->cat_ID);
|
||||||
return $category_description;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// out of the WordPress loop
|
// out of the WordPress loop
|
||||||
|
|
|
@ -193,8 +193,8 @@ function single_post_title($prefix = '', $display = true) {
|
||||||
if (!$p) {
|
if (!$p) {
|
||||||
$p = $wpdb->get_var("SELECT ID FROM $wpdb->posts WHERE post_name = '$name'");
|
$p = $wpdb->get_var("SELECT ID FROM $wpdb->posts WHERE post_name = '$name'");
|
||||||
}
|
}
|
||||||
$post_data = get_postdata($p);
|
$post = & get_post($p);
|
||||||
$title = $post_data['Title'];
|
$title = $post->post_title;
|
||||||
$title = apply_filters('single_post_title', $title);
|
$title = apply_filters('single_post_title', $title);
|
||||||
if ($display) {
|
if ($display) {
|
||||||
echo $prefix.strip_tags($title);
|
echo $prefix.strip_tags($title);
|
||||||
|
@ -347,11 +347,11 @@ function get_archives($type='', $limit='', $format='html', $before = '', $after
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} elseif ('postbypost' == $type) {
|
} elseif ('postbypost' == $type) {
|
||||||
$arcresults = $wpdb->get_results("SELECT ID, post_date, post_title FROM $wpdb->posts WHERE post_date < '$now' AND post_status = 'publish' ORDER BY post_date DESC" . $limit);
|
$arcresults = $wpdb->get_results("SELECT * FROM $wpdb->posts WHERE post_date < '$now' AND post_status = 'publish' ORDER BY post_date DESC" . $limit);
|
||||||
if ($arcresults) {
|
if ($arcresults) {
|
||||||
foreach ($arcresults as $arcresult) {
|
foreach ($arcresults as $arcresult) {
|
||||||
if ($arcresult->post_date != '0000-00-00 00:00:00') {
|
if ($arcresult->post_date != '0000-00-00 00:00:00') {
|
||||||
$url = get_permalink($arcresult->ID);
|
$url = get_permalink($arcresult);
|
||||||
$arc_title = $arcresult->post_title;
|
$arc_title = $arcresult->post_title;
|
||||||
if ($arc_title) {
|
if ($arc_title) {
|
||||||
$text = strip_tags($arc_title);
|
$text = strip_tags($arc_title);
|
||||||
|
|
|
@ -22,9 +22,7 @@ function permalink_anchor($mode = 'id') {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_permalink($id = false) {
|
function get_permalink($id = 0) {
|
||||||
global $post, $wpdb;
|
|
||||||
|
|
||||||
$rewritecode = array(
|
$rewritecode = array(
|
||||||
'%year%',
|
'%year%',
|
||||||
'%monthnum%',
|
'%monthnum%',
|
||||||
|
@ -39,29 +37,24 @@ function get_permalink($id = false) {
|
||||||
'%pagename%'
|
'%pagename%'
|
||||||
);
|
);
|
||||||
|
|
||||||
if ($id) {
|
$post = & get_post($id);
|
||||||
$idpost = $wpdb->get_row("SELECT ID, post_date, post_name, post_status, post_author FROM $wpdb->posts WHERE ID = $id");
|
if ($post->post_status == 'static') {
|
||||||
} else {
|
return get_page_link($post->ID);
|
||||||
$idpost = $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($idpost->post_status == 'static') {
|
|
||||||
return get_page_link($idpost->ID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$permalink = get_settings('permalink_structure');
|
$permalink = get_settings('permalink_structure');
|
||||||
|
|
||||||
if ('' != $permalink) {
|
if ('' != $permalink) {
|
||||||
$unixtime = strtotime($idpost->post_date);
|
$unixtime = strtotime($post->post_date);
|
||||||
|
|
||||||
$category = '';
|
$category = '';
|
||||||
if (strstr($permalink, '%category%')) {
|
if (strstr($permalink, '%category%')) {
|
||||||
$cats = get_the_category($idpost->ID);
|
$cats = get_the_category($post->ID);
|
||||||
$category = $cats[0]->category_nicename;
|
$category = $cats[0]->category_nicename;
|
||||||
if ($parent=$cats[0]->category_parent) $category = get_category_parents($parent, FALSE, '/', TRUE) . $category;
|
if ($parent=$cats[0]->category_parent) $category = get_category_parents($parent, FALSE, '/', TRUE) . $category;
|
||||||
}
|
}
|
||||||
|
|
||||||
$authordata = get_userdata($idpost->post_author);
|
$authordata = get_userdata($post->post_author);
|
||||||
$author = $authordata->user_nicename;
|
$author = $authordata->user_nicename;
|
||||||
$rewritereplace =
|
$rewritereplace =
|
||||||
array(
|
array(
|
||||||
|
@ -71,16 +64,16 @@ function get_permalink($id = false) {
|
||||||
date('H', $unixtime),
|
date('H', $unixtime),
|
||||||
date('i', $unixtime),
|
date('i', $unixtime),
|
||||||
date('s', $unixtime),
|
date('s', $unixtime),
|
||||||
$idpost->post_name,
|
$post->post_name,
|
||||||
$idpost->ID,
|
$post->ID,
|
||||||
$category,
|
$category,
|
||||||
$author,
|
$author,
|
||||||
$idpost->post_name,
|
$post->post_name,
|
||||||
);
|
);
|
||||||
return apply_filters('post_link', get_settings('home') . str_replace($rewritecode, $rewritereplace, $permalink), $idpost);
|
return apply_filters('post_link', get_settings('home') . str_replace($rewritecode, $rewritereplace, $permalink), $post);
|
||||||
} else { // if they're not using the fancy permalink option
|
} else { // if they're not using the fancy permalink option
|
||||||
$permalink = get_settings('home') . '/?p=' . $idpost->ID;
|
$permalink = get_settings('home') . '/?p=' . $post->ID;
|
||||||
return apply_filters('post_link', $permalink, $idpost);
|
return apply_filters('post_link', $permalink, $post);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,34 +26,23 @@ function the_title($before = '', $after = '', $echo = true) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_the_title($id = 0) {
|
function get_the_title($id = 0) {
|
||||||
global $post, $wpdb;
|
$post = &get_post($id);
|
||||||
|
|
||||||
if ( 0 != $id ) {
|
|
||||||
$id_post = $wpdb->get_row("SELECT post_title, post_password FROM $wpdb->posts WHERE ID = $id");
|
|
||||||
$title = $id_post->post_title;
|
|
||||||
if (!empty($id_post->post_password))
|
|
||||||
$title = sprintf(__('Protected: %s'), $title);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$title = $post->post_title;
|
$title = $post->post_title;
|
||||||
if (!empty($post->post_password))
|
if (!empty($post->post_password))
|
||||||
$title = sprintf(__('Protected: %s'), $title);
|
$title = sprintf(__('Protected: %s'), $title);
|
||||||
}
|
|
||||||
return $title;
|
return $title;
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_the_guid( $id = 0 ) {
|
function get_the_guid( $id = 0 ) {
|
||||||
global $post, $wpdb;
|
$post = &get_post($id);
|
||||||
$guid = $post->guid;
|
|
||||||
|
|
||||||
if ( 0 != $id )
|
return apply_filters('get_the_guid', $post->guid);
|
||||||
$guid = $wpdb->get_var("SELECT guid FROM $wpdb->posts WHERE ID = $id");
|
|
||||||
$guid = apply_filters('get_the_guid', $guid);
|
|
||||||
return $guid;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function the_guid( $id = 0 ) {
|
function the_guid( $id = 0 ) {
|
||||||
echo get_the_guid();
|
echo get_the_guid($id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -261,7 +250,7 @@ function the_meta() {
|
||||||
// Pages
|
// Pages
|
||||||
//
|
//
|
||||||
|
|
||||||
function get_pages($args = '') {
|
function &get_pages($args = '') {
|
||||||
global $wpdb, $cache_pages;
|
global $wpdb, $cache_pages;
|
||||||
|
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
@ -280,29 +269,20 @@ function get_pages($args = '') {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$dates = ",UNIX_TIMESTAMP(post_modified) AS time_modified";
|
|
||||||
$dates .= ",UNIX_TIMESTAMP(post_date) AS time_created";
|
|
||||||
|
|
||||||
$post_parent = '';
|
$post_parent = '';
|
||||||
if ($r['child_of']) {
|
if ($r['child_of']) {
|
||||||
$post_parent = ' AND post_parent=' . $r['child_of'] . ' ';
|
$post_parent = ' AND post_parent=' . $r['child_of'] . ' ';
|
||||||
}
|
}
|
||||||
|
|
||||||
$pages = $wpdb->get_results("SELECT " .
|
$pages = $wpdb->get_results("SELECT * " .
|
||||||
"ID, post_title, post_name, post_parent " .
|
|
||||||
"$dates " .
|
|
||||||
"FROM $wpdb->posts " .
|
"FROM $wpdb->posts " .
|
||||||
"WHERE post_status = 'static' " .
|
"WHERE post_status = 'static' " .
|
||||||
"$post_parent" .
|
"$post_parent" .
|
||||||
"$exclusions " .
|
"$exclusions " .
|
||||||
"ORDER BY " . $r['sort_column'] . " " . $r['sort_order']);
|
"ORDER BY " . $r['sort_column'] . " " . $r['sort_order']);
|
||||||
|
|
||||||
// Update page cache.
|
// Update cache.
|
||||||
if (count($pages)) {
|
update_post_cache($pages);
|
||||||
foreach($pages as $page) {
|
|
||||||
$cache_pages[$page->ID] = $page;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( empty($pages) )
|
if ( empty($pages) )
|
||||||
$pages = array();
|
$pages = array();
|
||||||
|
@ -319,7 +299,7 @@ function wp_list_pages($args = '') {
|
||||||
|
|
||||||
|
|
||||||
// Query pages.
|
// Query pages.
|
||||||
$pages = get_pages($args);
|
$pages = & get_pages($args);
|
||||||
if ( $pages ) :
|
if ( $pages ) :
|
||||||
|
|
||||||
if ( $r['title_li'] )
|
if ( $r['title_li'] )
|
||||||
|
@ -338,9 +318,9 @@ function wp_list_pages($args = '') {
|
||||||
// ts field.
|
// ts field.
|
||||||
if (! empty($r['show_date'])) {
|
if (! empty($r['show_date'])) {
|
||||||
if ('modified' == $r['show_date'])
|
if ('modified' == $r['show_date'])
|
||||||
$page_tree[$page->ID]['ts'] = $page->time_modified;
|
$page_tree[$page->ID]['ts'] = $page->post_modified;
|
||||||
else
|
else
|
||||||
$page_tree[$page->ID]['ts'] = $page->time_created;
|
$page_tree[$page->ID]['ts'] = $page->post_date;
|
||||||
}
|
}
|
||||||
|
|
||||||
// The tricky bit!!
|
// The tricky bit!!
|
||||||
|
@ -383,7 +363,7 @@ function _page_level_out($parent, $page_tree, $args, $depth = 0) {
|
||||||
$format = get_settings('date_format');
|
$format = get_settings('date_format');
|
||||||
if(isset($args['date_format']))
|
if(isset($args['date_format']))
|
||||||
$format = $args['date_format'];
|
$format = $args['date_format'];
|
||||||
echo " " . gmdate($format,$cur_page['ts']);
|
echo " " . mysql2date($format,$cur_page['ts']);
|
||||||
}
|
}
|
||||||
echo "\n";
|
echo "\n";
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue