-rw-r--r-- | noncore/apps/odict/dingwidget.cpp | 14 | ||||
-rw-r--r-- | noncore/apps/odict/dingwidget.h | 1 |
2 files changed, 11 insertions, 4 deletions
diff --git a/noncore/apps/odict/dingwidget.cpp b/noncore/apps/odict/dingwidget.cpp index d923b80..26c0066 100644 --- a/noncore/apps/odict/dingwidget.cpp +++ b/noncore/apps/odict/dingwidget.cpp @@ -34,2 +34,3 @@ DingWidget::DingWidget(QWidget *parent, QString word, QTextBrowser *browser_top, { + queryword = word; QString opie_dir = getenv("OPIEDIR"); @@ -59,3 +60,5 @@ void DingWidget::parseInfo( QStringList &lines, QString &top, QString &bottom ) { - QRegExp reg( "\\" ); + QRegExp reg_div( "\\" ); + QRegExp reg_word( queryword ); + QString substitute = "<b>"+queryword+"</b>"; QStringList toplist, bottomlist; @@ -64,7 +67,10 @@ void DingWidget::parseInfo( QStringList &lines, QString &top, QString &bottom ) QString current = *it; - toplist.append( current.left( current.find(reg) ) ); - bottomlist.append( current.right( current.length() - current.find(reg) - 1 ) ); + QString temp = current.left( current.find(reg_div) ); + temp.replace( reg_word, substitute ); + toplist.append( temp ); + temp = current.right( current.length() - current.find(reg_div) - 1 ); + temp.replace( reg_word, substitute ); + bottomlist.append( temp ); } - //thats it, the lists are rendered. Lets put them in one string diff --git a/noncore/apps/odict/dingwidget.h b/noncore/apps/odict/dingwidget.h index c82e0f0..644162f 100644 --- a/noncore/apps/odict/dingwidget.h +++ b/noncore/apps/odict/dingwidget.h @@ -25,2 +25,3 @@ class DingWidget : public QWidget void parseInfo( QStringList& , QString&, QString& ); + QString queryword; }; |