split up event listener loading, so parts can be called individually

This commit is contained in:
Shish 2012-10-16 22:31:50 +01:00
parent 44bcf6f322
commit 073b21aaa1

View File

@ -1207,16 +1207,11 @@ function _get_themelet_files($_theme) {
return array_merge($base_themelets, $ext_themelets, $custom_themelets); return array_merge($base_themelets, $ext_themelets, $custom_themelets);
} }
function _load_extensions() { function _set_event_listeners($classes) {
global $_event_listeners; global $_event_listeners;
$_event_listeners = array();
ctx_log_start("Loading extensions"); foreach($classes as $class) {
if(COMPILE_ELS && file_exists("data/cache/event_listeners.php")) {
require_once("data/cache/event_listeners.php");
}
else {
foreach(get_declared_classes() as $class) {
$rclass = new ReflectionClass($class); $rclass = new ReflectionClass($class);
if($rclass->isAbstract()) { if($rclass->isAbstract()) {
// don't do anything // don't do anything
@ -1233,8 +1228,9 @@ function _load_extensions() {
add_event_listener($c, $c->get_priority(), $my_events); add_event_listener($c, $c->get_priority(), $my_events);
} }
} }
}
if(COMPILE_ELS) { function _dump_event_listeners($event_listeners, $path) {
$p = "<"."?php\n"; $p = "<"."?php\n";
foreach(get_declared_classes() as $class) { foreach(get_declared_classes() as $class) {
@ -1247,7 +1243,7 @@ function _load_extensions() {
} }
$p .= "\$_event_listeners = array(\n"; $p .= "\$_event_listeners = array(\n";
foreach($_event_listeners as $event => $listeners) { foreach($event_listeners as $event => $listeners) {
$p .= "\t'$event' => array(\n"; $p .= "\t'$event' => array(\n";
foreach($listeners as $id => $listener) { foreach($listeners as $id => $listener) {
$p .= "\t\t$id => \$".get_class($listener).",\n"; $p .= "\t\t$id => \$".get_class($listener).",\n";
@ -1257,7 +1253,22 @@ function _load_extensions() {
$p .= ");\n"; $p .= ");\n";
$p .= "?".">"; $p .= "?".">";
file_put_contents(data_path("cache/event_listeners.php"), $p); file_put_contents($path, $p);
}
function _load_extensions() {
global $_event_listeners;
ctx_log_start("Loading extensions");
if(COMPILE_ELS && file_exists("data/cache/event_listeners.php")) {
require_once("data/cache/event_listeners.php");
}
else {
_set_event_listeners(get_declared_classes());
if(COMPILE_ELS) {
_dump_event_listeners($_event_listeners, data_path("cache/event_listeners.php"));
} }
} }