Allow `the_title_attribute()` to receive a `post` argument, and use this in `get_adjacent_post_rel_link()` to make sure tags are stripped from the title output there.

Fixes #24232.

git-svn-id: http://core.svn.wordpress.org/trunk@24783 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Mark Jaquith 2013-07-23 16:05:40 +00:00
parent a70604d441
commit 60c9de28b4
2 changed files with 8 additions and 9 deletions

View File

@ -1220,16 +1220,15 @@ function get_adjacent_post_rel_link($title = '%title', $in_same_cat = false, $ex
if ( empty($post) ) if ( empty($post) )
return; return;
if ( empty($post->post_title) ) $post_title = the_title_attribute( array( 'echo' => false, 'post' => $post ) );
if ( empty( $post_title ) )
$post_title = $previous ? __('Previous Post') : __('Next Post'); $post_title = $previous ? __('Previous Post') : __('Next Post');
else
$post_title = $post->post_title;
$date = mysql2date(get_option('date_format'), $post->post_date); $date = mysql2date(get_option('date_format'), $post->post_date);
$title = str_replace('%title', $post_title, $title); $title = str_replace('%title', $post_title, $title);
$title = str_replace('%date', $date, $title); $title = str_replace('%date', $date, $title);
$title = apply_filters('the_title', $title, $post->ID);
$link = $previous ? "<link rel='prev' title='" : "<link rel='next' title='"; $link = $previous ? "<link rel='prev' title='" : "<link rel='next' title='";
$link .= esc_attr( $title ); $link .= esc_attr( $title );

View File

@ -69,15 +69,15 @@ function the_title($before = '', $after = '', $echo = true) {
* @return string|null Null on failure or display. String when echo is false. * @return string|null Null on failure or display. String when echo is false.
*/ */
function the_title_attribute( $args = '' ) { function the_title_attribute( $args = '' ) {
$title = get_the_title(); $defaults = array('before' => '', 'after' => '', 'echo' => true, 'post' => get_post() );
$r = wp_parse_args($args, $defaults);
extract( $r, EXTR_SKIP );
$title = get_the_title( $post );
if ( strlen($title) == 0 ) if ( strlen($title) == 0 )
return; return;
$defaults = array('before' => '', 'after' => '', 'echo' => true);
$r = wp_parse_args($args, $defaults);
extract( $r, EXTR_SKIP );
$title = $before . $title . $after; $title = $before . $title . $after;
$title = esc_attr(strip_tags($title)); $title = esc_attr(strip_tags($title));