summaryrefslogtreecommitdiff
authortille <tille>2003-01-03 21:54:28 (UTC)
committer tille <tille>2003-01-03 21:54:28 (UTC)
commitbd02568a9a02f27b40c62ae8f56f4ce76bcb62da (patch) (side-by-side diff)
tree6385ee2ee68331f4fd06dc2ae030552a1e4f59d1
parent7fcee1764fb08804a68574c68427da567966402e (diff)
downloadopie-bd02568a9a02f27b40c62ae8f56f4ce76bcb62da.zip
opie-bd02568a9a02f27b40c62ae8f56f4ce76bcb62da.tar.gz
opie-bd02568a9a02f27b40c62ae8f56f4ce76bcb62da.tar.bz2
markup does not yet work
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--noncore/apps/odict/dingwidget.cpp30
-rw-r--r--noncore/apps/odict/dingwidget.h1
2 files changed, 20 insertions, 11 deletions
diff --git a/noncore/apps/odict/dingwidget.cpp b/noncore/apps/odict/dingwidget.cpp
index 26c0066..de02dcc 100644
--- a/noncore/apps/odict/dingwidget.cpp
+++ b/noncore/apps/odict/dingwidget.cpp
@@ -38,42 +38,50 @@ DingWidget::DingWidget(QWidget *parent, QString word, QTextBrowser *browser_top,
QStringList lines;
if( file.open( IO_ReadOnly ) )
{
QTextStream stream( &file );
while ( !stream.eof() )
{
lines.append( stream.readLine() );
}
file.close();
}
- lines = lines.grep( word );
+ lines = lines.grep( queryword );
QString top, bottom;
parseInfo( lines, top , bottom );
browser_top->setText( top );
browser_bottom->setText( bottom );
}
void DingWidget::parseInfo( QStringList &lines, QString &top, QString &bottom )
{
+
+ QString current;
+ QString left;
+ QString right;
QRegExp reg_div( "\\" );
QRegExp reg_word( queryword );
- QString substitute = "<b>"+queryword+"</b>";
+ QString substitute = "<font color='#FF0000'>"+queryword+"</font>";
QStringList toplist, bottomlist;
for( QStringList::Iterator it = lines.begin() ; it != lines.end() ; ++it )
{
- QString current = *it;
- 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 );
+ current = *it;
+ left = current.left( current.find(reg_div) );
+ right = current.right( current.length() - current.find(reg_div) - 1 );
+ if ( left.contains( reg_word ) ){
+ left.replace( queryword, substitute );
+ toplist.append( left + " -> " + right);
+ }else{
+ right.replace( reg_word, substitute );
+ bottomlist.append( right + " -> " + left );
+ }
+ // .replace( reg_word, substitute );
}
//thats it, the lists are rendered. Lets put them in one string
- bottom = bottomlist.join( "\n" );
- top = toplist.join( "\n" );
+ bottom = bottomlist.join( "<br>\n" );
+ top = toplist.join( "<br>\n" );
}
diff --git a/noncore/apps/odict/dingwidget.h b/noncore/apps/odict/dingwidget.h
index 644162f..cba1edf 100644
--- a/noncore/apps/odict/dingwidget.h
+++ b/noncore/apps/odict/dingwidget.h
@@ -13,15 +13,16 @@ class QString;
class QTextBrowser;
class QString;
class QStringList;
class DingWidget : public QWidget
{
Q_OBJECT
public:
DingWidget(QWidget *parent = 0, QString word = 0, QTextBrowser* = 0, QTextBrowser* =0);
private:
+ QString search_word;
void parseInfo( QStringList& , QString&, QString& );
QString queryword;
};