From 176317abcf8715ebe9b8337d1f000d14c642dd52 Mon Sep 17 00:00:00 2001 From: duck_ Date: Mon, 25 Jun 2012 20:41:14 +0000 Subject: [PATCH] Set $walk_dirs = true for post rewrite rule generation. See #21020 for trunk. Partial revert of r19737 and r19778 as some users were relying on this behaviour. git-svn-id: http://core.svn.wordpress.org/trunk@21112 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/canonical.php | 21 +++------------------ wp-includes/rewrite.php | 2 +- 2 files changed, 4 insertions(+), 19 deletions(-) diff --git a/wp-includes/canonical.php b/wp-includes/canonical.php index 683c1479a8..7001c98bcb 100644 --- a/wp-includes/canonical.php +++ b/wp-includes/canonical.php @@ -100,7 +100,7 @@ function redirect_canonical( $requested_url = null, $do_redirect = true ) { } if ( ! $redirect_url ) { - if ( $redirect_url = redirect_guess_404_permalink( $requested_url ) ) { + if ( $redirect_url = redirect_guess_404_permalink() ) { $redirect['query'] = _remove_qs_args_if_not_in_url( $redirect['query'], array( 'page', 'feed', 'p', 'page_id', 'attachment_id', 'pagename', 'name', 'post_type' ), $redirect_url ); } } @@ -461,31 +461,16 @@ function _remove_qs_args_if_not_in_url( $query_string, Array $args_to_check, $ur } /** - * Attempts to guess the correct URL from the current URL (that produced a 404) or - * the current query variables. + * Attempts to guess the correct URL based on query vars * * @since 2.3.0 * @uses $wpdb * - * @param string $current_url Optional. The URL that has 404'd. * @return bool|string The correct URL if one is found. False on failure. */ -function redirect_guess_404_permalink( $current_url = '' ) { +function redirect_guess_404_permalink() { global $wpdb, $wp_rewrite; - if ( ! empty( $current_url ) ) - $parsed_url = @parse_url( $current_url ); - - // Attempt to redirect bare category slugs if the permalink structure starts - // with the %category% tag. - if ( isset( $parsed_url['path'] ) - && preg_match( '#^[^%]+%category%#', $wp_rewrite->permalink_structure ) - && $cat = get_category_by_path( $parsed_url['path'] ) - ) { - if ( ! is_wp_error( $cat ) ) - return get_term_link( $cat ); - } - if ( get_query_var('name') ) { $where = $wpdb->prepare("post_name LIKE %s", like_escape( get_query_var('name') ) . '%'); diff --git a/wp-includes/rewrite.php b/wp-includes/rewrite.php index 13808d14ee..04f01c22c8 100644 --- a/wp-includes/rewrite.php +++ b/wp-includes/rewrite.php @@ -1537,7 +1537,7 @@ class WP_Rewrite { $registration_pages['.*wp-register.php$'] = $this->index . '?register=true'; // Deprecated // Post - $post_rewrite = $this->generate_rewrite_rules( $this->permalink_structure, EP_PERMALINK, false, true, false, false ); + $post_rewrite = $this->generate_rewrite_rules( $this->permalink_structure, EP_PERMALINK, false ); $post_rewrite = apply_filters('post_rewrite_rules', $post_rewrite); // Date