summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/odict/dingwidget.cpp19
1 files changed, 13 insertions, 6 deletions
diff --git a/noncore/apps/odict/dingwidget.cpp b/noncore/apps/odict/dingwidget.cpp
index 5939000..d5c2d65 100644
--- a/noncore/apps/odict/dingwidget.cpp
+++ b/noncore/apps/odict/dingwidget.cpp
@@ -19,48 +19,55 @@
#include <qfile.h>
#include <qpe/config.h>
#include <qhbox.h>
#include <qlabel.h>
#include <qpushbutton.h>
#include <qlineedit.h>
#include <qmainwindow.h>
#include <qstring.h>
#include <qtextstream.h>
#include <qstringlist.h>
#include <qregexp.h>
#include <qtextbrowser.h>
#include <stdlib.h> // for getenv
DingWidget::DingWidget(QWidget *parent, QString word, QTextBrowser *browser_top, QTextBrowser *browser_bottom) : QWidget(parent)
{
QString opie_dir = getenv("OPIEDIR");
QFile file( opie_dir+"/noncore/apps/odict/eng_ita.dic" );
QStringList lines;
if( file.open( IO_ReadOnly ) )
{
QTextStream stream( &file );
while ( !stream.eof() )
{
lines.append( stream.readLine() );
}
file.close();
}
lines = lines.grep( word );
-//X for( QStringList::Iterator it = lines.begin() ; it != lines.end() ; ++it )
-//X {
-//X qDebug( *it );
-//X }
QString top, bottom;
parseInfo( lines, top , bottom );
browser_top->setText( top );
browser_bottom->setText( bottom );
}
void DingWidget::parseInfo( QStringList &lines, QString &top, QString &bottom )
{
- top = "blah";
- bottom = lines.join( "\n" );
+ QRegExp reg( "\\" );
+ QStringList toplist, bottomlist;
+ for( QStringList::Iterator it = lines.begin() ; it != lines.end() ; ++it )
+ {
+ QString current = *it;
+ toplist.append( current.left( current.find(reg) ) );
+ bottomlist.append( current.right( current.find(reg) ) );
+ }
+
+
+ //thats it, the lists are rendered. Lets put them in one string
+ bottom = bottomlist.join( "\n" );
+ top = toplist.join( "\n" );
}