split up event listener loading, so parts can be called individually
This commit is contained in:
parent
44bcf6f322
commit
073b21aaa1
@ -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"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user