diff options
Diffstat (limited to 'modules/search')
| -rw-r--r-- | modules/search/helpers/search.php | 4 | ||||
| -rw-r--r-- | modules/search/helpers/search_task.php | 57 | ||||
| -rw-r--r-- | modules/search/module.info | 4 | ||||
| -rw-r--r-- | modules/search/views/search.html.php | 4 | 
4 files changed, 41 insertions, 28 deletions
| diff --git a/modules/search/helpers/search.php b/modules/search/helpers/search.php index ea8dad81..34eaecbd 100644 --- a/modules/search/helpers/search.php +++ b/modules/search/helpers/search.php @@ -50,6 +50,9 @@ class search_Core {      return array($count, new ORM_Iterator(ORM::factory("item"), $db->query($query)));    } +  /** +   * @return string An error message suitable for inclusion in the task log +   */    static function check_index() {      list ($remaining) = search::stats();      if ($remaining) { @@ -76,6 +79,7 @@ class search_Core {      $record->data = join(" ", $data);      $record->dirty = 0;      $record->save(); +    return t("Search index updated for '%title'", array("title" => p::purify($item->title)));    }    static function stats() { diff --git a/modules/search/helpers/search_task.php b/modules/search/helpers/search_task.php index 876661e4..df1dfe16 100644 --- a/modules/search/helpers/search_task.php +++ b/modules/search/helpers/search_task.php @@ -39,34 +39,43 @@ class search_task_Core {    }    static function update_index($task) { -    $completed = $task->get("completed", 0); +    try { +      $completed = $task->get("completed", 0); -    $start = microtime(true); -    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; -      } +      $start = microtime(true); +      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; +        } -      search::update($item); -      $completed++; -    } +        $message[] = search::update($item); +        $completed++; +      } -    list ($remaining, $total, $percent) = search::stats(); -    $task->set("completed", $completed); -    if ($remaining == 0 || !($remaining + $completed)) { +      list ($remaining, $total, $percent) = search::stats(); +      $task->set("completed", $completed); +      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)); +      } +      $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)); +      $message[] = $task->status; +    } catch (Exception $e) {        $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)); +      $task->state = "error"; +      $task->status = $e->getMessage(); +      $message[] = $e->__toString();      } -    $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)); +    $task->log($message);    }  } diff --git a/modules/search/module.info b/modules/search/module.info index b286ab6c..f417c4fa 100644 --- a/modules/search/module.info +++ b/modules/search/module.info @@ -1,3 +1,3 @@ -name = Search -description = Allows users to search their Gallery +name = "Search" +description = "Allows users to search their Gallery"  version = 1 diff --git a/modules/search/views/search.html.php b/modules/search/views/search.html.php index 5db07bad..6a222ef1 100644 --- a/modules/search/views/search.html.php +++ b/modules/search/views/search.html.php @@ -31,10 +31,10 @@        <a href="<?= url::site("items/$item->id") ?>">          <?= $item->thumb_img() ?>          <p> -          <?= p::clean($item->title) ?> +          <?= p::purify($item->title) ?>          </p>          <div> -          <?= p::clean($item->description) ?> +    <?= nl2br(p::purify($item->description)) ?>          </div>        </a>      </li> | 
