WordPress.org

Make WordPress Core

Ticket #19092: 19092.2.patch

File 19092.2.patch, 1.7 KB (added by SergeyBiryukov, 7 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(