Always pass back the custom classes `get_post_class()` was called with, even if the post was not found.

props F J Kaiser, Bueltge.
fixes #22271.

git-svn-id: https://develop.svn.wordpress.org/trunk@31408 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Sergey Biryukov 2015-02-11 03:59:06 +00:00
parent 2c12dc0ce3
commit 757fd2c1e4
2 changed files with 20 additions and 9 deletions

View File

@ -404,12 +404,20 @@ function post_class( $class = '', $post_id = null ) {
* @return array Array of classes. * @return array Array of classes.
*/ */
function get_post_class( $class = '', $post_id = null ) { function get_post_class( $class = '', $post_id = null ) {
$post = get_post($post_id); $post = get_post( $post_id );
$classes = array(); $classes = array();
if ( empty($post) ) if ( $class ) {
if ( ! is_array( $class ) ) {
$class = preg_split( '#\s+#', $class );
}
$classes = array_map( 'esc_attr', $class );
}
if ( ! $post ) {
return $classes; return $classes;
}
$classes[] = 'post-' . $post->ID; $classes[] = 'post-' . $post->ID;
if ( ! is_admin() ) if ( ! is_admin() )
@ -466,13 +474,7 @@ function get_post_class( $class = '', $post_id = null ) {
} }
} }
if ( !empty($class) ) { $classes = array_map( 'esc_attr', $classes );
if ( !is_array( $class ) )
$class = preg_split('#\s+#', $class);
$classes = array_merge($classes, $class);
}
$classes = array_map('esc_attr', $classes);
/** /**
* Filter the list of CSS classes for the current post. * Filter the list of CSS classes for the current post.

View File

@ -44,6 +44,15 @@ class Tests_Post_GetPostClass extends WP_UnitTestCase {
$this->assertContains( 'wptests_tax-bar', $found ); $this->assertContains( 'wptests_tax-bar', $found );
} }
/**
* @ticket 22271
*/
public function test_with_custom_classes_and_no_post() {
$this->assertEquals( array(), get_post_class( '', null ) );
$this->assertEquals( array( 'foo' ), get_post_class( 'foo', null ) );
$this->assertEquals( array( 'foo', 'bar' ), get_post_class( array( 'foo', 'bar' ), null ) );
}
/** /**
* @group cache * @group cache
*/ */