pretty permalinks for comment paging. Props Viper007Bind. fixes #7942

git-svn-id: http://svn.automattic.com/wordpress/trunk@9300 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2008-10-23 18:55:22 +00:00
parent fac34b2423
commit f275541cf6
4 changed files with 28 additions and 8 deletions

View File

@ -123,14 +123,15 @@ function redirect_canonical($requested_url=null, $do_redirect=true) {
} }
// paging and feeds // paging and feeds
if ( get_query_var('paged') || is_feed() ) { if ( get_query_var('paged') || is_feed() || get_query_var('cpage') ) {
if ( !$redirect_url ) if ( !$redirect_url )
$redirect_url = $requested_url; $redirect_url = $requested_url;
$paged_redirect = @parse_url($redirect_url); $paged_redirect = @parse_url($redirect_url);
while ( preg_match( '#page/[0-9]+?(/+)?$#', $paged_redirect['path'] ) || preg_match( '#/feed(/[a-z0-9-]*?(/+)?)?$#', $paged_redirect['path'] ) ) { while ( preg_match( '#page/[0-9]+?(/+)?$#', $paged_redirect['path'] ) || preg_match( '#/feed(/[a-z0-9-]*?(/+)?)?$#', $paged_redirect['path'] ) || preg_match( '#comment-page-[0-9]+/?$#', $paged_redirect['path'] ) ) {
// Strip off paging and feed // Strip off paging and feed
$paged_redirect['path'] = preg_replace('#/page/[0-9]+?(/+)?$#', '/', $paged_redirect['path']); // strip off any existing paging $paged_redirect['path'] = preg_replace('#/page/[0-9]+?(/+)?$#', '/', $paged_redirect['path']); // strip off any existing paging
$paged_redirect['path'] = preg_replace('#/feed(/[a-z0-9-]*?(/+)?)?$#', '/', $paged_redirect['path']); // strip off any existing feed $paged_redirect['path'] = preg_replace('#/feed(/[a-z0-9-]*?(/+)?)?$#', '/', $paged_redirect['path']); // strip off any existing feed
$paged_redirect['path'] = preg_replace('#comment-page-[0-9]+?(/+)?$#', '/', $paged_redirect['path']); // strip off any existing comment paging
} }
$paged_redirect['path'] = preg_replace('|/index.php/?$|', '/', $paged_redirect['path']); // strip off trailing /index.php/ $paged_redirect['path'] = preg_replace('|/index.php/?$|', '/', $paged_redirect['path']); // strip off trailing /index.php/
@ -148,10 +149,14 @@ function redirect_canonical($requested_url=null, $do_redirect=true) {
if ( is_feed() ) { if ( is_feed() ) {
$paged_redirect['path'] = user_trailingslashit( trailingslashit( $paged_redirect['path'] ) . 'feed/' . ( ( 'rss2' == get_query_var('feed') || 'feed' == get_query_var('feed') ) ? '' : get_query_var('feed') ), 'feed' ); $paged_redirect['path'] = user_trailingslashit( trailingslashit( $paged_redirect['path'] ) . 'feed/' . ( ( 'rss2' == get_query_var('feed') || 'feed' == get_query_var('feed') ) ? '' : get_query_var('feed') ), 'feed' );
} }
if ( get_query_var('cpage') > 1 ) {
$paged_redirect['path'] = user_trailingslashit( trailingslashit( $paged_redirect['path'] ) . 'comment-page-' . get_query_var('cpage'), 'commentpaged' );
}
$redirect_url = $paged_redirect['scheme'] . '://' . $paged_redirect['host'] . $paged_redirect['path']; $redirect_url = $paged_redirect['scheme'] . '://' . $paged_redirect['host'] . $paged_redirect['path'];
$redirect['path'] = $paged_redirect['path']; $redirect['path'] = $paged_redirect['path'];
$redirect['query'] = remove_query_arg( 'paged', $redirect['query'] ); $redirect['query'] = remove_query_arg( 'paged', $redirect['query'] );
$redirect['query'] = remove_query_arg( 'feed', $redirect['query'] ); $redirect['query'] = remove_query_arg( 'feed', $redirect['query'] );
$redirect['query'] = remove_query_arg( 'cpage', $redirect['query'] );
} }
} }

View File

