WordPress.org

Make WordPress Core

Ticket #19092: 19092.2.patch

File 19092.2.patch, 1.7 KB (added by SergeyBiryukov, 4 years ago)
  • wp-includes/widgets.php

     
    11641164function retrieve_widgets() { 
    11651165        global $wp_registered_widget_updates, $wp_registered_sidebars, $sidebars_widgets, $wp_registered_widgets; 
    11661166 
    1167         $_sidebars_widgets = array(); 
    1168         $sidebars = array_keys($wp_registered_sidebars); 
     1167        $registered_sidebar_keys = array_keys( $wp_registered_sidebars ); 
     1168 
    11691169        $old_sidebars_widgets = get_theme_mod( 'sidebars_widgets' ); 
    11701170        if ( is_array( $old_sidebars_widgets ) ) { 
    11711171                // time() that sidebars were stored is in $old_sidebars_widgets['time'] 
    1172                 $old_sidebars = $old_sidebars_widgets['data']; 
     1172                $_sidebars_widgets = $old_sidebars_widgets['data']; 
     1173                remove_theme_mod( 'sidebars_widgets' ); 
     1174  
     1175                $orphaned = 0; 
    11731176 
    1174                 // make sure the saved sidebars match 
    1175                 foreach ( $sidebars as $sidebar_id ) { 
    1176                         $_sidebars_widgets[$sidebar_id] = isset($old_sidebars[$sidebar_id]) ? $old_sidebars[$sidebar_id] : array(); 
     1177                foreach ( $_sidebars_widgets as $sidebar => $widgets ) { 
     1178                        if ( 'wp_inactive_widgets' == $sidebar || 'orphaned_widgets' == substr( $sidebar, 0, 16 ) ) 
     1179                                continue; 
     1180 
     1181                        if ( !in_array( $sidebar, $registered_sidebar_keys ) ) { 
     1182                                $_sidebars_widgets['orphaned_widgets_' . ++$orphaned] = $widgets; 
     1183                                unset( $_sidebars_widgets[$sidebar] ); 
     1184                        } 
    11771185                } 
    1178  
    1179                 remove_theme_mod( 'sidebars_widgets' ); 
    11801186        } else { 
    11811187                if ( empty( $sidebars_widgets ) ) 
    11821188                        return; 
     
    11851191 
    11861192                $old = array_keys($sidebars_widgets); 
    11871193                sort($old); 
    1188                 sort($sidebars); 
     1194                sort($registered_sidebar_keys); 
    11891195 
    1190                 if ( $old == $sidebars ) 
     1196                if ( $old == $registered_sidebar_keys ) 
    11911197                        return; 
    11921198 
    11931199                $_sidebars_widgets = array(