diff options
| author | donncha <donncha@7be80a69-a1ef-0310-a953-fb0f7c49ff36> | 2007-09-10 18:26:30 +0000 |
|---|---|---|
| committer | donncha <donncha@7be80a69-a1ef-0310-a953-fb0f7c49ff36> | 2007-09-10 18:26:30 +0000 |
| commit | b658e546840b8f23e2a1e413f6510104d73ea91f (patch) | |
| tree | 1cd6bbbda247b5ae6cfff42f2cea731b4d8b667f /wp-includes/vars.php | |
| parent | 305d7e7228e097a26a98abdb45eb8283df7d5603 (diff) | |
Sync with WP 2.2.3
git-svn-id: http://svn.automattic.com/wordpress-mu/trunk@1051 7be80a69-a1ef-0310-a953-fb0f7c49ff36
Diffstat (limited to 'wp-includes/vars.php')
| -rw-r--r-- | wp-includes/vars.php | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/wp-includes/vars.php b/wp-includes/vars.php index 0f749be..a8b4897 100644 --- a/wp-includes/vars.php +++ b/wp-includes/vars.php @@ -1,15 +1,24 @@ <?php // On which page are we ? -if ( preg_match('#([^/]+\.php)$#', $PHP_SELF, $self_matches) ) { +if ( is_admin() ) { + // wp-admin pages are checked more carefully + preg_match('#/wp-admin/?(.*?)$#i', $PHP_SELF, $self_matches); $pagenow = $self_matches[1]; -} elseif ( strpos($PHP_SELF, '?') !== false ) { - $pagenow = explode('/', $PHP_SELF); - $pagenow = trim($pagenow[(sizeof($pagenow)-1)]); - $pagenow = explode('?', $pagenow); - $pagenow = $pagenow[0]; + $pagenow = preg_replace('#\?.*?$#', '', $pagenow); + if ( '' === $pagenow || 'index' === $pagenow || 'index.php' === $pagenow ) { + $pagenow = 'index.php'; + } else { + preg_match('#(.*?)(/|$)#', $pagenow, $self_matches); + $pagenow = strtolower($self_matches[1]); + if ( '.php' !== substr($pagenow, -4, 4) ) + $pagenow .= '.php'; // for Options +Multiviews: /wp-admin/themes/index.php (themes.php is queried) + } } else { - $pagenow = 'index.php'; + if ( preg_match('#([^/]+\.php)([?/].*?)?$#i', $PHP_SELF, $self_matches) ) + $pagenow = strtolower($self_matches[1]); + else + $pagenow = 'index.php'; } // Simple browser detection |
