From 048bec139e022952d90c10b2ddb34f06dec607be Mon Sep 17 00:00:00 2001
From: Dries Buytaert <dries@buytaert.net>
Date: Thu, 2 Feb 2006 12:44:57 +0000
Subject: [PATCH] - Patch #13148 by Morbus: less  globals.

---
 includes/common.inc                           | 24 ++++++++++---------
 includes/theme.inc                            | 15 +++++-------
 themes/chameleon/chameleon.theme              |  3 +--
 themes/engines/phptemplate/phptemplate.engine |  5 ++--
 4 files changed, 22 insertions(+), 25 deletions(-)

diff --git a/includes/common.inc b/includes/common.inc
index 9f82fe440e30..5548ae68bc60 100644
--- a/includes/common.inc
+++ b/includes/common.inc
@@ -114,11 +114,8 @@ function drupal_set_html_head($data = NULL) {
  * Retrieve output to be displayed in the head tag of the HTML page.
  */
 function drupal_get_html_head() {
-  global $base_path;
-
   $output = "<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\" />\n";
-  $output .= theme('stylesheet_import', $base_path .'misc/drupal.css');
-
+  $output .= theme('stylesheet_import', base_path() .'misc/drupal.css');
   return $output . drupal_set_html_head();
 }
 
@@ -237,7 +234,6 @@ function drupal_goto($path = '', $query = NULL, $fragment = NULL) {
   exit();
 }
 
-
 /**
  * Generates a site off-line message
  */
@@ -918,7 +914,7 @@ function url($path = NULL, $query = NULL, $fragment = NULL, $absolute = FALSE) {
     return $path . $fragment;
   }
 
-  global $base_url, $base_path;
+  global $base_url;
   static $script;
   static $clean_url;
 
@@ -934,7 +930,7 @@ function url($path = NULL, $query = NULL, $fragment = NULL, $absolute = FALSE) {
     $clean_url = (bool)variable_get('clean_url', '0');
   }
 
-  $base = ($absolute ? $base_url . '/' : $base_path);
+  $base = ($absolute ? $base_url . '/' : base_path());
 
   // The special path '<front>' links to the default front page.
   if (isset($path) && $path != '<front>') {
@@ -1110,6 +1106,14 @@ function drupal_get_path($type, $name) {
   return dirname(drupal_get_filename($type, $name));
 }
 
+/**
+ * Returns the base URL path of the Drupal installation.
+ * At the very least, this will always default to /.
+ */
+function base_path() {
+  return $GLOBALS['base_path'];
+}
+
 /**
  * Provide a substitute clone() function for PHP4.
  */
@@ -1124,7 +1128,6 @@ function drupal_add_link($attributes) {
   drupal_set_html_head('<link'. drupal_attributes($attributes) ." />\n");
 }
 
-
 /**
  * Add a JavaScript file to the output.
  *
@@ -1133,15 +1136,14 @@ function drupal_add_link($attributes) {
  * depends on the 'killswitch' inside it.
  */
 function drupal_add_js($file) {
-  global $base_path;
   static $sent = array();
 
   if (!isset($sent['misc/drupal.js'])) {
-    drupal_set_html_head('<script type="text/javascript" src="'. $base_path .'misc/drupal.js"></script>');
+    drupal_set_html_head('<script type="text/javascript" src="'. base_path() .'misc/drupal.js"></script>');
     $sent['misc/drupal.js'] = true;
   }
   if (!isset($sent[$file])) {
-    drupal_set_html_head('<script type="text/javascript" src="'. check_url($base_path . $file) .'"></script>');
+    drupal_set_html_head('<script type="text/javascript" src="'. check_url(base_path() . $file) .'"></script>');
     $sent[$file] = true;
   }
 }
diff --git a/includes/theme.inc b/includes/theme.inc
index 29da91fe350a..1fd10cde8a10 100644
--- a/includes/theme.inc
+++ b/includes/theme.inc
@@ -280,7 +280,7 @@ function theme_get_settings($key = NULL) {
  *   The value of the requested setting, NULL if the setting does not exist.
  */
 function theme_get_setting($setting_name, $refresh = FALSE) {
-  global $theme_key, $base_path;
+  global $theme_key;
   static $settings;
 
   if (empty($settings) || $refresh) {
@@ -298,7 +298,7 @@ function theme_get_setting($setting_name, $refresh = FALSE) {
     }
 
     if ($settings['toggle_logo']) {
-      $settings['logo'] = $base_path;
+      $settings['logo'] = base_path();
       if ($settings['default_logo']) {
         $settings['logo'] .= dirname($theme_object->filename) .'/logo.png';
       }
@@ -308,7 +308,7 @@ function theme_get_setting($setting_name, $refresh = FALSE) {
     }
 
     if ($settings['toggle_favicon']) {
-      $settings['favicon'] = $base_path;
+      $settings['favicon'] = base_path();
       if ($settings['default_favicon']) {
         if (file_exists($favicon = dirname($theme_object->filename) .'/favicon.ico')) {
           $settings['favicon'] .= $favicon;
@@ -331,12 +331,11 @@ function theme_get_setting($setting_name, $refresh = FALSE) {
  * drupal_set_html_head() to enforce the correct CSS cascading order.
  */
 function theme_add_style($path = '', $media = 'all') {
-  global $base_path;
   static $styles = array();
 
   if ($path && !isset($styles["$media:$path"])) {
     $style = new stdClass();
-    $style->path = $base_path. $path;
+    $style->path = base_path() . $path;
     $style->media = $media;
     $styles["$media:$path"] = $style;
   }
@@ -427,10 +426,9 @@ function theme_page($content) {
 }
 
 function theme_maintenance_page($content) {
-  global $base_path;
   drupal_set_header('Content-Type: text/html; charset=utf-8');
   theme('add_style', 'misc/maintenance.css');
-  drupal_set_html_head('<link rel="shortcut icon" href="'. $base_path .'misc/favicon.ico" type="image/x-icon" />');
+  drupal_set_html_head('<link rel="shortcut icon" href="'. base_path() .'misc/favicon.ico" type="image/x-icon" />');
   $output = "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n";
   $output .= '<html xmlns="http://www.w3.org/1999/xhtml">';
   $output .= '<head>';
@@ -515,10 +513,9 @@ function theme_links($links, $delimiter = ' | ') {
  *   A string containing the image tag.
  */
 function theme_image($path, $alt = '', $title = '', $attributes = NULL, $getsize = TRUE) {
-  global $base_path;
   if (!$getsize || (is_file($path) && (list($width, $height, $type, $image_attributes) = @getimagesize($path)))) {
     $attributes = drupal_attributes($attributes);
-    return '<img src="'. check_url($base_path. $path) .'" alt="'. check_plain($alt) .'" title="'. check_plain($title) .'" '. $image_attributes . $attributes .' />';
+    return '<img src="'. check_url(base_path() . $path) .'" alt="'. check_plain($alt) .'" title="'. check_plain($title) .'" '. $image_attributes . $attributes .' />';
   }
 }
 
diff --git a/themes/chameleon/chameleon.theme b/themes/chameleon/chameleon.theme
index 52f278be44d6..44965ef069e6 100644
--- a/themes/chameleon/chameleon.theme
+++ b/themes/chameleon/chameleon.theme
@@ -22,7 +22,6 @@ function chameleon_regions() {
 }
 
 function chameleon_page($content) {
-  global $base_path;
   $language = $GLOBALS['locale'];
 
   if (theme_get_setting('toggle_favicon')) {
@@ -43,7 +42,7 @@ function chameleon_page($content) {
   $output .= " <div id=\"header\">";
 
   if ($logo = theme_get_setting('logo')) {
-    $output .= "  <a href=\"$base_path\" title=\"". t('Home') ."\"><img src=\"$logo\" alt=\"". t('Home') ."\" /></a>";
+    $output .= "  <a href=\"". base_path() ."\" title=\"". t('Home') ."\"><img src=\"$logo\" alt=\"". t('Home') ."\" /></a>";
   }
   if (theme_get_setting('toggle_name')) {
     $output .= "  <h1 class=\"site-name title\">". l(variable_get('site_name', 'drupal'), ""). "</h1>";
diff --git a/themes/engines/phptemplate/phptemplate.engine b/themes/engines/phptemplate/phptemplate.engine
index 6aa99f7f2aa0..d28423acfe91 100644
--- a/themes/engines/phptemplate/phptemplate.engine
+++ b/themes/engines/phptemplate/phptemplate.engine
@@ -140,9 +140,8 @@ function phptemplate_features() {
  * into a pluggable template engine.
  */
 function phptemplate_page($content) {
-  global $base_path;
-  /* Set title and breadcrumb to declared values */
 
+  /* Set title and breadcrumb to declared values */
   if ($_GET['q'] == variable_get('site_frontpage', 'node')) {
     $mission = theme_get_setting('mission');
     $frontpage = true;
@@ -186,7 +185,7 @@ function phptemplate_page($content) {
   }
 
   $variables = array(
-    'base_path'           => $base_path,
+    'base_path'           => base_path(),
     'breadcrumb'          => theme('breadcrumb', drupal_get_breadcrumb()),
     'closure'             => theme('closure'),
     'content'             => '<!-- begin content -->' . $content . '<!-- end content -->',
-- 
GitLab