Coding Standards: Use strict comparison in `wp-includes/class-wp.php`.
Includes minor code layout fixes for better readability. Follow-up to [1043], [2534], [2584], [2627], [2958], [3252], [3564], [21818], [37356]. Props aristath, poena, afercia, SergeyBiryukov. See #58831. Built from https://develop.svn.wordpress.org/trunk@56362 git-svn-id: http://core.svn.wordpress.org/trunk@55874 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
52317da292
commit
da0f366b22
|
@ -205,11 +205,13 @@ class WP {
|
||||||
$requested_path = $pathinfo;
|
$requested_path = $pathinfo;
|
||||||
} else {
|
} else {
|
||||||
// If the request uri is the index, blank it out so that we don't try to match it against a rule.
|
// If the request uri is the index, blank it out so that we don't try to match it against a rule.
|
||||||
if ( $req_uri == $wp_rewrite->index ) {
|
if ( $req_uri === $wp_rewrite->index ) {
|
||||||
$req_uri = '';
|
$req_uri = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
$requested_path = $req_uri;
|
$requested_path = $req_uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
$requested_file = $req_uri;
|
$requested_file = $req_uri;
|
||||||
|
|
||||||
$this->request = $requested_path;
|
$this->request = $requested_path;
|
||||||
|
@ -226,23 +228,32 @@ class WP {
|
||||||
} else {
|
} else {
|
||||||
foreach ( (array) $rewrite as $match => $query ) {
|
foreach ( (array) $rewrite as $match => $query ) {
|
||||||
// If the requested file is the anchor of the match, prepend it to the path info.
|
// If the requested file is the anchor of the match, prepend it to the path info.
|
||||||
if ( ! empty( $requested_file ) && str_starts_with( $match, $requested_file ) && $requested_file != $requested_path ) {
|
if ( ! empty( $requested_file )
|
||||||
|
&& str_starts_with( $match, $requested_file )
|
||||||
|
&& $requested_file !== $requested_path
|
||||||
|
) {
|
||||||
$request_match = $requested_file . '/' . $requested_path;
|
$request_match = $requested_file . '/' . $requested_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( preg_match( "#^$match#", $request_match, $matches ) ||
|
if ( preg_match( "#^$match#", $request_match, $matches )
|
||||||
preg_match( "#^$match#", urldecode( $request_match ), $matches ) ) {
|
|| preg_match( "#^$match#", urldecode( $request_match ), $matches )
|
||||||
|
) {
|
||||||
|
|
||||||
if ( $wp_rewrite->use_verbose_page_rules && preg_match( '/pagename=\$matches\[([0-9]+)\]/', $query, $varmatch ) ) {
|
if ( $wp_rewrite->use_verbose_page_rules
|
||||||
|
&& preg_match( '/pagename=\$matches\[([0-9]+)\]/', $query, $varmatch )
|
||||||
|
) {
|
||||||
// This is a verbose page match, let's check to be sure about it.
|
// This is a verbose page match, let's check to be sure about it.
|
||||||
$page = get_page_by_path( $matches[ $varmatch[1] ] );
|
$page = get_page_by_path( $matches[ $varmatch[1] ] );
|
||||||
|
|
||||||
if ( ! $page ) {
|
if ( ! $page ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$post_status_obj = get_post_status_object( $page->post_status );
|
$post_status_obj = get_post_status_object( $page->post_status );
|
||||||
|
|
||||||
if ( ! $post_status_obj->public && ! $post_status_obj->protected
|
if ( ! $post_status_obj->public && ! $post_status_obj->protected
|
||||||
&& ! $post_status_obj->private && $post_status_obj->exclude_from_search ) {
|
&& ! $post_status_obj->private && $post_status_obj->exclude_from_search
|
||||||
|
) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -267,13 +278,15 @@ class WP {
|
||||||
parse_str( $query, $perma_query_vars );
|
parse_str( $query, $perma_query_vars );
|
||||||
|
|
||||||
// If we're processing a 404 request, clear the error var since we found something.
|
// If we're processing a 404 request, clear the error var since we found something.
|
||||||
if ( '404' == $error ) {
|
if ( '404' === $error ) {
|
||||||
unset( $error, $_GET['error'] );
|
unset( $error, $_GET['error'] );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If req_uri is empty or if it is a request for ourself, unset error.
|
// If req_uri is empty or if it is a request for ourself, unset error.
|
||||||
if ( empty( $requested_path ) || $requested_file == $self || str_contains( $_SERVER['PHP_SELF'], 'wp-admin/' ) ) {
|
if ( empty( $requested_path ) || $requested_file === $self
|
||||||
|
|| str_contains( $_SERVER['PHP_SELF'], 'wp-admin/' )
|
||||||
|
) {
|
||||||
unset( $error, $_GET['error'] );
|
unset( $error, $_GET['error'] );
|
||||||
|
|
||||||
if ( isset( $perma_query_vars ) && str_contains( $_SERVER['PHP_SELF'], 'wp-admin/' ) ) {
|
if ( isset( $perma_query_vars ) && str_contains( $_SERVER['PHP_SELF'], 'wp-admin/' ) ) {
|
||||||
|
@ -306,8 +319,14 @@ class WP {
|
||||||
foreach ( $this->public_query_vars as $wpvar ) {
|
foreach ( $this->public_query_vars as $wpvar ) {
|
||||||
if ( isset( $this->extra_query_vars[ $wpvar ] ) ) {
|
if ( isset( $this->extra_query_vars[ $wpvar ] ) ) {
|
||||||
$this->query_vars[ $wpvar ] = $this->extra_query_vars[ $wpvar ];
|
$this->query_vars[ $wpvar ] = $this->extra_query_vars[ $wpvar ];
|
||||||
} elseif ( isset( $_GET[ $wpvar ] ) && isset( $_POST[ $wpvar ] ) && $_GET[ $wpvar ] !== $_POST[ $wpvar ] ) {
|
} elseif ( isset( $_GET[ $wpvar ] ) && isset( $_POST[ $wpvar ] )
|
||||||
wp_die( __( 'A variable mismatch has been detected.' ), __( 'Sorry, you are not allowed to view this item.' ), 400 );
|
&& $_GET[ $wpvar ] !== $_POST[ $wpvar ]
|
||||||
|
) {
|
||||||
|
wp_die(
|
||||||
|
__( 'A variable mismatch has been detected.' ),
|
||||||
|
__( 'Sorry, you are not allowed to view this item.' ),
|
||||||
|
400
|
||||||
|
);
|
||||||
} elseif ( isset( $_POST[ $wpvar ] ) ) {
|
} elseif ( isset( $_POST[ $wpvar ] ) ) {
|
||||||
$this->query_vars[ $wpvar ] = $_POST[ $wpvar ];
|
$this->query_vars[ $wpvar ] = $_POST[ $wpvar ];
|
||||||
} elseif ( isset( $_GET[ $wpvar ] ) ) {
|
} elseif ( isset( $_GET[ $wpvar ] ) ) {
|
||||||
|
@ -357,6 +376,7 @@ class WP {
|
||||||
// Limit publicly queried post_types to those that are 'publicly_queryable'.
|
// Limit publicly queried post_types to those that are 'publicly_queryable'.
|
||||||
if ( isset( $this->query_vars['post_type'] ) ) {
|
if ( isset( $this->query_vars['post_type'] ) ) {
|
||||||
$queryable_post_types = get_post_types( array( 'publicly_queryable' => true ) );
|
$queryable_post_types = get_post_types( array( 'publicly_queryable' => true ) );
|
||||||
|
|
||||||
if ( ! is_array( $this->query_vars['post_type'] ) ) {
|
if ( ! is_array( $this->query_vars['post_type'] ) ) {
|
||||||
if ( ! in_array( $this->query_vars['post_type'], $queryable_post_types, true ) ) {
|
if ( ! in_array( $this->query_vars['post_type'], $queryable_post_types, true ) ) {
|
||||||
unset( $this->query_vars['post_type'] );
|
unset( $this->query_vars['post_type'] );
|
||||||
|
@ -434,10 +454,12 @@ class WP {
|
||||||
}
|
}
|
||||||
if ( ! empty( $this->query_vars['error'] ) ) {
|
if ( ! empty( $this->query_vars['error'] ) ) {
|
||||||
$status = (int) $this->query_vars['error'];
|
$status = (int) $this->query_vars['error'];
|
||||||
|
|
||||||
if ( 404 === $status ) {
|
if ( 404 === $status ) {
|
||||||
if ( ! is_user_logged_in() ) {
|
if ( ! is_user_logged_in() ) {
|
||||||
$headers = array_merge( $headers, wp_get_nocache_headers() );
|
$headers = array_merge( $headers, wp_get_nocache_headers() );
|
||||||
}
|
}
|
||||||
|
|
||||||
$headers['Content-Type'] = get_option( 'html_type' ) . '; charset=' . get_option( 'blog_charset' );
|
$headers['Content-Type'] = get_option( 'html_type' ) . '; charset=' . get_option( 'blog_charset' );
|
||||||
} elseif ( in_array( $status, array( 403, 500, 502, 503 ), true ) ) {
|
} elseif ( in_array( $status, array( 403, 500, 502, 503 ), true ) ) {
|
||||||
$exit_required = true;
|
$exit_required = true;
|
||||||
|
@ -450,6 +472,7 @@ class WP {
|
||||||
if ( 'feed' === $this->query_vars['feed'] ) {
|
if ( 'feed' === $this->query_vars['feed'] ) {
|
||||||
$type = get_default_feed();
|
$type = get_default_feed();
|
||||||
}
|
}
|
||||||
|
|
||||||
$headers['Content-Type'] = feed_content_type( $type ) . '; charset=' . get_option( 'blog_charset' );
|
$headers['Content-Type'] = feed_content_type( $type ) . '; charset=' . get_option( 'blog_charset' );
|
||||||
|
|
||||||
// We're showing a feed, so WP is indeed the only thing that last changed.
|
// We're showing a feed, so WP is indeed the only thing that last changed.
|
||||||
|
@ -467,6 +490,7 @@ class WP {
|
||||||
) {
|
) {
|
||||||
$wp_last_modified_post = mysql2date( $date_format, get_lastpostmodified( 'GMT' ), false );
|
$wp_last_modified_post = mysql2date( $date_format, get_lastpostmodified( 'GMT' ), false );
|
||||||
$wp_last_modified_comment = mysql2date( $date_format, get_lastcommentmodified( 'GMT' ), false );
|
$wp_last_modified_comment = mysql2date( $date_format, get_lastcommentmodified( 'GMT' ), false );
|
||||||
|
|
||||||
if ( strtotime( $wp_last_modified_post ) > strtotime( $wp_last_modified_comment ) ) {
|
if ( strtotime( $wp_last_modified_post ) > strtotime( $wp_last_modified_comment ) ) {
|
||||||
$wp_last_modified = $wp_last_modified_post;
|
$wp_last_modified = $wp_last_modified_post;
|
||||||
} else {
|
} else {
|
||||||
|
@ -501,8 +525,9 @@ class WP {
|
||||||
$wp_modified_timestamp = strtotime( $wp_last_modified );
|
$wp_modified_timestamp = strtotime( $wp_last_modified );
|
||||||
|
|
||||||
if ( ( $client_last_modified && $client_etag ) ?
|
if ( ( $client_last_modified && $client_etag ) ?
|
||||||
( ( $client_modified_timestamp >= $wp_modified_timestamp ) && ( $client_etag == $wp_etag ) ) :
|
( ( $client_modified_timestamp >= $wp_modified_timestamp ) && ( $client_etag === $wp_etag ) ) :
|
||||||
( ( $client_modified_timestamp >= $wp_modified_timestamp ) || ( $client_etag == $wp_etag ) ) ) {
|
( ( $client_modified_timestamp >= $wp_modified_timestamp ) || ( $client_etag === $wp_etag ) )
|
||||||
|
) {
|
||||||
$status = 304;
|
$status = 304;
|
||||||
$exit_required = true;
|
$exit_required = true;
|
||||||
}
|
}
|
||||||
|
@ -570,12 +595,15 @@ class WP {
|
||||||
*/
|
*/
|
||||||
public function build_query_string() {
|
public function build_query_string() {
|
||||||
$this->query_string = '';
|
$this->query_string = '';
|
||||||
|
|
||||||
foreach ( (array) array_keys( $this->query_vars ) as $wpvar ) {
|
foreach ( (array) array_keys( $this->query_vars ) as $wpvar ) {
|
||||||
if ( '' != $this->query_vars[ $wpvar ] ) {
|
if ( '' !== $this->query_vars[ $wpvar ] ) {
|
||||||
$this->query_string .= ( strlen( $this->query_string ) < 1 ) ? '' : '&';
|
$this->query_string .= ( strlen( $this->query_string ) < 1 ) ? '' : '&';
|
||||||
|
|
||||||
if ( ! is_scalar( $this->query_vars[ $wpvar ] ) ) { // Discard non-scalars.
|
if ( ! is_scalar( $this->query_vars[ $wpvar ] ) ) { // Discard non-scalars.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->query_string .= $wpvar . '=' . rawurlencode( $this->query_vars[ $wpvar ] );
|
$this->query_string .= $wpvar . '=' . rawurlencode( $this->query_vars[ $wpvar ] );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -595,6 +623,7 @@ class WP {
|
||||||
'2.1.0',
|
'2.1.0',
|
||||||
'query_vars, request'
|
'query_vars, request'
|
||||||
);
|
);
|
||||||
|
|
||||||
parse_str( $this->query_string, $this->query_vars );
|
parse_str( $this->query_string, $this->query_vars );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.4-alpha-56361';
|
$wp_version = '6.4-alpha-56362';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue