Remove support from WP_Theme for multiple screenshots until we bring it to the UI. fixes #20546.

git-svn-id: https://develop.svn.wordpress.org/trunk@20590 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2012-04-25 17:40:43 +00:00
parent b7101b038f
commit fca5a81af2

View File

@ -470,7 +470,7 @@ final class WP_Theme implements ArrayAccess {
* @access private * @access private
* @since 3.4.0 * @since 3.4.0
* *
* @param string $key Type of data to store (theme, screenshot, screenshot_count, files, headers) * @param string $key Type of data to store (theme, screenshot, headers, page_templates)
* @param string $data Data to store * @param string $data Data to store
* @return bool Return value from wp_cache_add() * @return bool Return value from wp_cache_add()
*/ */
@ -486,7 +486,7 @@ final class WP_Theme implements ArrayAccess {
* @access private * @access private
* @since 3.4.0 * @since 3.4.0
* *
* @param string $key Type of data to retrieve (theme, screenshot, screenshot_count, files, headers) * @param string $key Type of data to retrieve (theme, screenshot, headers, page_templates)
* @return mixed Retrieved data * @return mixed Retrieved data
*/ */
private function cache_get( $key ) { private function cache_get( $key ) {
@ -500,7 +500,7 @@ final class WP_Theme implements ArrayAccess {
* @since 3.4.0 * @since 3.4.0
*/ */
public function cache_delete() { public function cache_delete() {
foreach ( array( 'theme', 'screenshot', 'screenshot_count', 'headers', 'page_templates' ) as $key ) foreach ( array( 'theme', 'screenshot', 'headers', 'page_templates' ) as $key )
wp_cache_delete( $key . '-' . $this->cache_hash, 'themes' ); wp_cache_delete( $key . '-' . $this->cache_hash, 'themes' );
$this->template = $this->textdomain_loaded = $this->theme_root_uri = $this->parent = $this->errors = $this->headers_sanitized = $this->name_translated = null; $this->template = $this->textdomain_loaded = $this->theme_root_uri = $this->parent = $this->errors = $this->headers_sanitized = $this->name_translated = null;
$this->headers = array(); $this->headers = array();
@ -856,8 +856,8 @@ final class WP_Theme implements ArrayAccess {
* *
* The main screenshot is called screenshot.png. gif and jpg extensions are also allowed. * The main screenshot is called screenshot.png. gif and jpg extensions are also allowed.
* *
* Screenshots for a theme must be in the stylesheet directory. (In the case of a child * Screenshots for a theme must be in the stylesheet directory. (In the case of child
* theme, a parent theme's screenshots are not inherited.) * themes, parent theme screenshots are not inherited.)
* *
* @since 3.4.0 * @since 3.4.0
* @access public * @access public
@ -885,68 +885,9 @@ final class WP_Theme implements ArrayAccess {
} }
$this->cache_add( 'screenshot', 0 ); $this->cache_add( 'screenshot', 0 );
$this->cache_add( 'screenshot_count', 0 );
return false; return false;
} }
/**
* Returns the number of screenshots for a theme.
*
* The first screenshot may be called screenshot.png, .gif, or .jpg. Subsequent
* screenshots can be screenshot-2.png, screenshot-3.png, etc. The count must
* be consecutive for screenshots to be counted, and all screenshots beyond the
* initial one must be image/png files.
*
* @see WP_Theme::get_screenshot()
* @since 3.4.0
* @access public
*
* @return int Number of screenshots. Can be 0.
*/
public function get_screenshot_count() {
$screenshot_count = $this->cache_get( 'screenshot_count' );
if ( is_numeric( $screenshot_count ) )
return $screenshot_count;
// This will set the screenshot cache.
// If there is no screenshot, the screenshot_count cache will also be set.
if ( ! $screenshot = $this->get_screenshot( 'relative' ) )
return 0;
$prefix = $this->get_stylesheet() . '/screenshot-';
$files = self::scandir( $this->get_stylesheet_directory(), $this->get_stylesheet(), 'png' );
$screenshot_count = 1;
while ( in_array( $prefix . ( $screenshot_count + 1 ) . '.png', $files['png'] ) )
$screenshot_count++;
$this->cache_add( 'screenshot_count', $screenshot_count );
return $screenshot_count;
}
/**
* Returns an array of screenshot filenames.
*
* @see WP_Theme::get_screenshot()
* @see WP_Theme::get_screenshot_count()
* @since 3.4.0
* @access public
*
* @param string $uri Type of URL to return, either 'relative' or an absolute URI. Defaults to absolute URI.
* @return array Screenshots. Empty array if no screenshors are found.
*/
public function get_screenshots( $uri = 'uri' ) {
if ( ! $count = $this->get_screenshot_count() )
return array();
$pre = 'relative' == $uri ? '' : $this->get_stylesheet_directory_uri() . '/';
$screenshots = array( $pre . $this->get_screenshot( 'relative' ) );
for ( $i = 2; $i <= $count; $i++ )
$screenshots[] = $pre . 'screenshot-' . $i . '.png';
return $screenshots;
}
/** /**
* Return files in the theme's directory. * Return files in the theme's directory.
* *