WordPress.org

Make WordPress Core

Ticket #19744: 19744.diff

File 19744.diff, 2.6 KB (added by wonderboymusic, 8 years ago)
  • wp-includes/class-wp.php

    diff --git wp-includes/class-wp.php wp-includes/class-wp.php
    index dc77688..a254609 100644
    class WP { 
    247247
    248248                $this->public_query_vars = apply_filters('query_vars', $this->public_query_vars);
    249249
    250                 foreach ( $GLOBALS['wp_post_types'] as $post_type => $t )
     250                foreach ( get_post_types( array(), 'objects' ) as $post_type => $t )
    251251                        if ( $t->query_var )
    252252                                $post_type_query_vars[$t->query_var] = $post_type;
    253253
    class WP { 
    280280                }
    281281
    282282                // Convert urldecoded spaces back into +
    283                 foreach ( $GLOBALS['wp_taxonomies'] as $taxonomy => $t )
     283                foreach ( get_taxonomies( array() , 'objects' ) as $taxonomy => $t )
    284284                        if ( $t->query_var && isset( $this->query_vars[$t->query_var] ) )
    285285                                $this->query_vars[$t->query_var] = str_replace( ' ', '+', $this->query_vars[$t->query_var] );
    286286
  • wp-includes/query.php

    diff --git wp-includes/query.php wp-includes/query.php
    index 04286aa..22ba6ab 100644
    class WP_Query { 
    16991699                        );
    17001700                }
    17011701
    1702                 foreach ( $GLOBALS['wp_taxonomies'] as $taxonomy => $t ) {
     1702                foreach ( get_taxonomies( array() , 'objects' ) as $taxonomy => $t ) {
    17031703                        if ( 'post_tag' == $taxonomy )
    17041704                                continue;       // Handled further down in the $q['tag'] block
    17051705
  • wp-includes/rewrite.php

    diff --git wp-includes/rewrite.php wp-includes/rewrite.php
    index e2dbc80..114471a 100644
    function url_to_postid($url) { 
    338338        $url = trim($url, '/');
    339339
    340340        $request = $url;
     341        $post_type_query_vars = array();
     342
     343        foreach ( get_post_types( array() , 'objects' ) as $post_type => $t ) {
     344                if ( ! empty( $t->query_var ) )
     345                        $post_type_query_vars[ $t->query_var ] = $post_type;
     346        }
    341347
    342348        // Look for matches.
    343349        $request_match = $request;
    function url_to_postid($url) { 
    365371
    366372                        // Filter out non-public query vars
    367373                        global $wp;
    368                         parse_str($query, $query_vars);
     374                        parse_str( $query, $query_vars );
    369375                        $query = array();
    370376                        foreach ( (array) $query_vars as $key => $value ) {
    371                                 if ( in_array($key, $wp->public_query_vars) )
     377                                if ( in_array( $key, $wp->public_query_vars ) ){
    372378                                        $query[$key] = $value;
     379                                        if ( isset( $post_type_query_vars[$key] ) ) {
     380                                                $query['post_type'] = $post_type_query_vars[$key];
     381                                                $query['name'] = $value;
     382                                        }
     383                                }
    373384                        }
    374385
    375386                        // Do the query
    376                         $query = new WP_Query($query);
    377                         if ( !empty($query->posts) && $query->is_singular )
     387                        $query = new WP_Query( $query );
     388                        if ( ! empty( $query->posts ) && $query->is_singular )
    378389                                return $query->post->ID;
    379390                        else
    380391                                return 0;