From f07ebeff913145cadcbb74307825d3773db1ffb4 Mon Sep 17 00:00:00 2001 From: Boone Gorges Date: Sat, 7 Mar 2015 16:35:27 +0000 Subject: [PATCH] In `WP_User_Query`, `$meta_query` should be a class property rather than a local variable. This provides better parity with other query classes, and makes it possible to write more direct unit tests. See #31265. Built from https://develop.svn.wordpress.org/trunk@31665 git-svn-id: http://core.svn.wordpress.org/trunk@31646 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/user.php | 31 ++++++++++++++++++++----------- wp-includes/version.php | 2 +- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/wp-includes/user.php b/wp-includes/user.php index d382beac5e..93e151d1dc 100644 --- a/wp-includes/user.php +++ b/wp-includes/user.php @@ -473,6 +473,15 @@ class WP_User_Query { */ private $total_users = 0; + /** + * Metadata query container. + * + * @since 4.2.0 + * @access public + * @var object WP_Meta_Query + */ + public $meta_query = false; + private $compat_fields = array( 'results', 'total_users' ); // SQL clauses @@ -730,8 +739,8 @@ class WP_User_Query { $qv['blog_id'] = $blog_id = 0; // Prevent extra meta query } - $meta_query = new WP_Meta_Query(); - $meta_query->parse_query_vars( $qv ); + $this->meta_query = new WP_Meta_Query(); + $this->meta_query->parse_query_vars( $qv ); $role = ''; if ( isset( $qv['role'] ) ) @@ -746,25 +755,25 @@ class WP_User_Query { $cap_meta_query['compare'] = 'like'; } - if ( empty( $meta_query->queries ) ) { - $meta_query->queries = array( $cap_meta_query ); - } elseif ( ! in_array( $cap_meta_query, $meta_query->queries, true ) ) { + if ( empty( $this->meta_query->queries ) ) { + $this->meta_query->queries = array( $cap_meta_query ); + } elseif ( ! in_array( $cap_meta_query, $this->meta_query->queries, true ) ) { // Append the cap query to the original queries and reparse the query. - $meta_query->queries = array( + $this->meta_query->queries = array( 'relation' => 'AND', - array( $meta_query->queries, $cap_meta_query ), + array( $this->meta_query->queries, $cap_meta_query ), ); } - $meta_query->parse_query_vars( $meta_query->queries ); + $this->meta_query->parse_query_vars( $this->meta_query->queries ); } - if ( !empty( $meta_query->queries ) ) { - $clauses = $meta_query->get_sql( 'user', $wpdb->users, 'ID', $this ); + if ( !empty( $this->meta_query->queries ) ) { + $clauses = $this->meta_query->get_sql( 'user', $wpdb->users, 'ID', $this ); $this->query_from .= $clauses['join']; $this->query_where .= $clauses['where']; - if ( 'OR' == $meta_query->relation ) + if ( 'OR' == $this->meta_query->relation ) $this->query_fields = 'DISTINCT ' . $this->query_fields; } diff --git a/wp-includes/version.php b/wp-includes/version.php index ed6f6f8227..2890557324 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -4,7 +4,7 @@ * * @global string $wp_version */ -$wp_version = '4.2-alpha-31664'; +$wp_version = '4.2-alpha-31665'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.