summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/odict/dingwidget.cpp59
-rw-r--r--noncore/apps/odict/odict.cpp4
2 files changed, 14 insertions, 49 deletions
diff --git a/noncore/apps/odict/dingwidget.cpp b/noncore/apps/odict/dingwidget.cpp
index cfef84d..16164ed 100644
--- a/noncore/apps/odict/dingwidget.cpp
+++ b/noncore/apps/odict/dingwidget.cpp
@@ -1,179 +1,148 @@
1/*************************************************************************** 1/***************************************************************************
2 application: : ODict 2 application: : ODict
3 3
4 begin : December 2002 4 begin : December 2002
5 copyright : ( C ) 2002, 2003 by Carsten Niehaus 5 copyright : ( C ) 2002, 2003 by Carsten Niehaus
6 email : cniehaus@handhelds.org 6 email : cniehaus@handhelds.org
7 **************************************************************************/ 7 **************************************************************************/
8 8
9/*************************************************************************** 9/***************************************************************************
10 * * 10 * *
11 * This program is free software; you can redistribute it and/or modify * 11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by * 12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or * 13 * the Free Software Foundation; either version 2 of the License, or *
14 * ( at your option ) any later version. * 14 * ( at your option ) any later version. *
15 * * 15 * *
16 **************************************************************************/ 16 **************************************************************************/
17#include "dingwidget.h" 17#include "dingwidget.h"
18 18
19#include <qfile.h> 19#include <qfile.h>
20#include <qpe/config.h> 20#include <qpe/config.h>
21#include <qhbox.h> 21#include <qhbox.h>
22#include <qlabel.h> 22#include <qlabel.h>
23#include <qpushbutton.h> 23#include <qpushbutton.h>
24#include <qlineedit.h> 24#include <qlineedit.h>
25#include <qmainwindow.h> 25#include <qmainwindow.h>
26#include <qstring.h> 26#include <qstring.h>
27#include <qtextstream.h> 27#include <qtextstream.h>
28#include <qstringlist.h> 28#include <qstringlist.h>
29#include <qregexp.h> 29#include <qregexp.h>
30#include <qtextbrowser.h> 30#include <qtextbrowser.h>
31#include <stdlib.h> // for getenv 31#include <stdlib.h> // for getenv
32 32
33
34DingWidget::DingWidget( ) 33DingWidget::DingWidget( )
35{ 34{
36 methodname = QString::null; 35 methodname = QString::null;
37 trenner = QString::null; 36 trenner = QString::null;
38 lines = 0L; 37 lines = 0L;
39} 38}
40 39
41void DingWidget::loadDict( QString name ) 40void DingWidget::loadDict( QString name )
42{ 41{
43 qDebug( "MUSS ich wirklich aufgerufen werder? schreit loadDict" ); 42 qDebug( "MUSS ich wirklich aufgerufen werder? schreit loadDict" );
44 qDebug( "Starte mit dem loadedDict(...)" ); 43 qDebug( "Starte mit dem loadedDict(...)" );
45 dictName = name; 44 dictName = name;
46 qDebug( "bin in loadedDict() und lade das Dict:" ); 45 qDebug( "bin in loadedDict() und lade das Dict:" );
47 qDebug( dictName ); 46 qDebug( dictName );
48 QString opie_dir = getenv("OPIEDIR"); 47 QString opie_dir = getenv("OPIEDIR");
49 QFile file( opie_dir+"/noncore/apps/odict/eng_ita.dic" ); 48 QFile file( opie_dir+"/noncore/apps/odict/eng_ita.dic" );
50 //FIXME:this should of course be not hardcoded ;) 49 //FIXME:this should of course be not hardcoded ;)
51 50
52 if( file.open( IO_ReadOnly ) ) 51 if( file.open( IO_ReadOnly ) )
53 { 52 {
54 QTextStream stream( &file ); 53 QTextStream stream( &file );
55 while ( !stream.eof() ) 54 while ( !stream.eof() )
56 { 55 {
57 lines.append( stream.readLine() ); 56 lines.append( stream.readLine() );
58 } 57 }
59 file.close(); 58 file.close();
60 } 59 }
61 qDebug( "loadedDict(...) ist beended" ); 60 qDebug( "loadedDict(...) ist beended" );
62 loadValues(); 61 loadValues();
63} 62}
64 63
65QString DingWidget::loadedDict() 64QString DingWidget::loadedDict()
66{ 65{
67 qDebug( dictName ); 66 qDebug( dictName );
68 qDebug( "^ ^ ^ ^ ^ ^ ^ war der dictName" ); 67 qDebug( "^ ^ ^ ^ ^ ^ ^ war der dictName" );
69 return dictName; 68 return dictName;
70} 69}
71 70
72void DingWidget::setCaseSensitive( bool caseS ) 71void DingWidget::setCaseSensitive( bool caseS )
73{ 72{
74 isCaseSensitive = caseS; 73 isCaseSensitive = caseS;
75} 74}
76 75
77void DingWidget::setDict( QString dict ) 76void DingWidget::setDict( QString dict )
78{ 77{
79 methodname = dict; 78 methodname = dict;
80} 79}
81 80
82void DingWidget::setCompleteWord( bool cword ) 81void DingWidget::setCompleteWord( bool cword )
83{ 82{
84 isCompleteWord = cword; 83 isCompleteWord = cword;
85} 84}
86 85
87void DingWidget::setQueryWord( QString qword ) 86void DingWidget::setQueryWord( QString qword )
88{ 87{
89 queryword = qword; 88 queryword = qword;
90} 89}
91 90
91
92void DingWidget::loadValues()
93{
94 Config cfg( "odict" );
95 cfg.setGroup( "Method_" + methodname );
96 trenner = cfg.readEntry( "Seperator" );
97}
98
92BroswerContent DingWidget::setText( QString word ) 99BroswerContent DingWidget::setText( QString word )
93{ 100{
94 queryword = word; 101 queryword = word;
95 qDebug( queryword ); 102 qDebug( queryword );
96 qDebug( "^ ^ ^ ^ ^ ^ ^ war das gesuchte Word"); 103 qDebug( "^ ^ ^ ^ ^ ^ ^ war das gesuchte Word");
97 return parseInfo(); 104 return parseInfo();
98} 105}
99 106
100void DingWidget::loadValues()
101{
102 Config cfg( "odict" );
103 cfg.setGroup( "Method_" + methodname );
104 trenner = cfg.readEntry( "Seperator" );
105}
106 107
107BroswerContent DingWidget::parseInfo() 108BroswerContent DingWidget::parseInfo()
108{ 109{
109 if ( isCompleteWord ) queryword = " " + queryword + " "; 110 if ( isCompleteWord )
111 queryword = " " + queryword + " ";
110 QStringList search = lines.grep( queryword , isCaseSensitive ); 112 QStringList search = lines.grep( queryword , isCaseSensitive );
111 113
112 QString current; 114 QString current;
113 QString left; 115 QString left;
114 QString right; 116 QString right;
115 QRegExp reg_div( trenner ); 117 QRegExp reg_div( trenner );
116 QRegExp reg_word( queryword ); 118 QRegExp reg_word( queryword );
117 reg_word.setCaseSensitive( isCaseSensitive ); 119 reg_word.setCaseSensitive( isCaseSensitive );
118 QStringList toplist, bottomlist; 120 QStringList toplist, bottomlist;
119 QString substitute = "<strong>"+queryword+"</strong>"; 121 QString substitute = "<strong>"+queryword+"</strong>";
120 122
121 /* Dieser Block ist von Patrik. Ich versuche einen neuen
122 * Ansatz. Zum einen ist HTML scheiße an dieser Stelle und
123 * zum andern funktioniert der Code nicht so wie er sollte.
124 QString substitute = "<a href=''>"+queryword+"</a>";
125
126 QString html_header = "<html><table>";
127 QString html_footer = "</table></html>";
128 QString html_table_left = "<tr><td width='50'>";
129 QString html_table_sep = "</td><td>";
130 QString html_table_right = "</td></tr>";
131
132 for( QStringList::Iterator it = search.begin() ; it != search.end() ; ++it )
133 {
134 current = *it;
135 left = current.left( current.find(reg_div) );
136 right = current.right( current.length() - current.find(reg_div) - 1 );
137 if ( left.contains( reg_word ) )
138 {
139 left.replace( queryword, substitute );
140 toplist.append( html_table_left + left + html_table_sep + right + html_table_right );
141 }
142 else
143 {
144 right.replace( reg_word, substitute );
145 bottomlist.append( html_table_left + right + html_table_sep + left + html_table_right );
146 }
147 }
148
149 //thats it, the lists are rendered. Lets put them in one string
150 s_strings.bottom = html_header + bottomlist.join( "<br>" ) + html_footer;
151 s_strings.top = html_header + toplist.join( "<br>" ) + html_footer;
152 */
153
154 for( QStringList::Iterator it = search.begin() ; it != search.end() ; ++it ) 123 for( QStringList::Iterator it = search.begin() ; it != search.end() ; ++it )
155 { 124 {
156 current = *it; 125 current = *it;
157 left = current.left( current.find( trenner ) ); 126 left = current.left( current.find( trenner ) );
158 127
159 right = current.right( current.length() - current.find(trenner) -2 ); 128 right = current.right( current.length() - current.find(trenner) - trenner.length() );
160 129
161 if ( left.contains( queryword , isCaseSensitive ) ) 130 if ( left.contains( queryword , isCaseSensitive ) )
162 { 131 {
163 left.replace( queryword, substitute ); 132 left.replace( queryword, substitute );
164 left = left + "-->" + right; 133 left = left + " -- " + right;
165 toplist.append( left ); 134 toplist.append( left );
166 } 135 }
167 else 136 else
168 { 137 {
169 right.replace( queryword, substitute ); 138 right.replace( queryword, substitute );
170 left = right + "-->" + left; 139 left = right + " -- " + left;
171 bottomlist.append( right ); 140 bottomlist.append( right );
172 } 141 }
173 } 142 }
174 143
175 s_strings.bottom = bottomlist.join( "\n" );
176 s_strings.top = toplist.join( "\n" ); 144 s_strings.top = toplist.join( "\n" );
145 s_strings.bottom = bottomlist.join( "\n" );
177 146
178 return s_strings; 147 return s_strings;
179} 148}
diff --git a/noncore/apps/odict/odict.cpp b/noncore/apps/odict/odict.cpp
index c4114f7..58cff5f 100644
--- a/noncore/apps/odict/odict.cpp
+++ b/noncore/apps/odict/odict.cpp
@@ -140,71 +140,67 @@ void ODict::slotSettings()
140 } 140 }
141 else qDebug( "abgebrochen" ); 141 else qDebug( "abgebrochen" );
142} 142}
143 143
144void ODict::slotSetParameter( int count ) 144void ODict::slotSetParameter( int count )
145{ 145{
146 if ( count == 0 ) 146 if ( count == 0 )
147 { 147 {
148 if ( casesens ) 148 if ( casesens )
149 casesens = false; 149 casesens = false;
150 else 150 else
151 casesens = true; 151 casesens = true;
152 } 152 }
153 153
154 if ( count == 1 ) 154 if ( count == 1 )
155 { 155 {
156 if ( completewords ) 156 if ( completewords )
157 completewords = false; 157 completewords = false;
158 else 158 else
159 completewords = true; 159 completewords = true;
160 } 160 }
161 if ( count == 2 ) 161 if ( count == 2 )
162 { 162 {
163 if ( regexp ) 163 if ( regexp )
164 regexp = false; 164 regexp = false;
165 else 165 else
166 regexp = true; 166 regexp = true;
167 } 167 }
168 else qWarning( "ERROR" ); 168 else qWarning( "ERROR" );
169} 169}
170 170
171void ODict::slotMethodChanged( int /*methodnumber*/ ) 171void ODict::slotMethodChanged( int /*methodnumber*/ )
172{ 172{
173 activated_name = query_co->currentText(); 173 activated_name = query_co->currentText();
174} 174}
175 175
176void ODict::setupMenus() 176void ODict::setupMenus()
177{ 177{
178 menu = new QMenuBar( this ); 178 menu = new QMenuBar( this );
179 179
180 settings = new QPopupMenu( menu ); 180 settings = new QPopupMenu( menu );
181 setting_a = new QAction(tr( "Config" ), Resource::loadPixmap( "today/config" ), QString::null, 0, this, 0 ); 181 setting_a = new QAction(tr( "Config" ), Resource::loadPixmap( "today/config" ), QString::null, 0, this, 0 );
182 connect( setting_a, SIGNAL( activated() ), this, SLOT( slotSettings() ) ); 182 connect( setting_a, SIGNAL( activated() ), this, SLOT( slotSettings() ) );
183 setting_a->addTo( settings ); 183 setting_a->addTo( settings );
184 setting_b = new QAction(tr( "Searchmethods" ), Resource::loadPixmap( "today/config" ), QString::null, 0, this, 0 ); 184 setting_b = new QAction(tr( "Searchmethods" ), Resource::loadPixmap( "today/config" ), QString::null, 0, this, 0 );
185 185
186 parameter = new QPopupMenu( menu ); 186 parameter = new QPopupMenu( menu );
187 connect( parameter, SIGNAL( activated( int ) ), this, SLOT( slotSetParameter( int ) ) ); 187 connect( parameter, SIGNAL( activated( int ) ), this, SLOT( slotSetParameter( int ) ) );
188 parameter->insertItem( tr( "C&ase sensitive" ), 0 ,0 ); 188 parameter->insertItem( tr( "C&ase sensitive" ), 0 ,0 );
189 parameter->insertItem( tr( "Only &complete Words" ), 1 , 1) ; 189 parameter->insertItem( tr( "Only &complete Words" ), 1 , 1) ;
190 parameter->insertItem( tr( "Allow &reg. expressions" ), 2 ); 190 parameter->insertItem( tr( "Allow &reg. expressions" ), 2 );
191 parameter->insertSeparator(); 191 parameter->insertSeparator();
192 error_tol_menu = new QPopupMenu( menu ); 192 error_tol_menu = new QPopupMenu( menu );
193 error_tol_menu->setCheckable( TRUE ); 193 error_tol_menu->setCheckable( TRUE );
194 connect( error_tol_menu, SIGNAL( activated( int ) ), this, SLOT( slotSetErrorcount( int ) ) ); 194 connect( error_tol_menu, SIGNAL( activated( int ) ), this, SLOT( slotSetErrorcount( int ) ) );
195 195
196 error_tol_menu->insertItem( tr( "0 Errors" ), 0 ); 196 error_tol_menu->insertItem( tr( "0 Errors" ), 0 );
197 error_tol_menu->insertItem( tr( "1 Errors" ), 1 ); 197 error_tol_menu->insertItem( tr( "1 Errors" ), 1 );
198 error_tol_menu->insertItem( tr( "2 Errors" ), 2 ); 198 error_tol_menu->insertItem( tr( "2 Errors" ), 2 );
199 error_tol_menu->insertItem( tr( "3 Errors" ), 3 ); 199 error_tol_menu->insertItem( tr( "3 Errors" ), 3 );
200 error_tol_menu->insertItem( tr( "4 Errors" ), 4 ); 200 error_tol_menu->insertItem( tr( "4 Errors" ), 4 );
201 error_tol_menu->insertItem( tr( "Until Hit" ), 5 ); 201 error_tol_menu->insertItem( tr( "Until Hit" ), 5 );
202 parameter->insertItem( tr( "&Error tolerance" ), error_tol_menu ); 202 parameter->insertItem( tr( "&Error tolerance" ), error_tol_menu );
203 203
204 help = new QPopupMenu( menu );
205 help->insertItem("&About",this,SLOT( slotDisplayAbout() ));
206
207 menu->insertItem( tr( "Settings" ) , settings ); 204 menu->insertItem( tr( "Settings" ) , settings );
208 menu->insertItem( tr( "Parameter" ) , parameter ); 205 menu->insertItem( tr( "Parameter" ) , parameter );
209 menu->insertItem( tr( "Help" ) , help );
210} 206}