summaryrefslogtreecommitdiff
path: root/modules/search/helpers/search_task.php
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2009-05-20 06:10:14 +0000
committerBharat Mediratta <bharat@menalto.com>2009-05-20 06:10:14 +0000
commit774e0b3737d51b70bb141f4e13c6c111208847c0 (patch)
tree8f367c99a16c1d4d3419838aec420a29a320bc3b /modules/search/helpers/search_task.php
parent54fe2c600e6930c2885f3f6048221710637a142f (diff)
Avoid complex inserts in available_tasks() to make admin/maintenance
run faster. This fixes ticket #235. Incidentally, refactor exif and search to use the same patterns overall so that if you understand one, you understand the other and they generally use the same strings for localization.
Diffstat (limited to 'modules/search/helpers/search_task.php')
-rw-r--r--modules/search/helpers/search_task.php56
1 files changed, 24 insertions, 32 deletions
diff --git a/modules/search/helpers/search_task.php b/modules/search/helpers/search_task.php
index e3884d53..876661e4 100644
--- a/modules/search/helpers/search_task.php
+++ b/modules/search/helpers/search_task.php
@@ -25,21 +25,16 @@ class search_task_Core {
"WHERE {search_records}.`item_id` NOT IN " .
"(SELECT `id` FROM {items})");
- // Insert missing search_records
- Database::instance()->query(
- "INSERT INTO {search_records}(`item_id`) (" .
- " SELECT {items}.`id` FROM {items} " .
- " LEFT JOIN {search_records} ON ({search_records}.`item_id` = {items}.`id`) " .
- " WHERE {search_records}.`id` IS NULL)");
-
- list ($remaining, $total, $percent) = self::_get_stats();
+ list ($remaining, $total, $percent) = search::stats();
return array(Task_Definition::factory()
->callback("search_task::update_index")
->name(t("Update Search Index"))
- ->description($remaining ?
- t("Search index is %percent% up-to-date",
- array("percent" => $percent))
- : t("Search index is up to date"))
+ ->description(
+ $remaining
+ ? t2("1 photo or album needs to be scanned",
+ "%count (%percent%) of your photos and albums need to be scanned",
+ $remaining, array("percent" => (100 - $percent)))
+ : t("Search data is up-to-date"))
->severity($remaining ? log::WARNING : log::SUCCESS));
}
@@ -47,34 +42,31 @@ class search_task_Core {
$completed = $task->get("completed", 0);
$start = microtime(true);
- while (!$task->done && microtime(true) - $start < 1) {
- foreach (ORM::factory("search_record")->where("dirty", 1)->limit(5)->find_all() as $record) {
- search::update_record($record);
- $completed++;
+ foreach (ORM::factory("item")
+ ->join("search_records", "items.id", "search_records.item_id", "left")
+ ->where("search_records.item_id", null)
+ ->orwhere("search_records.dirty", 1)
+ ->find_all() as $item) {
+ if (microtime(true) - $start > 1.5) {
+ break;
}
- list ($remaining, $total, $percent) = self::_get_stats();
- if ($remaining + $completed) {
- $task->percent_complete = round(100 * $completed / ($remaining + $completed));
- $task->status = t("%done records updated, index is %percent% up-to-date",
- array("done" => $completed, "percent" => $percent));
- } else {
- $task->percent_complete = 100;
- }
+ search::update($item);
+ $completed++;
}
+ list ($remaining, $total, $percent) = search::stats();
$task->set("completed", $completed);
- if ($remaining == 0) {
+ if ($remaining == 0 || !($remaining + $completed)) {
$task->done = true;
$task->state = "success";
site_status::clear("search_index_out_of_date");
+ $task->percent_complete = 100;
+ } else {
+ $task->percent_complete = round(100 * $completed / ($remaining + $completed));
}
- }
-
- private static function _get_stats() {
- $remaining = ORM::factory("search_record")->where("dirty", 1)->count_all();
- $total = ORM::factory("search_record")->count_all();
- $percent = round(100 * ($total - $remaining) / $total);
- return array($remaining, $total, $percent);
+ $task->status = t2("one record updated, index is %percent% up-to-date",
+ "%count records updated, index is %percent% up-to-date",
+ $completed, array("percent" => $percent));
}
}