false, 'hilight' => true, 'case_exact' => false, 'regex' => 'auto', 'sortby' => '-hi_content', 'noheader' => false, 'exclude' => false, // comma-seperated list of glob 'quiet' => true)); // be less verbose } function run($dbi, $argstr, &$request, $basepage) { $args = $this->getArgs($argstr, $request); if (empty($args['s'])) { return HTML(); } extract($args); $query = new TextSearchQuery($s, $case_exact, $regex); $pages = $dbi->fullSearch($query, $sortby, $limit, $exclude); $lines = array(); $hilight_re = $hilight ? $query->getHighlightRegexp() : false; $count = 0; if ($quiet) { // see how easy it is with PageList... unset($args['info']); $args['listtype'] = 'dl'; $args['types'] = array(new _PageList_Column_content ('rev:hi_content', _("Content"), "left", $s, $hilight_re)); $list = new PageList(false, $exclude, $args); $list->setCaption(fmt("Full text search results for '%s'", $s)); while ($page = $pages->next()) { $list->addPage( $page ); } return $list; } // Todo: we should better define a new PageListDL class for dl/dt/dd lists // But the new column types must have a callback then. (showhits) // See e.g. WikiAdminSearchReplace for custom pagelist columns $list = HTML::dl(); if (!$limit or !is_int($limit)) $limit = 0; // expand all page wildcards to a list of pages which should be ignored if ($exclude) $exclude = explodePageList($exclude); while ($page = $pages->next() and (!$limit or ($count < $limit))) { $name = $page->getName(); if ($exclude and in_array($name,$exclude)) continue; $count++; $list->pushContent(HTML::dt(WikiLink($page))); if ($hilight_re) $list->pushContent($this->showhits($page, $hilight_re)); unset($page); } if ($limit and $count >= $limit) //todo: pager link to list of next matches $list->pushContent(HTML::dd(fmt("only %d pages displayed",$limit))); if (!$list->getContent()) $list->pushContent(HTML::dd(_(""))); if (!empty($pages->stoplisted)) $list = HTML(HTML::p(fmt(_("Ignored stoplist words '%s'"), join(', ', $pages->stoplisted))), $list); if ($noheader) return $list; return HTML(HTML::p(fmt("Full text search results for '%s'", $s)), $list); } function showhits($page, $hilight_re) { $current = $page->getCurrentRevision(); $matches = preg_grep("/$hilight_re/i", $current->getContent()); $html = array(); foreach ($matches as $line) { $line = $this->highlight_line($line, $hilight_re); $html[] = HTML::dd(HTML::small(array('class' => 'search-context'), $line)); } return $html; } function highlight_line ($line, $hilight_re) { while (preg_match("/^(.*?)($hilight_re)/i", $line, $m)) { $line = substr($line, strlen($m[0])); $html[] = $m[1]; // prematch $html[] = HTML::strong(array('class' => 'search-term'), $m[2]); // match } $html[] = $line; // postmatch return $html; } }; /* * List of Links and link to ListLinks */ class _PageList_Column_hilight extends _PageList_Column { function _PageList_Column_WantedPages_links (&$params) { $this->parentobj =& $params[3]; $this->_PageList_Column($params[0],$params[1],$params[2]); } function _getValue(&$page, $revision_handle) { $html = false; $pagename = $page->getName(); $count = count($this->parentobj->_wpagelist[$pagename]); return LinkURL(WikiURL($page, array('action' => 'BackLinks'), false), fmt("(%d Links)", $count)); } } // Local Variables: // mode: php // tab-width: 8 // c-basic-offset: 4 // c-hanging-comment-ender-p: nil // indent-tabs-mode: nil // End: ?>