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