]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-includes/vars.php
Wordpress 2.6.2
[autoinstalls/wordpress.git] / wp-includes / vars.php
index 2573b27eb3595e033c6e81e7080d03b3e98e1dbe..dcb659dc7ec2d3daba548211f52b6b52ab74f6b0 100644 (file)
 <?php
+/**
+ * Creates common globals for the rest of WordPress
+ *
+ * Sets $pagenow global which is the current page. Checks
+ * for the browser to set which one is currently being used.
+ *
+ * Detects which user environment WordPress is being used on.
+ * Only attempts to check for Apache and IIS. Two web servers
+ * with known permalink capability.
+ *
+ * @package WordPress
+ */
 
 // 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];
-} else if (strstr($PHP_SELF, '?')) {
-       $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
-$is_lynx = 0; $is_gecko = 0; $is_winIE = 0; $is_macIE = 0; $is_opera = 0; $is_NS4 = 0;
+$is_lynx = $is_gecko = $is_winIE = $is_macIE = $is_opera = $is_NS4 = $is_safari = false;
 
-if (preg_match('/Lynx/', $_SERVER['HTTP_USER_AGENT'])) {
-       $is_lynx = 1;
-} elseif (preg_match('/Gecko/', $_SERVER['HTTP_USER_AGENT'])) {
-       $is_gecko = 1;
-} elseif ((preg_match('/MSIE/', $_SERVER['HTTP_USER_AGENT'])) && (preg_match('/Win/', $_SERVER['HTTP_USER_AGENT']))) {
-       $is_winIE = 1;
-} elseif ((preg_match('/MSIE/', $_SERVER['HTTP_USER_AGENT'])) && (preg_match('/Mac/', $_SERVER['HTTP_USER_AGENT']))) {
-       $is_macIE = 1;
-} elseif (preg_match('/Opera/', $_SERVER['HTTP_USER_AGENT'])) {
-       $is_opera = 1;
-} elseif ((preg_match('/Nav/', $_SERVER['HTTP_USER_AGENT']) ) || (preg_match('/Mozilla\/4\./', $_SERVER['HTTP_USER_AGENT']))) {
-       $is_NS4 = 1;
+if (strpos($_SERVER['HTTP_USER_AGENT'], 'Lynx') !== false) {
+       $is_lynx = true;
+} elseif ( strpos(strtolower($_SERVER['HTTP_USER_AGENT']), 'webkit') !== false ) {
+       $is_safari = true;
+} elseif (strpos($_SERVER['HTTP_USER_AGENT'], 'Gecko') !== false) {
+       $is_gecko = true;
+} elseif (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') !== false && strpos($_SERVER['HTTP_USER_AGENT'], 'Win') !== false) {
+       $is_winIE = true;
+} elseif (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') !== false && strpos($_SERVER['HTTP_USER_AGENT'], 'Mac') !== false) {
+       $is_macIE = true;
+} elseif (strpos($_SERVER['HTTP_USER_AGENT'], 'Opera') !== false) {
+       $is_opera = true;
+} elseif (strpos($_SERVER['HTTP_USER_AGENT'], 'Nav') !== false && strpos($_SERVER['HTTP_USER_AGENT'], 'Mozilla/4.') !== false) {
+       $is_NS4 = true;
 }
-$is_IE    = (($is_macIE) || ($is_winIE));
 
-// Server detection
-$is_apache = ( strstr($_SERVER['SERVER_SOFTWARE'], 'Apache') || strstr($_SERVER['SERVER_SOFTWARE'], 'LiteSpeed') ) ? 1 : 0;
-$is_IIS = strstr($_SERVER['SERVER_SOFTWARE'], 'Microsoft-IIS') ? 1 : 0;
-
-// On OS X Server, $_SERVER['REMOTE_ADDR'] is the server's address. Workaround this 
-// by using $_SERVER['HTTP_PC_REMOTE_ADDR'], which *is* the remote address.
-if ( isset($_SERVER['HTTP_PC_REMOTE_ADDR']) )
-       $_SERVER['REMOTE_ADDR'] = $_SERVER['HTTP_PC_REMOTE_ADDR'];
+$is_IE = ( $is_macIE || $is_winIE );
 
-// if the config file does not provide the smilies array, let's define it here
-if (!isset($wpsmiliestrans)) {
-       $wpsmiliestrans = array(
-       ':mrgreen:'     => 'icon_mrgreen.gif',
-       ':neutral:'     => 'icon_neutral.gif',
-       ':twisted:'     => 'icon_twisted.gif',
-       ':arrow:'       => 'icon_arrow.gif',
-       ':shock:'       => 'icon_eek.gif',
-       ':smile:'       => 'icon_smile.gif',
-       ' :???:'        => 'icon_confused.gif',
-       ':cool:'        => 'icon_cool.gif',
-       ':evil:'        => 'icon_evil.gif',
-       ':grin:'        => 'icon_biggrin.gif',
-       ':idea:'        => 'icon_idea.gif',
-       ':oops:'        => 'icon_redface.gif',
-       ':razz:'        => 'icon_razz.gif',
-       ':roll:'        => 'icon_rolleyes.gif',
-       ':wink:'        => 'icon_wink.gif',
-       ':cry:'         => 'icon_cry.gif',
-       ':eek:'         => 'icon_surprised.gif',
-       ':lol:'         => 'icon_lol.gif',
-       ':mad:'         => 'icon_mad.gif',
-       ':sad:'         => 'icon_sad.gif',
-       ' 8-)'          => 'icon_cool.gif',
-       ' 8-O'          => 'icon_eek.gif',
-       ' :-('          => 'icon_sad.gif',
-       ' :-)'          => 'icon_smile.gif',
-       ' :-?'          => 'icon_confused.gif',
-       ' :-D'          => 'icon_biggrin.gif',
-       ' :-P'          => 'icon_razz.gif',
-       ' :-o'          => 'icon_surprised.gif',
-       ' :-x'          => 'icon_mad.gif',
-       ' :-|'          => 'icon_neutral.gif',
-       ' ;-)'          => 'icon_wink.gif',
-       ' 8)'           => 'icon_cool.gif',
-       ' 8O'           => 'icon_eek.gif',
-       ' :('           => 'icon_sad.gif',
-       ' :)'           => 'icon_smile.gif',
-       ' :?'           => 'icon_confused.gif',
-       ' :D'           => 'icon_biggrin.gif',
-       ' :P'           => 'icon_razz.gif',
-       ' :o'           => 'icon_surprised.gif',
-       ' :x'           => 'icon_mad.gif',
-       ' :|'           => 'icon_neutral.gif',
-       ' ;)'           => 'icon_wink.gif',
-       ':!:'           => 'icon_exclaim.gif',
-       ':?:'           => 'icon_question.gif',
-       );
-}
+// Server detection
 
+/**
+ * Whether the server software is Apache or something else
+ * @global bool $is_apache
+ */
+$is_apache = ((strpos($_SERVER['SERVER_SOFTWARE'], 'Apache') !== false) || (strpos($_SERVER['SERVER_SOFTWARE'], 'LiteSpeed') !== false)) ? true : false;
 
-// generates smilies' search & replace arrays
-foreach($wpsmiliestrans as $smiley => $img) {
-       $wp_smiliessearch[] = $smiley;
-       $smiley_masked = htmlspecialchars( trim($smiley) , ENT_QUOTES);
-       $wp_smiliesreplace[] = " <img src='" . get_settings('siteurl') . "/wp-includes/images/smilies/$img' alt='$smiley_masked' class='wp-smiley' /> ";
-}
+/**
+ * Whether the server software is IIS or something else
+ * @global bool $is_IIS
+ */
+$is_IIS = (strpos($_SERVER['SERVER_SOFTWARE'], 'Microsoft-IIS') !== false) ? true : false;
 
 ?>