Docs: Add saner formatting and make readability improvements to a variety of inline comments in WP_Rewrite
and WP_Rewrite::generate_rewrite_rules()
.
See #34218. git-svn-id: https://develop.svn.wordpress.org/trunk@34957 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
3cc827ef5a
commit
694a56bc14
@ -456,15 +456,15 @@ class WP_Rewrite {
|
|||||||
public function page_uri_index() {
|
public function page_uri_index() {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
//get pages in order of hierarchy, i.e. children after parents
|
// Get pages in order of hierarchy, i.e. children after parents.
|
||||||
$pages = $wpdb->get_results("SELECT ID, post_name, post_parent FROM $wpdb->posts WHERE post_type = 'page' AND post_status != 'auto-draft'");
|
$pages = $wpdb->get_results("SELECT ID, post_name, post_parent FROM $wpdb->posts WHERE post_type = 'page' AND post_status != 'auto-draft'");
|
||||||
$posts = get_page_hierarchy( $pages );
|
$posts = get_page_hierarchy( $pages );
|
||||||
|
|
||||||
// If we have no pages get out quick
|
// If we have no pages get out quick.
|
||||||
if ( !$posts )
|
if ( !$posts )
|
||||||
return array( array(), array() );
|
return array( array(), array() );
|
||||||
|
|
||||||
//now reverse it, because we need parents after children for rewrite rules to work properly
|
// Now reverse it, because we need parents after children for rewrite rules to work properly.
|
||||||
$posts = array_reverse($posts, true);
|
$posts = array_reverse($posts, true);
|
||||||
|
|
||||||
$page_uris = array();
|
$page_uris = array();
|
||||||
@ -496,7 +496,7 @@ class WP_Rewrite {
|
|||||||
* @return array Page rewrite rules.
|
* @return array Page rewrite rules.
|
||||||
*/
|
*/
|
||||||
public function page_rewrite_rules() {
|
public function page_rewrite_rules() {
|
||||||
// the extra .? at the beginning prevents clashes with other regular expressions in the rules array
|
// The extra .? at the beginning prevents clashes with other regular expressions in the rules array.
|
||||||
$this->add_rewrite_tag( '%pagename%', '(.?.+?)', 'pagename=' );
|
$this->add_rewrite_tag( '%pagename%', '(.?.+?)', 'pagename=' );
|
||||||
|
|
||||||
return $this->generate_rewrite_rules( $this->get_page_permastruct(), EP_PAGES, true, true, false, false );
|
return $this->generate_rewrite_rules( $this->get_page_permastruct(), EP_PAGES, true, true, false, false );
|
||||||
@ -547,8 +547,10 @@ class WP_Rewrite {
|
|||||||
if ( empty($date_endian) )
|
if ( empty($date_endian) )
|
||||||
$date_endian = '%year%/%monthnum%/%day%';
|
$date_endian = '%year%/%monthnum%/%day%';
|
||||||
|
|
||||||
// Do not allow the date tags and %post_id% to overlap in the permalink
|
/*
|
||||||
// structure. If they do, move the date tags to $front/date/.
|
* Do not allow the date tags and %post_id% to overlap in the permalink
|
||||||
|
* structure. If they do, move the date tags to $front/date/.
|
||||||
|
*/
|
||||||
$front = $this->front;
|
$front = $this->front;
|
||||||
preg_match_all('/%.+?%/', $this->permalink_structure, $tokens);
|
preg_match_all('/%.+?%/', $this->permalink_structure, $tokens);
|
||||||
$tok_index = 1;
|
$tok_index = 1;
|
||||||
@ -859,37 +861,41 @@ class WP_Rewrite {
|
|||||||
* @return array Rewrite rule list.
|
* @return array Rewrite rule list.
|
||||||
*/
|
*/
|
||||||
public function generate_rewrite_rules($permalink_structure, $ep_mask = EP_NONE, $paged = true, $feed = true, $forcomments = false, $walk_dirs = true, $endpoints = true) {
|
public function generate_rewrite_rules($permalink_structure, $ep_mask = EP_NONE, $paged = true, $feed = true, $forcomments = false, $walk_dirs = true, $endpoints = true) {
|
||||||
//build a regex to match the feed section of URLs, something like (feed|atom|rss|rss2)/?
|
// Build a regex to match the feed section of URLs, something like (feed|atom|rss|rss2)/?
|
||||||
$feedregex2 = '';
|
$feedregex2 = '';
|
||||||
foreach ( (array) $this->feeds as $feed_name)
|
foreach ( (array) $this->feeds as $feed_name)
|
||||||
$feedregex2 .= $feed_name . '|';
|
$feedregex2 .= $feed_name . '|';
|
||||||
$feedregex2 = '(' . trim($feedregex2, '|') . ')/?$';
|
$feedregex2 = '(' . trim($feedregex2, '|') . ')/?$';
|
||||||
|
|
||||||
//$feedregex is identical but with /feed/ added on as well, so URLs like <permalink>/feed/atom
|
/*
|
||||||
//and <permalink>/atom are both possible
|
* $feedregex is identical but with /feed/ added on as well, so URLs like <permalink>/feed/atom
|
||||||
|
* and <permalink>/atom are both possible
|
||||||
|
*/
|
||||||
$feedregex = $this->feed_base . '/' . $feedregex2;
|
$feedregex = $this->feed_base . '/' . $feedregex2;
|
||||||
|
|
||||||
//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 = $this->pagination_base . '/?([0-9]{1,})/?$';
|
$pageregex = $this->pagination_base . '/?([0-9]{1,})/?$';
|
||||||
$commentregex = $this->comments_pagination_base . '-([0-9]{1,})/?$';
|
$commentregex = $this->comments_pagination_base . '-([0-9]{1,})/?$';
|
||||||
$embedregex = 'embed/?$';
|
$embedregex = 'embed/?$';
|
||||||
|
|
||||||
//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 ) {
|
||||||
$ep_query_append = array ();
|
$ep_query_append = array ();
|
||||||
foreach ( (array) $this->endpoints as $endpoint) {
|
foreach ( (array) $this->endpoints as $endpoint) {
|
||||||
//match everything after the endpoint name, but allow for nothing to appear there
|
// Match everything after the endpoint name, but allow for nothing to appear there.
|
||||||
$epmatch = $endpoint[1] . '(/(.*))?/?$';
|
$epmatch = $endpoint[1] . '(/(.*))?/?$';
|
||||||
//this will be appended on to the rest of the query for each dir
|
|
||||||
|
// This will be appended on to the rest of the query for each dir.
|
||||||
$epquery = '&' . $endpoint[2] . '=';
|
$epquery = '&' . $endpoint[2] . '=';
|
||||||
$ep_query_append[$epmatch] = array ( $endpoint[0], $epquery );
|
$ep_query_append[$epmatch] = array ( $endpoint[0], $epquery );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//get everything up to the first rewrite tag
|
// Get everything up to the first rewrite tag.
|
||||||
$front = substr($permalink_structure, 0, strpos($permalink_structure, '%'));
|
$front = substr($permalink_structure, 0, strpos($permalink_structure, '%'));
|
||||||
//build an array of the tags (note that said array ends up being in $tokens[0])
|
|
||||||
|
// Build an array of the tags (note that said array ends up being in $tokens[0]).
|
||||||
preg_match_all('/%.+?%/', $permalink_structure, $tokens);
|
preg_match_all('/%.+?%/', $permalink_structure, $tokens);
|
||||||
|
|
||||||
$num_tokens = count($tokens[0]);
|
$num_tokens = count($tokens[0]);
|
||||||
@ -899,8 +905,10 @@ class WP_Rewrite {
|
|||||||
$trackbackindex = $index;
|
$trackbackindex = $index;
|
||||||
$embedindex = $index;
|
$embedindex = $index;
|
||||||
|
|
||||||
//build a list from the rewritecode and queryreplace arrays, that will look something like
|
/*
|
||||||
//tagname=$matches[i] where i is the current $i
|
* Build a list from the rewritecode and queryreplace arrays, that will look something
|
||||||
|
* like tagname=$matches[i] where i is the current $i.
|
||||||
|
*/
|
||||||
$queries = array();
|
$queries = array();
|
||||||
for ( $i = 0; $i < $num_tokens; ++$i ) {
|
for ( $i = 0; $i < $num_tokens; ++$i ) {
|
||||||
if ( 0 < $i )
|
if ( 0 < $i )
|
||||||
@ -912,39 +920,41 @@ class WP_Rewrite {
|
|||||||
$queries[$i] .= $query_token;
|
$queries[$i] .= $query_token;
|
||||||
}
|
}
|
||||||
|
|
||||||
//get the structure, minus any cruft (stuff that isn't tags) at the front
|
// Get the structure, minus any cruft (stuff that isn't tags) at the front.
|
||||||
$structure = $permalink_structure;
|
$structure = $permalink_structure;
|
||||||
if ( $front != '/' )
|
if ( $front != '/' )
|
||||||
$structure = str_replace($front, '', $structure);
|
$structure = str_replace($front, '', $structure);
|
||||||
|
|
||||||
//create a list of dirs to walk over, making rewrite rules for each level
|
/*
|
||||||
//so for example, a $structure of /%year%/%monthnum%/%postname% would create
|
* Create a list of dirs to walk over, making rewrite rules for each level
|
||||||
//rewrite rules for /%year%/, /%year%/%monthnum%/ and /%year%/%monthnum%/%postname%
|
* so for example, a $structure of /%year%/%monthnum%/%postname% would create
|
||||||
|
* rewrite rules for /%year%/, /%year%/%monthnum%/ and /%year%/%monthnum%/%postname%
|
||||||
|
*/
|
||||||
$structure = trim($structure, '/');
|
$structure = trim($structure, '/');
|
||||||
$dirs = $walk_dirs ? explode('/', $structure) : array( $structure );
|
$dirs = $walk_dirs ? explode('/', $structure) : array( $structure );
|
||||||
$num_dirs = count($dirs);
|
$num_dirs = count($dirs);
|
||||||
|
|
||||||
//strip slashes from the front of $front
|
// Strip slashes from the front of $front.
|
||||||
$front = preg_replace('|^/+|', '', $front);
|
$front = preg_replace('|^/+|', '', $front);
|
||||||
|
|
||||||
//the main workhorse loop
|
// The main workhorse loop.
|
||||||
$post_rewrite = array();
|
$post_rewrite = array();
|
||||||
$struct = $front;
|
$struct = $front;
|
||||||
for ( $j = 0; $j < $num_dirs; ++$j ) {
|
for ( $j = 0; $j < $num_dirs; ++$j ) {
|
||||||
//get the struct for this dir, and trim slashes off the front
|
// Get the struct for this dir, and trim slashes off the front.
|
||||||
$struct .= $dirs[$j] . '/'; //accumulate. see comment near explode('/', $structure) above
|
$struct .= $dirs[$j] . '/'; // Accumulate. see comment near explode('/', $structure) above.
|
||||||
$struct = ltrim($struct, '/');
|
$struct = ltrim($struct, '/');
|
||||||
|
|
||||||
//replace tags with regexes
|
// Replace tags with regexes.
|
||||||
$match = str_replace($this->rewritecode, $this->rewritereplace, $struct);
|
$match = str_replace($this->rewritecode, $this->rewritereplace, $struct);
|
||||||
|
|
||||||
//make a list of tags, and store how many there are in $num_toks
|
// Make a list of tags, and store how many there are in $num_toks.
|
||||||
$num_toks = preg_match_all('/%.+?%/', $struct, $toks);
|
$num_toks = preg_match_all('/%.+?%/', $struct, $toks);
|
||||||
|
|
||||||
//get the 'tagname=$matches[i]'
|
// Get the 'tagname=$matches[i]'.
|
||||||
$query = ( ! empty( $num_toks ) && isset( $queries[$num_toks - 1] ) ) ? $queries[$num_toks - 1] : '';
|
$query = ( ! empty( $num_toks ) && isset( $queries[$num_toks - 1] ) ) ? $queries[$num_toks - 1] : '';
|
||||||
|
|
||||||
//set up $ep_mask_specific which is used to match more specific URL types
|
// Set up $ep_mask_specific which is used to match more specific URL types.
|
||||||
switch ( $dirs[$j] ) {
|
switch ( $dirs[$j] ) {
|
||||||
case '%year%':
|
case '%year%':
|
||||||
$ep_mask_specific = EP_YEAR;
|
$ep_mask_specific = EP_YEAR;
|
||||||
@ -959,65 +969,74 @@ class WP_Rewrite {
|
|||||||
$ep_mask_specific = EP_NONE;
|
$ep_mask_specific = EP_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
//create query for /page/xx
|
// Create query for /page/xx.
|
||||||
$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
|
// Create query for /comment-page-xx.
|
||||||
$commentmatch = $match . $commentregex;
|
$commentmatch = $match . $commentregex;
|
||||||
$commentquery = $index . '?' . $query . '&cpage=' . $this->preg_index($num_toks + 1);
|
$commentquery = $index . '?' . $query . '&cpage=' . $this->preg_index($num_toks + 1);
|
||||||
|
|
||||||
if ( get_option('page_on_front') ) {
|
if ( get_option('page_on_front') ) {
|
||||||
//create query for Root /comment-page-xx
|
// Create query for Root /comment-page-xx.
|
||||||
$rootcommentmatch = $match . $commentregex;
|
$rootcommentmatch = $match . $commentregex;
|
||||||
$rootcommentquery = $index . '?' . $query . '&page_id=' . get_option('page_on_front') . '&cpage=' . $this->preg_index($num_toks + 1);
|
$rootcommentquery = $index . '?' . $query . '&page_id=' . get_option('page_on_front') . '&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);
|
||||||
|
|
||||||
//create query for /(feed|atom|rss|rss2|rdf) (see comment near creation of $feedregex)
|
// Create query for /(feed|atom|rss|rss2|rdf) (see comment near creation of $feedregex).
|
||||||
$feedmatch2 = $match . $feedregex2;
|
$feedmatch2 = $match . $feedregex2;
|
||||||
$feedquery2 = $feedindex . '?' . $query . '&feed=' . $this->preg_index($num_toks + 1);
|
$feedquery2 = $feedindex . '?' . $query . '&feed=' . $this->preg_index($num_toks + 1);
|
||||||
|
|
||||||
//if asked to, turn the feed queries into comment feed ones
|
// If asked to, turn the feed queries into comment feed ones.
|
||||||
if ( $forcomments ) {
|
if ( $forcomments ) {
|
||||||
$feedquery .= '&withcomments=1';
|
$feedquery .= '&withcomments=1';
|
||||||
$feedquery2 .= '&withcomments=1';
|
$feedquery2 .= '&withcomments=1';
|
||||||
}
|
}
|
||||||
|
|
||||||
//start creating the array of rewrites for this dir
|
// Start creating the array of rewrites for this dir.
|
||||||
$rewrite = array();
|
$rewrite = array();
|
||||||
if ( $feed ) //...adding on /feed/ regexes => queries
|
|
||||||
$rewrite = array($feedmatch => $feedquery, $feedmatch2 => $feedquery2);
|
|
||||||
if ( $paged ) //...and /page/xx ones
|
|
||||||
$rewrite = array_merge($rewrite, array($pagematch => $pagequery));
|
|
||||||
|
|
||||||
//only on pages with comments add ../comment-page-xx/
|
// ...adding on /feed/ regexes => queries
|
||||||
|
if ( $feed ) {
|
||||||
|
$rewrite = array( $feedmatch => $feedquery, $feedmatch2 => $feedquery2 );
|
||||||
|
}
|
||||||
|
|
||||||
|
//...and /page/xx ones
|
||||||
|
if ( $paged ) {
|
||||||
|
$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 ) {
|
if ( EP_PAGES & $ep_mask || EP_PERMALINK & $ep_mask ) {
|
||||||
$rewrite = array_merge($rewrite, array($commentmatch => $commentquery));
|
$rewrite = array_merge($rewrite, array($commentmatch => $commentquery));
|
||||||
} elseif ( EP_ROOT & $ep_mask && get_option('page_on_front') ) {
|
} elseif ( EP_ROOT & $ep_mask && get_option('page_on_front') ) {
|
||||||
$rewrite = array_merge($rewrite, array($rootcommentmatch => $rootcommentquery));
|
$rewrite = array_merge($rewrite, array($rootcommentmatch => $rootcommentquery));
|
||||||
}
|
}
|
||||||
//do endpoints
|
|
||||||
|
// Do endpoints.
|
||||||
if ( $endpoints ) {
|
if ( $endpoints ) {
|
||||||
foreach ( (array) $ep_query_append as $regex => $ep) {
|
foreach ( (array) $ep_query_append as $regex => $ep) {
|
||||||
//add the endpoints on if the mask fits
|
// Add the endpoints on if the mask fits.
|
||||||
if ( $ep[0] & $ep_mask || $ep[0] & $ep_mask_specific )
|
if ( $ep[0] & $ep_mask || $ep[0] & $ep_mask_specific )
|
||||||
$rewrite[$match . $regex] = $index . '?' . $query . $ep[1] . $this->preg_index($num_toks + 2);
|
$rewrite[$match . $regex] = $index . '?' . $query . $ep[1] . $this->preg_index($num_toks + 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//if we've got some tags in this dir
|
// If we've got some tags in this dir.
|
||||||
if ( $num_toks ) {
|
if ( $num_toks ) {
|
||||||
$post = false;
|
$post = false;
|
||||||
$page = false;
|
$page = false;
|
||||||
|
|
||||||
//check to see if this dir is permalink-level: i.e. the structure specifies an
|
/*
|
||||||
//individual post. Do this by checking it contains at least one of 1) post name,
|
* Check to see if this dir is permalink-level: i.e. the structure specifies an
|
||||||
//2) post ID, 3) page name, 4) timestamp (year, month, day, hour, second and
|
* individual post. Do this by checking it contains at least one of 1) post name,
|
||||||
//minute all present). Set these flags now as we need them for the endpoints.
|
* 2) post ID, 3) page name, 4) timestamp (year, month, day, hour, second and
|
||||||
|
* minute all present). Set these flags now as we need them for the endpoints.
|
||||||
|
*/
|
||||||
if ( strpos($struct, '%postname%') !== false
|
if ( strpos($struct, '%postname%') !== false
|
||||||
|| strpos($struct, '%post_id%') !== false
|
|| strpos($struct, '%post_id%') !== false
|
||||||
|| strpos($struct, '%pagename%') !== false
|
|| strpos($struct, '%pagename%') !== false
|
||||||
@ -1033,15 +1052,17 @@ class WP_Rewrite {
|
|||||||
foreach ( get_post_types( array('_builtin' => false ) ) as $ptype ) {
|
foreach ( get_post_types( array('_builtin' => false ) ) as $ptype ) {
|
||||||
if ( strpos($struct, "%$ptype%") !== false ) {
|
if ( strpos($struct, "%$ptype%") !== false ) {
|
||||||
$post = true;
|
$post = true;
|
||||||
$page = is_post_type_hierarchical( $ptype ); // This is for page style attachment url's
|
|
||||||
|
// This is for page style attachment URLs.
|
||||||
|
$page = is_post_type_hierarchical( $ptype );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//if we're creating rules for a permalink, do all the endpoints like attachments etc
|
// If creating rules for a permalink, do all the endpoints like attachments etc.
|
||||||
if ( $post ) {
|
if ( $post ) {
|
||||||
//create query and regex for trackback
|
// Create query and regex for trackback.
|
||||||
$trackbackmatch = $match . $trackbackregex;
|
$trackbackmatch = $match . $trackbackregex;
|
||||||
$trackbackquery = $trackbackindex . '?' . $query . '&tb=1';
|
$trackbackquery = $trackbackindex . '?' . $query . '&tb=1';
|
||||||
|
|
||||||
@ -1049,37 +1070,59 @@ class WP_Rewrite {
|
|||||||
$embedmatch = $match . $embedregex;
|
$embedmatch = $match . $embedregex;
|
||||||
$embedquery = $embedindex . '?' . $query . '&embed=true';
|
$embedquery = $embedindex . '?' . $query . '&embed=true';
|
||||||
|
|
||||||
//trim slashes from the end of the regex for this dir
|
// Trim slashes from the end of the regex for this dir.
|
||||||
$match = rtrim($match, '/');
|
$match = rtrim($match, '/');
|
||||||
|
|
||||||
//get rid of brackets
|
// Get rid of brackets.
|
||||||
$submatchbase = str_replace( array('(', ')'), '', $match);
|
$submatchbase = str_replace( array('(', ')'), '', $match);
|
||||||
|
|
||||||
//add a rule for at attachments, which take the form of <permalink>/some-text
|
// Add a rule for at attachments, which take the form of <permalink>/some-text.
|
||||||
$sub1 = $submatchbase . '/([^/]+)/';
|
$sub1 = $submatchbase . '/([^/]+)/';
|
||||||
$sub1tb = $sub1 . $trackbackregex; //add trackback regex <permalink>/trackback/...
|
|
||||||
$sub1feed = $sub1 . $feedregex; //and <permalink>/feed/(atom|...)
|
|
||||||
$sub1feed2 = $sub1 . $feedregex2; //and <permalink>/(feed|atom...)
|
|
||||||
$sub1comment = $sub1 . $commentregex; //and <permalink>/comment-page-xx
|
|
||||||
$sub1embed = $sub1 . $embedregex; //and <permalink>/embed/...
|
|
||||||
|
|
||||||
//add another rule to match attachments in the explicit form:
|
// Add trackback regex <permalink>/trackback/...
|
||||||
//<permalink>/attachment/some-text
|
$sub1tb = $sub1 . $trackbackregex;
|
||||||
|
|
||||||
|
// And <permalink>/feed/(atom|...)
|
||||||
|
$sub1feed = $sub1 . $feedregex;
|
||||||
|
|
||||||
|
// And <permalink>/(feed|atom...)
|
||||||
|
$sub1feed2 = $sub1 . $feedregex2;
|
||||||
|
|
||||||
|
// And <permalink>/comment-page-xx
|
||||||
|
$sub1comment = $sub1 . $commentregex;
|
||||||
|
|
||||||
|
// And <permalink>/embed/...
|
||||||
|
$sub1embed = $sub1 . $embedregex;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add another rule to match attachments in the explicit form:
|
||||||
|
* <permalink>/attachment/some-text
|
||||||
|
*/
|
||||||
$sub2 = $submatchbase . '/attachment/([^/]+)/';
|
$sub2 = $submatchbase . '/attachment/([^/]+)/';
|
||||||
$sub2tb = $sub2 . $trackbackregex; //and add trackbacks <permalink>/attachment/trackback
|
|
||||||
$sub2feed = $sub2 . $feedregex; //feeds, <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
|
|
||||||
$sub2embed = $sub2 . $embedregex; //and <permalink>/embed/...
|
|
||||||
|
|
||||||
//create queries for these extra tag-ons we've just dealt with
|
// And add trackbacks <permalink>/attachment/trackback.
|
||||||
|
$sub2tb = $sub2 . $trackbackregex;
|
||||||
|
|
||||||
|
// Feeds, <permalink>/attachment/feed/(atom|...)
|
||||||
|
$sub2feed = $sub2 . $feedregex;
|
||||||
|
|
||||||
|
// And feeds again on to this <permalink>/attachment/(feed|atom...)
|
||||||
|
$sub2feed2 = $sub2 . $feedregex2;
|
||||||
|
|
||||||
|
// And <permalink>/comment-page-xx
|
||||||
|
$sub2comment = $sub2 . $commentregex;
|
||||||
|
|
||||||
|
// And <permalink>/embed/...
|
||||||
|
$sub2embed = $sub2 . $embedregex;
|
||||||
|
|
||||||
|
// 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);
|
$subcommentquery = $subquery . '&cpage=' . $this->preg_index(2);
|
||||||
$subembedquery = $subquery . '&embed=true';
|
$subembedquery = $subquery . '&embed=true';
|
||||||
|
|
||||||
//do endpoints for attachments
|
// Do endpoints for attachments.
|
||||||
if ( !empty($endpoints) ) {
|
if ( !empty($endpoints) ) {
|
||||||
foreach ( (array) $ep_query_append as $regex => $ep ) {
|
foreach ( (array) $ep_query_append as $regex => $ep ) {
|
||||||
if ( $ep[0] & EP_ATTACHMENT ) {
|
if ( $ep[0] & EP_ATTACHMENT ) {
|
||||||
@ -1089,39 +1132,47 @@ class WP_Rewrite {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//now we've finished with endpoints, finish off the $sub1 and $sub2 matches
|
/*
|
||||||
//add a ? as we don't have to match that last slash, and finally a $ so we
|
* Now we've finished with endpoints, finish off the $sub1 and $sub2 matches
|
||||||
//match to the end of the URL
|
* add a ? as we don't have to match that last slash, and finally a $ so we
|
||||||
|
* match to the end of the URL
|
||||||
|
*/
|
||||||
$sub1 .= '?$';
|
$sub1 .= '?$';
|
||||||
$sub2 .= '?$';
|
$sub2 .= '?$';
|
||||||
|
|
||||||
// Post pagination, e.g. <permalink>/2/
|
/*
|
||||||
// Previously: '(/[0-9]+)?/?$', which produced '/2' for page.
|
* Post pagination, e.g. <permalink>/2/
|
||||||
// When cast to int, returned 0.
|
* Previously: '(/[0-9]+)?/?$', which produced '/2' for page.
|
||||||
|
* When cast to int, returned 0.
|
||||||
|
*/
|
||||||
$match = $match . '(?:/([0-9]+))?/?$';
|
$match = $match . '(?:/([0-9]+))?/?$';
|
||||||
$query = $index . '?' . $query . '&page=' . $this->preg_index($num_toks + 1);
|
$query = $index . '?' . $query . '&page=' . $this->preg_index($num_toks + 1);
|
||||||
} else { //not matching a permalink so this is a lot simpler
|
|
||||||
//close the match and finalise the query
|
// Not matching a permalink so this is a lot simpler.
|
||||||
|
} else {
|
||||||
|
// Close the match and finalise the query.
|
||||||
$match .= '?$';
|
$match .= '?$';
|
||||||
$query = $index . '?' . $query;
|
$query = $index . '?' . $query;
|
||||||
}
|
}
|
||||||
|
|
||||||
//create the final array for this dir by joining the $rewrite array (which currently
|
/*
|
||||||
//only contains rules/queries for trackback, pages etc) to the main regex/query for
|
* Create the final array for this dir by joining the $rewrite array (which currently
|
||||||
//this dir
|
* only contains rules/queries for trackback, pages etc) to the main regex/query for
|
||||||
|
* this dir
|
||||||
|
*/
|
||||||
$rewrite = array_merge($rewrite, array($match => $query));
|
$rewrite = array_merge($rewrite, array($match => $query));
|
||||||
|
|
||||||
//if we're matching a permalink, add those extras (attachments etc) on
|
// If we're matching a permalink, add those extras (attachments etc) on.
|
||||||
if ( $post ) {
|
if ( $post ) {
|
||||||
//add trackback
|
// Add trackback.
|
||||||
$rewrite = array_merge(array($trackbackmatch => $trackbackquery), $rewrite);
|
$rewrite = array_merge(array($trackbackmatch => $trackbackquery), $rewrite);
|
||||||
|
|
||||||
// add embed
|
// Add embed.
|
||||||
$rewrite = array_merge( array( $embedmatch => $embedquery ), $rewrite );
|
$rewrite = array_merge( array( $embedmatch => $embedquery ), $rewrite );
|
||||||
|
|
||||||
//add regexes/queries for attachments, attachment trackbacks and so on
|
// Add regexes/queries for attachments, attachment trackbacks and so on.
|
||||||
if ( ! $page ) {
|
if ( ! $page ) {
|
||||||
//require <permalink>/attachment/stuff form for pages because of confusion with subpages
|
// Require <permalink>/attachment/stuff form for pages because of confusion with subpages.
|
||||||
$rewrite = array_merge( $rewrite, array(
|
$rewrite = array_merge( $rewrite, array(
|
||||||
$sub1 => $subquery,
|
$sub1 => $subquery,
|
||||||
$sub1tb => $subtbquery,
|
$sub1tb => $subtbquery,
|
||||||
@ -1134,11 +1185,13 @@ class WP_Rewrite {
|
|||||||
|
|
||||||
$rewrite = array_merge( array( $sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery, $sub2comment => $subcommentquery, $sub2embed => $subembedquery ), $rewrite );
|
$rewrite = array_merge( array( $sub2 => $subquery, $sub2tb => $subtbquery, $sub2feed => $subfeedquery, $sub2feed2 => $subfeedquery, $sub2comment => $subcommentquery, $sub2embed => $subembedquery ), $rewrite );
|
||||||
}
|
}
|
||||||
} //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.
|
||||||
$post_rewrite = array_merge($rewrite, $post_rewrite);
|
$post_rewrite = array_merge($rewrite, $post_rewrite);
|
||||||
} //foreach ($dir)
|
}
|
||||||
return $post_rewrite; //the finished rules. phew!
|
|
||||||
|
// The finished rules. phew!
|
||||||
|
return $post_rewrite;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user