mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-05 07:58:35 +01:00
Themes: Remove memoization from stylesheet and theme directories.
This fixes bugs introduced in [56635] whereby the template or stylesheet path could be memoized incorrectly if `get_template_directory()` or `get_stylesheet_directory()` were called before the theme has been fully initialized. Props partyfrikadelle, coreyw, kdowns, rebasaurus, meta4, flixos90, mukesh27, joemcgill. Fixes #59847. Built from https://develop.svn.wordpress.org/trunk@57129 git-svn-id: http://core.svn.wordpress.org/trunk@56640 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
2f4ffff0fb
commit
9b1479bc74
@ -491,8 +491,6 @@ function update_blog_option( $id, $option, $value, $deprecated = null ) {
|
|||||||
* @global array $_wp_switched_stack
|
* @global array $_wp_switched_stack
|
||||||
* @global bool $switched
|
* @global bool $switched
|
||||||
* @global string $table_prefix
|
* @global string $table_prefix
|
||||||
* @global string $wp_template_path
|
|
||||||
* @global string $wp_stylesheet_path
|
|
||||||
* @global WP_Object_Cache $wp_object_cache
|
* @global WP_Object_Cache $wp_object_cache
|
||||||
*
|
*
|
||||||
* @param int $new_blog_id The ID of the blog to switch to. Default: current blog.
|
* @param int $new_blog_id The ID of the blog to switch to. Default: current blog.
|
||||||
@ -536,8 +534,6 @@ function switch_to_blog( $new_blog_id, $deprecated = null ) {
|
|||||||
$wpdb->set_blog_id( $new_blog_id );
|
$wpdb->set_blog_id( $new_blog_id );
|
||||||
$GLOBALS['table_prefix'] = $wpdb->get_blog_prefix();
|
$GLOBALS['table_prefix'] = $wpdb->get_blog_prefix();
|
||||||
$GLOBALS['blog_id'] = $new_blog_id;
|
$GLOBALS['blog_id'] = $new_blog_id;
|
||||||
$GLOBALS['wp_template_path'] = null;
|
|
||||||
$GLOBALS['wp_stylesheet_path'] = null;
|
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_switch_to_blog' ) ) {
|
if ( function_exists( 'wp_cache_switch_to_blog' ) ) {
|
||||||
wp_cache_switch_to_blog( $new_blog_id );
|
wp_cache_switch_to_blog( $new_blog_id );
|
||||||
@ -604,8 +600,6 @@ function switch_to_blog( $new_blog_id, $deprecated = null ) {
|
|||||||
* @global int $blog_id
|
* @global int $blog_id
|
||||||
* @global bool $switched
|
* @global bool $switched
|
||||||
* @global string $table_prefix
|
* @global string $table_prefix
|
||||||
* @global string $wp_template_path
|
|
||||||
* @global string $wp_stylesheet_path
|
|
||||||
* @global WP_Object_Cache $wp_object_cache
|
* @global WP_Object_Cache $wp_object_cache
|
||||||
*
|
*
|
||||||
* @return bool True on success, false if we're already on the current blog.
|
* @return bool True on success, false if we're already on the current blog.
|
||||||
@ -633,8 +627,6 @@ function restore_current_blog() {
|
|||||||
$wpdb->set_blog_id( $new_blog_id );
|
$wpdb->set_blog_id( $new_blog_id );
|
||||||
$GLOBALS['blog_id'] = $new_blog_id;
|
$GLOBALS['blog_id'] = $new_blog_id;
|
||||||
$GLOBALS['table_prefix'] = $wpdb->get_blog_prefix();
|
$GLOBALS['table_prefix'] = $wpdb->get_blog_prefix();
|
||||||
$GLOBALS['wp_template_path'] = null;
|
|
||||||
$GLOBALS['wp_stylesheet_path'] = null;
|
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_switch_to_blog' ) ) {
|
if ( function_exists( 'wp_cache_switch_to_blog' ) ) {
|
||||||
wp_cache_switch_to_blog( $new_blog_id );
|
wp_cache_switch_to_blog( $new_blog_id );
|
||||||
|
@ -188,15 +188,11 @@ function get_stylesheet() {
|
|||||||
*
|
*
|
||||||
* @since 1.5.0
|
* @since 1.5.0
|
||||||
* @since 6.4.0 Memoizes filter execution so that it only runs once for the current theme.
|
* @since 6.4.0 Memoizes filter execution so that it only runs once for the current theme.
|
||||||
*
|
* @since 6.4.2 Memoization removed.
|
||||||
* @global string $wp_stylesheet_path Current theme stylesheet directory path.
|
|
||||||
*
|
*
|
||||||
* @return string Path to active theme's stylesheet directory.
|
* @return string Path to active theme's stylesheet directory.
|
||||||
*/
|
*/
|
||||||
function get_stylesheet_directory() {
|
function get_stylesheet_directory() {
|
||||||
global $wp_stylesheet_path;
|
|
||||||
|
|
||||||
if ( null === $wp_stylesheet_path ) {
|
|
||||||
$stylesheet = get_stylesheet();
|
$stylesheet = get_stylesheet();
|
||||||
$theme_root = get_theme_root( $stylesheet );
|
$theme_root = get_theme_root( $stylesheet );
|
||||||
$stylesheet_dir = "$theme_root/$stylesheet";
|
$stylesheet_dir = "$theme_root/$stylesheet";
|
||||||
@ -210,17 +206,7 @@ function get_stylesheet_directory() {
|
|||||||
* @param string $stylesheet Directory name of the active theme.
|
* @param string $stylesheet Directory name of the active theme.
|
||||||
* @param string $theme_root Absolute path to themes directory.
|
* @param string $theme_root Absolute path to themes directory.
|
||||||
*/
|
*/
|
||||||
$stylesheet_dir = apply_filters( 'stylesheet_directory', $stylesheet_dir, $stylesheet, $theme_root );
|
return apply_filters( 'stylesheet_directory', $stylesheet_dir, $stylesheet, $theme_root );
|
||||||
|
|
||||||
// If there are filter callbacks, force the logic to execute on every call.
|
|
||||||
if ( has_filter( 'stylesheet' ) || has_filter( 'theme_root' ) || has_filter( 'stylesheet_directory' ) ) {
|
|
||||||
return $stylesheet_dir;
|
|
||||||
}
|
|
||||||
|
|
||||||
$wp_stylesheet_path = $stylesheet_dir;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $wp_stylesheet_path;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -338,15 +324,11 @@ function get_template() {
|
|||||||
*
|
*
|
||||||
* @since 1.5.0
|
* @since 1.5.0
|
||||||
* @since 6.4.0 Memoizes filter execution so that it only runs once for the current theme.
|
* @since 6.4.0 Memoizes filter execution so that it only runs once for the current theme.
|
||||||
*
|
* @since 6.4.1 Memoization removed.
|
||||||
* @global string $wp_template_path Current theme template directory path.
|
|
||||||
*
|
*
|
||||||
* @return string Path to active theme's template directory.
|
* @return string Path to active theme's template directory.
|
||||||
*/
|
*/
|
||||||
function get_template_directory() {
|
function get_template_directory() {
|
||||||
global $wp_template_path;
|
|
||||||
|
|
||||||
if ( null === $wp_template_path ) {
|
|
||||||
$template = get_template();
|
$template = get_template();
|
||||||
$theme_root = get_theme_root( $template );
|
$theme_root = get_theme_root( $template );
|
||||||
$template_dir = "$theme_root/$template";
|
$template_dir = "$theme_root/$template";
|
||||||
@ -360,17 +342,7 @@ function get_template_directory() {
|
|||||||
* @param string $template Directory name of the active theme.
|
* @param string $template Directory name of the active theme.
|
||||||
* @param string $theme_root Absolute path to the themes directory.
|
* @param string $theme_root Absolute path to the themes directory.
|
||||||
*/
|
*/
|
||||||
$template_dir = apply_filters( 'template_directory', $template_dir, $template, $theme_root );
|
return apply_filters( 'template_directory', $template_dir, $template, $theme_root );
|
||||||
|
|
||||||
// If there are filter callbacks, force the logic to execute on every call.
|
|
||||||
if ( has_filter( 'template' ) || has_filter( 'theme_root' ) || has_filter( 'template_directory' ) ) {
|
|
||||||
return $template_dir;
|
|
||||||
}
|
|
||||||
|
|
||||||
$wp_template_path = $template_dir;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $wp_template_path;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -776,13 +748,11 @@ function locale_stylesheet() {
|
|||||||
* @global WP_Customize_Manager $wp_customize
|
* @global WP_Customize_Manager $wp_customize
|
||||||
* @global array $sidebars_widgets
|
* @global array $sidebars_widgets
|
||||||
* @global array $wp_registered_sidebars
|
* @global array $wp_registered_sidebars
|
||||||
* @global string $wp_stylesheet_path
|
|
||||||
* @global string $wp_template_path
|
|
||||||
*
|
*
|
||||||
* @param string $stylesheet Stylesheet name.
|
* @param string $stylesheet Stylesheet name.
|
||||||
*/
|
*/
|
||||||
function switch_theme( $stylesheet ) {
|
function switch_theme( $stylesheet ) {
|
||||||
global $wp_theme_directories, $wp_customize, $sidebars_widgets, $wp_registered_sidebars, $wp_stylesheet_path, $wp_template_path;
|
global $wp_theme_directories, $wp_customize, $sidebars_widgets, $wp_registered_sidebars;
|
||||||
|
|
||||||
$requirements = validate_theme_requirements( $stylesheet );
|
$requirements = validate_theme_requirements( $stylesheet );
|
||||||
if ( is_wp_error( $requirements ) ) {
|
if ( is_wp_error( $requirements ) ) {
|
||||||
@ -866,13 +836,6 @@ function switch_theme( $stylesheet ) {
|
|||||||
|
|
||||||
update_option( 'theme_switched', $old_theme->get_stylesheet() );
|
update_option( 'theme_switched', $old_theme->get_stylesheet() );
|
||||||
|
|
||||||
/*
|
|
||||||
* Reset globals to force refresh the next time these directories are
|
|
||||||
* accessed via `get_stylesheet_directory()` / `get_template_directory()`.
|
|
||||||
*/
|
|
||||||
$wp_stylesheet_path = null;
|
|
||||||
$wp_template_path = null;
|
|
||||||
|
|
||||||
// Clear pattern caches.
|
// Clear pattern caches.
|
||||||
$new_theme->delete_pattern_cache();
|
$new_theme->delete_pattern_cache();
|
||||||
$old_theme->delete_pattern_cache();
|
$old_theme->delete_pattern_cache();
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.5-alpha-57128';
|
$wp_version = '6.5-alpha-57129';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
Loading…
Reference in New Issue
Block a user