@ -1242,7 +1242,7 @@ function previous_comments_link($label='') {
* @return string Markup for pagination links. * @return string Markup for pagination links.
*/ */
function paginate_comments_links($args = array()) { function paginate_comments_links($args = array()) {
global $wp_query; global $wp_query, $wp_rewrite;
if ( !is_singular() ) if ( !is_singular() )
return; return;
@ -1259,6 +1259,9 @@ function paginate_comments_links($args = array()) {
'echo' => true, 'echo' => true,
'add_fragment' => '#comments' 'add_fragment' => '#comments'
); );
if ( $wp_rewrite->using_permalinks() )
$defaults['base'] = user_trailingslashit(get_permalink() . 'comment-page-%#%', 'commentpaged');
$args = wp_parse_args( $args, $defaults ); $args = wp_parse_args( $args, $defaults );
$page_links = paginate_links( $args ); $page_links = paginate_links( $args );

View File

@ -1259,6 +1259,7 @@ class WP_Rewrite {
//build a regex to match the trackback and page/xx parts of URLs //build a regex to match the trackback and page/xx parts of URLs
$trackbackregex = 'trackback/?$'; $trackbackregex = 'trackback/?$';
$pageregex = 'page/?([0-9]{1,})/?$'; $pageregex = 'page/?([0-9]{1,})/?$';
$commentregex = 'comment-page-([0-9]{1,})/?$';
//build up an array of endpoint regexes to append => queries to append //build up an array of endpoint regexes to append => queries to append
if ($endpoints) { if ($endpoints) {
@ -1339,6 +1340,10 @@ class WP_Rewrite {
$pagematch = $match . $pageregex; $pagematch = $match . $pageregex;
$pagequery = $index . '?' . $query . '&paged=' . $this->preg_index($num_toks + 1); $pagequery = $index . '?' . $query . '&paged=' . $this->preg_index($num_toks + 1);
//create query for /comment-page-xx
$commentmatch = $match . $commentregex;
$commentquery = $index . '?' . $query . '&cpage=' . $this->preg_index($num_toks + 1);
//create query for /feed/(feed|atom|rss|rss2|rdf) //create query for /feed/(feed|atom|rss|rss2|rdf)
$feedmatch = $match . $feedregex; $feedmatch = $match . $feedregex;
$feedquery = $feedindex . '?' . $query . '&feed=' . $this->preg_index($num_toks + 1); $feedquery = $feedindex . '?' . $query . '&feed=' . $this->preg_index($num_toks + 1);
@ -1360,6 +1365,10 @@ class WP_Rewrite {
if ($paged) //...and /page/xx ones if ($paged) //...and /page/xx ones
$rewrite = array_merge($rewrite, array($pagematch => $pagequery)); $rewrite = array_merge($rewrite, array($pagematch => $pagequery));
//only on pages with comments add ../comment-page-xx/
if ( EP_PAGES & $ep_mask || EP_PERMALINK & $ep_mask || EP_NONE & $ep_mask )
$rewrite = array_merge($rewrite, array($commentmatch => $commentquery));
//do endpoints //do endpoints
if ($endpoints) { if ($endpoints) {
foreach ( (array) $ep_query_append as $regex => $ep) { foreach ( (array) $ep_query_append as $regex => $ep) {
@ -1403,6 +1412,7 @@ class WP_Rewrite {
$sub1tb = $sub1 . $trackbackregex; //add trackback regex <permalink>/trackback/... $sub1tb = $sub1 . $trackbackregex; //add trackback regex <permalink>/trackback/...
$sub1feed = $sub1 . $feedregex; //and <permalink>/feed/(atom|...) $sub1feed = $sub1 . $feedregex; //and <permalink>/feed/(atom|...)
$sub1feed2 = $sub1 . $feedregex2; //and <permalink>/(feed|atom...) $sub1feed2 = $sub1 . $feedregex2; //and <permalink>/(feed|atom...)
$sub1comment = $sub1 . $commentregex; //and <permalink>/comment-page-xx
//add an ? as we don't have to match that last slash, and finally a $ so we //add an ? as we don't have to match that last slash, and finally a $ so we
//match to the end of the URL //match to the end of the URL
@ -1412,11 +1422,13 @@ class WP_Rewrite {
$sub2tb = $sub2 . $trackbackregex; //and add trackbacks <permalink>/attachment/trackback $sub2tb = $sub2 . $trackbackregex; //and add trackbacks <permalink>/attachment/trackback
$sub2feed = $sub2 . $feedregex; //feeds, <permalink>/attachment/feed/(atom|...) $sub2feed = $sub2 . $feedregex; //feeds, <permalink>/attachment/feed/(atom|...)
$sub2feed2 = $sub2 . $feedregex2; //and feeds again on to this <permalink>/attachment/(feed|atom...) $sub2feed2 = $sub2 . $feedregex2; //and feeds again on to this <permalink>/attachment/(feed|atom...)
$sub2comment = $sub2 . $commentregex; //and <permalink>/comment-page-xx
//create queries for these extra tag-ons we've just dealt with //create queries for these extra tag-ons we've just dealt with
$subquery = $index . '?attachment=' . $this->preg_index(1); $subquery = $index . '?attachment=' . $this->preg_index(1);
$subtbquery = $subquery . '&tb=1'; $subtbquery = $subquery . '&tb=1';
$subfeedquery = $subquery . '&feed=' . $this->preg_index(2); $subfeedquery = $subquery . '&feed=' . $this->preg_index(2);
$subcommentquery = $subquery . '&cpage=' . $this->preg_index(2);
//do endpoints for attachments //do endpoints for attachments
if ( !empty($endpoint) ) { foreach ( (array) $ep_query_append as $regex => $ep ) { if ( !empty($endpoint) ) { foreach ( (array) $ep_query_append as $regex => $ep ) {
@ -1451,8 +1463,8 @@ class WP_Rewrite {
//add regexes/queries for attachments, attachment trackbacks and so on //add regexes/queries for attachments, attachment trackbacks and so on
if ( ! $page ) //require <permalink>/attachment/stuff form for pages because of confusion with subpages if ( ! $page ) //require <permalink>/attachment/stuff form for pages because of confusion with subpages
$rewrite = array_merge($rewrite, array($sub1 => $subquery, $sub1tb => $subtbquery, $sub1feed => $subfeedquery, $sub1feed2 => $subfeedquery)); $rewrite = array_merge($rewrite, array($sub1 => $subquery, $sub1tb => $subtbquery, $sub1feed => $subfeedquery, $sub1feed2 => $subfeedquery, $sub1comment => $subcommentquery));
$rewrite = array_merge(array($sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery), $rewrite); $rewrite = array_merge(array($sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery, $sub2comment => $subcommentquery), $rewrite);
} }
} //if($num_toks) } //if($num_toks)
//add the rules for this dir to the accumulating $post_rewrite //add the rules for this dir to the accumulating $post_rewrite

View File

@ -8,13 +8,13 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '2.7-almost-beta-9296'; $wp_version = '2.7-almost-beta-9300';
/** /**
* 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.
* *
* @global int $wp_db_version * @global int $wp_db_version
*/ */
$wp_db_version = 9296; $wp_db_version = 9300;
?> ?>