Switch language

wpseek.com
A WordPress-centric search engine for devs and theme authors




wp_find_hierarchy_loop_tortoise_hare [ WordPress Function ]

wp_find_hierarchy_loop_tortoise_hare ( $callback, $start, $override = array(), $callback_args = array(), $_return_loop = false )
Access:
  • private
Parameters:
  • (callback) $callback function that accepts ( ID, callback_arg, ... ) and outputs parent_ID
  • (int) $start The ID to start the loop check at
  • (array) $override an array of ( ID => parent_ID, ... ) to use instead of $callback
  • (array) $callback_args optional additional arguments to send to $callback
  • (bool) $_return_loop Return loop members or just detect presence of loop? Only set to true if you already know the given $start is part of a loop (otherwise the returned array might include branches)
Returns:
  • (mixed) scalar ID of some arbitrary member of the loop, or array of IDs of all members of loop if $_return_loop
Defined at:



Uses the "The Tortoise and the Hare" algorithm to detect loops.

For every step of the algorithm, the hare takes two steps and the tortoise one. If the hare ever laps the tortoise, there must be a loop.

Source


<?php
function wp_find_hierarchy_loop_tortoise_hare$callback$start$override = array(), $callback_args = array(), $_return_loop false ) {
    
$tortoise $hare $evanescent_hare $start;
    
$return = array();

    
// Set evanescent_hare to one past hare
    // Increment hare two steps
    
while (
        
$tortoise
    
&&
        ( 
$evanescent_hare = isset( $override[$hare] ) ? $override[$hare] : call_user_func_array$callbackarray_merge( array( $hare ), $callback_args ) ) )
    &&
        ( 
$hare = isset( $override[$evanescent_hare] ) ? $override[$evanescent_hare] : call_user_func_array$callbackarray_merge( array( $evanescent_hare ), $callback_args ) ) )
    ) {
        if ( 
$_return_loop )
            
$return[$tortoise] = $return[$evanescent_hare] = $return[$hare] = true;

        
// tortoise got lapped - must be a loop
        
if ( $tortoise == $evanescent_hare || $tortoise == $hare )
            return 
$_return_loop $return $tortoise;

        
// Increment tortoise by one step
        
$tortoise = isset( $override[$tortoise] ) ? $override[$tortoise] : call_user_func_array$callbackarray_merge( array( $tortoise ), $callback_args ) );
    }

    return 
false;
}
?>

Examples [ wp-snippets.com ]

Top Google zoekresultaten

Meer ...

Gebruikersdiscussies [ wordpress.org ]

0 User Note(s)

Nog geen één. Wees de eerste!

Nieuw toevoegen ...



HTML5 Powered with CSS3 / Styling, Performance & Integration, and Semantics