mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-07 00:48:55 +01:00
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:
parent
fac34b2423
commit
f275541cf6
@ -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'] );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 );
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
Loading…
Reference in New Issue
Block a user