X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fplugin.php;h=e4727f85fec41ed5b2225cacf2611e4f133a2321;hb=0168fcf3d52cb4a9be7ef07ddbb57a60d14c7ffc;hp=696cab5c74ba12cd3b8edbca1bdb6c44eb7b7513;hpb=c27d5a49ce6c2e949f4a554ffeaa9acdfee9e513;p=squirrelmail.git diff --git a/functions/plugin.php b/functions/plugin.php index 696cab5c..e4727f85 100644 --- a/functions/plugin.php +++ b/functions/plugin.php @@ -19,28 +19,35 @@ // This function adds a plugin function use_plugin ($name) { - include ('../plugins/'.$name.'/setup.php'); - $function = 'squirrelmail_plugin_init_'.$name; - $function(); + if (file_exists('../plugins/'.$name.'/setup.php')) { + include ('../plugins/'.$name.'/setup.php'); + $function = 'squirrelmail_plugin_init_'.$name; + if (function_exists($function)) + $function(); + } } // This function executes a hook function do_hook ($name) { global $squirrelmail_plugin_hooks; + $Data = func_get_args(); if (is_array($squirrelmail_plugin_hooks[$name])) { - reset($squirrelmail_plugin_hooks[$name]); - - while (list ($id, $function) = - each ($squirrelmail_plugin_hooks[$name])) { + foreach ($squirrelmail_plugin_hooks[$name] as $id => $function) { // Add something to set correct gettext domain for plugin - $function(); + if (function_exists($function)) { + $function(&$Data); + } } } - } + + // Variable-length argument lists have a slight problem when + // passing values by reference. Pity. This is a workaround. + return $Data; + } // On startup, register all plugins configured for use if (is_array($plugins)) - while (list ($id, $name) = each ($plugins)) + foreach ($plugins as $id => $name) use_plugin($name); ?>