module.inc 2.25 KB
Newer Older
Dries's avatar
   
Dries committed
1
<?php
Dries's avatar
   
Dries committed
2

Dries's avatar
   
Dries committed
3
function module_iterate($function, $argument = "") {
Dries's avatar
   
Dries committed
4
5
  global $repository;
  foreach ($repository as $name=>$module) {
Dries's avatar
   
Dries committed
6
    $function($name, $module, $argument);
Dries's avatar
   
Dries committed
7
8
9
10
11
12
13
14
15
16
17
  }
}

function module_execute($module, $hook, $argument = "") {
  global $repository;
  return ($repository[$module][$hook]) ? $repository[$module][$hook]($argument) : "";
}

function module_rehash_crons($name, $module) {
  if ($module["cron"]) {
    if (!db_fetch_object(db_query("SELECT * FROM crons WHERE module = '$name'"))) {
Dries's avatar
   
Dries committed
18
      db_query("INSERT INTO crons (module, scheduled, timestamp) VALUES ('$name', '172800', '0')");
Dries's avatar
   
Dries committed
19
    }
Dries's avatar
   
Dries committed
20
21
22
23
24
25
26
  }
  else {
    db_query("DELETE FROM crons WHERE module = '$name'");
  }
}

function module_rehash_blocks($name, $module) {
27
  db_query("UPDATE blocks SET remove = '1' WHERE module = '$name'");
Dries's avatar
   
Dries committed
28
29
  if ($module["block"] && $blocks = $module["block"]()) {
    foreach ($blocks as $offset=>$block) {
Dries's avatar
   
Dries committed
30
31
      if (!db_fetch_object(db_query("SELECT * FROM blocks WHERE module = '$name' AND name = '$block[info]'"))) {
        db_query("INSERT INTO blocks (name, module, offset) VALUES ('$block[info]', '$name', '$offset')");
32
33
      }
      else {
Dries's avatar
   
Dries committed
34
        db_query("UPDATE blocks SET offset = '$offset', remove = '0' WHERE module = '$name' AND name = '$block[info]'");
35
      }
Dries's avatar
   
Dries committed
36
37
    }
  }
38
  db_query("DELETE FROM blocks WHERE module = '$name' AND remove = '1'");
Dries's avatar
   
Dries committed
39
40
41
42
}

function module_rehash($name) {
  global $repository;
Dries's avatar
   
Dries committed
43

Dries's avatar
   
Dries committed
44
45
46
47
  if ($module = $repository[$name]) {
    $result = db_query("SELECT * FROM modules WHERE name = '$name'");

    if (!$object = db_fetch_object($result)) {
Dries's avatar
   
Dries committed
48
      db_query("INSERT INTO modules (name) VALUES ('$name')");
Dries's avatar
   
Dries committed
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
    }

    // rehash crons (if necessary):
    module_rehash_crons($name, $module);

    // rehash blocks (if necessary):
    module_rehash_blocks($name, $module);
  }
  else {
    // remove all reference to module:
    db_query("DELETE FROM modules WHERE name = '$name'");
    db_query("DELETE FROM blocks WHERE module = '$name'");
    db_query("DELETE FROM crons WHERE module = '$name'");
  }
}

// load modules into repository:
$handle = opendir("modules");
while ($file = readdir($handle)) {
  if ($filename = substr($file, 0, strpos($file, ".module"))) {
    include "modules/$filename.module";
    $repository[$filename] = $module;
  }
}
closedir($handle);

?>