X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Fplugin.php;h=a6371dfa62e1c744e720e055451b2051090fe31e;hp=35dc67763d6fadb4d69229fd9904738aa7ba3168;hb=dae1f3e5f7dc0454a26535f7c3181c882ac146a3;hpb=245a6892bf5c780904ef9677f24d624ea17e0749
diff --git a/functions/plugin.php b/functions/plugin.php
index 35dc6776..a6371dfa 100644
--- a/functions/plugin.php
+++ b/functions/plugin.php
@@ -16,16 +16,35 @@
**/
- $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
\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
\n";
+ $function($plugin_general_debug);
+ }
+ elseif ($plugin_general_debug)
+ echo "plugin: -- Init function $function doesn't exist.
\n";
}
+ elseif ($plugin_general_debug)
+ echo "plugin: Couldn't find $name/setup.php
\n";
}
// This function executes a hook
@@ -37,7 +56,7 @@
foreach ($squirrelmail_plugin_hooks[$name] as $id => $function) {
// Add something to set correct gettext domain for plugin
if (function_exists($function)) {
- $function(&$Data);
+ $function($Data);
}
}
}
@@ -50,6 +69,22 @@
// 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
\n";
use_plugin($name);
+ }
+
+ if ($plugin_general_debug)
+ {
+ echo "plugin: Hook list
\n";
+ foreach ($squirrelmail_plugin_hooks as $Hook => $Plugins)
+ {
+ foreach ($Plugins as $Name => $Func)
+ {
+ echo "[$Hook][$Name] = $Func
\n";
+ }
+ }
+ }
?>