improve handling of result list truncature

This commit is contained in:
Jean-Francois Dockes 2012-10-05 08:45:21 +02:00
parent 770e3844fa
commit 36ebb49b92

View File

@ -105,6 +105,8 @@ void SpellW::init()
resTW->installEventFilter(this); resTW->installEventFilter(this);
} }
static const int maxexpand = 10000;
/* Expand term according to current mode */ /* Expand term according to current mode */
void SpellW::doExpand() void SpellW::doExpand()
{ {
@ -140,12 +142,14 @@ void SpellW::doExpand()
{ {
string l_stemlang = (const char*)stemLangCMB->currentText().toAscii(); string l_stemlang = (const char*)stemLangCMB->currentText().toAscii();
if (!rcldb->termMatch(mt, l_stemlang, expr, res, 200)) { if (!rcldb->termMatch(mt, l_stemlang, expr, res, maxexpand)) {
LOGERR(("SpellW::doExpand:rcldb::termMatch failed\n")); LOGERR(("SpellW::doExpand:rcldb::termMatch failed\n"));
return; return;
} }
statsLBL->setText(tr("Index: %1 documents, average length %2 terms") statsLBL->setText(tr("Index: %1 documents, average length %2 terms."
.arg(res.dbdoccount).arg(res.dbavgdoclen, 0, 'f', 1)); "%3 results")
.arg(res.dbdoccount).arg(res.dbavgdoclen, 0, 'f', 1)
.arg(res.entries.size()));
} }
break; break;
@ -176,6 +180,7 @@ void SpellW::doExpand()
res.entries.push_back(Rcl::TermMatchEntry(rclsugg)); res.entries.push_back(Rcl::TermMatchEntry(rclsugg));
} }
#endif // TESTING_XAPIAN_SPELL #endif // TESTING_XAPIAN_SPELL
statsLBL->setText(tr("%1 results").arg(res.entries.size()));
} }
#endif #endif
} }
@ -185,6 +190,23 @@ void SpellW::doExpand()
resTW->setItem(0, 0, new QTableWidgetItem(tr("No expansion found"))); resTW->setItem(0, 0, new QTableWidgetItem(tr("No expansion found")));
} else { } else {
int row = 0; int row = 0;
if (maxexpand > 0 && int(res.entries.size()) >= maxexpand) {
resTW->setRowCount(row + 1);
resTW->setSpan(row, 0, 1, 2);
resTW->setItem(row++, 0,
new QTableWidgetItem(
tr("List was truncated alphabetically, "
"some frequent ")));
resTW->setRowCount(row + 1);
resTW->setSpan(row, 0, 1, 2);
resTW->setItem(row++, 0, new QTableWidgetItem(
tr("terms may be missing. "
"Try using a longer root.")));
resTW->setRowCount(row + 1);
resTW->setItem(row++, 0, new QTableWidgetItem(""));
}
for (vector<Rcl::TermMatchEntry>::iterator it = res.entries.begin(); for (vector<Rcl::TermMatchEntry>::iterator it = res.entries.begin();
it != res.entries.end(); it++) { it != res.entries.end(); it++) {
LOGDEB(("SpellW::expand: %6d [%s]\n", it->wcf, it->term.c_str())); LOGDEB(("SpellW::expand: %6d [%s]\n", it->wcf, it->term.c_str()));
@ -193,14 +215,12 @@ void SpellW::doExpand()
sprintf(num, "%d / %d", it->docs, it->wcf); sprintf(num, "%d / %d", it->docs, it->wcf);
else else
num[0] = 0; num[0] = 0;
if (resTW->rowCount() <= row) resTW->setRowCount(row+1);
resTW->setRowCount(row+1);
resTW->setItem(row, 0, resTW->setItem(row, 0,
new QTableWidgetItem(QString::fromUtf8(it->term.c_str()))); new QTableWidgetItem(QString::fromUtf8(it->term.c_str())));
resTW->setItem(row++, 1, resTW->setItem(row++, 1,
new QTableWidgetItem(QString::fromAscii(num))); new QTableWidgetItem(QString::fromAscii(num)));
} }
resTW->setRowCount(row+1);
} }
} }