Skip to content

Commit

Permalink
Coding Standards: Use strict comparison in wp-admin/includes/menu.php.
Browse files Browse the repository at this point in the history
Includes minor code layout fixes for better readability.

Follow-up to [3536], [4093], [9578], [11092], [18034].

Props aristath, poena, afercia, SergeyBiryukov.
See #57839.
Built from https://develop.svn.wordpress.org/trunk@55873


git-svn-id: http://core.svn.wordpress.org/trunk@55385 1a063a9b-81f0-0310-95a4-ce76da25c4cd
  • Loading branch information
SergeyBiryukov committed May 31, 2023
1 parent f3b93e6 commit 3d1140c
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 14 deletions.
42 changes: 29 additions & 13 deletions wp-admin/includes/menu.php
Expand Up @@ -44,11 +44,13 @@
// Create list of page plugin hook names.
foreach ( $menu as $menu_page ) {
$pos = strpos( $menu_page[2], '?' );

if ( false !== $pos ) {
// Handle post_type=post|page|foo pages.
$hook_name = substr( $menu_page[2], 0, $pos );
$hook_args = substr( $menu_page[2], $pos + 1 );
wp_parse_str( $hook_args, $hook_args );

// Set the hook name to be the post type.
if ( isset( $hook_args['post_type'] ) ) {
$hook_name = $hook_args['post_type'];
Expand All @@ -59,6 +61,7 @@
} else {
$hook_name = basename( $menu_page[2], '.php' );
}

$hook_name = sanitize_title( $hook_name );

if ( isset( $compat[ $hook_name ] ) ) {
Expand Down Expand Up @@ -98,17 +101,20 @@
if ( empty( $submenu[ $data[2] ] ) ) {
continue;
}

$subs = $submenu[ $data[2] ];
$first_sub = reset( $subs );
$old_parent = $data[2];
$new_parent = $first_sub[2];

/*
* If the first submenu is not the same as the assigned parent,
* make the first submenu the new parent.
*/
if ( $new_parent != $old_parent ) {
if ( $new_parent !== $old_parent ) {
$_wp_real_parent_file[ $old_parent ] = $new_parent;
$menu[ $id ][2] = $new_parent;

$menu[ $id ][2] = $new_parent;

foreach ( $submenu[ $old_parent ] as $index => $data ) {
$submenu[ $new_parent ][ $index ] = $submenu[ $old_parent ][ $index ];
Expand Down Expand Up @@ -171,7 +177,8 @@
if ( ! empty( $submenu[ $data[2] ] ) && 1 === count( $submenu[ $data[2] ] ) ) {
$subs = $submenu[ $data[2] ];
$first_sub = reset( $subs );
if ( $data[2] == $first_sub[2] ) {

if ( $data[2] === $first_sub[2] ) {
unset( $submenu[ $data[2] ] );
}
}
Expand Down Expand Up @@ -217,32 +224,36 @@ function add_menu_classes( $menu ) {
$first_item = false;
$last_order = false;
$items_count = count( $menu );
$i = 0;

$i = 0;

foreach ( $menu as $order => $top ) {
$i++;

if ( 0 == $order ) { // Dashboard is always shown/single.
if ( 0 === $order ) { // Dashboard is always shown/single.
$menu[0][4] = add_cssclass( 'menu-top-first', $top[4] );
$last_order = 0;
continue;
}

if ( str_starts_with( $top[2], 'separator' ) && false !== $last_order ) { // If separator.
$first_item = true;
$classes = $menu[ $last_order ][4];
$first_item = true;
$classes = $menu[ $last_order ][4];

$menu[ $last_order ][4] = add_cssclass( 'menu-top-last', $classes );
continue;
}

if ( $first_item ) {
$classes = $menu[ $order ][4];
$first_item = false;
$classes = $menu[ $order ][4];

$menu[ $order ][4] = add_cssclass( 'menu-top-first', $classes );
$first_item = false;
}

if ( $i === $items_count ) { // Last item.
$classes = $menu[ $order ][4];
$classes = $menu[ $order ][4];

$menu[ $order ][4] = add_cssclass( 'menu-top-last', $classes );
}

Expand Down Expand Up @@ -272,10 +283,12 @@ function add_menu_classes( $menu ) {
*/
if ( apply_filters( 'custom_menu_order', false ) ) {
$menu_order = array();

foreach ( $menu as $menu_item ) {
$menu_order[] = $menu_item[2];
}
unset( $menu_item );

$default_menu_order = $menu_order;

/**
Expand All @@ -290,8 +303,9 @@ function add_menu_classes( $menu ) {
*
* @param array $menu_order An ordered array of menu items.
*/
$menu_order = apply_filters( 'menu_order', $menu_order );
$menu_order = array_flip( $menu_order );
$menu_order = apply_filters( 'menu_order', $menu_order );
$menu_order = array_flip( $menu_order );

$default_menu_order = array_flip( $default_menu_order );

/**
Expand All @@ -304,14 +318,16 @@ function add_menu_classes( $menu ) {
*/
function sort_menu( $a, $b ) {
global $menu_order, $default_menu_order;

$a = $a[2];
$b = $b[2];

if ( isset( $menu_order[ $a ] ) && ! isset( $menu_order[ $b ] ) ) {
return -1;
} elseif ( ! isset( $menu_order[ $a ] ) && isset( $menu_order[ $b ] ) ) {
return 1;
} elseif ( isset( $menu_order[ $a ] ) && isset( $menu_order[ $b ] ) ) {
if ( $menu_order[ $a ] == $menu_order[ $b ] ) {
if ( $menu_order[ $a ] === $menu_order[ $b ] ) {
return 0;
}
return ( $menu_order[ $a ] < $menu_order[ $b ] ) ? -1 : 1;
Expand Down
2 changes: 1 addition & 1 deletion wp-includes/version.php
Expand Up @@ -16,7 +16,7 @@
*
* @global string $wp_version
*/
$wp_version = '6.3-alpha-55872';
$wp_version = '6.3-alpha-55873';

/**
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
Expand Down

0 comments on commit 3d1140c

Please sign in to comment.