Clean up single_cat_title(), single_tag_title() and wp_title(). Fixes #14161

git-svn-id: http://svn.automattic.com/wordpress/trunk@15598 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
scribu 2010-09-08 16:21:13 +00:00
parent 00a9e39bcf
commit 6feafae8a1
1 changed files with 62 additions and 81 deletions

View File

@ -516,11 +516,6 @@ function get_bloginfo( $show = '', $filter = 'raw' ) {
function wp_title($sep = '»', $display = true, $seplocation = '') { function wp_title($sep = '»', $display = true, $seplocation = '') {
global $wpdb, $wp_locale, $wp_query; global $wpdb, $wp_locale, $wp_query;
$cat = get_query_var('cat');
$tag = get_query_var('tag_id');
$category_name = get_query_var('category_name');
$author = get_query_var('author');
$author_name = get_query_var('author_name');
$m = get_query_var('m'); $m = get_query_var('m');
$year = get_query_var('year'); $year = get_query_var('year');
$monthnum = get_query_var('monthnum'); $monthnum = get_query_var('monthnum');
@ -530,51 +525,38 @@ function wp_title($sep = '»', $display = true, $seplocation = '') {
$t_sep = '%WP_TITILE_SEP%'; // Temporary separator, for accurate flipping, if necessary $t_sep = '%WP_TITILE_SEP%'; // Temporary separator, for accurate flipping, if necessary
// If there's a category // If there is a post
if ( !empty($cat) ) { if ( is_single() || ( is_home() && !is_front_page() ) || ( is_page() && !is_front_page() ) ) {
// category exclusion $title = single_post_title( '', false );
if ( !stristr($cat,'-') )
$title = apply_filters('single_cat_title', get_the_category_by_ID($cat));
} elseif ( !empty($category_name) ) {
if ( stristr($category_name,'/') ) {
$category_name = explode('/',$category_name);
if ( $category_name[count($category_name)-1] )
$category_name = $category_name[count($category_name)-1]; // no trailing slash
else
$category_name = $category_name[count($category_name)-2]; // there was a trailling slash
}
$cat = get_term_by('slug', $category_name, 'category', OBJECT, 'display');
if ( $cat )
$title = apply_filters('single_cat_title', $cat->name);
} }
if ( !empty($tag) ) { // If there's a category or tag
$tag = get_term($tag, 'post_tag', OBJECT, 'display'); if ( is_category() || is_tag() ) {
if ( is_wp_error( $tag ) ) $title = single_term_title( '', false );
return $tag; }
if ( ! empty($tag->name) )
$title = apply_filters('single_tag_title', $tag->name); // If there's a taxonomy
if ( is_tax() ) {
$tax = get_taxonomy( get_query_var('taxonomy') );
$title = single_term_title( $tax->labels->name . $t_sep, false );
} }
// If there's an author // If there's an author
if ( !empty($author) ) { if ( is_author() ) {
$title = get_userdata($author); $author = $wp_query->get_queried_object();
$title = $title->display_name; $title = $author->display_name;
}
if ( !empty($author_name) ) {
// We do a direct query here because we don't cache by nicename.
$title = $wpdb->get_var($wpdb->prepare("SELECT display_name FROM $wpdb->users WHERE user_nicename = %s", $author_name));
} }
// If there's a month // If there's a month
if ( !empty($m) ) { if ( is_archive() && !empty($m) ) {
$my_year = substr($m, 0, 4); $my_year = substr($m, 0, 4);
$my_month = $wp_locale->get_month(substr($m, 4, 2)); $my_month = $wp_locale->get_month(substr($m, 4, 2));
$my_day = intval(substr($m, 6, 2)); $my_day = intval(substr($m, 6, 2));
$title = $my_year . ($my_month ? $t_sep . $my_month : "") . ($my_day ? $t_sep . $my_day : ""); $title = $my_year . ($my_month ? $t_sep . $my_month : "") . ($my_day ? $t_sep . $my_day : "");
} }
if ( !empty($year) ) { // If there's a year
if ( is_archive() && !empty($year) ) {
$title = $year; $title = $year;
if ( !empty($monthnum) ) if ( !empty($monthnum) )
$title .= $t_sep . $wp_locale->get_month($monthnum); $title .= $t_sep . $wp_locale->get_month($monthnum);
@ -582,27 +564,13 @@ function wp_title($sep = '»', $display = true, $seplocation = '') {
$title .= $t_sep . zeroise($day, 2); $title .= $t_sep . zeroise($day, 2);
} }
// If there is a post // If it's a search
if ( is_single() || ( is_home() && !is_front_page() ) || ( is_page() && !is_front_page() ) ) {
$post = $wp_query->get_queried_object();
$title = apply_filters( 'single_post_title', $post->post_title );
}
// If there's a taxonomy
if ( is_tax() ) {
$taxonomy = get_query_var( 'taxonomy' );
$tax = get_taxonomy( $taxonomy );
$term = $wp_query->get_queried_object();
$term = $term->name;
$title = $tax->labels->name . $t_sep . $term;
}
//If it's a search
if ( is_search() ) { if ( is_search() ) {
/* translators: 1: separator, 2: search phrase */ /* translators: 1: separator, 2: search phrase */
$title = sprintf(__('Search Results %1$s %2$s'), $t_sep, strip_tags($search)); $title = sprintf(__('Search Results %1$s %2$s'), $t_sep, strip_tags($search));
} }
// If it's a 404 page
if ( is_404() ) { if ( is_404() ) {
$title = __('Page not found'); $title = __('Page not found');
} }
@ -684,23 +652,8 @@ function single_post_title($prefix = '', $display = true) {
* @param bool $display Optional, default is true. Whether to display or retrieve title. * @param bool $display Optional, default is true. Whether to display or retrieve title.
* @return string|null Title when retrieving, null when displaying or failure. * @return string|null Title when retrieving, null when displaying or failure.
*/ */
function single_cat_title($prefix = '', $display = true ) { function single_cat_title( $prefix = '', $display = true ) {
global $wp_query; return single_term_title( $prefix, $display );
if ( is_tag() )
return single_tag_title($prefix, $display);
if ( !is_category() )
return;
$cat = $wp_query->get_queried_object();
$my_cat_name = apply_filters('single_cat_title', $cat->name);
if ( !empty($my_cat_name) ) {
if ( $display )
echo $prefix . $my_cat_name;
else
return $my_cat_name;
}
} }
/** /**
@ -720,23 +673,51 @@ function single_cat_title($prefix = '', $display = true ) {
* @param bool $display Optional, default is true. Whether to display or retrieve title. * @param bool $display Optional, default is true. Whether to display or retrieve title.
* @return string|null Title when retrieving, null when displaying or failure. * @return string|null Title when retrieving, null when displaying or failure.
*/ */
function single_tag_title($prefix = '', $display = true ) { function single_tag_title( $prefix = '', $display = true ) {
return single_term_title( $prefix, $display );
}
/**
* Display or retrieve page title for taxonomy term archive.
*
* Useful for taxonomy term template files for displaying the taxonomy term page title.
* It has less overhead than {@link wp_title()}, because of its limited implementation.
*
* It does not support placing the separator after the title, but by leaving the
* prefix parameter empty, you can set the title separator manually. The prefix
* does not automatically place a space between the prefix, so if there should
* be a space, the parameter value will need to have it at the end.
*
* @since 3.1.0
*
* @param string $prefix Optional. What to display before the title.
* @param bool $display Optional, default is true. Whether to display or retrieve title.
* @return string|null Title when retrieving, null when displaying or failure.
*/
function single_term_title( $prefix = '', $display = true ) {
global $wp_query; global $wp_query;
if ( !is_tag() )
$term = $wp_query->get_queried_object();
if ( !$term )
return; return;
$tag = $wp_query->get_queried_object(); if ( is_category() )
$term_name = apply_filters( 'single_cat_title', $term->name );
if ( ! $tag ) elseif ( is_tag() )
return; $term_name = apply_filters( 'single_tag_title', $term->name );
elseif ( is_term() )
$my_tag_name = apply_filters('single_tag_title', $tag->name); $term_name = apply_filters( 'single_term_title', $term->name );
if ( !empty($my_tag_name) ) {
if ( $display )
echo $prefix . $my_tag_name;
else else
return $my_tag_name; return;
}
if ( empty( $term_name ) )
return;
if ( $display )
echo $prefix . $term_name;
return $term_name;
} }
/** /**