X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/ac7339a398e6df50f722bc9616291ce5447d8e5e..refs/tags/wordpress-4.7-scripts:/wp-admin/includes/update-core.php diff --git a/wp-admin/includes/update-core.php b/wp-admin/includes/update-core.php index a15cc887..3e6aaa20 100644 --- a/wp-admin/includes/update-core.php +++ b/wp-admin/includes/update-core.php @@ -598,9 +598,10 @@ $_old_files = array( 'wp-admin/css/colors.min.css', 'wp-admin/css/colors-rtl.css', 'wp-admin/css/colors-rtl.min.css', -'wp-admin/css/media-rtl.min.css', -'wp-admin/css/media.min.css', -'wp-admin/css/farbtastic-rtl.min.css', +// Following files added back in 4.5 see #36083 +// 'wp-admin/css/media-rtl.min.css', +// 'wp-admin/css/media.min.css', +// 'wp-admin/css/farbtastic-rtl.min.css', 'wp-admin/images/lock-2x.png', 'wp-admin/images/lock.png', 'wp-admin/js/theme-preview.js', @@ -694,7 +695,16 @@ $_old_files = array( 'wp-includes/js/jquery/ui/jquery.ui.tabs.min.js', 'wp-includes/js/jquery/ui/jquery.ui.tooltip.min.js', 'wp-includes/js/jquery/ui/jquery.ui.widget.min.js', -'wp-includes/js/tinymce/skins/wordpress/images/dashicon-no-alt.png' +'wp-includes/js/tinymce/skins/wordpress/images/dashicon-no-alt.png', +// 4.3 +'wp-admin/js/wp-fullscreen.js', +'wp-admin/js/wp-fullscreen.min.js', +'wp-includes/js/tinymce/wp-mce-help.php', +'wp-includes/js/tinymce/plugins/wpfullscreen', +// 4.5 +'wp-includes/theme-compat/comments-popup.php', +// 4.6 +'wp-admin/includes/class-wp-automatic-upgrader.php', // Wrong file name, see #37628. ); /** @@ -710,6 +720,10 @@ $_old_files = array( * Directories should be noted by suffixing it with a trailing slash (/) * * @since 3.2.0 + * @since 4.7.0 New themes were not automatically installed for 4.4-4.6 on + * upgrade. New themes are now installed again. To disable new + * themes from being installed on upgrade, explicitly define + * CORE_UPGRADE_SKIP_NEW_BUNDLED as false. * @global array $_new_bundled_files * @var array * @name $_new_bundled_files @@ -717,26 +731,28 @@ $_old_files = array( global $_new_bundled_files; $_new_bundled_files = array( - 'plugins/akismet/' => '2.0', - 'themes/twentyten/' => '3.0', - 'themes/twentyeleven/' => '3.2', - 'themes/twentytwelve/' => '3.5', - 'themes/twentythirteen/' => '3.6', - 'themes/twentyfourteen/' => '3.8', - 'themes/twentyfifteen/' => '4.1', + 'plugins/akismet/' => '2.0', + 'themes/twentyten/' => '3.0', + 'themes/twentyeleven/' => '3.2', + 'themes/twentytwelve/' => '3.5', + 'themes/twentythirteen/' => '3.6', + 'themes/twentyfourteen/' => '3.8', + 'themes/twentyfifteen/' => '4.1', + 'themes/twentysixteen/' => '4.4', + 'themes/twentyseventeen/' => '4.7', ); /** - * Upgrade the core of WordPress. + * Upgrades the core of WordPress. * * This will create a .maintenance file at the base of the WordPress directory * to ensure that people can not access the web site, when the files are being * copied to their locations. * - * The files in the {@link $_old_files} list will be removed and the new files + * The files in the `$_old_files` list will be removed and the new files * copied from the zip file after the database is upgraded. * - * The files in the {@link $_new_bundled_files} list will be added to the installation + * The files in the `$_new_bundled_files` list will be added to the installation * if the version is greater than or equal to the old version being upgraded. * * The steps for the upgrader for after the new release is downloaded and @@ -768,8 +784,16 @@ $_new_bundled_files = array( * * @since 2.7.0 * + * @global WP_Filesystem_Base $wp_filesystem + * @global array $_old_files + * @global array $_new_bundled_files + * @global wpdb $wpdb + * @global string $wp_version + * @global string $required_php_version + * @global string $required_mysql_version + * * @param string $from New release unzipped path. - * @param string $to Path to old WordPress installation. + * @param string $to Path to old WordPress installation. * @return WP_Error|null WP_Error on failure, null on success. */ function update_core($from, $to) { @@ -778,7 +802,7 @@ function update_core($from, $to) { @set_time_limit( 300 ); /** - * Filter feedback messages displayed during the core update process. + * Filters feedback messages displayed during the core update process. * * The filter is first evaluated after the zip file for the latest version * has been downloaded and unzipped. It is evaluated five more times during @@ -810,8 +834,15 @@ function update_core($from, $to) { return new WP_Error( 'insane_distro', __('The update could not be unpacked') ); } - // Import $wp_version, $required_php_version, and $required_mysql_version from the new version - // $wp_filesystem->wp_content_dir() returned unslashed pre-2.8 + + /** + * Import $wp_version, $required_php_version, and $required_mysql_version from the new version + * $wp_filesystem->wp_content_dir() returned unslashed pre-2.8 + * + * @global string $wp_version + * @global string $required_php_version + * @global string $required_mysql_version + */ global $wp_version, $required_php_version, $required_mysql_version; $versions_file = trailingslashit( $wp_filesystem->wp_content_dir() ) . 'upgrade/version-current.php'; @@ -861,13 +892,15 @@ function update_core($from, $to) { if ( is_array( $checksums ) && isset( $checksums[ $wp_version ] ) ) $checksums = $checksums[ $wp_version ]; // Compat code for 3.7-beta2 if ( is_array( $checksums ) ) { - foreach( $checksums as $file => $checksum ) { + foreach ( $checksums as $file => $checksum ) { if ( 'wp-content' == substr( $file, 0, 10 ) ) continue; if ( ! file_exists( ABSPATH . $file ) ) continue; if ( ! file_exists( $working_dir_local . $file ) ) continue; + if ( '.' === dirname( $file ) && in_array( pathinfo( $file, PATHINFO_EXTENSION ), array( 'html', 'txt' ) ) ) + continue; if ( md5_file( ABSPATH . $file ) === $checksum ) $skip[] = $file; else @@ -929,6 +962,10 @@ function update_core($from, $to) { continue; if ( ! file_exists( $working_dir_local . $file ) ) continue; + if ( '.' === dirname( $file ) && in_array( pathinfo( $file, PATHINFO_EXTENSION ), array( 'html', 'txt' ) ) ) { + $skip[] = $file; + continue; + } if ( file_exists( ABSPATH . $file ) && md5_file( ABSPATH . $file ) == $checksum ) $skip[] = $file; else @@ -1053,6 +1090,9 @@ function update_core($from, $to) { // Remove any Genericons example.html's from the filesystem _upgrade_422_remove_genericons(); + // Remove the REST API plugin if its version is Beta 4 or lower + _upgrade_440_force_deactivate_incompatible_plugins(); + // Upgrade DB with separate request /** This filter is documented in wp-admin/includes/update-core.php */ apply_filters( 'update_feedback', __( 'Upgrading database…' ) ); @@ -1061,7 +1101,7 @@ function update_core($from, $to) { // Clear the cache to prevent an update_option() from saving a stale db_version to the cache wp_cache_flush(); - // (Not all cache backends listen to 'flush') + // (Not all cache back ends listen to 'flush') wp_cache_delete( 'alloptions', 'options' ); // Remove working directory @@ -1101,8 +1141,10 @@ function update_core($from, $to) { * @since 3.7.0 Updated not to use a regular expression for the skip list * @see copy_dir() * - * @param string $from source directory - * @param string $to destination directory + * @global WP_Filesystem_Base $wp_filesystem + * + * @param string $from source directory + * @param string $to destination directory * @param array $skip_list a list of files/folders to skip copying * @return mixed WP_Error on failure, True on success. */ @@ -1156,6 +1198,11 @@ function _copy_dir($from, $to, $skip_list = array() ) { * * @since 3.3.0 * + * @global string $wp_version + * @global string $pagenow + * @global string $action + * + * @param string $new_version */ function _redirect_to_about_wordpress( $new_version ) { global $wp_version, $pagenow, $action; @@ -1190,12 +1237,14 @@ window.location = 'about.php?updated'; include(ABSPATH . 'wp-admin/admin-footer.php'); exit(); } -add_action( '_core_updated_successfully', '_redirect_to_about_wordpress' ); /** * Cleans up Genericons example files. * * @since 4.2.2 + * + * @global array $wp_theme_directories + * @global WP_Filesystem_Base $wp_filesystem */ function _upgrade_422_remove_genericons() { global $wp_theme_directories, $wp_filesystem; @@ -1249,9 +1298,22 @@ function _upgrade_422_find_genericons_files_in_folder( $directory ) { $files[] = "{$directory}example.html"; } - foreach ( glob( $directory . '*', GLOB_ONLYDIR ) as $dir ) { - $files = array_merge( $files, _upgrade_422_find_genericons_files_in_folder( $dir ) ); + $dirs = glob( $directory . '*', GLOB_ONLYDIR ); + if ( $dirs ) { + foreach ( $dirs as $dir ) { + $files = array_merge( $files, _upgrade_422_find_genericons_files_in_folder( $dir ) ); + } } return $files; } + +/** + * @ignore + * @since 4.4.0 + */ +function _upgrade_440_force_deactivate_incompatible_plugins() { + if ( defined( 'REST_API_VERSION' ) && version_compare( REST_API_VERSION, '2.0-beta4', '<=' ) ) { + deactivate_plugins( array( 'rest-api/plugin.php' ), true ); + } +}