Improve performance of loop detection in `_get_term_children()`.
Using an array keyed by term_id allows us to use `isset()` rather than the slower `in_array()`. In addition, it lets us avoid the use of `wp_list_pluck()` on large arrays, and helps us to avoid arrays that are unnecessarily large due to duplicate entries. Fixes #32144 for 4.2 branch. Built from https://develop.svn.wordpress.org/branches/4.2@32383 git-svn-id: http://core.svn.wordpress.org/branches/4.2@32353 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
5c01870b62
commit
80d7ad721a
|
@ -3926,7 +3926,7 @@ function _get_term_hierarchy($taxonomy) {
|
||||||
* @param string $taxonomy The taxonomy which determines the hierarchy of the terms.
|
* @param string $taxonomy The taxonomy which determines the hierarchy of the terms.
|
||||||
* @param array $ancestors Term ancestors that have already been identified. Passed by reference, to keep track of
|
* @param array $ancestors Term ancestors that have already been identified. Passed by reference, to keep track of
|
||||||
* found terms when recursing the hierarchy. The array of located ancestors is used to prevent
|
* found terms when recursing the hierarchy. The array of located ancestors is used to prevent
|
||||||
* infinite recursion loops.
|
* infinite recursion loops. For performance, term_ids are used as array keys, with 1 as value.
|
||||||
* @return array The subset of $terms that are descendants of $term_id.
|
* @return array The subset of $terms that are descendants of $term_id.
|
||||||
*/
|
*/
|
||||||
function _get_term_children( $term_id, $terms, $taxonomy, &$ancestors = array() ) {
|
function _get_term_children( $term_id, $terms, $taxonomy, &$ancestors = array() ) {
|
||||||
|
@ -3942,7 +3942,7 @@ function _get_term_children( $term_id, $terms, $taxonomy, &$ancestors = array()
|
||||||
|
|
||||||
// Include the term itself in the ancestors array, so we can properly detect when a loop has occurred.
|
// Include the term itself in the ancestors array, so we can properly detect when a loop has occurred.
|
||||||
if ( empty( $ancestors ) ) {
|
if ( empty( $ancestors ) ) {
|
||||||
$ancestors[] = $term_id;
|
$ancestors[ $term_id ] = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ( (array) $terms as $term ) {
|
foreach ( (array) $terms as $term ) {
|
||||||
|
@ -3955,7 +3955,7 @@ function _get_term_children( $term_id, $terms, $taxonomy, &$ancestors = array()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't recurse if we've already identified the term as a child - this indicates a loop.
|
// Don't recurse if we've already identified the term as a child - this indicates a loop.
|
||||||
if ( in_array( $term->term_id, $ancestors ) ) {
|
if ( isset( $ancestors[ $term->term_id ] ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3968,11 +3968,7 @@ function _get_term_children( $term_id, $terms, $taxonomy, &$ancestors = array()
|
||||||
if ( !isset($has_children[$term->term_id]) )
|
if ( !isset($has_children[$term->term_id]) )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if ( $use_id ) {
|
$ancestors[ $term->term_id ] = 1;;
|
||||||
$ancestors = array_merge( $ancestors, $term_list );
|
|
||||||
} else {
|
|
||||||
$ancestors = array_merge( $ancestors, wp_list_pluck( $term_list, 'term_id' ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( $children = _get_term_children( $term->term_id, $terms, $taxonomy, $ancestors) )
|
if ( $children = _get_term_children( $term->term_id, $terms, $taxonomy, $ancestors) )
|
||||||
$term_list = array_merge($term_list, $children);
|
$term_list = array_merge($term_list, $children);
|
||||||
|
|
Loading…
Reference in New Issue