updated docs
[squirrelmail.git] / functions / plugin.php
index 1683fad906d17fce42f0072a0acab742f94e40f4..a6371dfa62e1c744e720e055451b2051090fe31e 100644 (file)
  **/
 
 
-   $plugin_php = true;
+   if (defined('plugin_php'))
+      return;
+   define('plugin_php', true);
+
+   global $plugin_general_debug, $squirrelmail_plugin_hooks;
+   $plugin_general_debug = false;
+   
+   $squirrelmail_plugin_hooks = array();
 
    // This function adds a plugin
    function use_plugin ($name) {
+      global $plugin_general_debug;
+      
       if (file_exists('../plugins/'.$name.'/setup.php')) {
+         if ($plugin_general_debug)
+           echo "plugin:  --  Loading $name/setup.php<br>\n";
          include ('../plugins/'.$name.'/setup.php');
          $function = 'squirrelmail_plugin_init_'.$name;
          if (function_exists($function))
-            $function();
+        {
+           if ($plugin_general_debug)
+              echo "plugin:  ---- Executing $function to init plugin<br>\n";
+            $function($plugin_general_debug);
+        }
+        elseif ($plugin_general_debug)
+           echo "plugin:  -- Init function $function doesn't exist.<br>\n";
       }
+      elseif ($plugin_general_debug)
+         echo "plugin:  Couldn't find $name/setup.php<br>\n";
    }
 
    // This function executes a hook
    // On startup, register all plugins configured for use
    if (isset($plugins) && is_array($plugins))
       foreach ($plugins as $id => $name)
+      {
+         if ($plugin_general_debug)
+           echo "plugin:  Attempting load of plugin $name<br>\n";
          use_plugin($name);
+      }
+
+   if ($plugin_general_debug)
+   {
+      echo "plugin:  Hook list<br>\n";
+      foreach ($squirrelmail_plugin_hooks as $Hook => $Plugins)
+      {
+          foreach ($Plugins as $Name => $Func)
+         {
+             echo "[$Hook][$Name] = $Func<br>\n";
+         }
+      }
+   }
 
 ?>