More specific error codes in the core upgrader when copying language, plugin, and theme files. see #22704.

git-svn-id: https://develop.svn.wordpress.org/trunk@25772 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2013-10-14 19:37:53 +00:00
parent dde2cb32fa
commit bd26f54af2

View File

@ -765,8 +765,11 @@ function update_core($from, $to) {
if ( @is_dir($lang_dir) ) { if ( @is_dir($lang_dir) ) {
$wp_lang_dir = $wp_filesystem->find_folder($lang_dir); $wp_lang_dir = $wp_filesystem->find_folder($lang_dir);
if ( $wp_lang_dir ) if ( $wp_lang_dir ) {
$result = copy_dir($from . $distro . 'wp-content/languages/', $wp_lang_dir); $result = copy_dir($from . $distro . 'wp-content/languages/', $wp_lang_dir);
if ( is_wp_error( $result ) )
$result = new WP_Error( $result->get_error_code() . '_languages', $result->get_error_message(), $result->get_error_data() );
}
} }
} }
@ -803,15 +806,20 @@ function update_core($from, $to) {
continue; continue;
if ( ! $wp_filesystem->copy($from . $distro . 'wp-content/' . $file, $dest . $filename, FS_CHMOD_FILE) ) if ( ! $wp_filesystem->copy($from . $distro . 'wp-content/' . $file, $dest . $filename, FS_CHMOD_FILE) )
$result = new WP_Error( 'copy_failed_for_new_bundled', __( 'Could not copy file.' ), $dest . $filename ); $result = new WP_Error( "copy_failed_for_new_bundled_$type", __( 'Could not copy file.' ), $dest . $filename );
} else { } else {
if ( ! $development_build && $wp_filesystem->is_dir( $dest . $filename ) ) if ( ! $development_build && $wp_filesystem->is_dir( $dest . $filename ) )
continue; continue;
$wp_filesystem->mkdir($dest . $filename, FS_CHMOD_DIR); $wp_filesystem->mkdir($dest . $filename, FS_CHMOD_DIR);
$_result = copy_dir( $from . $distro . 'wp-content/' . $file, $dest . $filename); $_result = copy_dir( $from . $distro . 'wp-content/' . $file, $dest . $filename);
if ( is_wp_error($_result) ) //If a error occurs partway through this final step, keep the error flowing through, but keep process going.
$result = $_result; // If a error occurs partway through this final step, keep the error flowing through, but keep process going.
if ( is_wp_error( $_result ) ) {
if ( ! is_wp_error( $result ) )
$result = new WP_Error;
$result->add( $_result->get_error_code() . "_$type", $_result->get_error_message(), $_result->get_error_data() );
}
} }
} }
} //end foreach } //end foreach