WP_List_Util::sort_callback( object|array $a, object|array $b ): int

This function’s access is marked private. This means it is not intended for use by plugin or theme developers, only by core. It is listed here for completeness.

Callback to sort an array by specific fields.

Description

See also

Parameters

$aobject|arrayrequired
One object to compare.
$bobject|arrayrequired
The other object to compare.

Return

int 0 if both objects equal. -1 if second object should come first, 1 otherwise.

Source

private function sort_callback( $a, $b ) {
	if ( empty( $this->orderby ) ) {
		return 0;
	}

	$a = (array) $a;
	$b = (array) $b;

	foreach ( $this->orderby as $field => $direction ) {
		if ( ! isset( $a[ $field ] ) || ! isset( $b[ $field ] ) ) {
			continue;
		}

		if ( $a[ $field ] == $b[ $field ] ) {
			continue;
		}

		$results = 'DESC' === $direction ? array( 1, -1 ) : array( -1, 1 );

		if ( is_numeric( $a[ $field ] ) && is_numeric( $b[ $field ] ) ) {
			return ( $a[ $field ] < $b[ $field ] ) ? $results[0] : $results[1];
		}

		return 0 > strcmp( $a[ $field ], $b[ $field ] ) ? $results[0] : $results[1];
	}

	return 0;
}

Changelog

VersionDescription
4.7.0Introduced.

User Contributed Notes

You must log in before being able to contribute a note or feedback.