Skip to content
Snippets Groups Projects
Commit 7fb56887 authored by chris's avatar chris
Browse files

support for plugin subfolders added - plugins/[name]/[type]/[file].php

darcs-hash:20050802191421-50fdc-abf82fcb52dfabd74b7119f2e6a53ea590bb1d90.gz
parent 4b8edb9d
No related branches found
No related tags found
No related merge requests found
...@@ -13,19 +13,19 @@ function plugin_printCSSJS(){ ...@@ -13,19 +13,19 @@ function plugin_printCSSJS(){
$plugins = plugin_list(); $plugins = plugin_list();
foreach ($plugins as $p){ foreach ($plugins as $p){
$dir = "lib/plugins/$p/"; $dir = "lib/plugins/$p/";
if(@file_exists(DOKU_INC.$dir.'style.css')){ if(@file_exists(DOKU_INC.$dir.'style.css')){
print ' <link rel="stylesheet" type="text/css" href="'.DOKU_BASE.$dir.'style.css" />'."\n"; print ' <link rel="stylesheet" type="text/css" href="'.DOKU_BASE.$dir.'style.css" />'."\n";
} }
if(@file_exists(DOKU_INC.$dir.'screen.css')){ if(@file_exists(DOKU_INC.$dir.'screen.css')){
print ' <link rel="stylesheet" media="screen" type="text/css" href="'.DOKU_BASE.$dir.'screen.css" />'."\n"; print ' <link rel="stylesheet" media="screen" type="text/css" href="'.DOKU_BASE.$dir.'screen.css" />'."\n";
} }
if(@file_exists(DOKU_INC.$dir.'print.css')){ if(@file_exists(DOKU_INC.$dir.'print.css')){
print ' <link rel="stylesheet" media="print" type="text/css" href="'.DOKU_BASE.$dir.'print.css" />'."\n"; print ' <link rel="stylesheet" media="print" type="text/css" href="'.DOKU_BASE.$dir.'print.css" />'."\n";
} }
if(@file_exists(DOKU_INC.$dir.'script.js')){ if(@file_exists(DOKU_INC.$dir.'script.js')){
print ' <script type="text/javascript" language="javascript" charset="utf-8" src="'.DOKU_BASE.$dir.'script.js"></script>'."\n"; print ' <script type="text/javascript" language="javascript" charset="utf-8" src="'.DOKU_BASE.$dir.'script.js"></script>'."\n";
} }
} }
} }
/** /**
...@@ -38,12 +38,22 @@ function plugin_printCSSJS(){ ...@@ -38,12 +38,22 @@ function plugin_printCSSJS(){
function plugin_list($type=''){ function plugin_list($type=''){
$plugins = array(); $plugins = array();
if ($dh = opendir(DOKU_PLUGIN)) { if ($dh = opendir(DOKU_PLUGIN)) {
while (false !== ($file = readdir($dh))) { while (false !== ($plugin = readdir($dh))) {
if ($file == '.' || $file == '..') continue; if ($plugin == '.' || $plugin == '..') continue;
if (is_file(DOKU_PLUGIN.$file)) continue; if (is_file(DOKU_PLUGIN.$plugin)) continue;
if ($type=='' || @file_exists(DOKU_PLUGIN.$file.'/'.$type.'.php')){ if ($type=='' || @file_exists(DOKU_PLUGIN."$plugin/$type.php")){
$plugins[] = $file; $plugins[] = $plugin;
} else {
if ($dp = @opendir(DOKU_PLUGIN."$plugin/$type/")) {
while (false !== ($component = readdir($dp))) {
if ($component == '.' || $component == '..' || strtolower(substr($component, -4)) != ".php") continue;
if (is_file(DOKU_PLUGIN."$plugin/$type/$component")) {
$plugins[] = $plugin.'_'.substr($component, 0, -4);
}
}
}
closedir($dp);
} }
} }
closedir($dh); closedir($dh);
...@@ -56,28 +66,33 @@ function plugin_list($type=''){ ...@@ -56,28 +66,33 @@ function plugin_list($type=''){
* *
* @author Andreas Gohr <andi@splitbrain.org> * @author Andreas Gohr <andi@splitbrain.org>
* *
* @param $type string type of plugin to load * @param $type string type of plugin to load
* @param $name string name of the plugin to load * @param $name string name of the plugin to load
* @return object the plugin object or null on failure * @return object the plugin object or null on failure
*/ */
function &plugin_load($type,$name){ function &plugin_load($type,$name){
//we keep all loaded plugins available in global scope for reuse //we keep all loaded plugins available in global scope for reuse
global $DOKU_PLUGINS; global $DOKU_PLUGINS;
//plugin already loaded? //plugin already loaded?
if($DOKU_PLUGINS[$type][$name] != null){ if($DOKU_PLUGINS[$type][$name] != null){
return $DOKU_PLUGINS[$type][$name]; return $DOKU_PLUGINS[$type][$name];
} }
//try to load the wanted plugin file //try to load the wanted plugin file
if(!include_once(DOKU_PLUGIN.$name.'/'.$type.'.php')){ if(!@include_once(DOKU_PLUGIN."$name/$type.php")){
return null; list($plugin, $component) = preg_split("/_/",$name, 2);
if (!$component || !@include_once(DOKU_PLUGIN."$plugin/$type/$component.php")) {
return null;
}
} }
global $plugin_investigate_pluginorder;
if (!isset($plugin_investigate_pluginorder)) $plugin_investigate_pluginorder = array();
$plugin_investigate_pluginorder[] = $name;
//construct class and instanciate //construct class and instanciate
$class = $type.'_plugin_'.$name; $class = $type.'_plugin_'.$name;
$DOKU_PLUGINS[$type][$name] = new $class; $DOKU_PLUGINS[$type][$name] = new $class;
return $DOKU_PLUGINS[$type][$name]; return $DOKU_PLUGINS[$type][$name];
} }
...@@ -62,6 +62,8 @@ class DokuWiki_Syntax_Plugin extends Doku_Parser_Mode { ...@@ -62,6 +62,8 @@ class DokuWiki_Syntax_Plugin extends Doku_Parser_Mode {
* *
* 'normal' - The plugin can be used inside paragraphs * 'normal' - The plugin can be used inside paragraphs
* 'block' - Open paragraphs need to be closed before plugin output * 'block' - Open paragraphs need to be closed before plugin output
* 'stack' - Special case. Plugin wraps other paragraphs. * 'stack' - Special case. Plugin wraps other paragraphs.
* *
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment