update mime-to-icon matching and get filename from function instead of guid. Props andy. see #5911
git-svn-id: http://svn.automattic.com/wordpress/trunk@7036 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
f4490b8acb
commit
16c4b30145
|
@ -47,7 +47,7 @@ foreach($posts_columns as $column_name=>$column_display_name) {
|
||||||
case 'media':
|
case 'media':
|
||||||
?>
|
?>
|
||||||
<td><strong><a href="# TODO: upload.php?action=edit&post=<?php the_ID(); ?>"><?php the_title(); ?></a></strong><br />
|
<td><strong><a href="# TODO: upload.php?action=edit&post=<?php the_ID(); ?>"><?php the_title(); ?></a></strong><br />
|
||||||
<?php echo strtoupper(preg_replace('/^.*?\.(\w+)$/', '$1', $post->guid)); ?>
|
<?php echo strtoupper(preg_replace('/^.*?\.(\w+)$/', '$1', get_attached_file($post->ID))); ?>
|
||||||
<?php do_action('manage_media_media_column', $post->ID); ?>
|
<?php do_action('manage_media_media_column', $post->ID); ?>
|
||||||
</td>
|
</td>
|
||||||
<?php
|
<?php
|
||||||
|
|
|
@ -2334,51 +2334,71 @@ function wp_attachment_is_image( $post_id = 0 ) {
|
||||||
* @return string|bool {@internal Missing Description}}
|
* @return string|bool {@internal Missing Description}}
|
||||||
*/
|
*/
|
||||||
function wp_mime_type_icon( $mime = 0 ) {
|
function wp_mime_type_icon( $mime = 0 ) {
|
||||||
$post_id = 0;
|
if ( !is_numeric($mime) )
|
||||||
|
$icon = wp_cache_get("mime_type_icon_$mime");
|
||||||
$icon = wp_cache_get('mime_type_icon');
|
|
||||||
|
|
||||||
if ( empty($icon) ) {
|
if ( empty($icon) ) {
|
||||||
|
$post_id = 0;
|
||||||
|
$post_mimes = array();
|
||||||
if ( is_numeric($mime) ) {
|
if ( is_numeric($mime) ) {
|
||||||
$mime = (int) $mime;
|
$mime = (int) $mime;
|
||||||
if ( !$post =& get_post( $mime ) )
|
if ( $post =& get_post( $mime ) ) {
|
||||||
return false;
|
$post_id = (int) $post->ID;
|
||||||
$post_id = (int) $post->ID;
|
$ext = preg_replace('/^.+?\.([^.]+)$/', '$1', $post->guid);
|
||||||
$mime = $post->post_mime_type;
|
if ( !empty($ext) )
|
||||||
$ext = preg_replace('/^.+?\.([^.]+)$/', '$1', $post->guid);
|
$post_mimes[] = $ext;
|
||||||
|
$mime = $post->post_mime_type;
|
||||||
|
} else {
|
||||||
|
$mime = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$post_mimes[] = $mime;
|
||||||
}
|
}
|
||||||
|
|
||||||
$types = array();
|
$icon_files = wp_cache_get('icon_files');
|
||||||
|
|
||||||
if ( !empty($ext) )
|
if ( !is_array($icon_files) ) {
|
||||||
$types[] = $ext;
|
$icon_dir = apply_filters( 'icon_dir', ABSPATH . WPINC . '/images' );
|
||||||
|
$icon_dir_uri = apply_filters( 'icon_dir_uri', trailingslashit(get_option('siteurl')) . WPINC . '/images' );
|
||||||
$icon_dir = apply_filters( 'icon_dir', get_template_directory() . '/images' );
|
$dirs = apply_filters( 'icon_dirs', array($icon_dir => $icon_dir_uri) );
|
||||||
$icon_dir_uri = apply_filters( 'icon_dir_uri', get_template_directory_uri() . '/images' );
|
$icon_files = array();
|
||||||
$image_dir = apply_filters( 'image_dir', ABSPATH . WPINC . '/images' );
|
foreach ( $dirs as $dir => $uri) {
|
||||||
$image_dir_uri = apply_filters( 'image_dir', get_option('siteurl') . '/' . WPINC . '/images' );
|
if ( $dh = opendir($dir) ) {
|
||||||
$dirs = array($icon_dir => $icon_dir_uri, $image_dir => $image_dir_uri);
|
while ( false !== $file = readdir($dh) ) {
|
||||||
|
$file = basename($file);
|
||||||
|
if ( !in_array(strtolower(substr($file, -4)), array('.png', '.gif', '.jpg') ) ) {
|
||||||
|
if ( is_dir($file) )
|
||||||
|
$dirs["$dir/$file"] = "$uri/$file";
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$icon_files["$dir/$file"] = "$uri/$file";
|
||||||
|
}
|
||||||
|
closedir($dh);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
wp_cache_set('icon_files', $icon_files, 600);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Icon basename - extension = MIME wildcard
|
||||||
|
foreach ( $icon_files as $file => $uri )
|
||||||
|
$types[ preg_replace('/^([^.]*).*$/', '$1', basename($file)) ] =& $icon_files[$file];
|
||||||
|
|
||||||
if ( ! empty($mime) ) {
|
if ( ! empty($mime) ) {
|
||||||
$types[] = substr($mime, 0, strpos($mime, '/'));
|
$post_mimes[] = substr($mime, 0, strpos($mime, '/'));
|
||||||
$types[] = substr($mime, strpos($mime, '/') + 1);
|
$post_mimes[] = substr($mime, strpos($mime, '/') + 1);
|
||||||
$types[] = str_replace('/', '_', $mime);
|
$post_mimes[] = str_replace('/', '_', $mime);
|
||||||
}
|
}
|
||||||
|
|
||||||
$types[] = 'default';
|
$post_mimes[] = 'default';
|
||||||
|
|
||||||
$exts = array('png', 'gif', 'jpg');
|
$matches = wp_match_mime_types(array_keys($types), $post_mimes);
|
||||||
|
|
||||||
foreach ( $types as $type ) {
|
foreach ( $matches as $match => $wilds ) {
|
||||||
foreach ( $exts as $ext ) {
|
if ( isset($types[$wilds[0]])) {
|
||||||
foreach ( $dirs as $dir => $uri ) {
|
$icon = $types[$wilds[0]];
|
||||||
$src_file = "$dir/$type.$ext";
|
if ( !is_numeric($mime) )
|
||||||
if ( file_exists($src_file) ) {
|
wp_cache_set("mime_type_icon_$mime", $icon);
|
||||||
$icon = "$uri/$type.$ext";
|
break;
|
||||||
break 3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue