summaryrefslogtreecommitdiff
path: root/noncore
Unidiff
Diffstat (limited to 'noncore') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-write/qrichtext_p.h157
-rw-r--r--noncore/apps/tableviewer/browsekeyentry.cpp53
-rw-r--r--noncore/apps/tableviewer/db/common.cpp165
-rw-r--r--noncore/apps/tableviewer/db/datacache.cpp68
-rw-r--r--noncore/apps/tableviewer/db/datacache.h24
-rw-r--r--noncore/apps/tableviewer/ui/browsekeyentry.cpp49
-rw-r--r--noncore/apps/tableviewer/ui/filterkeyentry.cpp42
-rw-r--r--noncore/apps/tableviewer/ui/tvfilterview.cpp55
-rw-r--r--noncore/apps/tinykate/libkate/kateconfig.cpp4
-rw-r--r--noncore/apps/zsafe/main.cpp25
-rw-r--r--noncore/apps/zsafe/zlistview.cpp11
-rw-r--r--noncore/apps/zsafe/zsafe.cpp51
-rw-r--r--noncore/comm/keypebble/krfbdecoder.cpp108
-rw-r--r--noncore/graphics/opie-eye/gui/iconview.cpp6
-rw-r--r--noncore/graphics/opie-eye/gui/viewmodebutton.cpp5
-rw-r--r--noncore/net/opietooth/lib/device.cc95
-rw-r--r--noncore/net/opietooth/lib/manager.cc65
-rw-r--r--noncore/net/opietooth/lib/parser.cc60
-rw-r--r--noncore/settings/mediummount/mediumglobal.cc11
-rw-r--r--noncore/styles/theme/othemebase.h981
20 files changed, 1037 insertions, 998 deletions
diff --git a/noncore/apps/opie-write/qrichtext_p.h b/noncore/apps/opie-write/qrichtext_p.h
index e368edb..3778feb 100644
--- a/noncore/apps/opie-write/qrichtext_p.h
+++ b/noncore/apps/opie-write/qrichtext_p.h
@@ -29,48 +29,51 @@
29** information about Qt Commercial License Agreements. 29** information about Qt Commercial License Agreements.
30** See http://www.trolltech.com/qpl/ for QPL licensing information. 30** See http://www.trolltech.com/qpl/ for QPL licensing information.
31** See http://www.trolltech.com/gpl/ for GPL licensing information. 31** See http://www.trolltech.com/gpl/ for GPL licensing information.
32** 32**
33** Contact info@trolltech.com if any conditions of this licensing are 33** Contact info@trolltech.com if any conditions of this licensing are
34** not clear to you. 34** not clear to you.
35** 35**
36**********************************************************************/ 36**********************************************************************/
37 37
38#ifndef QRICHTEXT_P_H 38#ifndef QRICHTEXT_P_H
39#define QRICHTEXT_P_H 39#define QRICHTEXT_P_H
40 40
41// 41//
42// W A R N I N G 42// W A R N I N G
43// ------------- 43// -------------
44// 44//
45// This file is not part of the Qt API. It exists for the convenience 45// This file is not part of the Qt API. It exists for the convenience
46// of a number of Qt sources files. This header file may change from 46// of a number of Qt sources files. This header file may change from
47// version to version without notice, or even be removed. 47// version to version without notice, or even be removed.
48// 48//
49// We mean it. 49// We mean it.
50// 50//
51// 51//
52 52
53#include <opie2/odebug.h>
54using namespace Opie::Core;
55
53#ifndef QT_H 56#ifndef QT_H
54#include "qstring.h" 57#include "qstring.h"
55#include "qlist.h" 58#include "qlist.h"
56#include "qrect.h" 59#include "qrect.h"
57#include "qfontmetrics.h" 60#include "qfontmetrics.h"
58#include "qintdict.h" 61#include "qintdict.h"
59#include "qmap.h" 62#include "qmap.h"
60#include "qstringlist.h" 63#include "qstringlist.h"
61#include "qfont.h" 64#include "qfont.h"
62#include "qcolor.h" 65#include "qcolor.h"
63#include "qsize.h" 66#include "qsize.h"
64#include "qvaluelist.h" 67#include "qvaluelist.h"
65#include "qvaluestack.h" 68#include "qvaluestack.h"
66#include "qobject.h" 69#include "qobject.h"
67#include "qdict.h" 70#include "qdict.h"
68#include "qtextstream.h" 71#include "qtextstream.h"
69#include "qpixmap.h" 72#include "qpixmap.h"
70#include "qstylesheet.h" 73#include "qstylesheet.h"
71#include "qvector.h" 74#include "qvector.h"
72#include "qpainter.h" 75#include "qpainter.h"
73#include "qlayout.h" 76#include "qlayout.h"
74#include "qobject.h" 77#include "qobject.h"
75#include "qcomplextext_p.h" 78#include "qcomplextext_p.h"
76#include "qapplication.h" 79#include "qapplication.h"
@@ -103,70 +106,70 @@ public:
103 // this is never called, initialize variables in QTextString::insert()!!! 106 // this is never called, initialize variables in QTextString::insert()!!!
104 QTextStringChar() : lineStart( 0 ), type( Regular ), startOfRun( 0 ) {d.format=0;} 107 QTextStringChar() : lineStart( 0 ), type( Regular ), startOfRun( 0 ) {d.format=0;}
105 ~QTextStringChar(); 108 ~QTextStringChar();
106 109
107 QChar c; 110 QChar c;
108 enum Type { Regular=0, Custom=1, Anchor=2, CustomAnchor=3 }; 111 enum Type { Regular=0, Custom=1, Anchor=2, CustomAnchor=3 };
109 uint lineStart : 1; 112 uint lineStart : 1;
110 uint rightToLeft : 1; 113 uint rightToLeft : 1;
111 uint hasCursor : 1; 114 uint hasCursor : 1;
112 uint canBreak : 1; 115 uint canBreak : 1;
113 Type type : 2; 116 Type type : 2;
114 uint startOfRun : 1; 117 uint startOfRun : 1;
115 118
116 int x; 119 int x;
117 int height() const; 120 int height() const;
118 int ascent() const; 121 int ascent() const;
119 int descent() const; 122 int descent() const;
120 bool isCustom() const { return (type & Custom) != 0; } 123 bool isCustom() const { return (type & Custom) != 0; }
121 QTextFormat *format() const; 124 QTextFormat *format() const;
122 QTextCustomItem *customItem() const; 125 QTextCustomItem *customItem() const;
123 void setFormat( QTextFormat *f ); 126 void setFormat( QTextFormat *f );
124 void setCustomItem( QTextCustomItem *i ); 127 void setCustomItem( QTextCustomItem *i );
125 struct CustomData 128 struct CustomData
126 { 129 {
127 QTextFormat *format; 130 QTextFormat *format;
128 QTextCustomItem *custom; 131 QTextCustomItem *custom;
129 QString anchorName; 132 QString anchorName;
130 QString anchorHref; 133 QString anchorHref;
131 }; 134 };
132 135
133 void loseCustomItem(); 136 void loseCustomItem();
134 137
135 union { 138 union {
136 QTextFormat* format; 139 QTextFormat* format;
137 CustomData* custom; 140 CustomData* custom;
138 } d; 141 } d;
139 142
140 bool isAnchor() const { return ( type & Anchor) != 0; } 143 bool isAnchor() const { return ( type & Anchor) != 0; }
141 QString anchorName() const; 144 QString anchorName() const;
142 QString anchorHref() const; 145 QString anchorHref() const;
143 void setAnchor( const QString& name, const QString& href ); 146 void setAnchor( const QString& name, const QString& href );
144 147
145private: 148private:
146 QTextStringChar &operator=( const QTextStringChar & ) { 149 QTextStringChar &operator=( const QTextStringChar & ) {
147 //abort(); 150 //abort();
148 return *this; 151 return *this;
149 } 152 }
150 friend class QComplexText; 153 friend class QComplexText;
151 friend class QTextParagraph; 154 friend class QTextParagraph;
152}; 155};
153 156
154#if defined(Q_TEMPLATEDLL) 157#if defined(Q_TEMPLATEDLL)
155// MOC_SKIP_BEGIN 158// MOC_SKIP_BEGIN
156Q_TEMPLATE_EXTERN template class Q_EXPORT QMemArray<QTextStringChar>; 159Q_TEMPLATE_EXTERN template class Q_EXPORT QMemArray<QTextStringChar>;
157// MOC_SKIP_END 160// MOC_SKIP_END
158#endif 161#endif
159 162
160class Q_EXPORT QTextString 163class Q_EXPORT QTextString
161{ 164{
162public: 165public:
163 166
164 QTextString(); 167 QTextString();
165 QTextString( const QTextString &s ); 168 QTextString( const QTextString &s );
166 virtual ~QTextString(); 169 virtual ~QTextString();
167 170
168 static QString toString( const QMemArray<QTextStringChar> &data ); 171 static QString toString( const QMemArray<QTextStringChar> &data );
169 QString toString() const; 172 QString toString() const;
170 173
171 QTextStringChar &at( int i ) const; 174 QTextStringChar &at( int i ) const;
172 int length() const; 175 int length() const;
@@ -187,56 +190,56 @@ public:
187 bool isRightToLeft() const; 190 bool isRightToLeft() const;
188 QChar::Direction direction() const; 191 QChar::Direction direction() const;
189 void setDirection( QChar::Direction d ) { dir = d; bidiDirty = TRUE; } 192 void setDirection( QChar::Direction d ) { dir = d; bidiDirty = TRUE; }
190 193
191 QMemArray<QTextStringChar> subString( int start = 0, int len = 0xFFFFFF ) const; 194 QMemArray<QTextStringChar> subString( int start = 0, int len = 0xFFFFFF ) const;
192 QMemArray<QTextStringChar> rawData() const { return data; } 195 QMemArray<QTextStringChar> rawData() const { return data; }
193 196
194 void operator=( const QString &s ) { clear(); insert( 0, s, 0 ); } 197 void operator=( const QString &s ) { clear(); insert( 0, s, 0 ); }
195 void operator+=( const QString &s ) {insert( length(), s, 0 ); } 198 void operator+=( const QString &s ) {insert( length(), s, 0 ); }
196 void prepend( const QString &s ) { insert( 0, s, 0 ); } 199 void prepend( const QString &s ) { insert( 0, s, 0 ); }
197 200
198private: 201private:
199 void checkBidi() const; 202 void checkBidi() const;
200 203
201 QMemArray<QTextStringChar> data; 204 QMemArray<QTextStringChar> data;
202 uint bidiDirty : 1; 205 uint bidiDirty : 1;
203 uint bidi : 1; // true when the paragraph has right to left characters 206 uint bidi : 1; // true when the paragraph has right to left characters
204 uint rightToLeft : 1; 207 uint rightToLeft : 1;
205 uint dir : 5; 208 uint dir : 5;
206}; 209};
207 210
208inline bool QTextString::isBidi() const 211inline bool QTextString::isBidi() const
209{ 212{
210 if ( bidiDirty ) 213 if ( bidiDirty )
211 checkBidi(); 214 checkBidi();
212 return bidi; 215 return bidi;
213} 216}
214 217
215inline bool QTextString::isRightToLeft() const 218inline bool QTextString::isRightToLeft() const
216{ 219{
217 if ( bidiDirty ) 220 if ( bidiDirty )
218 checkBidi(); 221 checkBidi();
219 return rightToLeft; 222 return rightToLeft;
220} 223}
221 224
222inline QChar::Direction QTextString::direction() const 225inline QChar::Direction QTextString::direction() const
223{ 226{
224 return (QChar::Direction) dir; 227 return (QChar::Direction) dir;
225} 228}
226 229
227// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 230// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
228 231
229#if defined(Q_TEMPLATEDLL) 232#if defined(Q_TEMPLATEDLL)
230// MOC_SKIP_BEGIN 233// MOC_SKIP_BEGIN
231Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<int>; 234Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<int>;
232Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<QTextParagraph*>; 235Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<QTextParagraph*>;
233Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<bool>; 236Q_TEMPLATE_EXTERN template class Q_EXPORT QValueStack<bool>;
234// MOC_SKIP_END 237// MOC_SKIP_END
235#endif 238#endif
236 239
237class Q_EXPORT QTextCursor 240class Q_EXPORT QTextCursor
238{ 241{
239public: 242public:
240 QTextCursor( QTextDocument *d = 0 ); 243 QTextCursor( QTextDocument *d = 0 );
241 QTextCursor( const QTextCursor &c ); 244 QTextCursor( const QTextCursor &c );
242 QTextCursor &operator=( const QTextCursor &c ); 245 QTextCursor &operator=( const QTextCursor &c );
@@ -363,49 +366,49 @@ public:
363 366
364 void setUndoDepth( int d ) { steps = d; } 367 void setUndoDepth( int d ) { steps = d; }
365 int undoDepth() const { return steps; } 368 int undoDepth() const { return steps; }
366 369
367 int historySize() const { return history.count(); } 370 int historySize() const { return history.count(); }
368 int currentPosition() const { return current; } 371 int currentPosition() const { return current; }
369 372
370private: 373private:
371 QPtrList<QTextCommand> history; 374 QPtrList<QTextCommand> history;
372 int current, steps; 375 int current, steps;
373 376
374}; 377};
375 378
376inline QTextCommandHistory::~QTextCommandHistory() 379inline QTextCommandHistory::~QTextCommandHistory()
377{ 380{
378 clear(); 381 clear();
379} 382}
380 383
381// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 384// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
382 385
383class Q_EXPORT QTextCustomItem 386class Q_EXPORT QTextCustomItem
384{ 387{
385public: 388public:
386 QTextCustomItem( QTextDocument *p ) 389 QTextCustomItem( QTextDocument *p )
387 : xpos(0), ypos(-1), width(-1), height(0), parent( p ) 390 : xpos(0), ypos(-1), width(-1), height(0), parent( p )
388 {} 391 {}
389 virtual ~QTextCustomItem(); 392 virtual ~QTextCustomItem();
390 virtual void draw(QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ) = 0; 393 virtual void draw(QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ) = 0;
391 394
392 virtual void adjustToPainter( QPainter* ); 395 virtual void adjustToPainter( QPainter* );
393 396
394 enum Placement { PlaceInline = 0, PlaceLeft, PlaceRight }; 397 enum Placement { PlaceInline = 0, PlaceLeft, PlaceRight };
395 virtual Placement placement() const; 398 virtual Placement placement() const;
396 bool placeInline() { return placement() == PlaceInline; } 399 bool placeInline() { return placement() == PlaceInline; }
397 400
398 virtual bool ownLine() const; 401 virtual bool ownLine() const;
399 virtual void resize( int nwidth ); 402 virtual void resize( int nwidth );
400 virtual void invalidate(); 403 virtual void invalidate();
401 virtual int ascent() const { return height; } 404 virtual int ascent() const { return height; }
402 405
403 virtual bool isNested() const; 406 virtual bool isNested() const;
404 virtual int minimumWidth() const; 407 virtual int minimumWidth() const;
405 408
406 virtual QString richText() const; 409 virtual QString richText() const;
407 410
408 int xpos; // used for floating items 411 int xpos; // used for floating items
409 int ypos; // used for floating items 412 int ypos; // used for floating items
410 int width; 413 int width;
411 int height; 414 int height;
@@ -417,74 +420,74 @@ public:
417 virtual bool next( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 420 virtual bool next( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
418 virtual bool prev( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 421 virtual bool prev( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
419 virtual bool down( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 422 virtual bool down( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
420 virtual bool up( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 423 virtual bool up( QTextCursor *, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
421 424
422 void setParagraph( QTextParagraph *p ) { parag = p; } 425 void setParagraph( QTextParagraph *p ) { parag = p; }
423 QTextParagraph *paragraph() const { return parag; } 426 QTextParagraph *paragraph() const { return parag; }
424 427
425 QTextDocument *parent; 428 QTextDocument *parent;
426 QTextParagraph *parag; 429 QTextParagraph *parag;
427 430
428 virtual void pageBreak( int y, QTextFlow* flow ); 431 virtual void pageBreak( int y, QTextFlow* flow );
429}; 432};
430 433
431#if defined(Q_TEMPLATEDLL) 434#if defined(Q_TEMPLATEDLL)
432// MOC_SKIP_BEGIN 435// MOC_SKIP_BEGIN
433Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<QString, QString>; 436Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<QString, QString>;
434// MOC_SKIP_END 437// MOC_SKIP_END
435#endif 438#endif
436 439
437class Q_EXPORT QTextImage : public QTextCustomItem 440class Q_EXPORT QTextImage : public QTextCustomItem
438{ 441{
439public: 442public:
440 QTextImage( QTextDocument *p, const QMap<QString, QString> &attr, const QString& context, 443 QTextImage( QTextDocument *p, const QMap<QString, QString> &attr, const QString& context,
441 QMimeSourceFactory &factory ); 444 QMimeSourceFactory &factory );
442 virtual ~QTextImage(); 445 virtual ~QTextImage();
443 446
444 Placement placement() const { return place; } 447 Placement placement() const { return place; }
445 void adjustToPainter( QPainter* ); 448 void adjustToPainter( QPainter* );
446 int minimumWidth() const { return width; } 449 int minimumWidth() const { return width; }
447 450
448 QString richText() const; 451 QString richText() const;
449 452
450 void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); 453 void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected );
451 454
452private: 455private:
453 QRegion* reg; 456 QRegion* reg;
454 QPixmap pm; 457 QPixmap pm;
455 Placement place; 458 Placement place;
456 int tmpwidth, tmpheight; 459 int tmpwidth, tmpheight;
457 QMap<QString, QString> attributes; 460 QMap<QString, QString> attributes;
458 QString imgId; 461 QString imgId;
459 462
460}; 463};
461 464
462class Q_EXPORT QTextHorizontalLine : public QTextCustomItem 465class Q_EXPORT QTextHorizontalLine : public QTextCustomItem
463{ 466{
464public: 467public:
465 QTextHorizontalLine( QTextDocument *p, const QMap<QString, QString> &attr, const QString& context, 468 QTextHorizontalLine( QTextDocument *p, const QMap<QString, QString> &attr, const QString& context,
466 QMimeSourceFactory &factory ); 469 QMimeSourceFactory &factory );
467 virtual ~QTextHorizontalLine(); 470 virtual ~QTextHorizontalLine();
468 471
469 void adjustToPainter( QPainter* ); 472 void adjustToPainter( QPainter* );
470 void draw(QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); 473 void draw(QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected );
471 QString richText() const; 474 QString richText() const;
472 475
473 bool ownLine() const { return TRUE; } 476 bool ownLine() const { return TRUE; }
474 477
475private: 478private:
476 int tmpheight; 479 int tmpheight;
477 QColor color; 480 QColor color;
478 481
479}; 482};
480 483
481#if defined(Q_TEMPLATEDLL) 484#if defined(Q_TEMPLATEDLL)
482// MOC_SKIP_BEGIN 485// MOC_SKIP_BEGIN
483Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextCustomItem>; 486Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextCustomItem>;
484// MOC_SKIP_END 487// MOC_SKIP_END
485#endif 488#endif
486 489
487class Q_EXPORT QTextFlow 490class Q_EXPORT QTextFlow
488{ 491{
489 friend class QTextDocument; 492 friend class QTextDocument;
490 friend class QTextTableCell; 493 friend class QTextTableCell;
@@ -511,53 +514,53 @@ public:
511 514
512 virtual bool isEmpty(); 515 virtual bool isEmpty();
513 516
514 void clear(); 517 void clear();
515 518
516private: 519private:
517 int w; 520 int w;
518 int pagesize; 521 int pagesize;
519 522
520 QPtrList<QTextCustomItem> leftItems; 523 QPtrList<QTextCustomItem> leftItems;
521 QPtrList<QTextCustomItem> rightItems; 524 QPtrList<QTextCustomItem> rightItems;
522 525
523}; 526};
524 527
525inline int QTextFlow::width() const { return w; } 528inline int QTextFlow::width() const { return w; }
526 529
527class QTextTable; 530class QTextTable;
528 531
529class Q_EXPORT QTextTableCell : public QLayoutItem 532class Q_EXPORT QTextTableCell : public QLayoutItem
530{ 533{
531 friend class QTextTable; 534 friend class QTextTable;
532 535
533public: 536public:
534 QTextTableCell( QTextTable* table, 537 QTextTableCell( QTextTable* table,
535 int row, int column, 538 int row, int column,
536 const QMap<QString, QString> &attr, 539 const QMap<QString, QString> &attr,
537 const QStyleSheetItem* style, 540 const QStyleSheetItem* style,
538 const QTextFormat& fmt, const QString& context, 541 const QTextFormat& fmt, const QString& context,
539 QMimeSourceFactory &factory, QStyleSheet *sheet, const QString& doc ); 542 QMimeSourceFactory &factory, QStyleSheet *sheet, const QString& doc );
540 virtual ~QTextTableCell(); 543 virtual ~QTextTableCell();
541 544
542 QSize sizeHint() const ; 545 QSize sizeHint() const ;
543 QSize minimumSize() const ; 546 QSize minimumSize() const ;
544 QSize maximumSize() const ; 547 QSize maximumSize() const ;
545 QSizePolicy::ExpandData expanding() const; 548 QSizePolicy::ExpandData expanding() const;
546 bool isEmpty() const; 549 bool isEmpty() const;
547 void setGeometry( const QRect& ) ; 550 void setGeometry( const QRect& ) ;
548 QRect geometry() const; 551 QRect geometry() const;
549 552
550 bool hasHeightForWidth() const; 553 bool hasHeightForWidth() const;
551 int heightForWidth( int ) const; 554 int heightForWidth( int ) const;
552 555
553 void adjustToPainter( QPainter* ); 556 void adjustToPainter( QPainter* );
554 557
555 int row() const { return row_; } 558 int row() const { return row_; }
556 int column() const { return col_; } 559 int column() const { return col_; }
557 int rowspan() const { return rowspan_; } 560 int rowspan() const { return rowspan_; }
558 int colspan() const { return colspan_; } 561 int colspan() const { return colspan_; }
559 int stretch() const { return stretch_; } 562 int stretch() const { return stretch_; }
560 563
561 QTextDocument* richText() const { return richtext; } 564 QTextDocument* richText() const { return richtext; }
562 QTextTable* table() const { return parent; } 565 QTextTable* table() const { return parent; }
563 566
@@ -585,49 +588,49 @@ private:
585 int cached_width; 588 int cached_width;
586 int cached_sizehint; 589 int cached_sizehint;
587 QMap<QString, QString> attributes; 590 QMap<QString, QString> attributes;
588 int align; 591 int align;
589}; 592};
590 593
591#if defined(Q_TEMPLATEDLL) 594#if defined(Q_TEMPLATEDLL)
592// MOC_SKIP_BEGIN 595// MOC_SKIP_BEGIN
593Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextTableCell>; 596Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextTableCell>;
594Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<QTextCursor*, int>; 597Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<QTextCursor*, int>;
595// MOC_SKIP_END 598// MOC_SKIP_END
596#endif 599#endif
597 600
598class Q_EXPORT QTextTable: public QTextCustomItem 601class Q_EXPORT QTextTable: public QTextCustomItem
599{ 602{
600 friend class QTextTableCell; 603 friend class QTextTableCell;
601 604
602public: 605public:
603 QTextTable( QTextDocument *p, const QMap<QString, QString> &attr ); 606 QTextTable( QTextDocument *p, const QMap<QString, QString> &attr );
604 virtual ~QTextTable(); 607 virtual ~QTextTable();
605 608
606 void adjustToPainter( QPainter *p ); 609 void adjustToPainter( QPainter *p );
607 void pageBreak( int y, QTextFlow* flow ); 610 void pageBreak( int y, QTextFlow* flow );
608 void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch, 611 void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch,
609 const QColorGroup& cg, bool selected ); 612 const QColorGroup& cg, bool selected );
610 613
611 bool noErase() const { return TRUE; } 614 bool noErase() const { return TRUE; }
612 bool ownLine() const { return TRUE; } 615 bool ownLine() const { return TRUE; }
613 Placement placement() const { return place; } 616 Placement placement() const { return place; }
614 bool isNested() const { return TRUE; } 617 bool isNested() const { return TRUE; }
615 void resize( int nwidth ); 618 void resize( int nwidth );
616 virtual void invalidate(); 619 virtual void invalidate();
617 620
618 virtual bool enter( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy, bool atEnd = FALSE ); 621 virtual bool enter( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy, bool atEnd = FALSE );
619 virtual bool enterAt( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy, const QPoint &pos ); 622 virtual bool enterAt( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy, const QPoint &pos );
620 virtual bool next( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 623 virtual bool next( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
621 virtual bool prev( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 624 virtual bool prev( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
622 virtual bool down( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 625 virtual bool down( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
623 virtual bool up( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy ); 626 virtual bool up( QTextCursor *c, QTextDocument *&doc, QTextParagraph *&parag, int &idx, int &ox, int &oy );
624 627
625 QString richText() const; 628 QString richText() const;
626 629
627 int minimumWidth() const; 630 int minimumWidth() const;
628 631
629 QPtrList<QTextTableCell> tableCells() const { return cells; } 632 QPtrList<QTextTableCell> tableCells() const { return cells; }
630 633
631 bool isStretching() const { return stretch; } 634 bool isStretching() const { return stretch; }
632 635
633private: 636private:
@@ -663,51 +666,51 @@ struct Q_EXPORT QTextDocumentSelection
663 QTextCursor startCursor, endCursor; 666 QTextCursor startCursor, endCursor;
664 bool swapped; 667 bool swapped;
665}; 668};
666 669
667#if defined(Q_TEMPLATEDLL) 670#if defined(Q_TEMPLATEDLL)
668// MOC_SKIP_BEGIN 671// MOC_SKIP_BEGIN
669Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QColor>; 672Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QColor>;
670Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, bool>; 673Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, bool>;
671Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextDocumentSelection>; 674Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextDocumentSelection>;
672Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextDocument>; 675Q_TEMPLATE_EXTERN template class Q_EXPORT QPtrList<QTextDocument>;
673// MOC_SKIP_END 676// MOC_SKIP_END
674#endif 677#endif
675 678
676class Q_EXPORT QTextDocument : public QObject 679class Q_EXPORT QTextDocument : public QObject
677{ 680{
678 Q_OBJECT 681 Q_OBJECT
679 682
680 friend class QTextTableCell; 683 friend class QTextTableCell;
681 friend class QTextCursor; 684 friend class QTextCursor;
682 friend class QTextEdit; 685 friend class QTextEdit;
683 friend class QTextParagraph; 686 friend class QTextParagraph;
684 687
685public: 688public:
686 enum SelectionIds { 689 enum SelectionIds {
687 Standard = 0, 690 Standard = 0,
688 Temp = 32000 // This selection must not be drawn, it's used e.g. by undo/redo to 691 Temp = 32000 // This selection must not be drawn, it's used e.g. by undo/redo to
689 // remove multiple lines with removeSelectedText() 692 // remove multiple lines with removeSelectedText()
690 }; 693 };
691 694
692 QTextDocument( QTextDocument *p ); 695 QTextDocument( QTextDocument *p );
693 QTextDocument( QTextDocument *d, QTextFormatCollection *f ); 696 QTextDocument( QTextDocument *d, QTextFormatCollection *f );
694 virtual ~QTextDocument(); 697 virtual ~QTextDocument();
695 698
696 QTextDocument *parent() const { return par; } 699 QTextDocument *parent() const { return par; }
697 QTextParagraph *parentParagraph() const { return parentPar; } 700 QTextParagraph *parentParagraph() const { return parentPar; }
698 701
699 void setText( const QString &text, const QString &context ); 702 void setText( const QString &text, const QString &context );
700 QMap<QString, QString> attributes() const { return attribs; } 703 QMap<QString, QString> attributes() const { return attribs; }
701 void setAttributes( const QMap<QString, QString> &attr ) { attribs = attr; } 704 void setAttributes( const QMap<QString, QString> &attr ) { attribs = attr; }
702 705
703 QString text() const; 706 QString text() const;
704 QString text( int parag ) const; 707 QString text( int parag ) const;
705 QString originalText() const; 708 QString originalText() const;
706 709
707 int x() const; 710 int x() const;
708 int y() const; 711 int y() const;
709 int width() const; 712 int width() const;
710 int widthUsed() const; 713 int widthUsed() const;
711 int visibleWidth() const; 714 int visibleWidth() const;
712 int height() const; 715 int height() const;
713 void setWidth( int w ); 716 void setWidth( int w );
@@ -770,53 +773,53 @@ public:
770 773
771 void setTextFormat( Qt::TextFormat f ); 774 void setTextFormat( Qt::TextFormat f );
772 Qt::TextFormat textFormat() const; 775 Qt::TextFormat textFormat() const;
773 776
774 bool inSelection( int selId, const QPoint &pos ) const; 777 bool inSelection( int selId, const QPoint &pos ) const;
775 778
776 QStyleSheet *styleSheet() const { return sheet_; } 779 QStyleSheet *styleSheet() const { return sheet_; }
777 QMimeSourceFactory *mimeSourceFactory() const { return factory_; } 780 QMimeSourceFactory *mimeSourceFactory() const { return factory_; }
778 QString context() const { return contxt; } 781 QString context() const { return contxt; }
779 782
780 void setStyleSheet( QStyleSheet *s ); 783 void setStyleSheet( QStyleSheet *s );
781 void setDefaultFormat( const QFont &font, const QColor &color ); 784 void setDefaultFormat( const QFont &font, const QColor &color );
782 void setMimeSourceFactory( QMimeSourceFactory *f ) { if ( f ) factory_ = f; } 785 void setMimeSourceFactory( QMimeSourceFactory *f ) { if ( f ) factory_ = f; }
783 void setContext( const QString &c ) { if ( !c.isEmpty() ) contxt = c; } 786 void setContext( const QString &c ) { if ( !c.isEmpty() ) contxt = c; }
784 787
785 void setUnderlineLinks( bool b ); 788 void setUnderlineLinks( bool b );
786 bool underlineLinks() const { return underlLinks; } 789 bool underlineLinks() const { return underlLinks; }
787 790
788 void setPaper( QBrush *brush ) { if ( backBrush ) delete backBrush; backBrush = brush; } 791 void setPaper( QBrush *brush ) { if ( backBrush ) delete backBrush; backBrush = brush; }
789 QBrush *paper() const { return backBrush; } 792 QBrush *paper() const { return backBrush; }
790 793
791 void doLayout( QPainter *p, int w ); 794 void doLayout( QPainter *p, int w );
792 void draw( QPainter *p, const QRect& rect, const QColorGroup &cg, const QBrush *paper = 0 ); 795 void draw( QPainter *p, const QRect& rect, const QColorGroup &cg, const QBrush *paper = 0 );
793 void drawParagraph( QPainter *p, QTextParagraph *parag, int cx, int cy, int cw, int ch, 796 void drawParagraph( QPainter *p, QTextParagraph *parag, int cx, int cy, int cw, int ch,
794 QPixmap *&doubleBuffer, const QColorGroup &cg, 797 QPixmap *&doubleBuffer, const QColorGroup &cg,
795 bool drawCursor, QTextCursor *cursor, bool resetChanged = TRUE ); 798 bool drawCursor, QTextCursor *cursor, bool resetChanged = TRUE );
796 QTextParagraph *draw( QPainter *p, int cx, int cy, int cw, int ch, const QColorGroup &cg, 799 QTextParagraph *draw( QPainter *p, int cx, int cy, int cw, int ch, const QColorGroup &cg,
797 bool onlyChanged = FALSE, bool drawCursor = FALSE, QTextCursor *cursor = 0, 800 bool onlyChanged = FALSE, bool drawCursor = FALSE, QTextCursor *cursor = 0,
798 bool resetChanged = TRUE ); 801 bool resetChanged = TRUE );
799 802
800 void registerCustomItem( QTextCustomItem *i, QTextParagraph *p ); 803 void registerCustomItem( QTextCustomItem *i, QTextParagraph *p );
801 void unregisterCustomItem( QTextCustomItem *i, QTextParagraph *p ); 804 void unregisterCustomItem( QTextCustomItem *i, QTextParagraph *p );
802 805
803 void setFlow( QTextFlow *f ); 806 void setFlow( QTextFlow *f );
804 void takeFlow(); 807 void takeFlow();
805 QTextFlow *flow() const { return flow_; } 808 QTextFlow *flow() const { return flow_; }
806 bool isPageBreakEnabled() const { return pages; } 809 bool isPageBreakEnabled() const { return pages; }
807 void setPageBreakEnabled( bool b ) { pages = b; } 810 void setPageBreakEnabled( bool b ) { pages = b; }
808 811
809 void setUseFormatCollection( bool b ) { useFC = b; } 812 void setUseFormatCollection( bool b ) { useFC = b; }
810 bool useFormatCollection() const { return useFC; } 813 bool useFormatCollection() const { return useFC; }
811 814
812 QTextTableCell *tableCell() const { return tc; } 815 QTextTableCell *tableCell() const { return tc; }
813 void setTableCell( QTextTableCell *c ) { tc = c; } 816 void setTableCell( QTextTableCell *c ) { tc = c; }
814 817
815 void setPlainText( const QString &text ); 818 void setPlainText( const QString &text );
816 void setRichText( const QString &text, const QString &context ); 819 void setRichText( const QString &text, const QString &context );
817 QString richText() const; 820 QString richText() const;
818 QString plainText() const; 821 QString plainText() const;
819 822
820 bool focusNextPrevChild( bool next ); 823 bool focusNextPrevChild( bool next );
821 824
822 int alignment() const; 825 int alignment() const;
@@ -837,64 +840,64 @@ public:
837 void insertChild( QObject *o ) { QObject::insertChild( o ); } 840 void insertChild( QObject *o ) { QObject::insertChild( o ); }
838 void removeChild( QObject *o ) { QObject::removeChild( o ); } 841 void removeChild( QObject *o ) { QObject::removeChild( o ); }
839 void insertChild( QTextDocument *d ) { childList.append( d ); } 842 void insertChild( QTextDocument *d ) { childList.append( d ); }
840 void removeChild( QTextDocument *d ) { childList.removeRef( d ); } 843 void removeChild( QTextDocument *d ) { childList.removeRef( d ); }
841 QPtrList<QTextDocument> children() const { return childList; } 844 QPtrList<QTextDocument> children() const { return childList; }
842 845
843 bool hasFocusParagraph() const; 846 bool hasFocusParagraph() const;
844 QString focusHref() const; 847 QString focusHref() const;
845 848
846 void invalidateOriginalText() { oTextValid = FALSE; oText = ""; } 849 void invalidateOriginalText() { oTextValid = FALSE; oText = ""; }
847 850
848 static QString section( QString str, const QString &sep, int start, int end = 0xffffffff ); 851 static QString section( QString str, const QString &sep, int start, int end = 0xffffffff );
849 static bool endsWith( QString str, const QString &s); 852 static bool endsWith( QString str, const QString &s);
850 853
851signals: 854signals:
852 void minimumWidthChanged( int ); 855 void minimumWidthChanged( int );
853 856
854private: 857private:
855 void init(); 858 void init();
856 QPixmap *bufferPixmap( const QSize &s ); 859 QPixmap *bufferPixmap( const QSize &s );
857 // HTML parser 860 // HTML parser
858 bool hasPrefix(const QChar* doc, int length, int pos, QChar c); 861 bool hasPrefix(const QChar* doc, int length, int pos, QChar c);
859 bool hasPrefix(const QChar* doc, int length, int pos, const QString& s); 862 bool hasPrefix(const QChar* doc, int length, int pos, const QString& s);
860 QTextCustomItem* parseTable( const QMap<QString, QString> &attr, const QTextFormat &fmt, 863 QTextCustomItem* parseTable( const QMap<QString, QString> &attr, const QTextFormat &fmt,
861 const QChar* doc, int length, int& pos, QTextParagraph *curpar ); 864 const QChar* doc, int length, int& pos, QTextParagraph *curpar );
862 bool eatSpace(const QChar* doc, int length, int& pos, bool includeNbsp = FALSE ); 865 bool eatSpace(const QChar* doc, int length, int& pos, bool includeNbsp = FALSE );
863 bool eat(const QChar* doc, int length, int& pos, QChar c); 866 bool eat(const QChar* doc, int length, int& pos, QChar c);
864 QString parseOpenTag(const QChar* doc, int length, int& pos, QMap<QString, QString> &attr, bool& emptyTag); 867 QString parseOpenTag(const QChar* doc, int length, int& pos, QMap<QString, QString> &attr, bool& emptyTag);
865 QString parseCloseTag( const QChar* doc, int length, int& pos ); 868 QString parseCloseTag( const QChar* doc, int length, int& pos );
866 QChar parseHTMLSpecialChar(const QChar* doc, int length, int& pos); 869 QChar parseHTMLSpecialChar(const QChar* doc, int length, int& pos);
867 QString parseWord(const QChar* doc, int length, int& pos, bool lower = TRUE); 870 QString parseWord(const QChar* doc, int length, int& pos, bool lower = TRUE);
868 QChar parseChar(const QChar* doc, int length, int& pos, QStyleSheetItem::WhiteSpaceMode wsm ); 871 QChar parseChar(const QChar* doc, int length, int& pos, QStyleSheetItem::WhiteSpaceMode wsm );
869 void setRichTextInternal( const QString &text, QTextCursor* cursor = 0 ); 872 void setRichTextInternal( const QString &text, QTextCursor* cursor = 0 );
870 void setRichTextMarginsInternal( QPtrList< QPtrVector<QStyleSheetItem> >& styles, QTextParagraph* stylesPar ); 873 void setRichTextMarginsInternal( QPtrList< QPtrVector<QStyleSheetItem> >& styles, QTextParagraph* stylesPar );
871 874
872private: 875private:
873 struct Q_EXPORT Focus { 876 struct Q_EXPORT Focus {
874 QTextParagraph *parag; 877 QTextParagraph *parag;
875 int start, len; 878 int start, len;
876 QString href; 879 QString href;
877 }; 880 };
878 881
879 int cx, cy, cw, vw; 882 int cx, cy, cw, vw;
880 QTextParagraph *fParag, *lParag; 883 QTextParagraph *fParag, *lParag;
881 QTextPreProcessor *pProcessor; 884 QTextPreProcessor *pProcessor;
882 QMap<int, QColor> selectionColors; 885 QMap<int, QColor> selectionColors;
883 QMap<int, QTextDocumentSelection> selections; 886 QMap<int, QTextDocumentSelection> selections;
884 QMap<int, bool> selectionText; 887 QMap<int, bool> selectionText;
885 QTextCommandHistory *commandHistory; 888 QTextCommandHistory *commandHistory;
886 QTextFormatter *pFormatter; 889 QTextFormatter *pFormatter;
887 QTextIndent *indenter; 890 QTextIndent *indenter;
888 QTextFormatCollection *fCollection; 891 QTextFormatCollection *fCollection;
889 Qt::TextFormat txtFormat; 892 Qt::TextFormat txtFormat;
890 uint preferRichText : 1; 893 uint preferRichText : 1;
891 uint pages : 1; 894 uint pages : 1;
892 uint useFC : 1; 895 uint useFC : 1;
893 uint withoutDoubleBuffer : 1; 896 uint withoutDoubleBuffer : 1;
894 uint underlLinks : 1; 897 uint underlLinks : 1;
895 uint nextDoubleBuffered : 1; 898 uint nextDoubleBuffered : 1;
896 uint oTextValid : 1; 899 uint oTextValid : 1;
897 uint mightHaveCustomItems : 1; 900 uint mightHaveCustomItems : 1;
898 int align; 901 int align;
899 int nSelections; 902 int nSelections;
900 QTextFlow *flow_; 903 QTextFlow *flow_;
@@ -910,72 +913,72 @@ private:
910 int rightmargin; 913 int rightmargin;
911 QTextParagraph *minwParag, *curParag; 914 QTextParagraph *minwParag, *curParag;
912 QStyleSheet* sheet_; 915 QStyleSheet* sheet_;
913 QMimeSourceFactory* factory_; 916 QMimeSourceFactory* factory_;
914 QString contxt; 917 QString contxt;
915 QMap<QString, QString> attribs; 918 QMap<QString, QString> attribs;
916 int *tArray; 919 int *tArray;
917 int tStopWidth; 920 int tStopWidth;
918 int uDepth; 921 int uDepth;
919 QString oText; 922 QString oText;
920 QPtrList<QTextDocument> childList; 923 QPtrList<QTextDocument> childList;
921 QColor linkColor; 924 QColor linkColor;
922 double scaleFontsFactor; 925 double scaleFontsFactor;
923 926
924 short list_tm,list_bm, list_lm, li_tm, li_bm, par_tm, par_bm; 927 short list_tm,list_bm, list_lm, li_tm, li_bm, par_tm, par_bm;
925}; 928};
926 929
927// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 930// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
928 931
929 932
930class Q_EXPORT QTextDeleteCommand : public QTextCommand 933class Q_EXPORT QTextDeleteCommand : public QTextCommand
931{ 934{
932public: 935public:
933 QTextDeleteCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str, 936 QTextDeleteCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str,
934 const QByteArray& oldStyle ); 937 const QByteArray& oldStyle );
935 QTextDeleteCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str ); 938 QTextDeleteCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str );
936 virtual ~QTextDeleteCommand(); 939 virtual ~QTextDeleteCommand();
937 940
938 Commands type() const { return Delete; } 941 Commands type() const { return Delete; }
939 QTextCursor *execute( QTextCursor *c ); 942 QTextCursor *execute( QTextCursor *c );
940 QTextCursor *unexecute( QTextCursor *c ); 943 QTextCursor *unexecute( QTextCursor *c );
941 944
942protected: 945protected:
943 int id, index; 946 int id, index;
944 QTextParagraph *parag; 947 QTextParagraph *parag;
945 QMemArray<QTextStringChar> text; 948 QMemArray<QTextStringChar> text;
946 QByteArray styleInformation; 949 QByteArray styleInformation;
947 950
948}; 951};
949 952
950class Q_EXPORT QTextInsertCommand : public QTextDeleteCommand 953class Q_EXPORT QTextInsertCommand : public QTextDeleteCommand
951{ 954{
952public: 955public:
953 QTextInsertCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str, 956 QTextInsertCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str,
954 const QByteArray& oldStyleInfo ) 957 const QByteArray& oldStyleInfo )
955 : QTextDeleteCommand( d, i, idx, str, oldStyleInfo ) {} 958 : QTextDeleteCommand( d, i, idx, str, oldStyleInfo ) {}
956 QTextInsertCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str ) 959 QTextInsertCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str )
957 : QTextDeleteCommand( p, idx, str ) {} 960 : QTextDeleteCommand( p, idx, str ) {}
958 virtual ~QTextInsertCommand() {} 961 virtual ~QTextInsertCommand() {}
959 962
960 Commands type() const { return Insert; } 963 Commands type() const { return Insert; }
961 QTextCursor *execute( QTextCursor *c ) { return QTextDeleteCommand::unexecute( c ); } 964 QTextCursor *execute( QTextCursor *c ) { return QTextDeleteCommand::unexecute( c ); }
962 QTextCursor *unexecute( QTextCursor *c ) { return QTextDeleteCommand::execute( c ); } 965 QTextCursor *unexecute( QTextCursor *c ) { return QTextDeleteCommand::execute( c ); }
963 966
964}; 967};
965 968
966class Q_EXPORT QTextFormatCommand : public QTextCommand 969class Q_EXPORT QTextFormatCommand : public QTextCommand
967{ 970{
968public: 971public:
969 QTextFormatCommand( QTextDocument *d, int sid, int sidx, int eid, int eidx, const QMemArray<QTextStringChar> &old, QTextFormat *f, int fl ); 972 QTextFormatCommand( QTextDocument *d, int sid, int sidx, int eid, int eidx, const QMemArray<QTextStringChar> &old, QTextFormat *f, int fl );
970 virtual ~QTextFormatCommand(); 973 virtual ~QTextFormatCommand();
971 974
972 Commands type() const { return Format; } 975 Commands type() const { return Format; }
973 QTextCursor *execute( QTextCursor *c ); 976 QTextCursor *execute( QTextCursor *c );
974 QTextCursor *unexecute( QTextCursor *c ); 977 QTextCursor *unexecute( QTextCursor *c );
975 978
976protected: 979protected:
977 int startId, startIndex, endId, endIndex; 980 int startId, startIndex, endId, endIndex;
978 QTextFormat *format; 981 QTextFormat *format;
979 QMemArray<QTextStringChar> oldFormats; 982 QMemArray<QTextStringChar> oldFormats;
980 int flags; 983 int flags;
981 984
@@ -990,79 +993,79 @@ public:
990 Commands type() const { return Style; } 993 Commands type() const { return Style; }
991 QTextCursor *execute( QTextCursor *c ); 994 QTextCursor *execute( QTextCursor *c );
992 QTextCursor *unexecute( QTextCursor *c ); 995 QTextCursor *unexecute( QTextCursor *c );
993 996
994 static QByteArray readStyleInformation( QTextDocument* d, int fParag, int lParag ); 997 static QByteArray readStyleInformation( QTextDocument* d, int fParag, int lParag );
995 static void writeStyleInformation( QTextDocument* d, int fParag, const QByteArray& style ); 998 static void writeStyleInformation( QTextDocument* d, int fParag, const QByteArray& style );
996 999
997private: 1000private:
998 int firstParag, lastParag; 1001 int firstParag, lastParag;
999 QByteArray before; 1002 QByteArray before;
1000 QByteArray after; 1003 QByteArray after;
1001}; 1004};
1002 1005
1003// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1006// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1004 1007
1005struct Q_EXPORT QTextParagraphSelection 1008struct Q_EXPORT QTextParagraphSelection
1006{ 1009{
1007 int start, end; 1010 int start, end;
1008}; 1011};
1009 1012
1010struct Q_EXPORT QTextLineStart 1013struct Q_EXPORT QTextLineStart
1011{ 1014{
1012 QTextLineStart() : y( 0 ), baseLine( 0 ), h( 0 ) 1015 QTextLineStart() : y( 0 ), baseLine( 0 ), h( 0 )
1013#ifndef QT_NO_COMPLEXTEXT 1016#ifndef QT_NO_COMPLEXTEXT
1014 , bidicontext( 0 ) 1017 , bidicontext( 0 )
1015#endif 1018#endif
1016 { } 1019 { }
1017 QTextLineStart( ushort y_, ushort bl, ushort h_ ) : y( y_ ), baseLine( bl ), h( h_ ), 1020 QTextLineStart( ushort y_, ushort bl, ushort h_ ) : y( y_ ), baseLine( bl ), h( h_ ),
1018 w( 0 ) 1021 w( 0 )
1019#ifndef QT_NO_COMPLEXTEXT 1022#ifndef QT_NO_COMPLEXTEXT
1020 , bidicontext( 0 ) 1023 , bidicontext( 0 )
1021#endif 1024#endif
1022 { } 1025 { }
1023#ifndef QT_NO_COMPLEXTEXT 1026#ifndef QT_NO_COMPLEXTEXT
1024 QTextLineStart( QBidiContext *c, QBidiStatus s ) : y(0), baseLine(0), h(0), 1027 QTextLineStart( QBidiContext *c, QBidiStatus s ) : y(0), baseLine(0), h(0),
1025 status( s ), bidicontext( c ) { if ( bidicontext ) bidicontext->ref(); } 1028 status( s ), bidicontext( c ) { if ( bidicontext ) bidicontext->ref(); }
1026#endif 1029#endif
1027 1030
1028 virtual ~QTextLineStart() 1031 virtual ~QTextLineStart()
1029 { 1032 {
1030#ifndef QT_NO_COMPLEXTEXT 1033#ifndef QT_NO_COMPLEXTEXT
1031 if ( bidicontext && bidicontext->deref() ) 1034 if ( bidicontext && bidicontext->deref() )
1032 delete bidicontext; 1035 delete bidicontext;
1033#endif 1036#endif
1034 } 1037 }
1035 1038
1036#ifndef QT_NO_COMPLEXTEXT 1039#ifndef QT_NO_COMPLEXTEXT
1037 void setContext( QBidiContext *c ) { 1040 void setContext( QBidiContext *c ) {
1038 if ( c == bidicontext ) 1041 if ( c == bidicontext )
1039 return; 1042 return;
1040 if ( bidicontext && bidicontext->deref() ) 1043 if ( bidicontext && bidicontext->deref() )
1041 delete bidicontext; 1044 delete bidicontext;
1042 bidicontext = c; 1045 bidicontext = c;
1043 if ( bidicontext ) 1046 if ( bidicontext )
1044 bidicontext->ref(); 1047 bidicontext->ref();
1045 } 1048 }
1046 QBidiContext *context() const { return bidicontext; } 1049 QBidiContext *context() const { return bidicontext; }
1047#endif 1050#endif
1048 1051
1049public: 1052public:
1050 ushort y, baseLine, h; 1053 ushort y, baseLine, h;
1051#ifndef QT_NO_COMPLEXTEXT 1054#ifndef QT_NO_COMPLEXTEXT
1052 QBidiStatus status; 1055 QBidiStatus status;
1053#endif 1056#endif
1054 int w; 1057 int w;
1055 1058
1056private: 1059private:
1057#ifndef QT_NO_COMPLEXTEXT 1060#ifndef QT_NO_COMPLEXTEXT
1058 QBidiContext *bidicontext; 1061 QBidiContext *bidicontext;
1059#endif 1062#endif
1060}; 1063};
1061 1064
1062#if defined(Q_TEMPLATEDLL) 1065#if defined(Q_TEMPLATEDLL)
1063// MOC_SKIP_BEGIN 1066// MOC_SKIP_BEGIN
1064Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextParagraphSelection>; 1067Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextParagraphSelection>;
1065Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextLineStart*>; 1068Q_TEMPLATE_EXTERN template class Q_EXPORT QMap<int, QTextLineStart*>;
1066// MOC_SKIP_END 1069// MOC_SKIP_END
1067#endif 1070#endif
1068 1071
@@ -1162,49 +1165,49 @@ public:
1162 bool fullSelected( int id ) const; 1165 bool fullSelected( int id ) const;
1163 1166
1164 void setEndState( int s ); 1167 void setEndState( int s );
1165 int endState() const; 1168 int endState() const;
1166 1169
1167 void setParagId( int i ); 1170 void setParagId( int i );
1168 int paragId() const; 1171 int paragId() const;
1169 1172
1170 bool firstPreProcess() const; 1173 bool firstPreProcess() const;
1171 void setFirstPreProcess( bool b ); 1174 void setFirstPreProcess( bool b );
1172 1175
1173 void indent( int *oldIndent = 0, int *newIndent = 0 ); 1176 void indent( int *oldIndent = 0, int *newIndent = 0 );
1174 1177
1175 void setExtraData( QTextParagraphData *data ); 1178 void setExtraData( QTextParagraphData *data );
1176 QTextParagraphData *extraData() const; 1179 QTextParagraphData *extraData() const;
1177 1180
1178 QMap<int, QTextLineStart*> &lineStartList(); 1181 QMap<int, QTextLineStart*> &lineStartList();
1179 1182
1180 void setFormat( int index, int len, QTextFormat *f, bool useCollection = TRUE, int flags = -1 ); 1183 void setFormat( int index, int len, QTextFormat *f, bool useCollection = TRUE, int flags = -1 );
1181 1184
1182 void setAlignment( int a ); 1185 void setAlignment( int a );
1183 int alignment() const; 1186 int alignment() const;
1184 1187
1185 virtual void paint( QPainter &painter, const QColorGroup &cg, QTextCursor *cursor = 0, bool drawSelections = FALSE, 1188 virtual void paint( QPainter &painter, const QColorGroup &cg, QTextCursor *cursor = 0, bool drawSelections = FALSE,
1186 int clipx = -1, int clipy = -1, int clipw = -1, int cliph = -1 ); 1189 int clipx = -1, int clipy = -1, int clipw = -1, int cliph = -1 );
1187 1190
1188 virtual int topMargin() const; 1191 virtual int topMargin() const;
1189 virtual int bottomMargin() const; 1192 virtual int bottomMargin() const;
1190 virtual int leftMargin() const; 1193 virtual int leftMargin() const;
1191 virtual int firstLineMargin() const; 1194 virtual int firstLineMargin() const;
1192 virtual int rightMargin() const; 1195 virtual int rightMargin() const;
1193 virtual int lineSpacing() const; 1196 virtual int lineSpacing() const;
1194 1197
1195 void registerFloatingItem( QTextCustomItem *i ); 1198 void registerFloatingItem( QTextCustomItem *i );
1196 void unregisterFloatingItem( QTextCustomItem *i ); 1199 void unregisterFloatingItem( QTextCustomItem *i );
1197 1200
1198 void setFullWidth( bool b ) { fullWidth = b; } 1201 void setFullWidth( bool b ) { fullWidth = b; }
1199 bool isFullWidth() const { return fullWidth; } 1202 bool isFullWidth() const { return fullWidth; }
1200 1203
1201 QTextTableCell *tableCell() const; 1204 QTextTableCell *tableCell() const;
1202 1205
1203 QBrush *background() const; 1206 QBrush *background() const;
1204 1207
1205 int documentWidth() const; 1208 int documentWidth() const;
1206 int documentVisibleWidth() const; 1209 int documentVisibleWidth() const;
1207 int documentX() const; 1210 int documentX() const;
1208 int documentY() const; 1211 int documentY() const;
1209 QTextFormatCollection *formatCollection() const; 1212 QTextFormatCollection *formatCollection() const;
1210 QTextFormatter *formatter() const; 1213 QTextFormatter *formatter() const;
@@ -1225,51 +1228,51 @@ public:
1225 QTextCursor *undo( QTextCursor *c = 0 ); 1228 QTextCursor *undo( QTextCursor *c = 0 );
1226 QTextCursor *redo( QTextCursor *c = 0 ); 1229 QTextCursor *redo( QTextCursor *c = 0 );
1227 QTextCommandHistory *commands() const; 1230 QTextCommandHistory *commands() const;
1228 virtual void copyParagData( QTextParagraph *parag ); 1231 virtual void copyParagData( QTextParagraph *parag );
1229 1232
1230 void setBreakable( bool b ) { breakable = b; } 1233 void setBreakable( bool b ) { breakable = b; }
1231 bool isBreakable() const { return breakable; } 1234 bool isBreakable() const { return breakable; }
1232 1235
1233 void setBackgroundColor( const QColor &c ); 1236 void setBackgroundColor( const QColor &c );
1234 QColor *backgroundColor() const { return bgcol; } 1237 QColor *backgroundColor() const { return bgcol; }
1235 void clearBackgroundColor(); 1238 void clearBackgroundColor();
1236 1239
1237 void setMovedDown( bool b ) { movedDown = b; } 1240 void setMovedDown( bool b ) { movedDown = b; }
1238 bool wasMovedDown() const { return movedDown; } 1241 bool wasMovedDown() const { return movedDown; }
1239 1242
1240 void setDirection( QChar::Direction d ); 1243 void setDirection( QChar::Direction d );
1241 QChar::Direction direction() const; 1244 QChar::Direction direction() const;
1242 1245
1243 void readStyleInformation( QDataStream& stream ); 1246 void readStyleInformation( QDataStream& stream );
1244 void writeStyleInformation( QDataStream& stream ) const; 1247 void writeStyleInformation( QDataStream& stream ) const;
1245 1248
1246protected: 1249protected:
1247 virtual void drawLabel( QPainter* p, int x, int y, int w, int h, int base, const QColorGroup& cg ); 1250 virtual void drawLabel( QPainter* p, int x, int y, int w, int h, int base, const QColorGroup& cg );
1248 virtual void drawString( QPainter &painter, const QString &str, int start, int len, int xstart, 1251 virtual void drawString( QPainter &painter, const QString &str, int start, int len, int xstart,
1249 int y, int baseLine, int w, int h, int selection, 1252 int y, int baseLine, int w, int h, int selection,
1250 QTextStringChar *formatChar, const QColorGroup& cg, 1253 QTextStringChar *formatChar, const QColorGroup& cg,
1251 bool rightToLeft ); 1254 bool rightToLeft );
1252 1255
1253private: 1256private:
1254 QMap<int, QTextParagraphSelection> &selections() const; 1257 QMap<int, QTextParagraphSelection> &selections() const;
1255 QPtrList<QTextCustomItem> &floatingItems() const; 1258 QPtrList<QTextCustomItem> &floatingItems() const;
1256 QBrush backgroundBrush( const QColorGroup&cg ) { if ( bgcol ) return *bgcol; return cg.brush( QColorGroup::Base ); } 1259 QBrush backgroundBrush( const QColorGroup&cg ) { if ( bgcol ) return *bgcol; return cg.brush( QColorGroup::Base ); }
1257 void invalidateStyleCache(); 1260 void invalidateStyleCache();
1258 1261
1259 QMap<int, QTextLineStart*> lineStarts; 1262 QMap<int, QTextLineStart*> lineStarts;
1260 int invalid; 1263 int invalid;
1261 QRect r; 1264 QRect r;
1262 QTextParagraph *p, *n; 1265 QTextParagraph *p, *n;
1263 void *docOrPseudo; 1266 void *docOrPseudo;
1264 uint changed : 1; 1267 uint changed : 1;
1265 uint firstFormat : 1; 1268 uint firstFormat : 1;
1266 uint firstPProcess : 1; 1269 uint firstPProcess : 1;
1267 uint needPreProcess : 1; 1270 uint needPreProcess : 1;
1268 uint fullWidth : 1; 1271 uint fullWidth : 1;
1269 uint lastInFrame : 1; 1272 uint lastInFrame : 1;
1270 uint visible : 1; 1273 uint visible : 1;
1271 uint breakable : 1; 1274 uint breakable : 1;
1272 uint movedDown : 1; 1275 uint movedDown : 1;
1273 uint mightHaveCustomItems : 1; 1276 uint mightHaveCustomItems : 1;
1274 uint hasdoc : 1; 1277 uint hasdoc : 1;
1275 uint litem : 1; // whether the paragraph is a list item 1278 uint litem : 1; // whether the paragraph is a list item
@@ -1294,52 +1297,52 @@ private:
1294 1297
1295class Q_EXPORT QTextFormatter 1298class Q_EXPORT QTextFormatter
1296{ 1299{
1297public: 1300public:
1298 QTextFormatter(); 1301 QTextFormatter();
1299 virtual ~QTextFormatter(); 1302 virtual ~QTextFormatter();
1300 1303
1301 virtual int format( QTextDocument *doc, QTextParagraph *parag, int start, const QMap<int, QTextLineStart*> &oldLineStarts ) = 0; 1304 virtual int format( QTextDocument *doc, QTextParagraph *parag, int start, const QMap<int, QTextLineStart*> &oldLineStarts ) = 0;
1302 virtual int formatVertically( QTextDocument* doc, QTextParagraph* parag ); 1305 virtual int formatVertically( QTextDocument* doc, QTextParagraph* parag );
1303 1306
1304 bool isWrapEnabled( QTextParagraph *p ) const { if ( !wrapEnabled ) return FALSE; if ( p && !p->isBreakable() ) return FALSE; return TRUE;} 1307 bool isWrapEnabled( QTextParagraph *p ) const { if ( !wrapEnabled ) return FALSE; if ( p && !p->isBreakable() ) return FALSE; return TRUE;}
1305 int wrapAtColumn() const { return wrapColumn;} 1308 int wrapAtColumn() const { return wrapColumn;}
1306 virtual void setWrapEnabled( bool b ); 1309 virtual void setWrapEnabled( bool b );
1307 virtual void setWrapAtColumn( int c ); 1310 virtual void setWrapAtColumn( int c );
1308 virtual void setAllowBreakInWords( bool b ) { biw = b; } 1311 virtual void setAllowBreakInWords( bool b ) { biw = b; }
1309 bool allowBreakInWords() const { return biw; } 1312 bool allowBreakInWords() const { return biw; }
1310 1313
1311 int minimumWidth() const { return thisminw; } 1314 int minimumWidth() const { return thisminw; }
1312 int widthUsed() const { return thiswused; } 1315 int widthUsed() const { return thiswused; }
1313 1316
1314 static bool isBreakable( QTextString *string, int pos ); 1317 static bool isBreakable( QTextString *string, int pos );
1315 1318
1316protected: 1319protected:
1317 virtual QTextLineStart *formatLine( QTextParagraph *parag, QTextString *string, QTextLineStart *line, QTextStringChar *start, 1320 virtual QTextLineStart *formatLine( QTextParagraph *parag, QTextString *string, QTextLineStart *line, QTextStringChar *start,
1318 QTextStringChar *last, int align = Qt3::AlignAuto, int space = 0 ); 1321 QTextStringChar *last, int align = Qt3::AlignAuto, int space = 0 );
1319#ifndef QT_NO_COMPLEXTEXT 1322#ifndef QT_NO_COMPLEXTEXT
1320 virtual QTextLineStart *bidiReorderLine( QTextParagraph *parag, QTextString *string, QTextLineStart *line, QTextStringChar *start, 1323 virtual QTextLineStart *bidiReorderLine( QTextParagraph *parag, QTextString *string, QTextLineStart *line, QTextStringChar *start,
1321 QTextStringChar *last, int align, int space ); 1324 QTextStringChar *last, int align, int space );
1322#endif 1325#endif
1323 void insertLineStart( QTextParagraph *parag, int index, QTextLineStart *ls ); 1326 void insertLineStart( QTextParagraph *parag, int index, QTextLineStart *ls );
1324 1327
1325 int thisminw; 1328 int thisminw;
1326 int thiswused; 1329 int thiswused;
1327 1330
1328private: 1331private:
1329 bool wrapEnabled; 1332 bool wrapEnabled;
1330 int wrapColumn; 1333 int wrapColumn;
1331 bool biw; 1334 bool biw;
1332 1335
1333#ifdef HAVE_THAI_BREAKS 1336#ifdef HAVE_THAI_BREAKS
1334 static QCString *thaiCache; 1337 static QCString *thaiCache;
1335 static QTextString *cachedString; 1338 static QTextString *cachedString;
1336 static ThBreakIterator *thaiIt; 1339 static ThBreakIterator *thaiIt;
1337#endif 1340#endif
1338}; 1341};
1339 1342
1340// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1343// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1341 1344
1342class Q_EXPORT QTextFormatterBreakInWords : public QTextFormatter 1345class Q_EXPORT QTextFormatterBreakInWords : public QTextFormatter
1343{ 1346{
1344public: 1347public:
1345 QTextFormatterBreakInWords(); 1348 QTextFormatterBreakInWords();
@@ -1358,80 +1361,80 @@ public:
1358 virtual ~QTextFormatterBreakWords() {} 1361 virtual ~QTextFormatterBreakWords() {}
1359 1362
1360 int format( QTextDocument *doc, QTextParagraph *parag, int start, const QMap<int, QTextLineStart*> &oldLineStarts ); 1363 int format( QTextDocument *doc, QTextParagraph *parag, int start, const QMap<int, QTextLineStart*> &oldLineStarts );
1361 1364
1362}; 1365};
1363 1366
1364// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1367// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1365 1368
1366class Q_EXPORT QTextIndent 1369class Q_EXPORT QTextIndent
1367{ 1370{
1368public: 1371public:
1369 QTextIndent(); 1372 QTextIndent();
1370 virtual ~QTextIndent() {} 1373 virtual ~QTextIndent() {}
1371 1374
1372 virtual void indent( QTextDocument *doc, QTextParagraph *parag, int *oldIndent = 0, int *newIndent = 0 ) = 0; 1375 virtual void indent( QTextDocument *doc, QTextParagraph *parag, int *oldIndent = 0, int *newIndent = 0 ) = 0;
1373 1376
1374}; 1377};
1375 1378
1376// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1379// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1377 1380
1378class Q_EXPORT QTextPreProcessor 1381class Q_EXPORT QTextPreProcessor
1379{ 1382{
1380public: 1383public:
1381 enum Ids { 1384 enum Ids {
1382 Standard = 0 1385 Standard = 0
1383 }; 1386 };
1384 1387
1385 QTextPreProcessor(); 1388 QTextPreProcessor();
1386 virtual ~QTextPreProcessor() {} 1389 virtual ~QTextPreProcessor() {}
1387 1390
1388 virtual void process( QTextDocument *doc, QTextParagraph *, int, bool = TRUE ) = 0; 1391 virtual void process( QTextDocument *doc, QTextParagraph *, int, bool = TRUE ) = 0;
1389 virtual QTextFormat *format( int id ) = 0; 1392 virtual QTextFormat *format( int id ) = 0;
1390 1393
1391}; 1394};
1392 1395
1393// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1396// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1394 1397
1395class Q_EXPORT QTextFormat 1398class Q_EXPORT QTextFormat
1396{ 1399{
1397 friend class QTextFormatCollection; 1400 friend class QTextFormatCollection;
1398 friend class QTextDocument; 1401 friend class QTextDocument;
1399 1402
1400public: 1403public:
1401 enum Flags { 1404 enum Flags {
1402 NoFlags, 1405 NoFlags,
1403 Bold = 1, 1406 Bold = 1,
1404 Italic = 2, 1407 Italic = 2,
1405 Underline = 4, 1408 Underline = 4,
1406 Family = 8, 1409 Family = 8,
1407 Size = 16, 1410 Size = 16,
1408 Color = 32, 1411 Color = 32,
1409 Misspelled = 64, 1412 Misspelled = 64,
1410 VAlign = 128, 1413 VAlign = 128,
1411 StrikeOut= 256, 1414 StrikeOut= 256,
1412 Font = Bold | Italic | Underline | Family | Size | StrikeOut, 1415 Font = Bold | Italic | Underline | Family | Size | StrikeOut,
1413 Format = Font | Color | Misspelled | VAlign 1416 Format = Font | Color | Misspelled | VAlign
1414 }; 1417 };
1415 1418
1416 enum VerticalAlignment { AlignNormal, AlignSuperScript, AlignSubScript }; 1419 enum VerticalAlignment { AlignNormal, AlignSuperScript, AlignSubScript };
1417 1420
1418 QTextFormat(); 1421 QTextFormat();
1419 virtual ~QTextFormat(); 1422 virtual ~QTextFormat();
1420 1423
1421 QTextFormat( const QStyleSheetItem *s ); 1424 QTextFormat( const QStyleSheetItem *s );
1422 QTextFormat( const QFont &f, const QColor &c, QTextFormatCollection *parent = 0 ); 1425 QTextFormat( const QFont &f, const QColor &c, QTextFormatCollection *parent = 0 );
1423 QTextFormat( const QTextFormat &fm ); 1426 QTextFormat( const QTextFormat &fm );
1424 QTextFormat makeTextFormat( const QStyleSheetItem *style, const QMap<QString,QString>& attr, double scaleFontsFactor ) const; 1427 QTextFormat makeTextFormat( const QStyleSheetItem *style, const QMap<QString,QString>& attr, double scaleFontsFactor ) const;
1425 QTextFormat& operator=( const QTextFormat &fm ); 1428 QTextFormat& operator=( const QTextFormat &fm );
1426 QColor color() const; 1429 QColor color() const;
1427 QFont font() const; 1430 QFont font() const;
1428 bool isMisspelled() const; 1431 bool isMisspelled() const;
1429 VerticalAlignment vAlign() const; 1432 VerticalAlignment vAlign() const;
1430 int minLeftBearing() const; 1433 int minLeftBearing() const;
1431 int minRightBearing() const; 1434 int minRightBearing() const;
1432 int width( const QChar &c ) const; 1435 int width( const QChar &c ) const;
1433 int width( const QString &str, int pos ) const; 1436 int width( const QString &str, int pos ) const;
1434 int height() const; 1437 int height() const;
1435 int ascent() const; 1438 int ascent() const;
1436 int descent() const; 1439 int descent() const;
1437 int leading() const; 1440 int leading() const;
@@ -1708,56 +1711,56 @@ inline void QTextDocument::setAlignment( int a )
1708 1711
1709inline int *QTextDocument::tabArray() const 1712inline int *QTextDocument::tabArray() const
1710{ 1713{
1711 return tArray; 1714 return tArray;
1712} 1715}
1713 1716
1714inline int QTextDocument::tabStopWidth() const 1717inline int QTextDocument::tabStopWidth() const
1715{ 1718{
1716 return tStopWidth; 1719 return tStopWidth;
1717} 1720}
1718 1721
1719inline void QTextDocument::setTabArray( int *a ) 1722inline void QTextDocument::setTabArray( int *a )
1720{ 1723{
1721 tArray = a; 1724 tArray = a;
1722} 1725}
1723 1726
1724inline void QTextDocument::setTabStops( int tw ) 1727inline void QTextDocument::setTabStops( int tw )
1725{ 1728{
1726 tStopWidth = tw; 1729 tStopWidth = tw;
1727} 1730}
1728 1731
1729inline QString QTextDocument::originalText() const 1732inline QString QTextDocument::originalText() const
1730{ 1733{
1731 if ( oTextValid ) 1734 if ( oTextValid )
1732 return oText; 1735 return oText;
1733 return text(); 1736 return text();
1734} 1737}
1735 1738
1736inline void QTextDocument::setFlow( QTextFlow *f ) 1739inline void QTextDocument::setFlow( QTextFlow *f )
1737{ 1740{
1738 if ( flow_ ) 1741 if ( flow_ )
1739 delete flow_; 1742 delete flow_;
1740 flow_ = f; 1743 flow_ = f;
1741} 1744}
1742 1745
1743inline void QTextDocument::takeFlow() 1746inline void QTextDocument::takeFlow()
1744{ 1747{
1745 flow_ = 0; 1748 flow_ = 0;
1746} 1749}
1747 1750
1748// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1751// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1749 1752
1750inline QColor QTextFormat::color() const 1753inline QColor QTextFormat::color() const
1751{ 1754{
1752 return col; 1755 return col;
1753} 1756}
1754 1757
1755inline QFont QTextFormat::font() const 1758inline QFont QTextFormat::font() const
1756{ 1759{
1757 return fn; 1760 return fn;
1758} 1761}
1759 1762
1760inline bool QTextFormat::isMisspelled() const 1763inline bool QTextFormat::isMisspelled() const
1761{ 1764{
1762 return missp; 1765 return missp;
1763} 1766}
@@ -1765,53 +1768,53 @@ inline bool QTextFormat::isMisspelled() const
1765inline QTextFormat::VerticalAlignment QTextFormat::vAlign() const 1768inline QTextFormat::VerticalAlignment QTextFormat::vAlign() const
1766{ 1769{
1767 return ha; 1770 return ha;
1768} 1771}
1769 1772
1770inline bool QTextFormat::operator==( const QTextFormat &f ) const 1773inline bool QTextFormat::operator==( const QTextFormat &f ) const
1771{ 1774{
1772 return k == f.k; 1775 return k == f.k;
1773} 1776}
1774 1777
1775inline QTextFormatCollection *QTextFormat::parent() const 1778inline QTextFormatCollection *QTextFormat::parent() const
1776{ 1779{
1777 return collection; 1780 return collection;
1778} 1781}
1779 1782
1780inline void QTextFormat::addRef() 1783inline void QTextFormat::addRef()
1781{ 1784{
1782 ref++; 1785 ref++;
1783} 1786}
1784 1787
1785inline void QTextFormat::removeRef() 1788inline void QTextFormat::removeRef()
1786{ 1789{
1787 ref--; 1790 ref--;
1788 if ( !collection ) 1791 if ( !collection )
1789 return; 1792 return;
1790 if ( this == collection->defFormat ) 1793 if ( this == collection->defFormat )
1791 return; 1794 return;
1792 if ( ref == 0 ) 1795 if ( ref == 0 )
1793 collection->remove( this ); 1796 collection->remove( this );
1794} 1797}
1795 1798
1796inline QString QTextFormat::key() const 1799inline QString QTextFormat::key() const
1797{ 1800{
1798 return k; 1801 return k;
1799} 1802}
1800 1803
1801inline bool QTextFormat::useLinkColor() const 1804inline bool QTextFormat::useLinkColor() const
1802{ 1805{
1803 return linkColor; 1806 return linkColor;
1804} 1807}
1805 1808
1806 1809
1807// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1810// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1808 1811
1809inline QTextStringChar &QTextString::at( int i ) const 1812inline QTextStringChar &QTextString::at( int i ) const
1810{ 1813{
1811 return data[ i ]; 1814 return data[ i ];
1812} 1815}
1813 1816
1814// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1817// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1815 1818
1816inline QTextStringChar *QTextParagraph::at( int i ) const 1819inline QTextStringChar *QTextParagraph::at( int i ) const
1817{ 1820{
@@ -1822,123 +1825,123 @@ inline bool QTextParagraph::isValid() const
1822{ 1825{
1823 return invalid == -1; 1826 return invalid == -1;
1824} 1827}
1825 1828
1826inline bool QTextParagraph::hasChanged() const 1829inline bool QTextParagraph::hasChanged() const
1827{ 1830{
1828 return changed; 1831 return changed;
1829} 1832}
1830 1833
1831inline void QTextParagraph::setBackgroundColor( const QColor & c ) 1834inline void QTextParagraph::setBackgroundColor( const QColor & c )
1832{ 1835{
1833 delete bgcol; 1836 delete bgcol;
1834 bgcol = new QColor( c ); 1837 bgcol = new QColor( c );
1835 setChanged( TRUE ); 1838 setChanged( TRUE );
1836} 1839}
1837 1840
1838inline void QTextParagraph::clearBackgroundColor() 1841inline void QTextParagraph::clearBackgroundColor()
1839{ 1842{
1840 delete bgcol; bgcol = 0; setChanged( TRUE ); 1843 delete bgcol; bgcol = 0; setChanged( TRUE );
1841} 1844}
1842 1845
1843inline void QTextParagraph::append( const QString &s, bool reallyAtEnd ) 1846inline void QTextParagraph::append( const QString &s, bool reallyAtEnd )
1844{ 1847{
1845 if ( reallyAtEnd ) 1848 if ( reallyAtEnd )
1846 insert( str->length(), s ); 1849 insert( str->length(), s );
1847 else 1850 else
1848 insert( QMAX( str->length() - 1, 0 ), s ); 1851 insert( QMAX( str->length() - 1, 0 ), s );
1849} 1852}
1850 1853
1851inline QTextParagraph *QTextParagraph::prev() const 1854inline QTextParagraph *QTextParagraph::prev() const
1852{ 1855{
1853 return p; 1856 return p;
1854} 1857}
1855 1858
1856inline QTextParagraph *QTextParagraph::next() const 1859inline QTextParagraph *QTextParagraph::next() const
1857{ 1860{
1858 return n; 1861 return n;
1859} 1862}
1860 1863
1861inline bool QTextParagraph::hasAnySelection() const 1864inline bool QTextParagraph::hasAnySelection() const
1862{ 1865{
1863 return mSelections ? !selections().isEmpty() : FALSE; 1866 return mSelections ? !selections().isEmpty() : FALSE;
1864} 1867}
1865 1868
1866inline void QTextParagraph::setEndState( int s ) 1869inline void QTextParagraph::setEndState( int s )
1867{ 1870{
1868 if ( s == state ) 1871 if ( s == state )
1869 return; 1872 return;
1870 state = s; 1873 state = s;
1871} 1874}
1872 1875
1873inline int QTextParagraph::endState() const 1876inline int QTextParagraph::endState() const
1874{ 1877{
1875 return state; 1878 return state;
1876} 1879}
1877 1880
1878inline void QTextParagraph::setParagId( int i ) 1881inline void QTextParagraph::setParagId( int i )
1879{ 1882{
1880 id = i; 1883 id = i;
1881} 1884}
1882 1885
1883inline int QTextParagraph::paragId() const 1886inline int QTextParagraph::paragId() const
1884{ 1887{
1885 if ( id == -1 ) 1888 if ( id == -1 )
1886 qWarning( "invalid parag id!!!!!!!! (%p)", (void*)this ); 1889 owarn << "invalid parag id!!!!!!!! (" << (void*)this << ")" << oendl;
1887 return id; 1890 return id;
1888} 1891}
1889 1892
1890inline bool QTextParagraph::firstPreProcess() const 1893inline bool QTextParagraph::firstPreProcess() const
1891{ 1894{
1892 return firstPProcess; 1895 return firstPProcess;
1893} 1896}
1894 1897
1895inline void QTextParagraph::setFirstPreProcess( bool b ) 1898inline void QTextParagraph::setFirstPreProcess( bool b )
1896{ 1899{
1897 firstPProcess = b; 1900 firstPProcess = b;
1898} 1901}
1899 1902
1900inline QMap<int, QTextLineStart*> &QTextParagraph::lineStartList() 1903inline QMap<int, QTextLineStart*> &QTextParagraph::lineStartList()
1901{ 1904{
1902 return lineStarts; 1905 return lineStarts;
1903} 1906}
1904 1907
1905inline QTextString *QTextParagraph::string() const 1908inline QTextString *QTextParagraph::string() const
1906{ 1909{
1907 return str; 1910 return str;
1908} 1911}
1909 1912
1910inline QTextDocument *QTextParagraph::document() const 1913inline QTextDocument *QTextParagraph::document() const
1911{ 1914{
1912 if ( hasdoc ) 1915 if ( hasdoc )
1913 return (QTextDocument*) docOrPseudo; 1916 return (QTextDocument*) docOrPseudo;
1914 return 0; 1917 return 0;
1915} 1918}
1916 1919
1917inline QTextParagraphPseudoDocument *QTextParagraph::pseudoDocument() const 1920inline QTextParagraphPseudoDocument *QTextParagraph::pseudoDocument() const
1918{ 1921{
1919 if ( hasdoc ) 1922 if ( hasdoc )
1920 return 0; 1923 return 0;
1921 return (QTextParagraphPseudoDocument*) docOrPseudo; 1924 return (QTextParagraphPseudoDocument*) docOrPseudo;
1922} 1925}
1923 1926
1924 1927
1925inline QTextTableCell *QTextParagraph::tableCell() const 1928inline QTextTableCell *QTextParagraph::tableCell() const
1926{ 1929{
1927 return hasdoc ? document()->tableCell () : 0; 1930 return hasdoc ? document()->tableCell () : 0;
1928} 1931}
1929 1932
1930inline QTextCommandHistory *QTextParagraph::commands() const 1933inline QTextCommandHistory *QTextParagraph::commands() const
1931{ 1934{
1932 return hasdoc ? document()->commands() : pseudoDocument()->commandHistory; 1935 return hasdoc ? document()->commands() : pseudoDocument()->commandHistory;
1933} 1936}
1934 1937
1935 1938
1936inline int QTextParagraph::alignment() const 1939inline int QTextParagraph::alignment() const
1937{ 1940{
1938 return align; 1941 return align;
1939} 1942}
1940 1943
1941inline void QTextParagraph::registerFloatingItem( QTextCustomItem *i ) 1944inline void QTextParagraph::registerFloatingItem( QTextCustomItem *i )
1942{ 1945{
1943 floatingItems().append( i ); 1946 floatingItems().append( i );
1944} 1947}
diff --git a/noncore/apps/tableviewer/browsekeyentry.cpp b/noncore/apps/tableviewer/browsekeyentry.cpp
index 04e7902..bab9af6 100644
--- a/noncore/apps/tableviewer/browsekeyentry.cpp
+++ b/noncore/apps/tableviewer/browsekeyentry.cpp
@@ -1,200 +1,202 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "browsekeyentry.h" 20#include "browsekeyentry.h"
21 21
22/* OPIE */
23#include <opie2/odebug.h>
24using namespace Opie::Core;
25
26/* QT */
22#include <qtoolbutton.h> 27#include <qtoolbutton.h>
23#include <qwidgetstack.h> 28#include <qwidgetstack.h>
24#include <qlayout.h> 29#include <qlayout.h>
25#include <qlineedit.h> 30#include <qlineedit.h>
26#include <qpushbutton.h> 31#include <qpushbutton.h>
27#include <qpopupmenu.h> 32#include <qpopupmenu.h>
28#include <qhbox.h> 33#include <qhbox.h>
29#include <qdatetime.h> 34#include <qdatetime.h>
30 35
31//#include <iostream.h>
32#include <qheader.h>
33// For qWarning(const char *)
34 36
35/*! 37/*!
36 \class TVBrowseKeyEntry 38 \class TVBrowseKeyEntry
37 \brief a Widget used enter keys into the TVBrowseViewWidget 39 \brief a Widget used enter keys into the TVBrowseViewWidget
38 40
39 The TVBrowseKeyEntry Widget provides the facility to enter 41 The TVBrowseKeyEntry Widget provides the facility to enter
40 various key types to be search on in the table. The key can be changed 42 various key types to be search on in the table. The key can be changed
41 and the entry field will update to the correct sort of widget appropriately 43 and the entry field will update to the correct sort of widget appropriately
42*/ 44*/
43 45
44/*! 46/*!
45 Constructs the widget 47 Constructs the widget
46*/ 48*/
47TVBrowseKeyEntry::TVBrowseKeyEntry(QWidget *parent, const char *name, WFlags f) 49TVBrowseKeyEntry::TVBrowseKeyEntry(QWidget *parent, const char *name, WFlags f)
48 : QWidget(parent, name, f) 50 : QWidget(parent, name, f)
49{ 51{
50 int stack_elem = 0; 52 int stack_elem = 0;
51 QHBoxLayout *h_layout = new QHBoxLayout(this); 53 QHBoxLayout *h_layout = new QHBoxLayout(this);
52 54
53 textKey = new QLineEdit(this, 0); 55 textKey = new QLineEdit(this, 0);
54 56
55 dateKey = new QHBox(this, 0); 57 dateKey = new QHBox(this, 0);
56 dayKey = new QLineEdit(dateKey, 0); 58 dayKey = new QLineEdit(dateKey, 0);
57 monthKey = new QLineEdit(dateKey, 0); 59 monthKey = new QLineEdit(dateKey, 0);
58 yearKey = new QLineEdit(dateKey, 0); 60 yearKey = new QLineEdit(dateKey, 0);
59 61
60 timeKey = new QHBox(this, 0); 62 timeKey = new QHBox(this, 0);
61 hourKey = new QLineEdit(timeKey, 0); 63 hourKey = new QLineEdit(timeKey, 0);
62 minuteKey = new QLineEdit(timeKey, 0); 64 minuteKey = new QLineEdit(timeKey, 0);
63 secondKey = new QLineEdit(timeKey, 0); 65 secondKey = new QLineEdit(timeKey, 0);
64 66
65 resetButton = new QPushButton(this, "reset"); 67 resetButton = new QPushButton(this, "reset");
66 resetButton->setMinimumSize(QSize(50, 0)); 68 resetButton->setMinimumSize(QSize(50, 0));
67 resetButton->setText(tr("Reset")); 69 resetButton->setText(tr("Reset"));
68 70
69 changeKeyButton = new QToolButton(this, "changekey"); 71 changeKeyButton = new QToolButton(this, "changekey");
70 // TODO The icon stuff. 72 // TODO The icon stuff.
71 changeKeyButton->setText(tr("key")); 73 changeKeyButton->setText(tr("key"));
72 74
73 totalKeys = 0; 75 totalKeys = 0;
74 ts = 0; 76 ts = 0;
75 keyMenu = new QPopupMenu(this, "keymenu"); 77 keyMenu = new QPopupMenu(this, "keymenu");
76 78
77 ws = new QWidgetStack(this, 0); 79 ws = new QWidgetStack(this, 0);
78 ws->addWidget(textKey, stack_elem++); 80 ws->addWidget(textKey, stack_elem++);
79 ws->addWidget(timeKey, stack_elem++); 81 ws->addWidget(timeKey, stack_elem++);
80 ws->addWidget(dateKey, stack_elem++); 82 ws->addWidget(dateKey, stack_elem++);
81 83
82 ws->raiseWidget(0); 84 ws->raiseWidget(0);
83 85
84 // TODO connect slots and signals.... 86 // TODO connect slots and signals....
85 connect(changeKeyButton, SIGNAL(clicked()), 87 connect(changeKeyButton, SIGNAL(clicked()),
86 this, SLOT(changeKeyMenuSlot())); 88 this, SLOT(changeKeyMenuSlot()));
87 connect(resetButton, SIGNAL(clicked()), 89 connect(resetButton, SIGNAL(clicked()),
88 this, SLOT(resetKeySlot())); 90 this, SLOT(resetKeySlot()));
89 91
90 connect(textKey, SIGNAL(textChanged(const QString&)), 92 connect(textKey, SIGNAL(textChanged(const QString&)),
91 this, SLOT(searchOnText())); 93 this, SLOT(searchOnText()));
92 94
93 connect(dayKey, SIGNAL(textChanged(const QString&)), 95 connect(dayKey, SIGNAL(textChanged(const QString&)),
94 this, SLOT(searchOnText())); 96 this, SLOT(searchOnText()));
95 connect(monthKey, SIGNAL(textChanged(const QString&)), 97 connect(monthKey, SIGNAL(textChanged(const QString&)),
96 this, SLOT(searchOnText())); 98 this, SLOT(searchOnText()));
97 connect(yearKey, SIGNAL(textChanged(const QString&)), 99 connect(yearKey, SIGNAL(textChanged(const QString&)),
98 this, SLOT(searchOnText())); 100 this, SLOT(searchOnText()));
99 101
100 connect(secondKey, SIGNAL(textChanged(const QString&)), 102 connect(secondKey, SIGNAL(textChanged(const QString&)),
101 this, SLOT(searchOnText())); 103 this, SLOT(searchOnText()));
102 connect(minuteKey, SIGNAL(textChanged(const QString&)), 104 connect(minuteKey, SIGNAL(textChanged(const QString&)),
103 this, SLOT(searchOnText())); 105 this, SLOT(searchOnText()));
104 connect(hourKey, SIGNAL(textChanged(const QString&)), 106 connect(hourKey, SIGNAL(textChanged(const QString&)),
105 this, SLOT(searchOnText())); 107 this, SLOT(searchOnText()));
106 108
107 h_layout->addWidget(ws); 109 h_layout->addWidget(ws);
108 h_layout->addWidget(resetButton); 110 h_layout->addWidget(resetButton);
109 h_layout->addWidget(changeKeyButton); 111 h_layout->addWidget(changeKeyButton);
110} 112}
111 113
112/*! 114/*!
113 Destructs the widget 115 Destructs the widget
114*/ 116*/
115TVBrowseKeyEntry::~TVBrowseKeyEntry() 117TVBrowseKeyEntry::~TVBrowseKeyEntry()
116{ 118{
117} 119}
118 120
119/*! 121/*!
120 Changes which key the user intends to search on 122 Changes which key the user intends to search on
121 123
122 \param id_param the index of the key future searches should be base on 124 \param id_param the index of the key future searches should be base on
123*/ 125*/
124void TVBrowseKeyEntry::changeKeySlot(int id_param) 126void TVBrowseKeyEntry::changeKeySlot(int id_param)
125{ 127{
126 emit sortChanged(id_param); 128 emit sortChanged(id_param);
127 switch(ts->kRep->getKeyType(ts->current_column)) { 129 switch(ts->kRep->getKeyType(ts->current_column)) {
128 /* work out what to raise */ 130 /* work out what to raise */
129 case kt_string: 131 case kt_string:
130 case kt_int: 132 case kt_int:
131 ws->raiseWidget(0); 133 ws->raiseWidget(0);
132 break; 134 break;
133 case kt_time: 135 case kt_time:
134 ws->raiseWidget(1); 136 ws->raiseWidget(1);
135 break; 137 break;
136 case kt_date: 138 case kt_date:
137 ws->raiseWidget(2); 139 ws->raiseWidget(2);
138 break; 140 break;
139 default: 141 default:
140 return; 142 return;
141 } 143 }
142} 144}
143 145
144/*! 146/*!
145 Opens the change key menu 147 Opens the change key menu
146*/ 148*/
147void TVBrowseKeyEntry::changeKeyMenuSlot() 149void TVBrowseKeyEntry::changeKeyMenuSlot()
148{ 150{
149 if(ts) 151 if(ts)
150 keyMenu->exec(changeKeyButton->mapToGlobal(QPoint(0,0))); 152 keyMenu->exec(changeKeyButton->mapToGlobal(QPoint(0,0)));
151} 153}
152/*! 154/*!
153 Blanks the key entry widget 155 Blanks the key entry widget
154 \TODO the actual implmentation 156 \TODO the actual implmentation
155*/ 157*/
156void TVBrowseKeyEntry::resetKeySlot() { 158void TVBrowseKeyEntry::resetKeySlot() {
157 ; 159 ;
158} 160}
159 161
160void TVBrowseKeyEntry::setTableState(TableState *t) { 162void TVBrowseKeyEntry::setTableState(TableState *t) {
161 int i; 163 int i;
162 ts = t; 164 ts = t;
163 165
164 /* clear the old */ 166 /* clear the old */
165 keyMenu->clear(); 167 keyMenu->clear();
166 168
167 for (i = 0; i < t->kRep->getNumFields(); i++) { 169 for (i = 0; i < t->kRep->getNumFields(); i++) {
168 keyMenu->insertItem(ts->kRep->getKeyName(i), this, 170 keyMenu->insertItem(ts->kRep->getKeyName(i), this,
169 SLOT(changeKeySlot(int)), 0, i); 171 SLOT(changeKeySlot(int)), 0, i);
170 keyMenu->setItemParameter(i, i); 172 keyMenu->setItemParameter(i, i);
171 } 173 }
172} 174}
173 175
174/*! 176/*!
175 Searches on the current value of the key entry provided that the 177 Searches on the current value of the key entry provided that the
176 current key is of type text WARNING, TODO fix memory leaks 178 current key is of type text WARNING, TODO fix memory leaks
177*/ 179*/
178void TVBrowseKeyEntry::searchOnText() 180void TVBrowseKeyEntry::searchOnText()
179{ 181{
180 void *sendkey; 182 void *sendkey;
181 int tmp; 183 int tmp;
182 184
183 switch(ts->kRep->getKeyType(ts->current_column)) { 185 switch(ts->kRep->getKeyType(ts->current_column)) {
184 /* work out what to raise */ 186 /* work out what to raise */
185 case kt_string: 187 case kt_string:
186 sendkey = (void *)new QString(textKey->text()); 188 sendkey = (void *)new QString(textKey->text());
187 break; 189 break;
188 case kt_int: { 190 case kt_int: {
189 bool ok; 191 bool ok;
190 tmp = textKey->text().toInt(&ok); 192 tmp = textKey->text().toInt(&ok);
191 sendkey = &tmp; 193 sendkey = &tmp;
192 if (!ok) 194 if (!ok)
193 return; 195 return;
194 break; 196 break;
195 } 197 }
196 case kt_time: { 198 case kt_time: {
197 bool ok; 199 bool ok;
198 int s,m,h; 200 int s,m,h;
199 s = secondKey->text().toInt(&ok); 201 s = secondKey->text().toInt(&ok);
200 if (!ok) 202 if (!ok)
@@ -207,36 +209,35 @@ void TVBrowseKeyEntry::searchOnText()
207 return; 209 return;
208 if(!QTime::isValid(h, m, s)) 210 if(!QTime::isValid(h, m, s))
209 return; 211 return;
210 sendkey = (void *) new QTime(h, m, s); 212 sendkey = (void *) new QTime(h, m, s);
211 break; 213 break;
212 } 214 }
213 case kt_date: { 215 case kt_date: {
214 bool ok; 216 bool ok;
215 int d,m,y; 217 int d,m,y;
216 d = dayKey->text().toInt(&ok); 218 d = dayKey->text().toInt(&ok);
217 if (!ok) 219 if (!ok)
218 return; 220 return;
219 m = monthKey->text().toInt(&ok); 221 m = monthKey->text().toInt(&ok);
220 if (!ok) 222 if (!ok)
221 return; 223 return;
222 y = yearKey->text().toInt(&ok); 224 y = yearKey->text().toInt(&ok);
223 if (!ok) 225 if (!ok)
224 return; 226 return;
225 if(!QDate::isValid(y, m, d)) 227 if(!QDate::isValid(y, m, d))
226 return; 228 return;
227 sendkey = (void *) new QDate(y, m, d); 229 sendkey = (void *) new QDate(y, m, d);
228 break; 230 break;
229 } 231 }
230 default: 232 default:
231 qWarning("TVBrowseKeyEntry::searchOnText() " 233 owarn << "TVBrowseKeyEntry::searchOnText() cannot work out data type" << oendl;
232 "cannot work out data type");
233 return; 234 return;
234 } 235 }
235 emit searchOnKey(ts->current_column, sendkey); 236 emit searchOnKey(ts->current_column, sendkey);
236} 237}
237 238
238/*! \fn void TVBrowseKeyEntry::searchOnKey(int currentKeyId, void *v) 239/*! \fn void TVBrowseKeyEntry::searchOnKey(int currentKeyId, void *v)
239 240
240 This signal indicates that a search on key index currentKeyId should be 241 This signal indicates that a search on key index currentKeyId should be
241 done searching for the value v. 242 done searching for the value v.
242*/ 243*/
diff --git a/noncore/apps/tableviewer/db/common.cpp b/noncore/apps/tableviewer/db/common.cpp
index b58af85..c35dbea 100644
--- a/noncore/apps/tableviewer/db/common.cpp
+++ b/noncore/apps/tableviewer/db/common.cpp
@@ -1,44 +1,44 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "common.h" 20#include "common.h"
21#include "datacache.h" 21#include "datacache.h"
22 22
23/* OPIE */ 23/* OPIE */
24#include <opie2/odebug.h> 24#include <opie2/odebug.h>
25#include <qpe/timestring.h> 25#include <qpe/timestring.h>
26using namespace Opie::Core; 26using namespace Opie::Core;
27 27
28/* QT */ 28/* QT */
29#include <qstring.h> 29#include <qstring.h>
30#include <qheader.h> 30#include <qheader.h>
31#include <qvector.h> 31#include <qvector.h>
32#include <qdatetime.h> 32#include <qdatetime.h>
33 33
34/* STD */ 34/* STD */
35#include <assert.h> 35#include <assert.h>
36#include <stdlib.h> 36#include <stdlib.h>
37 37
38static const int del_flag = 0x1; 38static const int del_flag = 0x1;
39static const int new_flag = 0x2; 39static const int new_flag = 0x2;
40 40
41/* Helper function */ 41/* Helper function */
42 42
43int parseNextNumber(QString *q) { 43int parseNextNumber(QString *q) {
44 QChar c; 44 QChar c;
@@ -67,55 +67,55 @@ int parseNextNumber(QString *q) {
67 67
68/*! 68/*!
69 \class QStringVector 69 \class QStringVector
70 \brief A Vector of QStrings that can be sorted and searched 70 \brief A Vector of QStrings that can be sorted and searched
71 71
72 Implmented in order to allow reverse lookup on the string name 72 Implmented in order to allow reverse lookup on the string name
73 73
74*/ 74*/
75 75
76/*! 76/*!
77 This function implements the compare function in order to allow the 77 This function implements the compare function in order to allow the
78 searching and sorting of the QStringVector to occur 78 searching and sorting of the QStringVector to occur
79 79
80 \returns an int which is either 80 \returns an int which is either
81 <UL> 81 <UL>
82 <LI> < 0 if the first string is smaller than the second,</LI> 82 <LI> < 0 if the first string is smaller than the second,</LI>
83 <LI> > 0 if the first string is bigger then the second,</LI> 83 <LI> > 0 if the first string is bigger then the second,</LI>
84 <LI> == 0 if the first string is equal to the second.</LI> 84 <LI> == 0 if the first string is equal to the second.</LI>
85 </UL> 85 </UL>
86*/ 86*/
87int QStringVector::compareItems(Item a, Item b) 87int QStringVector::compareItems(Item a, Item b)
88{ 88{
89 QString *qa = (QString *)a; 89 QString *qa = (QString *)a;
90 QString *qb = (QString *)b; 90 QString *qb = (QString *)b;
91 91
92 return QString::compare(*qa, *qb); 92 return QString::compare(*qa, *qb);
93} 93}
94 94
95/*! 95/*!
96 \class TVVariant 96 \class TVVariant
97 A way of abstracting void * and keeping information on 97 A way of abstracting void * and keeping information on
98 the keytypes and behaviours in one place 98 the keytypes and behaviours in one place
99*/ 99*/
100 100
101TVVariantPrivate::TVVariantPrivate() 101TVVariantPrivate::TVVariantPrivate()
102{ 102{
103 typ = TVVariant::Invalid; 103 typ = TVVariant::Invalid;
104} 104}
105 105
106TVVariantPrivate::TVVariantPrivate( TVVariantPrivate *d) 106TVVariantPrivate::TVVariantPrivate( TVVariantPrivate *d)
107{ 107{
108 switch(d->typ) 108 switch(d->typ)
109 { 109 {
110 case TVVariant::Invalid: 110 case TVVariant::Invalid:
111 break; 111 break;
112 case TVVariant::String: 112 case TVVariant::String:
113 value.ptr = new QString(*((QString *)d->value.ptr)); 113 value.ptr = new QString(*((QString *)d->value.ptr));
114 break; 114 break;
115 case TVVariant::Date: 115 case TVVariant::Date:
116 value.ptr = new QDate(*((QDate *)d->value.ptr)); 116 value.ptr = new QDate(*((QDate *)d->value.ptr));
117 break; 117 break;
118 case TVVariant::Time: 118 case TVVariant::Time:
119 value.ptr = new QTime(*((QTime *)d->value.ptr)); 119 value.ptr = new QTime(*((QTime *)d->value.ptr));
120 break; 120 break;
121 case TVVariant::Int: 121 case TVVariant::Int:
@@ -299,49 +299,49 @@ void TVVariant::load(QDataStream &s )
299 } 299 }
300 break; 300 break;
301 case Time: 301 case Time:
302 { 302 {
303 QTime *x = new QTime; 303 QTime *x = new QTime;
304 s >> *x; 304 s >> *x;
305 d->value.ptr = x; 305 d->value.ptr = x;
306 } 306 }
307 break; 307 break;
308 case Date: 308 case Date:
309 { 309 {
310 QDate *x = new QDate; 310 QDate *x = new QDate;
311 s >> *x; 311 s >> *x;
312 d->value.ptr = x; 312 d->value.ptr = x;
313 } 313 }
314 break; 314 break;
315 case Int: 315 case Int:
316 { 316 {
317 int x; 317 int x;
318 s >> x; 318 s >> x;
319 d->value.i = x; 319 d->value.i = x;
320 } 320 }
321 break; 321 break;
322 default: 322 default:
323 ofatal << "Unrecognized data type" << oendl; 323 ofatal << "Unrecognized data type" << oendl;
324 } 324 }
325} 325}
326 326
327void TVVariant::save( QDataStream &s ) const 327void TVVariant::save( QDataStream &s ) const
328{ 328{
329 s << type(); 329 s << type();
330 330
331 switch( d->typ ) { 331 switch( d->typ ) {
332 case String: 332 case String:
333 s << *((QString *)d->value.ptr); 333 s << *((QString *)d->value.ptr);
334 break; 334 break;
335 case Date: 335 case Date:
336 s << *((QDate *)d->value.ptr); 336 s << *((QDate *)d->value.ptr);
337 break; 337 break;
338 case Time: 338 case Time:
339 s << *((QTime *)d->value.ptr); 339 s << *((QTime *)d->value.ptr);
340 break; 340 break;
341 case Int: 341 case Int:
342 s << d->value.i; 342 s << d->value.i;
343 break; 343 break;
344 case Invalid: 344 case Invalid:
345 break; 345 break;
346 } 346 }
347} 347}
@@ -361,121 +361,121 @@ QDataStream& operator<<(QDataStream &s, const TVVariant& p)
361QDataStream& operator>> (QDataStream &s, TVVariant::KeyType& p) 361QDataStream& operator>> (QDataStream &s, TVVariant::KeyType& p)
362{ 362{
363 Q_UINT8 u = 0; 363 Q_UINT8 u = 0;
364 s >> u; 364 s >> u;
365 p = (TVVariant::KeyType) u; 365 p = (TVVariant::KeyType) u;
366 366
367 return s; 367 return s;
368} 368}
369 369
370QDataStream& operator<< (QDataStream& s, const TVVariant::KeyType& p) 370QDataStream& operator<< (QDataStream& s, const TVVariant::KeyType& p)
371{ 371{
372 s << (Q_UINT8)p; 372 s << (Q_UINT8)p;
373 return s; 373 return s;
374} 374}
375 375
376const QString TVVariant::toString() const 376const QString TVVariant::toString() const
377{ 377{
378 switch(d->typ) { 378 switch(d->typ) {
379 case String: 379 case String:
380 return *((QString*)d->value.ptr); 380 return *((QString*)d->value.ptr);
381 case Date: 381 case Date:
382 return ((QDate*)d->value.ptr)->toString(); 382 return ((QDate*)d->value.ptr)->toString();
383 case Time: 383 case Time:
384 return ((QTime*)d->value.ptr)->toString(); 384 return ((QTime*)d->value.ptr)->toString();
385 case Int: 385 case Int:
386 return QString::number(d->value.i); 386 return QString::number(d->value.i);
387 case Invalid: 387 case Invalid:
388 default: 388 default:
389 return QString::null; 389 return QString::null;
390 } 390 }
391 return QString::null; 391 return QString::null;
392} 392}
393 393
394// TODO DO, this properly, */ 394// TODO DO, this properly, */
395int TVVariant::toInt() const 395int TVVariant::toInt() const
396{ 396{
397 if(d->typ == Int) 397 if(d->typ == Int)
398 return d->value.i; 398 return d->value.i;
399 399
400 if(d->typ == String) { 400 if(d->typ == String) {
401 QString tmpq(*(QString *)d->value.ptr); 401 QString tmpq(*(QString *)d->value.ptr);
402 return parseNextNumber(&tmpq); 402 return parseNextNumber(&tmpq);
403 } 403 }
404 404
405 return 0; 405 return 0;
406} 406}
407 407
408const QDate TVVariant::toDate() const 408const QDate TVVariant::toDate() const
409{ 409{
410 if(d->typ == Date) 410 if(d->typ == Date)
411 return *((QDate *)d->value.ptr); 411 return *((QDate *)d->value.ptr);
412 412
413 if(d->typ == String) { 413 if(d->typ == String) {
414 QString q = toString(); 414 QString q = toString();
415 415
416 /* date format is day mon d yyyy */ 416 /* date format is day mon d yyyy */
417 /* ignore the first three letters, read the next 417 /* ignore the first three letters, read the next
418 three for month.. etc */ 418 three for month.. etc */
419 419
420 int day = parseNextNumber(&q); 420 int day = parseNextNumber(&q);
421 int month = parseNextNumber(&q); 421 int month = parseNextNumber(&q);
422 int year = parseNextNumber(&q); 422 int year = parseNextNumber(&q);
423 if (!QDate::isValid(year, month, day)) 423 if (!QDate::isValid(year, month, day))
424 return QDate(); 424 return QDate();
425 return QDate(year, month, day); 425 return QDate(year, month, day);
426 } 426 }
427 427
428 428
429 return QDate(); 429 return QDate();
430} 430}
431 431
432const QTime TVVariant::toTime() const 432const QTime TVVariant::toTime() const
433{ 433{
434 if(d->typ == Time) 434 if(d->typ == Time)
435 return *((QTime *)d->value.ptr); 435 return *((QTime *)d->value.ptr);
436 436
437 if(d->typ == String) { 437 if(d->typ == String) {
438 QString q = toString(); 438 QString q = toString();
439 int hour = parseNextNumber(&q); 439 int hour = parseNextNumber(&q);
440 int minute = parseNextNumber(&q); 440 int minute = parseNextNumber(&q);
441 int second = parseNextNumber(&q); 441 int second = parseNextNumber(&q);
442 int msecond = parseNextNumber(&q); 442 int msecond = parseNextNumber(&q);
443 if (!QTime::isValid(hour, minute, second, msecond)) 443 if (!QTime::isValid(hour, minute, second, msecond))
444 return QTime(); 444 return QTime();
445 return QTime(hour, minute, second, msecond); 445 return QTime(hour, minute, second, msecond);
446 } 446 }
447 447
448 return QTime(); 448 return QTime();
449} 449}
450 450
451#define TV_VARIANT_AS( f ) Q##f& TVVariant::as##f() { \ 451#define TV_VARIANT_AS( f ) Q##f& TVVariant::as##f() { \
452 if ( d->typ != f ) \ 452 if ( d->typ != f ) \
453 *this = TVVariant( to##f() ); \ 453 *this = TVVariant( to##f() ); \
454 else \ 454 else \
455 detach(); \ 455 detach(); \
456 return *((Q##f*)d->value.ptr); } 456 return *((Q##f*)d->value.ptr); }
457 457
458TV_VARIANT_AS(String) 458TV_VARIANT_AS(String)
459TV_VARIANT_AS(Date) 459TV_VARIANT_AS(Date)
460TV_VARIANT_AS(Time) 460TV_VARIANT_AS(Time)
461 461
462#undef TV_VARIANT_AS 462#undef TV_VARIANT_AS
463 463
464int& TVVariant::asInt() 464int& TVVariant::asInt()
465{ 465{
466 detach(); 466 detach();
467 if (d->typ != Int) { 467 if (d->typ != Int) {
468 d->value.i = toInt(); 468 d->value.i = toInt();
469 d->typ = Int; 469 d->typ = Int;
470 } 470 }
471 return d->value.i; 471 return d->value.i;
472} 472}
473 473
474/*! 474/*!
475 valid cast is 475 valid cast is
476 anything to String 476 anything to String
477 same to same 477 same to same
478*/ 478*/
479bool TVVariant::canCast(KeyType t) const 479bool TVVariant::canCast(KeyType t) const
480{ 480{
481 if(d->typ == t) 481 if(d->typ == t)
@@ -539,186 +539,186 @@ bool TVVariant::operator<( const TVVariant &v ) const
539 539
540bool TVVariant::operator>( const TVVariant &v ) const 540bool TVVariant::operator>( const TVVariant &v ) const
541{ 541{
542 switch(d->typ) { 542 switch(d->typ) {
543 case String: 543 case String:
544 return toString().lower() > v.toString().lower(); 544 return toString().lower() > v.toString().lower();
545 case Date: 545 case Date:
546 return toDate() > v.toDate(); 546 return toDate() > v.toDate();
547 case Time: 547 case Time:
548 return toTime() > v.toTime(); 548 return toTime() > v.toTime();
549 case Int: 549 case Int:
550 return toInt() > v.toInt(); 550 return toInt() > v.toInt();
551 case Invalid: 551 case Invalid:
552 default: 552 default:
553 break; 553 break;
554 } 554 }
555 return FALSE; 555 return FALSE;
556} 556}
557 557
558/*! True if n is closer to this than o */ 558/*! True if n is closer to this than o */
559bool TVVariant::closer(TVVariant n, TVVariant o) 559bool TVVariant::closer(TVVariant n, TVVariant o)
560{ 560{
561 /* Nothing is close to an invalid, so nothing can be closer */ 561 /* Nothing is close to an invalid, so nothing can be closer */
562 if(d->typ == Invalid) 562 if(d->typ == Invalid)
563 return FALSE; 563 return FALSE;
564 564
565 /* can't be closer if of different type */ 565 /* can't be closer if of different type */
566 if(n.type() != type()) 566 if(n.type() != type())
567 return FALSE; 567 return FALSE;
568 568
569 /* if new shares type, and old doesn't, then new is closer */ 569 /* if new shares type, and old doesn't, then new is closer */
570 if(o.type() != type()) 570 if(o.type() != type())
571 return TRUE; 571 return TRUE;
572 572
573 switch(type()){ 573 switch(type()){
574 case String: { 574 case String: {
575 /* case for strings is close is a substring.. closer is 575 /* case for strings is close is a substring.. closer is
576 * earlier alphabetically */ 576 * earlier alphabetically */
577 QString qs1 = n.toString().lower(); 577 QString qs1 = n.toString().lower();
578 QString qs2 = o.toString().lower(); 578 QString qs2 = o.toString().lower();
579 QString qsv = toString().lower(); 579 QString qsv = toString().lower();
580 580
581 if (!qs1.startsWith(qsv)) 581 if (!qs1.startsWith(qsv))
582 return FALSE; 582 return FALSE;
583 583
584 /* contains sub-str, if later than is not closer */ 584 /* contains sub-str, if later than is not closer */
585 if(QString::compare(qs1, qs2) > 0) 585 if(QString::compare(qs1, qs2) > 0)
586 return FALSE; 586 return FALSE;
587 return TRUE; 587 return TRUE;
588 } 588 }
589 case Int: { 589 case Int: {
590 /* case for int is smallest absolute difference */ 590 /* case for int is smallest absolute difference */
591 int i1 = n.toInt(); 591 int i1 = n.toInt();
592 int i2 = o.toInt(); 592 int i2 = o.toInt();
593 int iv = toInt(); 593 int iv = toInt();
594 594
595 int diff1 = (i1 - iv); 595 int diff1 = (i1 - iv);
596 if (diff1 < 0) 596 if (diff1 < 0)
597 diff1 = -diff1; 597 diff1 = -diff1;
598 int diff2 = (i2 - iv); 598 int diff2 = (i2 - iv);
599 if (diff2 < 0) 599 if (diff2 < 0)
600 diff2 = -diff2; 600 diff2 = -diff2;
601 601
602 if (diff1 < diff2) 602 if (diff1 < diff2)
603 return TRUE; 603 return TRUE;
604 return FALSE; 604 return FALSE;
605 } 605 }
606 case Date: { 606 case Date: {
607 QDate i1 = n.toDate(); 607 QDate i1 = n.toDate();
608 QDate i2 = o.toDate(); 608 QDate i2 = o.toDate();
609 QDate iv = toDate(); 609 QDate iv = toDate();
610 610
611 /* definition of closer is the least difference in days */ 611 /* definition of closer is the least difference in days */
612 int diff1 = i1.daysTo(iv); 612 int diff1 = i1.daysTo(iv);
613 if (diff1 < 0) 613 if (diff1 < 0)
614 diff1 = -diff1; 614 diff1 = -diff1;
615 int diff2 = i2.daysTo(iv); 615 int diff2 = i2.daysTo(iv);
616 if (diff2 < 0) 616 if (diff2 < 0)
617 diff2 = -diff2; 617 diff2 = -diff2;
618 618
619 if (diff1 < diff2) 619 if (diff1 < diff2)
620 return TRUE; 620 return TRUE;
621 return FALSE; 621 return FALSE;
622 } 622 }
623 case Time: { 623 case Time: {
624 QTime i1 = n.toTime(); 624 QTime i1 = n.toTime();
625 QTime i2 = o.toTime(); 625 QTime i2 = o.toTime();
626 QTime iv = toTime(); 626 QTime iv = toTime();
627 627
628 /* definition of closer is the least difference in days */ 628 /* definition of closer is the least difference in days */
629 int diff1 = i1.msecsTo(iv); 629 int diff1 = i1.msecsTo(iv);
630 if (diff1 < 0) 630 if (diff1 < 0)
631 diff1 = -diff1; 631 diff1 = -diff1;
632 int diff2 = i2.msecsTo(iv); 632 int diff2 = i2.msecsTo(iv);
633 if (diff2 < 0) 633 if (diff2 < 0)
634 diff2 = -diff2; 634 diff2 = -diff2;
635 if (diff1 < diff2) 635 if (diff1 < diff2)
636 return TRUE; 636 return TRUE;
637 return FALSE; 637 return FALSE;
638 } 638 }
639 default: 639 default:
640 /* don't know how to do 'closer' on this type, hence never closer 640 /* don't know how to do 'closer' on this type, hence never closer
641 * or even close */ 641 * or even close */
642 break; 642 break;
643 } 643 }
644 return FALSE; 644 return FALSE;
645} 645}
646 646
647/*! True if n is close to this */ 647/*! True if n is close to this */
648bool TVVariant::close(TVVariant n) 648bool TVVariant::close(TVVariant n)
649{ 649{
650 /* Nothing is close to an invalid, so nothing can be closer */ 650 /* Nothing is close to an invalid, so nothing can be closer */
651 if(type() == Invalid) 651 if(type() == Invalid)
652 return FALSE; 652 return FALSE;
653 653
654 /* can't be close if of different type */ 654 /* can't be close if of different type */
655 if(n.type() != type()) 655 if(n.type() != type())
656 return FALSE; 656 return FALSE;
657 657
658 switch(type()){ 658 switch(type()){
659 case String: { 659 case String: {
660 /* case for strings is close is a substring.. closer is 660 /* case for strings is close is a substring.. closer is
661 * earlier alphabetically */ 661 * earlier alphabetically */
662 QString qs1 = n.toString().lower(); 662 QString qs1 = n.toString().lower();
663 QString qsv = toString().lower(); 663 QString qsv = toString().lower();
664 664
665 if (!qs1.startsWith(qsv)) 665 if (!qs1.startsWith(qsv))
666 return FALSE; 666 return FALSE;
667 return TRUE; 667 return TRUE;
668 } 668 }
669 case Int: 669 case Int:
670 case Date: 670 case Date:
671 case Time: 671 case Time:
672 return TRUE; 672 return TRUE;
673 default: 673 default:
674 /* don't know how to do 'closer' on this type, hence never closer 674 /* don't know how to do 'closer' on this type, hence never closer
675 * or even close */ 675 * or even close */
676 break; 676 break;
677 } 677 }
678 return FALSE; 678 return FALSE;
679} 679}
680 680
681/*! 681/*!
682 \class Key 682 \class Key
683 \brief document me! 683 \brief document me!
684 684
685 document me! 685 document me!
686*/ 686*/
687 687
688Key::Key() : kname(), kexample(), kflags(0) { } 688Key::Key() : kname(), kexample(), kflags(0) { }
689 689
690Key::Key(QString name, TVVariant example, int flags) : 690Key::Key(QString name, TVVariant example, int flags) :
691 kname(name), kexample(example), kflags(flags) { } 691 kname(name), kexample(example), kflags(flags) { }
692 692
693Key::Key(const Key &other) 693Key::Key(const Key &other)
694{ 694{
695 kname = other.kname; 695 kname = other.kname;
696 kexample = other.kexample; 696 kexample = other.kexample;
697 kflags = other.kflags; 697 kflags = other.kflags;
698} 698}
699 699
700Key& Key::operator=(const Key& key) 700Key& Key::operator=(const Key& key)
701{ 701{
702 kname = key.kname; 702 kname = key.kname;
703 kexample = key.kexample; 703 kexample = key.kexample;
704 kflags = key.kflags; 704 kflags = key.kflags;
705 return *this; 705 return *this;
706} 706}
707 707
708QString Key::name() const 708QString Key::name() const
709{ 709{
710 return QString(kname); 710 return QString(kname);
711} 711}
712 712
713TVVariant Key::example() const 713TVVariant Key::example() const
714{ 714{
715 return TVVariant(kexample); 715 return TVVariant(kexample);
716} 716}
717 717
718TVVariant::KeyType Key::type() const 718TVVariant::KeyType Key::type() const
719{ 719{
720 return kexample.type(); 720 return kexample.type();
721} 721}
722 722
723void Key::setName(const QString &name) 723void Key::setName(const QString &name)
724{ 724{
@@ -756,206 +756,205 @@ bool Key::newFlag() const
756 756
757void Key::setDelFlag(bool v) 757void Key::setDelFlag(bool v)
758{ 758{
759 if(delFlag() != v) 759 if(delFlag() != v)
760 kflags = kflags ^ del_flag; 760 kflags = kflags ^ del_flag;
761} 761}
762 762
763void Key::setNewFlag(bool v) 763void Key::setNewFlag(bool v)
764{ 764{
765 if(newFlag() != v) 765 if(newFlag() != v)
766 kflags = kflags ^ new_flag; 766 kflags = kflags ^ new_flag;
767} 767}
768 768
769/*! 769/*!
770 \class KeyList 770 \class KeyList
771 \brief A represntation of keys used for a table. 771 \brief A represntation of keys used for a table.
772 772
773 The KeyList class is used to store the representation of keys used in table 773 The KeyList class is used to store the representation of keys used in table
774 headings by DBStore. It stores the names and types of the keys 774 headings by DBStore. It stores the names and types of the keys
775*/ 775*/
776 776
777/*! 777/*!
778 Constructs a KeyList 778 Constructs a KeyList
779*/ 779*/
780KeyList::KeyList() : QIntDict<Key>(20) 780KeyList::KeyList() : QIntDict<Key>(20)
781{ 781{
782 setAutoDelete(TRUE); 782 setAutoDelete(TRUE);
783} 783}
784 784
785/* Should be deep copy, but isn't */ 785/* Should be deep copy, but isn't */
786KeyList::KeyList(const KeyList &k) : QIntDict<Key>(k) 786KeyList::KeyList(const KeyList &k) : QIntDict<Key>(k)
787{ 787{
788 KeyListIterator it(k); 788 KeyListIterator it(k);
789 while(it.current()) { 789 while(it.current()) {
790 replace(it.currentKey(), new Key(*it.current())); 790 replace(it.currentKey(), new Key(*it.current()));
791 ++it; 791 ++it;
792 } 792 }
793 793
794 setAutoDelete(TRUE); 794 setAutoDelete(TRUE);
795} 795}
796 796
797/*! 797/*!
798 Destroys a KeyList 798 Destroys a KeyList
799*/ 799*/
800KeyList::~KeyList() { 800KeyList::~KeyList() {
801} 801}
802 802
803/* Do a comparision base on Keys */ 803/* Do a comparision base on Keys */
804bool KeyList::operator!=(const KeyList &other) 804bool KeyList::operator!=(const KeyList &other)
805{ 805{
806 KeyListIterator it(*this); 806 KeyListIterator it(*this);
807 807
808 if (other.getNumFields() != getNumFields()) 808 if (other.getNumFields() != getNumFields())
809 return TRUE; 809 return TRUE;
810 810
811 while(it.current()) { 811 while(it.current()) {
812 //it.currentKey(), it.current(); 812 //it.currentKey(), it.current();
813 if (other.getKeyName(it.currentKey()) != getKeyName(it.currentKey())) 813 if (other.getKeyName(it.currentKey()) != getKeyName(it.currentKey()))
814 return TRUE; 814 return TRUE;
815 if (other.getKeyType(it.currentKey()) != getKeyType(it.currentKey())) 815 if (other.getKeyType(it.currentKey()) != getKeyType(it.currentKey()))
816 return TRUE; 816 return TRUE;
817 ++it; 817 ++it;
818 } 818 }
819 return FALSE; 819 return FALSE;
820} 820}
821 821
822/*! 822/*!
823 Returns the number of keys stored in the KeyList 823 Returns the number of keys stored in the KeyList
824*/ 824*/
825int KeyList::getNumFields() const 825int KeyList::getNumFields() const
826{ 826{
827 return count(); 827 return count();
828} 828}
829 829
830/*! 830/*!
831 Adds a new key to the KeyList 831 Adds a new key to the KeyList
832 832
833 \param name the name of the new key 833 \param name the name of the new key
834 \param type the type of the new key 834 \param type the type of the new key
835*/ 835*/
836int KeyList::addKey(QString name, TVVariant example) 836int KeyList::addKey(QString name, TVVariant example)
837{ 837{
838 int i = count(); 838 int i = count();
839 while(find(i) && (i > -1)) 839 while(find(i) && (i > -1))
840 i--; 840 i--;
841 replace(i, new Key(name, example, 0)); 841 replace(i, new Key(name, example, 0));
842 return i; 842 return i;
843} 843}
844 844
845int KeyList::addKey(QString name, TVVariant::KeyType type) 845int KeyList::addKey(QString name, TVVariant::KeyType type)
846{ 846{
847 /* generate a valid type for the example? */ 847 /* generate a valid type for the example? */
848 TVVariant e = TVVariant("0"); 848 TVVariant e = TVVariant("0");
849 switch(type) { 849 switch(type) {
850 case TVVariant::String: 850 case TVVariant::String:
851 return addKey(name, TVVariant("<undefined>").asString()); 851 return addKey(name, TVVariant("<undefined>").asString());
852 break; 852 break;
853 case TVVariant::Date: 853 case TVVariant::Date:
854 return addKey(name, TVVariant(QDate::currentDate()).asDate()); 854 return addKey(name, TVVariant(QDate::currentDate()).asDate());
855 break; 855 break;
856 case TVVariant::Time: 856 case TVVariant::Time:
857 return addKey(name, TVVariant(QTime(0,0,0)).toTime()); 857 return addKey(name, TVVariant(QTime(0,0,0)).toTime());
858 break; 858 break;
859 case TVVariant::Int: 859 case TVVariant::Int:
860 return addKey(name, TVVariant(0).toInt()); 860 return addKey(name, TVVariant(0).toInt());
861 break; 861 break;
862 default: 862 default:
863 qWarning(QObject::tr("KeyList::addKey() Cannot make default " 863 owarn << "KeyList::addKey() Cannot make default value for type " << type << ", Key not added." << oendl;
864 "value for type %1, Key not added.").arg(type));
865 break; 864 break;
866 } 865 }
867 return -1; 866 return -1;
868} 867}
869 868
870void KeyList::setKeyFlags(int i, int flag) 869void KeyList::setKeyFlags(int i, int flag)
871{ 870{
872 if(find(i)) 871 if(find(i))
873 find(i)->setFlags(flag); 872 find(i)->setFlags(flag);
874} 873}
875 874
876int KeyList::getKeyFlags(int i) const 875int KeyList::getKeyFlags(int i) const
877{ 876{
878 if(find(i)) 877 if(find(i))
879 return find(i)->flags(); 878 return find(i)->flags();
880 return 0; 879 return 0;
881} 880}
882 881
883bool KeyList::checkNewFlag(int i) const 882bool KeyList::checkNewFlag(int i) const
884{ 883{
885 if (find(i)) 884 if (find(i))
886 return find(i)->newFlag(); 885 return find(i)->newFlag();
887 return false; 886 return false;
888} 887}
889 888
890void KeyList::setNewFlag(int i, bool f) 889void KeyList::setNewFlag(int i, bool f)
891{ 890{
892 if(!find(i)) 891 if(!find(i))
893 return; 892 return;
894 find(i)->setNewFlag(f); 893 find(i)->setNewFlag(f);
895} 894}
896 895
897bool KeyList::checkDeleteFlag(int i) const 896bool KeyList::checkDeleteFlag(int i) const
898{ 897{
899 if (find(i)) 898 if (find(i))
900 return find(i)->delFlag(); 899 return find(i)->delFlag();
901 return false; 900 return false;
902} 901}
903 902
904void KeyList::setDeleteFlag(int i, bool f) 903void KeyList::setDeleteFlag(int i, bool f)
905{ 904{
906 if(!find(i)) 905 if(!find(i))
907 return; 906 return;
908 find(i)->setDelFlag(f); 907 find(i)->setDelFlag(f);
909} 908}
910 909
911/*! 910/*!
912 Returns the name of the key at index i 911 Returns the name of the key at index i
913*/ 912*/
914QString KeyList::getKeyName(int i) const 913QString KeyList::getKeyName(int i) const
915{ 914{
916 if (find (i)) 915 if (find (i))
917 return find(i)->name(); 916 return find(i)->name();
918 return QString(); 917 return QString();
919} 918}
920 919
921void KeyList::setKeyName(int i, const QString &n) 920void KeyList::setKeyName(int i, const QString &n)
922{ 921{
923 if(find(i)) 922 if(find(i))
924 find(i)->setName(n); 923 find(i)->setName(n);
925} 924}
926 925
927/*! 926/*!
928 Returns the type of the key at index i 927 Returns the type of the key at index i
929*/ 928*/
930TVVariant::KeyType KeyList::getKeyType(int i) const 929TVVariant::KeyType KeyList::getKeyType(int i) const
931{ 930{
932 if(find(i)) 931 if(find(i))
933 return find(i)->type(); 932 return find(i)->type();
934 return TVVariant::Invalid; 933 return TVVariant::Invalid;
935} 934}
936 935
937void KeyList::setKeyType(int i, TVVariant::KeyType t) 936void KeyList::setKeyType(int i, TVVariant::KeyType t)
938{ 937{
939 if(!find(i)) 938 if(!find(i))
940 return; 939 return;
941 switch(t) { 940 switch(t) {
942 case TVVariant::String: 941 case TVVariant::String:
943 find(i)->setExample(TVVariant(QString("default"))); 942 find(i)->setExample(TVVariant(QString("default")));
944 return; 943 return;
945 case TVVariant::Int: 944 case TVVariant::Int:
946 find(i)->setExample(TVVariant(int(0))); 945 find(i)->setExample(TVVariant(int(0)));
947 return; 946 return;
948 case TVVariant::Date: 947 case TVVariant::Date:
949 find(i)->setExample(TVVariant(QDate::currentDate())); 948 find(i)->setExample(TVVariant(QDate::currentDate()));
950 return; 949 return;
951 case TVVariant::Time: 950 case TVVariant::Time:
952 find(i)->setExample(TVVariant(QTime(0,0,0,0))); 951 find(i)->setExample(TVVariant(QTime(0,0,0,0)));
953 return; 952 return;
954 default: 953 default:
955 break; 954 break;
956 } 955 }
957 return; 956 return;
958} 957}
959 958
960TVVariant KeyList::getKeyExample(int i) const 959TVVariant KeyList::getKeyExample(int i) const
961{ 960{
@@ -1019,328 +1018,326 @@ QDataStream &operator>>( QDataStream &s, KeyList &k)
1019 TVVariant type = TVVariant(); 1018 TVVariant type = TVVariant();
1020 QString name; 1019 QString name;
1021 1020
1022 s >> size; 1021 s >> size;
1023 1022
1024 for (i=0; i < size; i++) { 1023 for (i=0; i < size; i++) {
1025 s >> (Q_UINT16 &)index; 1024 s >> (Q_UINT16 &)index;
1026 s >> name; 1025 s >> name;
1027 s >> type; 1026 s >> type;
1028 s >> (Q_UINT16 &)flags; 1027 s >> (Q_UINT16 &)flags;
1029 k.replace(index, new Key(name, type, flags)); 1028 k.replace(index, new Key(name, type, flags));
1030 } 1029 }
1031 return s; 1030 return s;
1032} 1031}
1033 1032
1034/*! 1033/*!
1035 \class DataElem 1034 \class DataElem
1036 \brief A class representing a single row or element of a table in a DBStore 1035 \brief A class representing a single row or element of a table in a DBStore
1037 1036
1038 This class holds the data of a row in a table. 1037 This class holds the data of a row in a table.
1039*/ 1038*/
1040 1039
1041 1040
1042/*! 1041/*!
1043 Constructs a DataElem. This function needs a container because the 1042 Constructs a DataElem. This function needs a container because the
1044 size, types of keys and primary key are all defined by the containing 1043 size, types of keys and primary key are all defined by the containing
1045 database 1044 database
1046*/ 1045*/
1047DataElem::DataElem(DBStore *c) : values(20) 1046DataElem::DataElem(DBStore *c) : values(20)
1048{ 1047{
1049 int size; 1048 int size;
1050 contained = c; 1049 contained = c;
1051 size = c->getNumFields(); 1050 size = c->getNumFields();
1052 values.setAutoDelete(TRUE); 1051 values.setAutoDelete(TRUE);
1053} 1052}
1054 1053
1055/*! 1054/*!
1056 Destroys a DataElem and frees memory used by the DataElem 1055 Destroys a DataElem and frees memory used by the DataElem
1057*/ 1056*/
1058DataElem::~DataElem() { 1057DataElem::~DataElem() {
1059} 1058}
1060 1059
1061 1060
1062 1061
1063QDataStream &operator<<( QDataStream &s, const DataElem &d) 1062QDataStream &operator<<( QDataStream &s, const DataElem &d)
1064{ 1063{
1065 int size = d.getNumFields(); 1064 int size = d.getNumFields();
1066 1065
1067 s << size; /* redundent data but makes streaming easier */ 1066 s << size; /* redundent data but makes streaming easier */
1068 KeyList k = d.getKeys(); 1067 KeyList k = d.getKeys();
1069 1068
1070 KeyListIterator it(k); 1069 KeyListIterator it(k);
1071 1070
1072 while(it.current()) { 1071 while(it.current()) {
1073 s << (Q_UINT16)it.currentKey(); 1072 s << (Q_UINT16)it.currentKey();
1074 s << d.getField(it.currentKey()); 1073 s << d.getField(it.currentKey());
1075 ++it; 1074 ++it;
1076 } 1075 }
1077 return s; 1076 return s;
1078} 1077}
1079 1078
1080QDataStream &operator>>( QDataStream &s, DataElem &d) 1079QDataStream &operator>>( QDataStream &s, DataElem &d)
1081{ 1080{
1082 int i; 1081 int i;
1083 int size; 1082 int size;
1084 TVVariant t; 1083 TVVariant t;
1085 Q_UINT16 index = 0; 1084 Q_UINT16 index = 0;
1086 1085
1087 s >> size; /* redundent data but makes streaming easier */ 1086 s >> size; /* redundent data but makes streaming easier */
1088 if (size != d.getNumFields()) { 1087 if (size != d.getNumFields()) {
1089 owarn << "DataSize mis-match" << oendl; 1088 owarn << "DataSize mis-match" << oendl;
1090 return s; /* sanity check failed.. don't load */ 1089 return s; /* sanity check failed.. don't load */
1091 } 1090 }
1092 1091
1093 for(i = 0; i < size; i++) { 1092 for(i = 0; i < size; i++) {
1094 s >> index; 1093 s >> index;
1095 s >> t; 1094 s >> t;
1096 d.setField(index, t); 1095 d.setField(index, t);
1097 } 1096 }
1098 return s; 1097 return s;
1099} 1098}
1100 1099
1101/*! Returns the number of possible (not valid) fields in the data element */ 1100/*! Returns the number of possible (not valid) fields in the data element */
1102int DataElem::getNumFields() const 1101int DataElem::getNumFields() const
1103{ 1102{
1104 return contained->getNumFields(); 1103 return contained->getNumFields();
1105} 1104}
1106 1105
1107KeyList DataElem::getKeys() const 1106KeyList DataElem::getKeys() const
1108{ 1107{
1109 return *(contained->getKeys()); 1108 return *(contained->getKeys());
1110} 1109}
1111 1110
1112/*! 1111/*!
1113 This function determines whether field index i of the element has been 1112 This function determines whether field index i of the element has been
1114 set yet. 1113 set yet.
1115 1114
1116 \return A boolean value that is TRUE if the specfied field of this 1115 \return A boolean value that is TRUE if the specfied field of this
1117 element has been set and FALSE if the field has not yet been set 1116 element has been set and FALSE if the field has not yet been set
1118*/ 1117*/
1119bool DataElem::hasValidValue(int i) const 1118bool DataElem::hasValidValue(int i) const
1120{ 1119{
1121 if(!values.find(i)) 1120 if(!values.find(i))
1122 return FALSE; 1121 return FALSE;
1123 if(!contained->getKeys()->validIndex(i)) 1122 if(!contained->getKeys()->validIndex(i))
1124 return FALSE; 1123 return FALSE;
1125 return values.find(i)->isValid(); 1124 return values.find(i)->isValid();
1126} 1125}
1127 1126
1128/*! 1127/*!
1129 This function determines whether field name qs of the element has been 1128 This function determines whether field name qs of the element has been
1130 set yet. 1129 set yet.
1131 1130
1132 \return A boolean value that is TRUE if the specfied field of this 1131 \return A boolean value that is TRUE if the specfied field of this
1133 element has been set and FALSE if the field has not yet been set 1132 element has been set and FALSE if the field has not yet been set
1134*/ 1133*/
1135bool DataElem::hasValidValue(QString qs) const 1134bool DataElem::hasValidValue(QString qs) const
1136{ 1135{
1137 int i = contained->getKeyIndex(qs); 1136 int i = contained->getKeyIndex(qs);
1138 return hasValidValue(i); 1137 return hasValidValue(i);
1139} 1138}
1140 1139
1141/*! returns the type of the field specified by index i */ 1140/*! returns the type of the field specified by index i */
1142TVVariant::KeyType DataElem::getFieldType(int i) const 1141TVVariant::KeyType DataElem::getFieldType(int i) const
1143{ 1142{
1144 return contained->getKeyType(i); 1143 return contained->getKeyType(i);
1145} 1144}
1146 1145
1147/*! returns the type of the field specified by name qs */ 1146/*! returns the type of the field specified by name qs */
1148TVVariant::KeyType DataElem::getFieldType(QString qs) const 1147TVVariant::KeyType DataElem::getFieldType(QString qs) const
1149{ 1148{
1150 int i = contained->getKeyIndex(qs); 1149 int i = contained->getKeyIndex(qs);
1151 return contained->getKeyType(i); 1150 return contained->getKeyType(i);
1152} 1151}
1153 1152
1154/*! 1153/*!
1155 returns a pointer to the data stored in field index i for this 1154 returns a pointer to the data stored in field index i for this
1156 data element, (value may not be valid) 1155 data element, (value may not be valid)
1157*/ 1156*/
1158TVVariant DataElem::getField(int i) const 1157TVVariant DataElem::getField(int i) const
1159{ 1158{
1160 if(hasValidValue(i)) 1159 if(hasValidValue(i))
1161 return TVVariant(*values.find(i)); 1160 return TVVariant(*values.find(i));
1162 return TVVariant(); 1161 return TVVariant();
1163} 1162}
1164 1163
1165/*! 1164/*!
1166 returns a pointer to the data stored in field name qs for this 1165 returns a pointer to the data stored in field name qs for this
1167 data element, (value may not be valid) 1166 data element, (value may not be valid)
1168*/ 1167*/
1169TVVariant DataElem::getField(QString qs) const 1168TVVariant DataElem::getField(QString qs) const
1170{ 1169{
1171 int i = contained->getKeyIndex(qs); 1170 int i = contained->getKeyIndex(qs);
1172 return getField(i); 1171 return getField(i);
1173} 1172}
1174 1173
1175/*! 1174/*!
1176 Sets the value of the elements field index i to the value represented in 1175 Sets the value of the elements field index i to the value represented in
1177 the QString q. 1176 the QString q.
1178 1177
1179 \param i index of the field to set 1178 \param i index of the field to set
1180 \param q a string that can be parsed to get the value to be set 1179 \param q a string that can be parsed to get the value to be set
1181*/ 1180*/
1182void DataElem::setField(int i, QString q) 1181void DataElem::setField(int i, QString q)
1183{ 1182{
1184 /* from the type of the field, parse q and store */ 1183 /* from the type of the field, parse q and store */
1185 TVVariant::KeyType kt = contained->getKeyType(i); 1184 TVVariant::KeyType kt = contained->getKeyType(i);
1186 1185
1187 TVVariant t = TVVariant(q); 1186 TVVariant t = TVVariant(q);
1188 1187
1189 switch(kt) { 1188 switch(kt) {
1190 case TVVariant::Int: { 1189 case TVVariant::Int: {
1191 t.asInt(); 1190 t.asInt();
1192 setField(i, t); 1191 setField(i, t);
1193 return; 1192 return;
1194 } 1193 }
1195 case TVVariant::String: { 1194 case TVVariant::String: {
1196 t.asString(); 1195 t.asString();
1197 setField(i, t); 1196 setField(i, t);
1198 return; 1197 return;
1199 } 1198 }
1200 case TVVariant::Date: { 1199 case TVVariant::Date: {
1201 t.asDate(); 1200 t.asDate();
1202 setField(i, t); 1201 setField(i, t);
1203 return; 1202 return;
1204 } 1203 }
1205 case TVVariant::Time: { 1204 case TVVariant::Time: {
1206 t.asTime(); 1205 t.asTime();
1207 setField(i, t); 1206 setField(i, t);
1208 return; 1207 return;
1209 } 1208 }
1210 default: 1209 default:
1211 qWarning( 1210 owarn << "DataElem::setField(" << i << ", " << q << ") No valid type found" << oendl;
1212 QObject::tr("DataElem::setField(%1, %2) No valid type found").arg(i).arg(q)
1213 );
1214 } 1211 }
1215} 1212}
1216 1213
1217/*! 1214/*!
1218 Sets the value of the elements field index i to the value at the pointer 1215 Sets the value of the elements field index i to the value at the pointer
1219 value. 1216 value.
1220 1217
1221 \param i index of the field to set 1218 \param i index of the field to set
1222 \param value a pointer to the (already allocated) value to set 1219 \param value a pointer to the (already allocated) value to set
1223*/ 1220*/
1224void DataElem::setField(int i, TVVariant value) 1221void DataElem::setField(int i, TVVariant value)
1225{ 1222{
1226 if (value.isValid()) { 1223 if (value.isValid()) {
1227 values.remove(i); 1224 values.remove(i);
1228 values.replace(i, new TVVariant(value)); 1225 values.replace(i, new TVVariant(value));
1229 } 1226 }
1230} 1227}
1231 1228
1232/*! 1229/*!
1233 Sets the value of the elements field name qs to the value represented in 1230 Sets the value of the elements field name qs to the value represented in
1234 the QString q. 1231 the QString q.
1235 1232
1236 \param qs name of the field to set 1233 \param qs name of the field to set
1237 \param q a string that can be parsed to get the value to be set 1234 \param q a string that can be parsed to get the value to be set
1238*/ 1235*/
1239void DataElem::setField(QString qs, QString q) 1236void DataElem::setField(QString qs, QString q)
1240{ 1237{
1241 /* from the type of the field, parse q and store */ 1238 /* from the type of the field, parse q and store */
1242 int i = contained->getKeyIndex(qs); 1239 int i = contained->getKeyIndex(qs);
1243 setField(i, qs); 1240 setField(i, qs);
1244} 1241}
1245 1242
1246/*! 1243/*!
1247 Sets the value of the elements field name qs to the value at the pointer 1244 Sets the value of the elements field name qs to the value at the pointer
1248 value. 1245 value.
1249 1246
1250 \param qs name of the field to set 1247 \param qs name of the field to set
1251 \param value a pointer to the (already allocated) value to set 1248 \param value a pointer to the (already allocated) value to set
1252*/ 1249*/
1253void DataElem::setField(QString qs, TVVariant value) 1250void DataElem::setField(QString qs, TVVariant value)
1254{ 1251{
1255 int i = contained->getKeyIndex(qs); 1252 int i = contained->getKeyIndex(qs);
1256 setField(i, value); 1253 setField(i, value);
1257} 1254}
1258 1255
1259void DataElem::unsetField(int i) { 1256void DataElem::unsetField(int i) {
1260 values.remove(i); 1257 values.remove(i);
1261} 1258}
1262 1259
1263void DataElem::unsetField(QString qs) 1260void DataElem::unsetField(QString qs)
1264{ 1261{
1265 int i = contained->getKeyIndex(qs); 1262 int i = contained->getKeyIndex(qs);
1266 unsetField(i); 1263 unsetField(i);
1267} 1264}
1268 1265
1269/*! 1266/*!
1270 Converts the data element to a Rich Text QString 1267 Converts the data element to a Rich Text QString
1271*/ 1268*/
1272QString DataElem::toQString() const 1269QString DataElem::toQString() const
1273{ 1270{
1274 /* lets make an attempt at this function */ 1271 /* lets make an attempt at this function */
1275 int i; 1272 int i;
1276 QString scratch = ""; 1273 QString scratch = "";
1277 1274
1278 QIntDictIterator<TVVariant> it(values); 1275 QIntDictIterator<TVVariant> it(values);
1279 1276
1280 while (it.current()) { 1277 while (it.current()) {
1281 i = it.currentKey(); 1278 i = it.currentKey();
1282 if(hasValidValue(i)) { 1279 if(hasValidValue(i)) {
1283 scratch += "<B>" + contained->getKeyName(i) + ":</B> "; 1280 scratch += "<B>" + contained->getKeyName(i) + ":</B> ";
1284 scratch += getField(i).toString(); 1281 scratch += getField(i).toString();
1285 scratch += "<br>"; 1282 scratch += "<br>";
1286 } 1283 }
1287 ++it; 1284 ++it;
1288 } 1285 }
1289 return scratch; 1286 return scratch;
1290} 1287}
1291 1288
1292/*! formats individual fields to strings so can be displayed */ 1289/*! formats individual fields to strings so can be displayed */
1293QString DataElem::toQString(int i) const 1290QString DataElem::toQString(int i) const
1294{ 1291{
1295 if(hasValidValue(i)) { 1292 if(hasValidValue(i)) {
1296 return getField(i).toString(); 1293 return getField(i).toString();
1297 } 1294 }
1298 return ""; 1295 return "";
1299} 1296}
1300/*! formats individual fields to strings so can be sorted by QListView */ 1297/*! formats individual fields to strings so can be sorted by QListView */
1301QString DataElem::toSortableQString(int i) const 1298QString DataElem::toSortableQString(int i) const
1302{ 1299{
1303 QString scratch = ""; 1300 QString scratch = "";
1304 if(hasValidValue(i)) { 1301 if(hasValidValue(i)) {
1305 switch (contained->getKeyType(i)) { 1302 switch (contained->getKeyType(i)) {
1306 case TVVariant::String: { 1303 case TVVariant::String: {
1307 scratch += getField(i).toString(); 1304 scratch += getField(i).toString();
1308 break; 1305 break;
1309 } 1306 }
1310 case TVVariant::Int: { 1307 case TVVariant::Int: {
1311 scratch.sprintf("%08d", getField(i).toInt()); 1308 scratch.sprintf("%08d", getField(i).toInt());
1312 break; 1309 break;
1313 } 1310 }
1314 case TVVariant::Date: { 1311 case TVVariant::Date: {
1315 static QDate epochD(1800, 1, 1); 1312 static QDate epochD(1800, 1, 1);
1316 scratch.sprintf("%08d", 1313 scratch.sprintf("%08d",
1317 epochD.daysTo(getField(i).toDate())); 1314 epochD.daysTo(getField(i).toDate()));
1318 break; 1315 break;
1319 } 1316 }
1320 case TVVariant::Time: { 1317 case TVVariant::Time: {
1321 static QTime epochT(0, 0, 0); 1318 static QTime epochT(0, 0, 0);
1322 scratch.sprintf("%08d", 1319 scratch.sprintf("%08d",
1323 epochT.msecsTo(getField(i).toTime())); 1320 epochT.msecsTo(getField(i).toTime()));
1324 break; 1321 break;
1325 } 1322 }
1326 default: 1323 default:
1327 scratch += "Unknown type"; 1324 scratch += "Unknown type";
1328 break; 1325 break;
1329 } 1326 }
1330 } 1327 }
1331 return scratch; 1328 return scratch;
1332} 1329}
1333 1330
1334/* compare functions */ 1331/* compare functions */
1335 1332
1336bool DataElem::lessThan(int i, TVVariant v) const 1333bool DataElem::lessThan(int i, TVVariant v) const
1337{ 1334{
1338 if (!hasValidValue(i)) return FALSE; 1335 if (!hasValidValue(i)) return FALSE;
1339 1336
1340 if (getField(i).type() != v.type()) 1337 if (getField(i).type() != v.type())
1341 return FALSE; 1338 return FALSE;
1342 1339
1343 return (getField(i) < v); 1340 return (getField(i) < v);
1344} 1341}
1345 1342
1346bool DataElem::moreThan(int i, TVVariant v) const 1343bool DataElem::moreThan(int i, TVVariant v) const
@@ -1359,120 +1356,120 @@ bool DataElem::equalTo(int i, TVVariant v) const
1359 1356
1360 if (getField(i).type() != v.type()) 1357 if (getField(i).type() != v.type())
1361 return FALSE; 1358 return FALSE;
1362 1359
1363 return (getField(i) == v); 1360 return (getField(i) == v);
1364} 1361}
1365 1362
1366bool DataElem::contains(int i, TVVariant v) const 1363bool DataElem::contains(int i, TVVariant v) const
1367{ 1364{
1368 if (!hasValidValue(i)) return FALSE; 1365 if (!hasValidValue(i)) return FALSE;
1369 1366
1370 if (getField(i).type() != v.type()) 1367 if (getField(i).type() != v.type())
1371 return FALSE; 1368 return FALSE;
1372 1369
1373 switch(getField(i).type()) { 1370 switch(getField(i).type()) {
1374 case TVVariant::String: { 1371 case TVVariant::String: {
1375 QString qs1 = getField(i).toString().lower(); 1372 QString qs1 = getField(i).toString().lower();
1376 QString qs2 = v.toString().lower(); 1373 QString qs2 = v.toString().lower();
1377 if (qs1.contains(qs2) > 0) return TRUE; 1374 if (qs1.contains(qs2) > 0) return TRUE;
1378 break; 1375 break;
1379 } 1376 }
1380 /* meaningless for ints */ 1377 /* meaningless for ints */
1381 /* meaningless for time */ 1378 /* meaningless for time */
1382 /* meaningless for dates */ 1379 /* meaningless for dates */
1383 case TVVariant::Int: 1380 case TVVariant::Int:
1384 case TVVariant::Time: 1381 case TVVariant::Time:
1385 case TVVariant::Date: 1382 case TVVariant::Date:
1386 break; 1383 break;
1387 default: 1384 default:
1388 owarn << "Tried to compare unknown data type" << oendl; 1385 owarn << "Tried to compare unknown data type" << oendl;
1389 } 1386 }
1390 return FALSE; 1387 return FALSE;
1391} 1388}
1392 1389
1393bool DataElem::startsWith(int i, TVVariant v) const 1390bool DataElem::startsWith(int i, TVVariant v) const
1394{ 1391{
1395 if (!hasValidValue(i)) return FALSE; 1392 if (!hasValidValue(i)) return FALSE;
1396 1393
1397 if (getField(i).type() != v.type()) 1394 if (getField(i).type() != v.type())
1398 return FALSE; 1395 return FALSE;
1399 1396
1400 switch(getField(i).type()) { 1397 switch(getField(i).type()) {
1401 case TVVariant::String: { 1398 case TVVariant::String: {
1402 QString qs1 = getField(i).toString().lower(); 1399 QString qs1 = getField(i).toString().lower();
1403 QString qs2 = v.toString().lower(); 1400 QString qs2 = v.toString().lower();
1404 return qs1.startsWith(qs2); 1401 return qs1.startsWith(qs2);
1405 } 1402 }
1406 /* meaningless for ints */ 1403 /* meaningless for ints */
1407 /* meaningless for time */ 1404 /* meaningless for time */
1408 /* meaningless for dates */ 1405 /* meaningless for dates */
1409 case TVVariant::Int: 1406 case TVVariant::Int:
1410 case TVVariant::Time: 1407 case TVVariant::Time:
1411 case TVVariant::Date: 1408 case TVVariant::Date:
1412 return FALSE; 1409 return FALSE;
1413 default: 1410 default:
1414 owarn << "Tried to compare unknown data type" << oendl; 1411 owarn << "Tried to compare unknown data type" << oendl;
1415 } 1412 }
1416 return FALSE; 1413 return FALSE;
1417} 1414}
1418 1415
1419bool DataElem::endsWith(int i, TVVariant v) const 1416bool DataElem::endsWith(int i, TVVariant v) const
1420{ 1417{
1421 if (!hasValidValue(i)) return FALSE; 1418 if (!hasValidValue(i)) return FALSE;
1422 1419
1423 if (getField(i).type() != v.type()) 1420 if (getField(i).type() != v.type())
1424 return FALSE; 1421 return FALSE;
1425 1422
1426 switch(getField(i).type()) { 1423 switch(getField(i).type()) {
1427 case TVVariant::String: { 1424 case TVVariant::String: {
1428 QString qs1 = getField(i).toString().lower(); 1425 QString qs1 = getField(i).toString().lower();
1429 QString qs2 = v.toString().lower(); 1426 QString qs2 = v.toString().lower();
1430 return qs1.startsWith(qs2); 1427 return qs1.startsWith(qs2);
1431 } 1428 }
1432 /* meaningless for ints */ 1429 /* meaningless for ints */
1433 /* meaningless for time */ 1430 /* meaningless for time */
1434 /* meaningless for dates */ 1431 /* meaningless for dates */
1435 case TVVariant::Int: 1432 case TVVariant::Int:
1436 case TVVariant::Time: 1433 case TVVariant::Time:
1437 case TVVariant::Date: 1434 case TVVariant::Date:
1438 return FALSE; 1435 return FALSE;
1439 default: 1436 default:
1440 owarn << "Tried to compare unknown data type" << oendl; 1437 owarn << "Tried to compare unknown data type" << oendl;
1441 } 1438 }
1442 return FALSE; 1439 return FALSE;
1443} 1440}
1444 1441
1445/*! 1442/*!
1446 Determins which of the first to parameters are closer to the third, target 1443 Determins which of the first to parameters are closer to the third, target
1447 parameter. 1444 parameter.
1448 1445
1449 \return 1446 \return
1450 <UL> 1447 <UL>
1451 <LI>TRUE if the first element is a closer match to the target than the 1448 <LI>TRUE if the first element is a closer match to the target than the
1452 second element</LI> 1449 second element</LI>
1453 <LI>FALSE if the first element is not a closer match to the target than 1450 <LI>FALSE if the first element is not a closer match to the target than
1454 the second element</LI> 1451 the second element</LI>
1455 </UL> 1452 </UL>
1456*/ 1453*/
1457bool DataElem::closer(DataElem*d1, DataElem *d2, TVVariant target, int column) 1454bool DataElem::closer(DataElem*d1, DataElem *d2, TVVariant target, int column)
1458{ 1455{
1459 int type; 1456 int type;
1460 1457
1461 if(!d1) return FALSE; 1458 if(!d1) return FALSE;
1462 1459
1463 if (!d1->hasValidValue(column)) return FALSE; 1460 if (!d1->hasValidValue(column)) return FALSE;
1464 1461
1465 if(!target.isValid()) return FALSE; 1462 if(!target.isValid()) return FALSE;
1466 1463
1467 type = d1->getField(column).type(); 1464 type = d1->getField(column).type();
1468 1465
1469 if(d2) { 1466 if(d2) {
1470 if (type != d2->getField(column).type()) { 1467 if (type != d2->getField(column).type()) {
1471 /* can't do compare */ 1468 /* can't do compare */
1472 owarn << "Tried to compare two incompatable types" << oendl; 1469 owarn << "Tried to compare two incompatable types" << oendl;
1473 return FALSE; 1470 return FALSE;
1474 } 1471 }
1475 return target.closer(d1->getField(column), d2->getField(column)); 1472 return target.closer(d1->getField(column), d2->getField(column));
1476 } 1473 }
1477 return target.close(d1->getField(column)); 1474 return target.close(d1->getField(column));
1478} 1475}
diff --git a/noncore/apps/tableviewer/db/datacache.cpp b/noncore/apps/tableviewer/db/datacache.cpp
index 6380e1b..de57961 100644
--- a/noncore/apps/tableviewer/db/datacache.cpp
+++ b/noncore/apps/tableviewer/db/datacache.cpp
@@ -1,301 +1,301 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20/* 20/*
21 * This file is used to load the xml files that represent the database. 21 * This file is used to load the xml files that represent the database.
22 * The main requirment for said file is each data entry must contain a key, 22 * The main requirment for said file is each data entry must contain a key,
23 * otherwise any other data headings are allowed. 23 * otherwise any other data headings are allowed.
24 */ 24 */
25 25
26#include "datacache.h" 26#include "datacache.h"
27#include "xmlsource.h" 27#include "xmlsource.h"
28#include "csvsource.h" 28#include "csvsource.h"
29 29
30/* OPIE */ 30/* OPIE */
31#include <opie2/odebug.h> 31#include <opie2/odebug.h>
32using namespace Opie::Core; 32using namespace Opie::Core;
33 33
34/* QT */ 34/* QT */
35#include <qheader.h> 35#include <qheader.h>
36 36
37/* STD */ 37/* STD */
38#include <stdlib.h> 38#include <stdlib.h>
39 39
40#define INIT_TABLE_SIZE 128 40#define INIT_TABLE_SIZE 128
41 41
42/*! 42/*!
43 \class DBStore datastore.h 43 \class DBStore datastore.h
44 44
45 \brief The DBStore class is the class responsible for storing, sorting and 45 \brief The DBStore class is the class responsible for storing, sorting and
46 searching the data loaded by the application 46 searching the data loaded by the application
47 47
48*/ 48*/
49 49
50/*! 50/*!
51 Constructs a DBStore item 51 Constructs a DBStore item
52*/ 52*/
53DBStore::DBStore() 53DBStore::DBStore()
54{ 54{
55 name = ""; 55 name = "";
56 number_elems = 0; 56 number_elems = 0;
57 full = false; 57 full = false;
58 kRep = new KeyList(); 58 kRep = new KeyList();
59 master_table.resize(INIT_TABLE_SIZE); 59 master_table.resize(INIT_TABLE_SIZE);
60 table_size = INIT_TABLE_SIZE; 60 table_size = INIT_TABLE_SIZE;
61 61
62 current_elem = 0; 62 current_elem = 0;
63 archive = 0; 63 archive = 0;
64} 64}
65 65
66//TODO 66//TODO
67/*! 67/*!
68 Reinitializes the table to empty (include a resize of the master table, 68 Reinitializes the table to empty (include a resize of the master table,
69 which should free some memory) 69 which should free some memory)
70*/ 70*/
71void DBStore::freeTable() 71void DBStore::freeTable()
72{ 72{
73 name = ""; 73 name = "";
74 if(archive) { 74 if(archive) {
75 delete archive; 75 delete archive;
76 archive = 0; 76 archive = 0;
77 } 77 }
78 kRep->clear(); /* clear the current key list */ 78 kRep->clear(); /* clear the current key list */
79 79
80 number_elems = 0; 80 number_elems = 0;
81 table_size = INIT_TABLE_SIZE; 81 table_size = INIT_TABLE_SIZE;
82 master_table.resize(table_size); 82 master_table.resize(table_size);
83 full = false; 83 full = false;
84 current_elem = 0; 84 current_elem = 0;
85} 85}
86 86
87/*! 87/*!
88 Removes all items from the DBStore and destroys the DBStore 88 Removes all items from the DBStore and destroys the DBStore
89*/ 89*/
90DBStore::~DBStore() 90DBStore::~DBStore()
91{ 91{
92 freeTable(); 92 freeTable();
93} 93}
94 94
95/*! 95/*!
96 This function opens the given xml file, loads it and sets up the 96 This function opens the given xml file, loads it and sets up the
97 appropriate data structures. 97 appropriate data structures.
98 98
99 \param file_name A string representing the name of the file to be opened 99 \param file_name A string representing the name of the file to be opened
100 \return true if successful, false otherwise. 100 \return true if successful, false otherwise.
101*/ 101*/
102bool DBStore::openSource(QIODevice *inDev, const QString &source) { 102bool DBStore::openSource(QIODevice *inDev, const QString &source) {
103 103
104 /* first check if db is already open, if contains data.. then clear */ 104 /* first check if db is already open, if contains data.. then clear */
105 if(number_elems > 0) { 105 if(number_elems > 0) {
106 freeTable(); 106 freeTable();
107 } 107 }
108 108
109 if (source == "text/x-xml-tableviewer") { 109 if (source == "text/x-xml-tableviewer") {
110 archive = new DBXml(this); 110 archive = new DBXml(this);
111 } else if (source == "text/csv") { 111 } else if (source == "text/csv") {
112 archive = new DBCsv(this); 112 archive = new DBCsv(this);
113 } else 113 } else
114 return false; 114 return false;
115 115
116 return (archive->openSource(inDev)); 116 return (archive->openSource(inDev));
117} 117}
118 118
119bool DBStore::saveSource(QIODevice *outDev, const QString &source) 119bool DBStore::saveSource(QIODevice *outDev, const QString &source)
120{ 120{
121 /* saving a new file */ 121 /* saving a new file */
122 if(!archive) { 122 if(!archive) {
123 if (source == "text/x-xml-tableviewer") { 123 if (source == "text/x-xml-tableviewer") {
124 archive = new DBXml(this); 124 archive = new DBXml(this);
125 } else if (source == "text/x-xml-tableviewer") { 125 } else if (source == "text/x-xml-tableviewer") {
126 archive = new DBCsv(this); 126 archive = new DBCsv(this);
127 } else 127 } else
128 return false; 128 return false;
129 } 129 }
130 130
131 /* changing file type */ 131 /* changing file type */
132 if(archive->type() != source) { 132 if(archive->type() != source) {
133 delete archive; 133 delete archive;
134 if (source == "text/x-xml-tableviewer") { 134 if (source == "text/x-xml-tableviewer") {
135 archive = new DBXml(this); 135 archive = new DBXml(this);
136 } else if (source == "text/x-xml-tableviewer") { 136 } else if (source == "text/x-xml-tableviewer") {
137 archive = new DBCsv(this); 137 archive = new DBCsv(this);
138 } else 138 } else
139 return false; 139 return false;
140 } 140 }
141 141
142 return (archive->saveSource(outDev)); 142 return (archive->saveSource(outDev));
143} 143}
144 144
145/*! 145/*!
146 This function is used to add new elements to the database. If the database 146 This function is used to add new elements to the database. If the database
147 has already reached the maximum allowable size this function does not alter 147 has already reached the maximum allowable size this function does not alter
148 the database. 148 the database.
149 149
150 \param delm An already allocated and initialized data element to be added 150 \param delm An already allocated and initialized data element to be added
151*/ 151*/
152void DBStore::addItem(DataElem *delem) 152void DBStore::addItem(DataElem *delem)
153{ 153{
154 addItemInternal(delem); 154 addItemInternal(delem);
155} 155}
156 156
157void DBStore::addItemInternal(DataElem *delem) 157void DBStore::addItemInternal(DataElem *delem)
158{ 158{
159 /* if already full, don't over fill, do a qWarning though */ 159 /* if already full, don't over fill, do a owarn though */
160 if (full) { 160 if (full) {
161 owarn << "Attempted to add items to already full table" << oendl; 161 owarn << "Attempted to add items to already full table" << oendl;
162 return; 162 return;
163 } 163 }
164 164
165 master_table.insert(number_elems, delem); 165 master_table.insert(number_elems, delem);
166 166
167 current_elem = number_elems; 167 current_elem = number_elems;
168 number_elems++; 168 number_elems++;
169 169
170 if(number_elems >= table_size) { 170 if(number_elems >= table_size) {
171 /* filled current table, double if we can */ 171 /* filled current table, double if we can */
172 table_size = table_size << 1; 172 table_size = table_size << 1;
173 173
174 /* check that the new table size is still valid, i.e. that we didn't 174 /* check that the new table size is still valid, i.e. that we didn't
175 just shift the 1 bit of the end of the int. */ 175 just shift the 1 bit of the end of the int. */
176 if (!table_size) { 176 if (!table_size) {
177 full = true; 177 full = true;
178 /* no point in doing antying else. */ 178 /* no point in doing antying else. */
179 return; 179 return;
180 } 180 }
181 master_table.resize(table_size); 181 master_table.resize(table_size);
182 } 182 }
183} 183}
184 184
185void DBStore::removeItem(DataElem *r) 185void DBStore::removeItem(DataElem *r)
186{ 186{
187 int position = master_table.findRef(r); 187 int position = master_table.findRef(r);
188 if(position != -1) { 188 if(position != -1) {
189 /* there is at least one item, this is it */ 189 /* there is at least one item, this is it */
190 /* replace this with the last element, decrease the element count */ 190 /* replace this with the last element, decrease the element count */
191 master_table.insert(position, master_table.at(--number_elems)); 191 master_table.insert(position, master_table.at(--number_elems));
192 master_table.remove(number_elems); 192 master_table.remove(number_elems);
193 delete r; 193 delete r;
194 } 194 }
195} 195}
196 196
197/*! 197/*!
198 Sets the name of the database 198 Sets the name of the database
199 199
200 \param n A string representing the new name of the database. 200 \param n A string representing the new name of the database.
201*/ 201*/
202void DBStore::setName(const QString &n) 202void DBStore::setName(const QString &n)
203{ 203{
204 name = n; 204 name = n;
205} 205}
206 206
207/*! 207/*!
208 Gets the name of the database 208 Gets the name of the database
209 209
210 \return A string representing the name of the database. 210 \return A string representing the name of the database.
211*/ 211*/
212QString DBStore::getName() 212QString DBStore::getName()
213{ 213{
214 return name; 214 return name;
215} 215}
216 216
217/*! 217/*!
218 Retrieves a pointer to the key representation of the database for 218 Retrieves a pointer to the key representation of the database for
219 other classes to use as reference. 219 other classes to use as reference.
220 220
221 \return a pointer to the databases key representaion 221 \return a pointer to the databases key representaion
222*/ 222*/
223KeyList *DBStore::getKeys() 223KeyList *DBStore::getKeys()
224{ 224{
225 return kRep; 225 return kRep;
226} 226}
227 227
228/*! 228/*!
229 sets the database's key representation the passed pointer 229 sets the database's key representation the passed pointer
230 \param a pointer to a key representaton 230 \param a pointer to a key representaton
231*/ 231*/
232void DBStore::setKeys(KeyList *k) 232void DBStore::setKeys(KeyList *k)
233{ 233{
234 kRep = k; 234 kRep = k;
235} 235}
236 236
237/*! 237/*!
238 Sets the current element to the first element of the database 238 Sets the current element to the first element of the database
239*/ 239*/
240void DBStore::first() 240void DBStore::first()
241{ 241{
242 current_elem = 0; 242 current_elem = 0;
243} 243}
244 244
245/*! 245/*!
246 Sets the current element to the last element of the database 246 Sets the current element to the last element of the database
247*/ 247*/
248void DBStore::last() 248void DBStore::last()
249{ 249{
250 current_elem = number_elems - 1; 250 current_elem = number_elems - 1;
251} 251}
252 252
253/*! 253/*!
254 Sets the current element to the next element of the database if 254 Sets the current element to the next element of the database if
255 there exists an element after the current one. 255 there exists an element after the current one.
256*/ 256*/
257bool DBStore::next() 257bool DBStore::next()
258{ 258{
259 unsigned int new_current_elem = current_elem + 1; 259 unsigned int new_current_elem = current_elem + 1;
260 if (current_elem < number_elems) 260 if (current_elem < number_elems)
261 /* was valid before inc (it is possible but unlikely that inc current 261 /* was valid before inc (it is possible but unlikely that inc current
262 elem will change it from invalid to valid) */ 262 elem will change it from invalid to valid) */
263 if (new_current_elem < number_elems) { 263 if (new_current_elem < number_elems) {
264 /* is valid after inc */ 264 /* is valid after inc */
265 current_elem = new_current_elem; 265 current_elem = new_current_elem;
266 return true; 266 return true;
267 } 267 }
268 return false; 268 return false;
269} 269}
270 270
271/*! 271/*!
272 Sets the current element to the previous element of the database if 272 Sets the current element to the previous element of the database if
273 there exists an element before the current one. 273 there exists an element before the current one.
274*/ 274*/
275bool DBStore::previous() 275bool DBStore::previous()
276{ 276{
277 unsigned int new_current_elem = current_elem -1; 277 unsigned int new_current_elem = current_elem -1;
278 if (current_elem < number_elems) 278 if (current_elem < number_elems)
279 /* was valid */ 279 /* was valid */
280 if (new_current_elem < number_elems) { 280 if (new_current_elem < number_elems) {
281 /* still is (if was 0, then now -1, but as is unsigned will wrap 281 /* still is (if was 0, then now -1, but as is unsigned will wrap
282 and hence be invalid */ 282 and hence be invalid */
283 current_elem = new_current_elem; 283 current_elem = new_current_elem;
284 return true; 284 return true;
285 } 285 }
286 return false; 286 return false;
287} 287}
288 288
289/*! 289/*!
290 Returns the current data element in the database. Which element is current 290 Returns the current data element in the database. Which element is current
291 is affected by newly added items, findItem, next, previous, first and 291 is affected by newly added items, findItem, next, previous, first and
292 last functions 292 last functions
293 293
294 \return a pointer to the current data element 294 \return a pointer to the current data element
295*/ 295*/
296DataElem *DBStore::getCurrentData() 296DataElem *DBStore::getCurrentData()
297{ 297{
298 if (current_elem >= number_elems) 298 if (current_elem >= number_elems)
299 return NULL; 299 return NULL;
300 return master_table[current_elem]; 300 return master_table[current_elem];
301} 301}
diff --git a/noncore/apps/tableviewer/db/datacache.h b/noncore/apps/tableviewer/db/datacache.h
index c5dc637..e38050c 100644
--- a/noncore/apps/tableviewer/db/datacache.h
+++ b/noncore/apps/tableviewer/db/datacache.h
@@ -6,125 +6,131 @@
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21/* 21/*
22 * This file is used to load the xml files that represent the database. 22 * This file is used to load the xml files that represent the database.
23 * The main requirment for said file is each data entry must contain a key, 23 * The main requirment for said file is each data entry must contain a key,
24 * otherwise any other data headings are allowed. 24 * otherwise any other data headings are allowed.
25 */ 25 */
26 26
27#ifndef __DATACACHE_H__ 27#ifndef __DATACACHE_H__
28#define __DATACACHE_H__ 28#define __DATACACHE_H__
29 29
30#include "common.h"
31
32/* OPIE */
33#include <opie2/odebug.h>
34using namespace Opie::Core;
35
36/* QT */
30#include <qstring.h> 37#include <qstring.h>
31#include <qvector.h> 38#include <qvector.h>
32#include "common.h"
33 39
34class DBStore; 40class DBStore;
35 41
36/*! Abstract class that defines how database stuff can be accessed */ 42/*! Abstract class that defines how database stuff can be accessed */
37class DBAccess { 43class DBAccess {
38public: 44public:
39 45
40// DBAccess(DBStore *d) { dstore = d; } 46// DBAccess(DBStore *d) { dstore = d; }
41 virtual ~DBAccess() {} 47 virtual ~DBAccess() {}
42 48
43 virtual QString type() { 49 virtual QString type() {
44 return QString(); 50 return QString();
45 } 51 }
46 52
47 virtual bool openSource(QIODevice *) { 53 virtual bool openSource(QIODevice *) {
48 qWarning("DBAccess::openSource not yet implemented"); 54 owarn << "DBAccess::openSource not yet implemented" << oendl;
49 return false; 55 return false;
50 } 56 }
51 57
52 virtual bool saveSource(QIODevice *) { 58 virtual bool saveSource(QIODevice *) {
53 qWarning("DBAccess::saveSource(QString) not yet implemented"); 59 owarn << "DBAccess::saveSource(QString) not yet implemented" << oendl;
54 return false; 60 return false;
55 } 61 }
56 62
57protected: 63protected:
58 DBStore *dstore; 64 DBStore *dstore;
59 QString source_name; 65 QString source_name;
60}; 66};
61 67
62class DBStore { 68class DBStore {
63public: 69public:
64 DBStore(); 70 DBStore();
65 ~DBStore(); 71 ~DBStore();
66 72
67 bool openSource(QIODevice *, const QString &source); 73 bool openSource(QIODevice *, const QString &source);
68 bool saveSource(QIODevice *, const QString &source); 74 bool saveSource(QIODevice *, const QString &source);
69 75
70 // Add an item 76 // Add an item
71 void addItem(DataElem *); 77 void addItem(DataElem *);
72 void addItemInternal(DataElem *); 78 void addItemInternal(DataElem *);
73 void removeItem(DataElem *); 79 void removeItem(DataElem *);
74 80
75 // Set the name of the database 81 // Set the name of the database
76 void setName(const QString &name); 82 void setName(const QString &name);
77 83
78 // Get the name of the database 84 // Get the name of the database
79 QString getName(); 85 QString getName();
80 86
81 KeyList *getKeys(); 87 KeyList *getKeys();
82 void setKeys(KeyList *); 88 void setKeys(KeyList *);
83 89
84 /*! gets the number of fields defined in the database */ 90 /*! gets the number of fields defined in the database */
85 inline int getNumFields() { 91 inline int getNumFields() {
86 return kRep->getNumFields(); 92 return kRep->getNumFields();
87 } 93 }
88 94
89 /*! gets the index of a key given its name */ 95 /*! gets the index of a key given its name */
90 inline int getKeyIndex(QString qs) { 96 inline int getKeyIndex(QString qs) {
91 return kRep->getKeyIndex(qs); 97 return kRep->getKeyIndex(qs);
92 } 98 }
93 99
94 /*! gets the type of a key given its index */ 100 /*! gets the type of a key given its index */
95 inline TVVariant::KeyType getKeyType(int i) { 101 inline TVVariant::KeyType getKeyType(int i) {
96 return kRep->getKeyType(i); 102 return kRep->getKeyType(i);
97 } 103 }
98 104
99 /*! gets the name of a key given its index */ 105 /*! gets the name of a key given its index */
100 inline QString getKeyName(int i) { 106 inline QString getKeyName(int i) {
101 return kRep->getKeyName(i); 107 return kRep->getKeyName(i);
102 } 108 }
103 109
104// Access functions.. iterator type stuff 110// Access functions.. iterator type stuff
105 111
106 void first(); 112 void first();
107 void last(); 113 void last();
108 114
109 bool next(); 115 bool next();
110 bool previous(); 116 bool previous();
111 117
112 DataElem* getCurrentData(); 118 DataElem* getCurrentData();
113 119
114private: 120private:
115 /* does the work of freeing used memory */ 121 /* does the work of freeing used memory */
116 void freeTable(); 122 void freeTable();
117 QString name; 123 QString name;
118 124
119 QVector<DataElem> master_table; 125 QVector<DataElem> master_table;
120 DBAccess *archive; 126 DBAccess *archive;
121 127
122 KeyList *kRep; 128 KeyList *kRep;
123 129
124 unsigned int number_elems; 130 unsigned int number_elems;
125 unsigned int table_size; /* should always be a power of 2 */ 131 unsigned int table_size; /* should always be a power of 2 */
126 bool full; /* since because we are using an int for indexing there is 132 bool full; /* since because we are using an int for indexing there is
127 an upper limit on the number of items we can store. */ 133 an upper limit on the number of items we can store. */
128 unsigned int current_elem; 134 unsigned int current_elem;
129}; 135};
130#endif 136#endif
diff --git a/noncore/apps/tableviewer/ui/browsekeyentry.cpp b/noncore/apps/tableviewer/ui/browsekeyentry.cpp
index 42e24dd..6b78437 100644
--- a/noncore/apps/tableviewer/ui/browsekeyentry.cpp
+++ b/noncore/apps/tableviewer/ui/browsekeyentry.cpp
@@ -1,206 +1,205 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "browsekeyentry.h" 20#include "browsekeyentry.h"
21#include "commonwidgets.h" 21#include "commonwidgets.h"
22 22
23#include <opie2/odebug.h>
24using namespace Opie::Core;
25
23#include <qtoolbutton.h> 26#include <qtoolbutton.h>
24#include <qwidgetstack.h> 27#include <qwidgetstack.h>
25#include <qlayout.h> 28#include <qlayout.h>
26#include <qlineedit.h> 29#include <qlineedit.h>
27#include <qpushbutton.h> 30#include <qpushbutton.h>
28#include <qpopupmenu.h> 31#include <qpopupmenu.h>
29#include <qhbox.h> 32#include <qhbox.h>
30#include <qdatetime.h> 33#include <qdatetime.h>
31 34
32#include <qheader.h>
33// For qWarning(const char *)
34
35/*! 35/*!
36 \class TVBrowseKeyEntry 36 \class TVBrowseKeyEntry
37 \brief a Widget used enter keys into the TVBrowseViewWidget 37 \brief a Widget used enter keys into the TVBrowseViewWidget
38 38
39 The TVBrowseKeyEntry Widget provides the facility to enter 39 The TVBrowseKeyEntry Widget provides the facility to enter
40 various key types to be search on in the table. The key can be changed 40 various key types to be search on in the table. The key can be changed
41 and the entry field will update to the correct sort of widget appropriately 41 and the entry field will update to the correct sort of widget appropriately
42*/ 42*/
43 43
44/*! 44/*!
45 Constructs the widget 45 Constructs the widget
46*/ 46*/
47TVBrowseKeyEntry::TVBrowseKeyEntry(QWidget *parent, const char *name, WFlags f) 47TVBrowseKeyEntry::TVBrowseKeyEntry(QWidget *parent, const char *name, WFlags f)
48 : QWidget(parent, name, f) 48 : QWidget(parent, name, f)
49{ 49{
50 QHBoxLayout *h_layout = new QHBoxLayout(this); 50 QHBoxLayout *h_layout = new QHBoxLayout(this);
51 51
52 textKey = new QLineEdit(this, 0); 52 textKey = new QLineEdit(this, 0);
53 intKey = new IntEdit(this, 0); 53 intKey = new IntEdit(this, 0);
54 dateKey = new DateEdit(this, 0); 54 dateKey = new DateEdit(this, 0);
55 timeKey = new TimeEdit(this, 0); 55 timeKey = new TimeEdit(this, 0);
56 56
57 resetButton = new QPushButton(this, "reset"); 57 resetButton = new QPushButton(this, "reset");
58 resetButton->setMinimumSize(QSize(50, 0)); 58 resetButton->setMinimumSize(QSize(50, 0));
59 resetButton->setText(tr("Reset")); 59 resetButton->setText(tr("Reset"));
60 60
61 changeKeyButton = new QToolButton(this, "changekey"); 61 changeKeyButton = new QToolButton(this, "changekey");
62 // TODO The icon stuff. 62 // TODO The icon stuff.
63 changeKeyButton->setText(tr("key")); 63 changeKeyButton->setText(tr("key"));
64 64
65 totalKeys = 0; 65 totalKeys = 0;
66 ts = 0; 66 ts = 0;
67 keyMenu = new QPopupMenu(this, "keymenu"); 67 keyMenu = new QPopupMenu(this, "keymenu");
68 68
69 ws = new QWidgetStack(this, 0); 69 ws = new QWidgetStack(this, 0);
70 ws->addWidget(textKey, TVVariant::String); 70 ws->addWidget(textKey, TVVariant::String);
71 ws->addWidget(intKey, TVVariant::Int); 71 ws->addWidget(intKey, TVVariant::Int);
72 ws->addWidget(timeKey, TVVariant::Time); 72 ws->addWidget(timeKey, TVVariant::Time);
73 ws->addWidget(dateKey, TVVariant::Date); 73 ws->addWidget(dateKey, TVVariant::Date);
74 74
75 ws->raiseWidget(TVVariant::String); 75 ws->raiseWidget(TVVariant::String);
76 76
77 // TODO connect slots and signals.... 77 // TODO connect slots and signals....
78 connect(changeKeyButton, SIGNAL(clicked()), 78 connect(changeKeyButton, SIGNAL(clicked()),
79 this, SLOT(changeKeyMenuSlot())); 79 this, SLOT(changeKeyMenuSlot()));
80 80
81 connect(resetButton, SIGNAL(clicked()), 81 connect(resetButton, SIGNAL(clicked()),
82 textKey, SLOT(clear())); 82 textKey, SLOT(clear()));
83 connect(resetButton, SIGNAL(clicked()), 83 connect(resetButton, SIGNAL(clicked()),
84 intKey, SLOT(clear())); 84 intKey, SLOT(clear()));
85 connect(resetButton, SIGNAL(clicked()), 85 connect(resetButton, SIGNAL(clicked()),
86 dateKey, SLOT(clear())); 86 dateKey, SLOT(clear()));
87 connect(resetButton, SIGNAL(clicked()), 87 connect(resetButton, SIGNAL(clicked()),
88 timeKey, SLOT(clear())); 88 timeKey, SLOT(clear()));
89 89
90 h_layout->addWidget(ws); 90 h_layout->addWidget(ws);
91 h_layout->addWidget(resetButton); 91 h_layout->addWidget(resetButton);
92 h_layout->addWidget(changeKeyButton); 92 h_layout->addWidget(changeKeyButton);
93 93
94 connect(textKey, SIGNAL(textChanged(const QString&)), 94 connect(textKey, SIGNAL(textChanged(const QString&)),
95 this, SLOT(searchOnText())); 95 this, SLOT(searchOnText()));
96 connect(intKey, SIGNAL(valueChanged(int)), 96 connect(intKey, SIGNAL(valueChanged(int)),
97 this, SLOT(searchOnText())); 97 this, SLOT(searchOnText()));
98 connect(dateKey, SIGNAL(valueChanged(const QDate&)), 98 connect(dateKey, SIGNAL(valueChanged(const QDate&)),
99 this, SLOT(searchOnText())); 99 this, SLOT(searchOnText()));
100 connect(timeKey, SIGNAL(valueChanged(const QTime&)), 100 connect(timeKey, SIGNAL(valueChanged(const QTime&)),
101 this, SLOT(searchOnText())); 101 this, SLOT(searchOnText()));
102} 102}
103 103
104/*! 104/*!
105 Destructs the widget 105 Destructs the widget
106*/ 106*/
107TVBrowseKeyEntry::~TVBrowseKeyEntry() 107TVBrowseKeyEntry::~TVBrowseKeyEntry()
108{ 108{
109} 109}
110 110
111/*! 111/*!
112 Changes which key the user intends to search on 112 Changes which key the user intends to search on
113 113
114 \param id_param the index of the key future searches should be base on 114 \param id_param the index of the key future searches should be base on
115*/ 115*/
116void TVBrowseKeyEntry::changeKeySlot(int id_param) 116void TVBrowseKeyEntry::changeKeySlot(int id_param)
117{ 117{
118 if(ts) { 118 if(ts) {
119 emit sortChanged(id_param); 119 emit sortChanged(id_param);
120 ws->raiseWidget(ts->kRep->getKeyType(ts->current_column)); 120 ws->raiseWidget(ts->kRep->getKeyType(ts->current_column));
121 } 121 }
122} 122}
123 123
124/*! 124/*!
125 Opens the change key menu 125 Opens the change key menu
126*/ 126*/
127void TVBrowseKeyEntry::changeKeyMenuSlot() 127void TVBrowseKeyEntry::changeKeyMenuSlot()
128{ 128{
129 if(ts) 129 if(ts)
130 keyMenu->exec(changeKeyButton->mapToGlobal(QPoint(0,0))); 130 keyMenu->exec(changeKeyButton->mapToGlobal(QPoint(0,0)));
131} 131}
132 132
133 133
134void TVBrowseKeyEntry::setTableState(TableState *t) { 134void TVBrowseKeyEntry::setTableState(TableState *t) {
135 ts = t; 135 ts = t;
136} 136}
137 137
138void TVBrowseKeyEntry::rebuildKeys() { 138void TVBrowseKeyEntry::rebuildKeys() {
139 int i; 139 int i;
140 if (!ts) return; 140 if (!ts) return;
141 if (!ts->kRep) return; 141 if (!ts->kRep) return;
142 142
143 /* clear the old */ 143 /* clear the old */
144 keyMenu->clear(); 144 keyMenu->clear();
145 145
146 KeyListIterator it(*ts->kRep); 146 KeyListIterator it(*ts->kRep);
147 147
148 for (i = 0; i < ts->kRep->getNumFields(); i++) { 148 for (i = 0; i < ts->kRep->getNumFields(); i++) {
149 keyMenu->insertItem(it.current()->name(), this, 149 keyMenu->insertItem(it.current()->name(), this,
150 SLOT(changeKeySlot(int)), 0, i); 150 SLOT(changeKeySlot(int)), 0, i);
151 keyMenu->setItemParameter(i, it.currentKey()); 151 keyMenu->setItemParameter(i, it.currentKey());
152 ++it; 152 ++it;
153 } 153 }
154} 154}
155 155
156void TVBrowseKeyEntry::reset() 156void TVBrowseKeyEntry::reset()
157{ 157{
158 textKey->clear(); 158 textKey->clear();
159 intKey->clear(); 159 intKey->clear();
160 dateKey->clear(); 160 dateKey->clear();
161 timeKey->clear(); 161 timeKey->clear();
162 162
163 keyMenu->clear(); 163 keyMenu->clear();
164} 164}
165/*! 165/*!
166 Searches on the current value of the key entry provided that the 166 Searches on the current value of the key entry provided that the
167 current key is of type text WARNING, TODO fix memory leaks 167 current key is of type text WARNING, TODO fix memory leaks
168*/ 168*/
169void TVBrowseKeyEntry::searchOnText() 169void TVBrowseKeyEntry::searchOnText()
170{ 170{
171 TVVariant sendkey; 171 TVVariant sendkey;
172 172
173 if (!ts) 173 if (!ts)
174 return; 174 return;
175 175
176 switch(ts->kRep->getKeyType(ts->current_column)) { 176 switch(ts->kRep->getKeyType(ts->current_column)) {
177 case TVVariant::String: 177 case TVVariant::String:
178 sendkey = TVVariant(QString(textKey->text())); 178 sendkey = TVVariant(QString(textKey->text()));
179 break; 179 break;
180 case TVVariant::Int: { 180 case TVVariant::Int: {
181 sendkey = TVVariant(intKey->value()); 181 sendkey = TVVariant(intKey->value());
182 break; 182 break;
183 } 183 }
184 case TVVariant::Time: { 184 case TVVariant::Time: {
185 sendkey = TVVariant(QTime(timeKey->time())); 185 sendkey = TVVariant(QTime(timeKey->time()));
186 break; 186 break;
187 } 187 }
188 case TVVariant::Date: { 188 case TVVariant::Date: {
189 sendkey = TVVariant(QDate(dateKey->date())); 189 sendkey = TVVariant(QDate(dateKey->date()));
190 break; 190 break;
191 } 191 }
192 case TVVariant::Invalid: 192 case TVVariant::Invalid:
193 break; 193 break;
194 default: 194 default:
195 qWarning("TVBrowseKeyEntry::searchOnText() " 195 owarn << "TVBrowseKeyEntry::searchOnText() cannot work out data type" << oendl;
196 "cannot work out data type");
197 return; 196 return;
198 } 197 }
199 emit searchOnKey(ts->current_column, sendkey); 198 emit searchOnKey(ts->current_column, sendkey);
200} 199}
201 200
202/*! \fn void TVBrowseKeyEntry::searchOnKey(int currentKeyId, TVVariant) 201/*! \fn void TVBrowseKeyEntry::searchOnKey(int currentKeyId, TVVariant)
203 202
204 This signal indicates that a search on key index currentKeyId should be 203 This signal indicates that a search on key index currentKeyId should be
205 done searching for the value v. 204 done searching for the value v.
206*/ 205*/
diff --git a/noncore/apps/tableviewer/ui/filterkeyentry.cpp b/noncore/apps/tableviewer/ui/filterkeyentry.cpp
index d108fbd..4d74d6b 100644
--- a/noncore/apps/tableviewer/ui/filterkeyentry.cpp
+++ b/noncore/apps/tableviewer/ui/filterkeyentry.cpp
@@ -1,46 +1,51 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "filterkeyentry.h" 20#include "filterkeyentry.h"
21#include "commonwidgets.h" 21#include "commonwidgets.h"
22 22
23/* OPIE */
24#include <opie2/odebug.h>
25using namespace Opie::Core;
26
27/* QT */
23#include <qwidgetstack.h> 28#include <qwidgetstack.h>
24#include <qcombobox.h> 29#include <qcombobox.h>
25#include <qlayout.h> 30#include <qlayout.h>
26#include <qlineedit.h> 31#include <qlineedit.h>
27#include <qsizepolicy.h> 32#include <qsizepolicy.h>
28#include <qdatetime.h> 33#include <qdatetime.h>
29#include <qhbox.h> 34#include <qhbox.h>
30 35
31TVFilterKeyEntry::TVFilterKeyEntry(QWidget *parent, const char *name, WFlags f) 36TVFilterKeyEntry::TVFilterKeyEntry(QWidget *parent, const char *name, WFlags f)
32 : QWidget(parent, name, f) 37 : QWidget(parent, name, f)
33{ 38{
34 int stack_elem = 0; 39 int stack_elem = 0;
35 40
36 layout = new QHBoxLayout(this, 0); 41 layout = new QHBoxLayout(this, 0);
37 layout->setSpacing(0); 42 layout->setSpacing(0);
38 layout->setMargin(0); 43 layout->setMargin(0);
39 44
40 textEntry = new QHBox(this, 0); 45 textEntry = new QHBox(this, 0);
41 textEntry->setSpacing(0); 46 textEntry->setSpacing(0);
42 textEntry->setMargin(0); 47 textEntry->setMargin(0);
43 48
44 intEntry = new QHBox(this, 0); 49 intEntry = new QHBox(this, 0);
45 intEntry->setSpacing(0); 50 intEntry->setSpacing(0);
46 intEntry->setMargin(0); 51 intEntry->setMargin(0);
@@ -77,76 +82,76 @@ TVFilterKeyEntry::TVFilterKeyEntry(QWidget *parent, const char *name, WFlags f)
77 82
78 /* Build the time combo list */ 83 /* Build the time combo list */
79 timeCombo->insertItem("less than"); 84 timeCombo->insertItem("less than");
80 timeCombo->insertItem("more than"); 85 timeCombo->insertItem("more than");
81 timeCombo->insertItem("equal to"); 86 timeCombo->insertItem("equal to");
82 87
83 dateCombo = new QComboBox(dateEntry, 0); 88 dateCombo = new QComboBox(dateEntry, 0);
84 dateKey = new DateEdit(dateEntry, 0); 89 dateKey = new DateEdit(dateEntry, 0);
85 90
86 /* Build the date combo list */ 91 /* Build the date combo list */
87 dateCombo->insertItem("less than"); 92 dateCombo->insertItem("less than");
88 dateCombo->insertItem("more than"); 93 dateCombo->insertItem("more than");
89 dateCombo->insertItem("equal to"); 94 dateCombo->insertItem("equal to");
90 95
91 ts = 0; 96 ts = 0;
92 97
93 ws = new QWidgetStack(this, 0); 98 ws = new QWidgetStack(this, 0);
94 ws->setMargin(0); 99 ws->setMargin(0);
95 ws->addWidget(textEntry, TVVariant::String); 100 ws->addWidget(textEntry, TVVariant::String);
96 ws->addWidget(intEntry, TVVariant::Int); 101 ws->addWidget(intEntry, TVVariant::Int);
97 ws->addWidget(timeEntry, TVVariant::Time); 102 ws->addWidget(timeEntry, TVVariant::Time);
98 ws->addWidget(dateEntry, TVVariant::Date); 103 ws->addWidget(dateEntry, TVVariant::Date);
99 104
100 /* connect the signals down */ 105 /* connect the signals down */
101 connect(textKey, SIGNAL(textChanged(const QString&)), 106 connect(textKey, SIGNAL(textChanged(const QString&)),
102 this, SIGNAL(valueChanged())); 107 this, SIGNAL(valueChanged()));
103 connect(intKey, SIGNAL(valueChanged(int)), 108 connect(intKey, SIGNAL(valueChanged(int)),
104 this, SIGNAL(valueChanged())); 109 this, SIGNAL(valueChanged()));
105 connect(dateKey, SIGNAL(valueChanged(const QDate&)), 110 connect(dateKey, SIGNAL(valueChanged(const QDate&)),
106 this, SIGNAL(valueChanged())); 111 this, SIGNAL(valueChanged()));
107 connect(timeKey, SIGNAL(valueChanged(const QTime&)), 112 connect(timeKey, SIGNAL(valueChanged(const QTime&)),
108 this, SIGNAL(valueChanged())); 113 this, SIGNAL(valueChanged()));
109 114
110 connect(intCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged())); 115 connect(intCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged()));
111 connect(textCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged())); 116 connect(textCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged()));
112 connect(timeCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged())); 117 connect(timeCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged()));
113 connect(dateCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged())); 118 connect(dateCombo, SIGNAL(activated(int)), this, SIGNAL(valueChanged()));
114 119
115 ws->raiseWidget(TVVariant::String); 120 ws->raiseWidget(TVVariant::String);
116 layout->addWidget(ws); 121 layout->addWidget(ws);
117 122
118 current_type = TVVariant::String; 123 current_type = TVVariant::String;
119} 124}
120 125
121/*! 126/*!
122 Destructs the widget 127 Destructs the widget
123*/ 128*/
124TVFilterKeyEntry::~TVFilterKeyEntry() 129TVFilterKeyEntry::~TVFilterKeyEntry()
125{ 130{
126} 131}
127 132
128void TVFilterKeyEntry::setKey(int i) 133void TVFilterKeyEntry::setKey(int i)
129{ 134{
130 135
131 if (!ts) return; 136 if (!ts) return;
132 if (!ts->kRep) return; 137 if (!ts->kRep) return;
133 138
134 /* set up to raise appropriate widget set */ 139 /* set up to raise appropriate widget set */
135 if (current_type != ts->kRep->getKeyType(i)) { 140 if (current_type != ts->kRep->getKeyType(i)) {
136 current_type = ts->kRep->getKeyType(i); 141 current_type = ts->kRep->getKeyType(i);
137 ws->raiseWidget(current_type); 142 ws->raiseWidget(current_type);
138 } 143 }
139} 144}
140 145
141void TVFilterKeyEntry::setTableState(TableState *t) { 146void TVFilterKeyEntry::setTableState(TableState *t) {
142 int i; 147 int i;
143 ts = t; 148 ts = t;
144 if(!t) return; 149 if(!t) return;
145 if (!t->kRep) 150 if (!t->kRep)
146 return; 151 return;
147 if (t->kRep->getNumFields() < 1) 152 if (t->kRep->getNumFields() < 1)
148 return; 153 return;
149 setKey(0); 154 setKey(0);
150 /* set up the the menu stuff.. */ 155 /* set up the the menu stuff.. */
151} 156}
152 157
@@ -162,47 +167,46 @@ CmpType TVFilterKeyEntry::getCompareType()
162 CmpType k = (CmpType) intCombo->currentItem(); 167 CmpType k = (CmpType) intCombo->currentItem();
163 return k; 168 return k;
164 } 169 }
165 case TVVariant::Time: { 170 case TVVariant::Time: {
166 CmpType k = (CmpType) timeCombo->currentItem(); 171 CmpType k = (CmpType) timeCombo->currentItem();
167 return k; 172 return k;
168 } 173 }
169 case TVVariant::Date: { 174 case TVVariant::Date: {
170 CmpType k = (CmpType) dateCombo->currentItem(); 175 CmpType k = (CmpType) dateCombo->currentItem();
171 return k; 176 return k;
172 } 177 }
173 default: 178 default:
174 break; 179 break;
175 } 180 }
176 return ct_equal; 181 return ct_equal;
177} 182}
178 183
179/* MUST return a valid pointer */ 184/* MUST return a valid pointer */
180TVVariant TVFilterKeyEntry::getCompareValue() 185TVVariant TVFilterKeyEntry::getCompareValue()
181{ 186{
182 TVVariant sendkey; 187 TVVariant sendkey;
183 int tmp; 188 int tmp;
184 189
185 switch(current_type) { 190 switch(current_type) {
186 case TVVariant::String: 191 case TVVariant::String:
187 sendkey = TVVariant(QString(textKey->text())); 192 sendkey = TVVariant(QString(textKey->text()));
188 break; 193 break;
189 case TVVariant::Int: { 194 case TVVariant::Int: {
190 sendkey = TVVariant(intKey->value()); 195 sendkey = TVVariant(intKey->value());
191 break; 196 break;
192 } 197 }
193 case TVVariant::Time: { 198 case TVVariant::Time: {
194 sendkey = TVVariant(QTime(timeKey->time())); 199 sendkey = TVVariant(QTime(timeKey->time()));
195 break; 200 break;
196 } 201 }
197 case TVVariant::Date: { 202 case TVVariant::Date: {
198 sendkey = TVVariant(QDate(dateKey->date())); 203 sendkey = TVVariant(QDate(dateKey->date()));
199 break; 204 break;
200 } 205 }
201 default: { 206 default: {
202 sendkey = TVVariant(0); 207 sendkey = TVVariant(0);
203 qWarning("TVFilterKeyEntry::getCompareValue() " 208 owarn << "TVFilterKeyEntry::getCompareValue() cannot work out data type" << oendl;
204 "cannot work out data type");
205 } 209 }
206 } 210 }
207 return sendkey; 211 return sendkey;
208} 212}
diff --git a/noncore/apps/tableviewer/ui/tvfilterview.cpp b/noncore/apps/tableviewer/ui/tvfilterview.cpp
index 22f1fb7..198c8b5 100644
--- a/noncore/apps/tableviewer/ui/tvfilterview.cpp
+++ b/noncore/apps/tableviewer/ui/tvfilterview.cpp
@@ -1,59 +1,65 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "tvfilterview.h" 20#include "tvfilterview.h"
21
22/* OPIE */
23#include <opie2/odebug.h>
24#include <qpe/qpeapplication.h>
25using namespace Opie::Core;
26
27/* QT */
21#include <qtoolbutton.h> 28#include <qtoolbutton.h>
22#include <qcombobox.h> 29#include <qcombobox.h>
23#include <qlistview.h> 30#include <qlistview.h>
24#include <qlayout.h> 31#include <qlayout.h>
25#include <qheader.h> 32#include <qheader.h>
26#include <qpushbutton.h> 33#include <qpushbutton.h>
27#include <qlabel.h> 34#include <qlabel.h>
28 35
29#include <qpe/qpeapplication.h>
30 36
31TVFilterView::TVFilterView(TableState *t, QWidget* parent, 37TVFilterView::TVFilterView(TableState *t, QWidget* parent,
32 const char *name, WFlags fl ) : QDialog(parent, name, TRUE, fl) 38 const char *name, WFlags fl ) : QDialog(parent, name, TRUE, fl)
33{ 39{
34 if ( !name ) 40 if ( !name )
35 setName( "Filter View" ); 41 setName( "Filter View" );
36 42
37 QVBoxLayout *vlayout = new QVBoxLayout(this); 43 QVBoxLayout *vlayout = new QVBoxLayout(this);
38 44
39 display = new QListView(this, "display"); 45 display = new QListView(this, "display");
40 display->addColumn("Key"); 46 display->addColumn("Key");
41 display->addColumn("Constraint"); 47 display->addColumn("Constraint");
42 display->addColumn("Value"); 48 display->addColumn("Value");
43 display->header()->setClickEnabled(FALSE); 49 display->header()->setClickEnabled(FALSE);
44 display->header()->setResizeEnabled(FALSE); 50 display->header()->setResizeEnabled(FALSE);
45 51
46 vlayout->addWidget(display); 52 vlayout->addWidget(display);
47 53
48 QHBoxLayout *hlayout = new QHBoxLayout; 54 QHBoxLayout *hlayout = new QHBoxLayout;
49 hlayout->addItem(new QSpacerItem(20, 20, QSizePolicy::Expanding, QSizePolicy::Minimum)); 55 hlayout->addItem(new QSpacerItem(20, 20, QSizePolicy::Expanding, QSizePolicy::Minimum));
50 56
51 newFilterButton = new QPushButton(this, "new Filter"); 57 newFilterButton = new QPushButton(this, "new Filter");
52 newFilterButton->setMaximumSize(QSize(50, 32767)); 58 newFilterButton->setMaximumSize(QSize(50, 32767));
53 newFilterButton->setText("New"); 59 newFilterButton->setText("New");
54 hlayout->addWidget(newFilterButton); 60 hlayout->addWidget(newFilterButton);
55 61
56 deleteFilterButton = new QPushButton(this, "delete Filter"); 62 deleteFilterButton = new QPushButton(this, "delete Filter");
57 deleteFilterButton->setMaximumSize(QSize(50, 32767)); 63 deleteFilterButton->setMaximumSize(QSize(50, 32767));
58 deleteFilterButton->setText("Delete"); 64 deleteFilterButton->setText("Delete");
59 hlayout->addWidget(deleteFilterButton); 65 hlayout->addWidget(deleteFilterButton);
@@ -67,240 +73,239 @@ TVFilterView::TVFilterView(TableState *t, QWidget* parent,
67 73
68 QHBoxLayout *hlayout2 = new QHBoxLayout; 74 QHBoxLayout *hlayout2 = new QHBoxLayout;
69 75
70 keyNameCombo = new QComboBox(FALSE, this, "key name"); 76 keyNameCombo = new QComboBox(FALSE, this, "key name");
71 keyNameCombo->setEnabled(FALSE); 77 keyNameCombo->setEnabled(FALSE);
72 hlayout2->addWidget(keyNameCombo); 78 hlayout2->addWidget(keyNameCombo);
73 79
74 QLabel *label = new QLabel(this); 80 QLabel *label = new QLabel(this);
75 label->setText("has value"); 81 label->setText("has value");
76 hlayout2->addWidget(label); 82 hlayout2->addWidget(label);
77 83
78 keyEntry = new TVFilterKeyEntry(this, "key entry"); 84 keyEntry = new TVFilterKeyEntry(this, "key entry");
79 keyEntry->setEnabled(FALSE); 85 keyEntry->setEnabled(FALSE);
80 86
81 vlayout->addLayout(hlayout2); 87 vlayout->addLayout(hlayout2);
82 vlayout->addWidget(keyEntry); 88 vlayout->addWidget(keyEntry);
83 89
84 connect(newFilterButton, SIGNAL( clicked() ), this, SLOT( newTerm() )); 90 connect(newFilterButton, SIGNAL( clicked() ), this, SLOT( newTerm() ));
85 connect(deleteFilterButton, SIGNAL( clicked() ), this, SLOT( deleteTerm())); 91 connect(deleteFilterButton, SIGNAL( clicked() ), this, SLOT( deleteTerm()));
86 connect(clearFilterButton, SIGNAL( clicked() ), this, SLOT( clearTerms())); 92 connect(clearFilterButton, SIGNAL( clicked() ), this, SLOT( clearTerms()));
87 93
88 connect(keyEntry, SIGNAL(valueChanged()), this, SLOT( updateTerm() )); 94 connect(keyEntry, SIGNAL(valueChanged()), this, SLOT( updateTerm() ));
89 connect(keyNameCombo, SIGNAL(activated(int)), this, SLOT( updateTerm() )); 95 connect(keyNameCombo, SIGNAL(activated(int)), this, SLOT( updateTerm() ));
90 96
91 connect(display, SIGNAL(selectionChanged(QListViewItem*)), this, 97 connect(display, SIGNAL(selectionChanged(QListViewItem*)), this,
92 SLOT(setTerm(QListViewItem*))); 98 SLOT(setTerm(QListViewItem*)));
93 99
94 ts = t; 100 ts = t;
95 current = 0; 101 current = 0;
96 terms.setAutoDelete(true); 102 terms.setAutoDelete(true);
97 do_filter = false; 103 do_filter = false;
98 104
99#ifdef Q_WS_QWS 105#ifdef Q_WS_QWS
100 QPEApplication::showDialog( this ); 106 QPEApplication::showDialog( this );
101#endif 107#endif
102} 108}
103 109
104/*! 110/*!
105 Destroys the TVFilterView widget 111 Destroys the TVFilterView widget
106*/ 112*/
107TVFilterView::~TVFilterView() 113TVFilterView::~TVFilterView()
108{ 114{
109} 115}
110 116
111void TVFilterView::rebuildData() 117void TVFilterView::rebuildData()
112{ 118{
113} 119}
114 120
115void TVFilterView::reset() 121void TVFilterView::reset()
116{ 122{
117 keyNameCombo->clear(); 123 keyNameCombo->clear();
118 keyIds.clear(); 124 keyIds.clear();
119} 125}
120 126
121void TVFilterView::rebuildKeys() 127void TVFilterView::rebuildKeys()
122{ 128{
123 int i; 129 int i;
124 130
125 if (!ts) return; 131 if (!ts) return;
126 if(!ts->kRep) return; 132 if(!ts->kRep) return;
127 keyEntry->setTableState(ts); 133 keyEntry->setTableState(ts);
128 134
129 /* set up the list of keys that can be compared on */ 135 /* set up the list of keys that can be compared on */
130 keyNameCombo->clear(); 136 keyNameCombo->clear();
131 KeyListIterator it(*ts->kRep); 137 KeyListIterator it(*ts->kRep);
132 138
133 i = 0; 139 i = 0;
134 while(it.current()) { 140 while(it.current()) {
135 if(ts->kRep->validIndex(it.currentKey())) { 141 if(ts->kRep->validIndex(it.currentKey())) {
136 keyNameCombo->insertItem(it.current()->name()); 142 keyNameCombo->insertItem(it.current()->name());
137 keyIds.insert(i, it.currentKey()); 143 keyIds.insert(i, it.currentKey());
138 ++i; 144 ++i;
139 } 145 }
140 ++it; 146 ++it;
141 } 147 }
142} 148}
143 149
144bool TVFilterView::passesFilter(DataElem *d) { 150bool TVFilterView::passesFilter(DataElem *d) {
145 if (!filterActive()) return true; 151 if (!filterActive()) return true;
146 152
147 153
148 FilterTerm *t; 154 FilterTerm *t;
149 155
150 for (t = terms.first(); t != 0; t = terms.next() ) { 156 for (t = terms.first(); t != 0; t = terms.next() ) {
151 /* check against filter */ 157 /* check against filter */
152 switch(t->ct) { 158 switch(t->ct) {
153 case ct_less: 159 case ct_less:
154 if (!d->lessThan(t->keyIndex, t->value)) 160 if (!d->lessThan(t->keyIndex, t->value))
155 return false; 161 return false;
156 break; 162 break;
157 case ct_more: 163 case ct_more:
158 if (!d->moreThan(t->keyIndex, t->value)) 164 if (!d->moreThan(t->keyIndex, t->value))
159 return false; 165 return false;
160 break; 166 break;
161 case ct_equal: 167 case ct_equal:
162 if (!d->equalTo(t->keyIndex, t->value)) 168 if (!d->equalTo(t->keyIndex, t->value))
163 return false; 169 return false;
164 break; 170 break;
165 case ct_contains: 171 case ct_contains:
166 if (!d->contains(t->keyIndex, t->value)) 172 if (!d->contains(t->keyIndex, t->value))
167 return false; 173 return false;
168 break; 174 break;
169 case ct_startswith: 175 case ct_startswith:
170 if (!d->startsWith(t->keyIndex, t->value)) 176 if (!d->startsWith(t->keyIndex, t->value))
171 return false; 177 return false;
172 break; 178 break;
173 case ct_endswith: 179 case ct_endswith:
174 if (!d->endsWith(t->keyIndex, t->value)) 180 if (!d->endsWith(t->keyIndex, t->value))
175 return false; 181 return false;
176 break; 182 break;
177 default: 183 default:
178 qWarning("TVFilterView::passesFilter() " 184 owarn << "TVFilterView::passesFilter() unrecognized filter type" << oendl;
179 "unrecognized filter type");
180 return false; 185 return false;
181 } 186 }
182 } 187 }
183 return true; 188 return true;
184} 189}
185 190
186bool TVFilterView::filterActive() const 191bool TVFilterView::filterActive() const
187{ 192{
188 /* when button operated, also check the do_filter value 193 /* when button operated, also check the do_filter value
189 return do_filter; 194 return do_filter;
190 */ 195 */
191 if (terms.isEmpty()) 196 if (terms.isEmpty())
192 return false; 197 return false;
193 return true; 198 return true;
194} 199}
195 200
196/* SLOTS */ 201/* SLOTS */
197void TVFilterView::newTerm() 202void TVFilterView::newTerm()
198{ 203{
199 if (!ts) return; 204 if (!ts) return;
200 205
201 FilterTerm *term = new FilterTerm; 206 FilterTerm *term = new FilterTerm;
202 current = term; 207 current = term;
203 208
204 term->view = 0; 209 term->view = 0;
205 210
206 updateTerm(); 211 updateTerm();
207 212
208 display->setSelected(term->view, true); 213 display->setSelected(term->view, true);
209 terms.append(term); 214 terms.append(term);
210 215
211 keyEntry->setEnabled(true); 216 keyEntry->setEnabled(true);
212 keyNameCombo->setEnabled(true); 217 keyNameCombo->setEnabled(true);
213} 218}
214 219
215void TVFilterView::updateTerm() 220void TVFilterView::updateTerm()
216{ 221{
217 FilterTerm *term; 222 FilterTerm *term;
218 /* Read the widget values (keyname, compare type, value) 223 /* Read the widget values (keyname, compare type, value)
219 * and build the lists */ 224 * and build the lists */
220 if (!ts) return; 225 if (!ts) return;
221 if (!current) return; 226 if (!current) return;
222 227
223 QString keyString; 228 QString keyString;
224 QString cmpString; 229 QString cmpString;
225 QString vString; 230 QString vString;
226 231
227 term = current; 232 term = current;
228 233
229 /* create new list item, set initial values, enable widgets */ 234 /* create new list item, set initial values, enable widgets */
230 term->keyIndex = keyIds[keyNameCombo->currentItem()]; 235 term->keyIndex = keyIds[keyNameCombo->currentItem()];
231 keyEntry->setKey(term->keyIndex); /* so the next two items make sense */ 236 keyEntry->setKey(term->keyIndex); /* so the next two items make sense */
232 term->ct = keyEntry->getCompareType(), 237 term->ct = keyEntry->getCompareType(),
233 term->value = keyEntry->getCompareValue(); 238 term->value = keyEntry->getCompareValue();
234 239
235 keyString = keyNameCombo->currentText(); 240 keyString = keyNameCombo->currentText();
236 241
237 switch(term->ct) { 242 switch(term->ct) {
238 case ct_less: 243 case ct_less:
239 cmpString = " less than "; 244 cmpString = " less than ";
240 break; 245 break;
241 case ct_more: 246 case ct_more:
242 cmpString = " more than "; 247 cmpString = " more than ";
243 break; 248 break;
244 case ct_equal: 249 case ct_equal:
245 cmpString = " equal to "; 250 cmpString = " equal to ";
246 break; 251 break;
247 case ct_contains: 252 case ct_contains:
248 cmpString = " containing "; 253 cmpString = " containing ";
249 break; 254 break;
250 case ct_startswith: 255 case ct_startswith:
251 cmpString = " starting with "; 256 cmpString = " starting with ";
252 break; 257 break;
253 case ct_endswith: 258 case ct_endswith:
254 cmpString = " ending with "; 259 cmpString = " ending with ";
255 break; 260 break;
256 default: 261 default:
257 cmpString = " ERROR "; 262 cmpString = " ERROR ";
258 } 263 }
259 264
260 vString = term->value.toString(); 265 vString = term->value.toString();
261 266
262 /* remove old view */ 267 /* remove old view */
263 if (term->view) 268 if (term->view)
264 delete(term->view); 269 delete(term->view);
265 term->view = new QListViewItem(display, 0, keyString, cmpString, vString); 270 term->view = new QListViewItem(display, 0, keyString, cmpString, vString);
266 display->setSelected(term->view, true); 271 display->setSelected(term->view, true);
267} 272}
268 273
269/* deletes current term */ 274/* deletes current term */
270void TVFilterView::deleteTerm() 275void TVFilterView::deleteTerm()
271{ 276{
272 if(!current) return; 277 if(!current) return;
273 if (current->view) 278 if (current->view)
274 delete(current->view); 279 delete(current->view);
275 280
276 terms.removeRef(current); 281 terms.removeRef(current);
277 282
278 current = terms.first(); 283 current = terms.first();
279 284
280 if(terms.isEmpty()) { 285 if(terms.isEmpty()) {
281 keyEntry->setEnabled(false); 286 keyEntry->setEnabled(false);
282 keyNameCombo->setEnabled(false); 287 keyNameCombo->setEnabled(false);
283 } 288 }
284} 289}
285 290
286/* clears all terminations */ 291/* clears all terminations */
287void TVFilterView::clearTerms() 292void TVFilterView::clearTerms()
288{ 293{
289 while(current) 294 while(current)
290 deleteTerm(); 295 deleteTerm();
291} 296}
292 297
293void TVFilterView::setTerm(QListViewItem *target) 298void TVFilterView::setTerm(QListViewItem *target)
294{ 299{
295 /* Iterate through the list to find item with view=target.. 300 /* Iterate through the list to find item with view=target..
296 * set as current, delete */ 301 * set as current, delete */
297 FilterTerm *term = current; 302 FilterTerm *term = current;
298 303
299 for (current = terms.first(); current != 0; current = terms.next() ) 304 for (current = terms.first(); current != 0; current = terms.next() )
300 if (current->view == target) 305 if (current->view == target)
301 break; 306 break;
302 307
303 if (!current) { 308 if (!current) {
304 current = term; 309 current = term;
305 } 310 }
306} 311}
diff --git a/noncore/apps/tinykate/libkate/kateconfig.cpp b/noncore/apps/tinykate/libkate/kateconfig.cpp
index 782b629..4b8ce78 100644
--- a/noncore/apps/tinykate/libkate/kateconfig.cpp
+++ b/noncore/apps/tinykate/libkate/kateconfig.cpp
@@ -3,48 +3,49 @@
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#define QTOPIA_INTERNAL_LANGLIST 21#define QTOPIA_INTERNAL_LANGLIST
22#include "kateconfig.h" 22#include "kateconfig.h"
23 23
24/* OPIE */ 24/* OPIE */
25#include <opie2/odebug.h> 25#include <opie2/odebug.h>
26#include <qpe/global.h> 26#include <qpe/global.h>
27using namespace Opie::Core;
27 28
28/* QT */ 29/* QT */
29#include <qdir.h> 30#include <qdir.h>
30#include <qmessagebox.h> 31#include <qmessagebox.h>
31#if QT_VERSION <= 230 && defined(QT_NO_CODECS) 32#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
32#include <qtextcodec.h> 33#include <qtextcodec.h>
33#endif 34#endif
34#include <qtextstream.h> 35#include <qtextstream.h>
35 36
36/* STD */ 37/* STD */
37#include <sys/stat.h> 38#include <sys/stat.h>
38#include <sys/types.h> 39#include <sys/types.h>
39#include <fcntl.h> 40#include <fcntl.h>
40#include <stdlib.h> 41#include <stdlib.h>
41#include <unistd.h> 42#include <unistd.h>
42 43
43 44
44/*! 45/*!
45 \internal 46 \internal
46*/ 47*/
47QString KateConfig::configFilename(const QString& name, Domain d) 48QString KateConfig::configFilename(const QString& name, Domain d)
48{ 49{
49 switch (d) { 50 switch (d) {
50 case File: 51 case File:
@@ -535,50 +536,49 @@ void KateConfig::write( const QString &fn )
535 QCString cstr; 536 QCString cstr;
536 QMap< QString, KateConfigGroup >::Iterator g_it = groups.begin(); 537 QMap< QString, KateConfigGroup >::Iterator g_it = groups.begin();
537 538
538 for ( ; g_it != groups.end(); ++g_it ) { 539 for ( ; g_it != groups.end(); ++g_it ) {
539 str += "[" + g_it.key() + "]\n"; 540 str += "[" + g_it.key() + "]\n";
540 KateConfigGroup::Iterator e_it = ( *g_it ).begin(); 541 KateConfigGroup::Iterator e_it = ( *g_it ).begin();
541 for ( ; e_it != ( *g_it ).end(); ++e_it ) 542 for ( ; e_it != ( *g_it ).end(); ++e_it )
542 str += e_it.key() + " = " + *e_it + "\n"; 543 str += e_it.key() + " = " + *e_it + "\n";
543 } 544 }
544 cstr = str.utf8(); 545 cstr = str.utf8();
545 546
546 int total_length; 547 int total_length;
547 total_length = f.writeBlock( cstr.data(), cstr.length() ); 548 total_length = f.writeBlock( cstr.data(), cstr.length() );
548 if ( total_length != int(cstr.length()) ) { 549 if ( total_length != int(cstr.length()) ) {
549 QMessageBox::critical( 0, QObject::tr("Out of Space"), 550 QMessageBox::critical( 0, QObject::tr("Out of Space"),
550 QObject::tr("There was a problem creating\nKateConfiguration Information \nfor this program.\n\nPlease free up some space and\ntry again.") ); 551 QObject::tr("There was a problem creating\nKateConfiguration Information \nfor this program.\n\nPlease free up some space and\ntry again.") );
551 f.close(); 552 f.close();
552 QFile::remove( strNewFile ); 553 QFile::remove( strNewFile );
553 return; 554 return;
554 } 555 }
555 556
556 f.close(); 557 f.close();
557 // now rename the file... 558 // now rename the file...
558 if ( rename( strNewFile, filename ) < 0 ) { 559 if ( rename( strNewFile, filename ) < 0 ) {
559 qWarning( "problem renaming the file %s to %s", strNewFile.latin1(), 560 owarn << "problem renaming the file " << strNewFile.latin1() << " to " << filename.latin1() << oendl;
560 filename.latin1() );
561 QFile::remove( strNewFile ); 561 QFile::remove( strNewFile );
562 } 562 }
563} 563}
564 564
565/*! 565/*!
566 Returns whether the KateConfig is in a valid state. 566 Returns whether the KateConfig is in a valid state.
567*/ 567*/
568bool KateConfig::isValid() const 568bool KateConfig::isValid() const
569{ 569{
570 return groups.end() != git; 570 return groups.end() != git;
571} 571}
572 572
573/*! 573/*!
574 \internal 574 \internal
575*/ 575*/
576void KateConfig::read() 576void KateConfig::read()
577{ 577{
578 changed = FALSE; 578 changed = FALSE;
579 579
580 if ( !QFileInfo( filename ).exists() ) { 580 if ( !QFileInfo( filename ).exists() ) {
581 git = groups.end(); 581 git = groups.end();
582 return; 582 return;
583 } 583 }
584 584
diff --git a/noncore/apps/zsafe/main.cpp b/noncore/apps/zsafe/main.cpp
index 4fe319b..5f48f77 100644
--- a/noncore/apps/zsafe/main.cpp
+++ b/noncore/apps/zsafe/main.cpp
@@ -1,111 +1,116 @@
1/* 1/*
2** Author: Carsten Schneider <CarstenSchneider@t-online.de> 2** Author: Carsten Schneider <CarstenSchneider@t-online.de>
3** 3**
4** $Id$ 4** $Id$
5** 5**
6** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html 6** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html
7*/ 7*/
8 8
9 9
10#include "zsafe.h" 10#include "zsafe.h"
11
12/* OPIE */
13#include <opie2/odebug.h>
14using namespace Opie::Core;
15
16/* QT */
11#ifdef DESKTOP 17#ifdef DESKTOP
12#include <qapplication.h> 18#include <qapplication.h>
13#else 19#else
14#include <qpe/qpeapplication.h> 20#include <qpe/qpeapplication.h>
15#endif 21#endif
22
23/* STD */
16#include <stdio.h> 24#include <stdio.h>
17#include <signal.h> 25#include <signal.h>
18 26
19ZSafe *zs; 27ZSafe *zs;
20#ifdef DESKTOP 28#ifdef DESKTOP
21QApplication *appl; 29QApplication *appl;
22#else 30#else
23QPEApplication *appl; 31QPEApplication *appl;
24#endif 32#endif
25 33
26int DeskW; 34int DeskW;
27int DeskH; 35int DeskH;
28 36
29void suspend (int signum) 37void suspend (int signum)
30{ 38{
31 printf ("Suspend signal %d received\n", signum); 39 printf ("Suspend signal %d received\n", signum);
32} 40}
33 41
34void resume (int signum) 42void resume (int signum)
35{ 43{
36 printf ("Resume signal %d received\n", signum); 44 printf ("Resume signal %d received\n", signum);
37 zs->resume(signum); 45 zs->resume(signum);
38} 46}
39 47
40int main( int argc, char ** argv ) 48int main( int argc, char ** argv )
41{ 49{
42#ifndef WIN32 50#ifndef WIN32
43 // install signal handler 51 // install signal handler
44 signal (SIGSTOP, suspend); 52 signal (SIGSTOP, suspend);
45#endif 53#endif
46 54
47#ifdef DESKTOP 55#ifdef DESKTOP
48 QApplication a( argc, argv ); 56 QApplication a( argc, argv );
49#else 57#else
50 QPEApplication a( argc, argv ); 58 QPEApplication a( argc, argv );
51#endif 59#endif
52 appl = &a; 60 appl = &a;
53 61
54#ifdef DESKTOP 62#ifdef DESKTOP
55 if (argc >= 3) 63 if (argc >= 3)
56 { 64 {
57#ifndef WIN32 65#ifndef WIN32
58 DeskW = atoi(argv[1]); 66 DeskW = atoi(argv[1]);
59 DeskH = atoi(argv[2]); 67 DeskH = atoi(argv[2]);
60#else 68#else
61 int w, h; 69 int w, h;
62 sscanf (argv[1], "%d", &w); 70 sscanf (argv[1], "%d", &w);
63 sscanf (argv[2], "%d", &h); 71 sscanf (argv[2], "%d", &h);
64 DeskW = w; 72 DeskW = w;
65 DeskH = h; 73 DeskH = h;
66#endif 74#endif
67 } 75 }
68 else 76 else
69 { 77 {
70 DeskW = 600; 78 DeskW = 600;
71 DeskH = 400; 79 DeskH = 400;
72 } 80 }
73#else 81#else
74 DeskW = a.desktop()->width(); 82 DeskW = a.desktop()->width();
75 DeskH = a.desktop()->height(); 83 DeskH = a.desktop()->height();
76 84
77 char buf[128]; 85 owarn << "Width: " << DeskW << " Height: " << DeskH << oendl;
78 sprintf (buf, "Width: %d Height: %d\n", DeskW, DeskH);
79 qWarning (buf);
80 86
81#ifdef JPATCH_HDE 87#ifdef JPATCH_HDE
82 // nothings 88 // nothings
83#else 89#else
84 if (DeskW > 240) 90 if (DeskW > 240)
85 { 91 {
86 DeskW -= 20; 92 DeskW -= 20;
87 DeskH += 25; 93 DeskH += 25;
88 sprintf (buf, "Changed width: %d Height: %d\n", DeskW, DeskH); 94 owarn << "Changed width: " << DeskW << " Height: " << DeskH << oendl;
89 qWarning (buf);
90 } 95 }
91#endif 96#endif
92 97
93#endif 98#endif
94 99
95 ZSafe mw; 100 ZSafe mw;
96 zs = &mw; 101 zs = &mw;
97 102
98#ifndef WIN32 103#ifndef WIN32
99 signal (SIGCONT, resume); 104 signal (SIGCONT, resume);
100#endif 105#endif
101#ifdef DESKTOP 106#ifdef DESKTOP
102 a.setMainWidget(&mw); 107 a.setMainWidget(&mw);
103 mw.show(); 108 mw.show();
104#else 109#else
105 // a.showMainWidget( &mw ); 110 // a.showMainWidget( &mw );
106 a.showMainDocumentWidget( &mw ); 111 a.showMainDocumentWidget( &mw );
107#endif 112#endif
108 int ret = a.exec(); 113 int ret = a.exec();
109 114
110 return ret; 115 return ret;
111} 116}
diff --git a/noncore/apps/zsafe/zlistview.cpp b/noncore/apps/zsafe/zlistview.cpp
index ba02a15..7d0b8c2 100644
--- a/noncore/apps/zsafe/zlistview.cpp
+++ b/noncore/apps/zsafe/zlistview.cpp
@@ -1,36 +1,39 @@
1/* 1/*
2** $Id$ 2** $Id$
3*/ 3*/
4 4
5#include "zlistview.h" 5#include "zlistview.h"
6#include <stdio.h>
7#include "zsafe.h" 6#include "zsafe.h"
8 7
8/* OPIE */
9//#include <opie2/odebug.h>
10
11/* STD */
12#include <stdio.h>
13
9ZListView::ZListView (ZSafe *zsafe, const char *id) : QListView(zsafe, id) 14ZListView::ZListView (ZSafe *zsafe, const char *id) : QListView(zsafe, id)
10{ 15{
11 zs = zsafe; 16 zs = zsafe;
12} 17}
13 18
14ZListView::~ZListView() 19ZListView::~ZListView()
15{ 20{
16} 21}
17 22
18void ZListView::keyPressEvent ( QKeyEvent *e ) 23void ZListView::keyPressEvent ( QKeyEvent *e )
19{ 24{
20/* 25/*
21 char buf[64]; 26 owarn << "key: " << e->key() << oendl;
22 sprintf (buf, "key: %d\n", e->key());
23 qWarning (buf);
24*/ 27*/
25 28
26 switch (e->key()) 29 switch (e->key())
27 { 30 {
28 case 32: // middle cursor key pressed 31 case 32: // middle cursor key pressed
29 zs->showInfo (zs->selectedItem); 32 zs->showInfo (zs->selectedItem);
30 break; 33 break;
31 default: 34 default:
32 QListView::keyPressEvent( e ); 35 QListView::keyPressEvent( e );
33 } 36 }
34 37
35} 38}
36 39
diff --git a/noncore/apps/zsafe/zsafe.cpp b/noncore/apps/zsafe/zsafe.cpp
index 6ff05ac..ca3ff52 100644
--- a/noncore/apps/zsafe/zsafe.cpp
+++ b/noncore/apps/zsafe/zsafe.cpp
@@ -860,126 +860,126 @@ void ZSafe::findPwd()
860 dialog->NameField->setText(lastSearchedName); 860 dialog->NameField->setText(lastSearchedName);
861 else 861 else
862 dialog->NameField->setText(""); 862 dialog->NameField->setText("");
863 if (lastSearchedUsername) 863 if (lastSearchedUsername)
864 dialog->UsernameField->setText(lastSearchedUsername); 864 dialog->UsernameField->setText(lastSearchedUsername);
865 else 865 else
866 dialog->UsernameField->setText(""); 866 dialog->UsernameField->setText("");
867 if (lastSearchedComment) 867 if (lastSearchedComment)
868 dialog->CommentField->setText(lastSearchedComment); 868 dialog->CommentField->setText(lastSearchedComment);
869 else 869 else
870 dialog->CommentField->setText(""); 870 dialog->CommentField->setText("");
871 DialogCode result = (DialogCode) dialog->exec(); 871 DialogCode result = (DialogCode) dialog->exec();
872#ifdef DESKTOP 872#ifdef DESKTOP
873 result = Accepted; 873 result = Accepted;
874#endif 874#endif
875 875
876 QString name; 876 QString name;
877 QString username; 877 QString username;
878 QString comment; 878 QString comment;
879 if (result == Accepted) 879 if (result == Accepted)
880 { 880 {
881 name = dialog->NameField->text(); 881 name = dialog->NameField->text();
882 username = dialog->UsernameField->text(); 882 username = dialog->UsernameField->text();
883 comment = dialog->CommentField->text(); 883 comment = dialog->CommentField->text();
884 qWarning (name); 884 owarn << name << oendl;
885 } 885 }
886 else 886 else
887 { 887 {
888 delete dialog; 888 delete dialog;
889 return; 889 return;
890 } 890 }
891 891
892 if (!name.isEmpty() && name != lastSearchedName || 892 if (!name.isEmpty() && name != lastSearchedName ||
893 lastSearchedName.isEmpty() && !name.isEmpty()) 893 lastSearchedName.isEmpty() && !name.isEmpty())
894 { 894 {
895 // set search at the beginning if a new name is given 895 // set search at the beginning if a new name is given
896 lastSearchedCategory = NULL; 896 lastSearchedCategory = NULL;
897 lastSearchedItem = NULL; 897 lastSearchedItem = NULL;
898 } 898 }
899 lastSearchedName = name; 899 lastSearchedName = name;
900 if (!username.isEmpty() && username != lastSearchedUsername || 900 if (!username.isEmpty() && username != lastSearchedUsername ||
901 lastSearchedUsername.isEmpty() && !username.isEmpty()) 901 lastSearchedUsername.isEmpty() && !username.isEmpty())
902 { 902 {
903 // set search at the beginning if a new name is given 903 // set search at the beginning if a new name is given
904 lastSearchedCategory = NULL; 904 lastSearchedCategory = NULL;
905 lastSearchedItem = NULL; 905 lastSearchedItem = NULL;
906 } 906 }
907 lastSearchedUsername = username; 907 lastSearchedUsername = username;
908 if (!comment.isEmpty() && comment != lastSearchedComment || 908 if (!comment.isEmpty() && comment != lastSearchedComment ||
909 lastSearchedComment.isEmpty() && !comment.isEmpty()) 909 lastSearchedComment.isEmpty() && !comment.isEmpty())
910 { 910 {
911 // set search at the beginning if a new name is given 911 // set search at the beginning if a new name is given
912 lastSearchedCategory = NULL; 912 lastSearchedCategory = NULL;
913 lastSearchedItem = NULL; 913 lastSearchedItem = NULL;
914 } 914 }
915 lastSearchedComment = comment; 915 lastSearchedComment = comment;
916 916
917 ListView->clearSelection(); 917 ListView->clearSelection();
918 918
919 bool found=FALSE; 919 bool found=FALSE;
920 // step through all categories 920 // step through all categories
921 QListViewItem *i; 921 QListViewItem *i;
922 if (lastSearchedCategory) 922 if (lastSearchedCategory)
923 i = lastSearchedCategory; 923 i = lastSearchedCategory;
924 else 924 else
925 i = ListView->firstChild(); 925 i = ListView->firstChild();
926 for (; 926 for (;
927 i != NULL; 927 i != NULL;
928 i = i->nextSibling()) 928 i = i->nextSibling())
929 { 929 {
930 qWarning (i->text(0)); 930 owarn << i->text(0) << oendl;
931 i->setSelected(FALSE); 931 i->setSelected(FALSE);
932 932
933 // step through all subitems 933 // step through all subitems
934 QListViewItem *si; 934 QListViewItem *si;
935 if (lastSearchedItem) 935 if (lastSearchedItem)
936 si = lastSearchedItem; 936 si = lastSearchedItem;
937 else 937 else
938 si = i->firstChild(); 938 si = i->firstChild();
939 // for (si = i->firstChild(); 939 // for (si = i->firstChild();
940 for (; 940 for (;
941 si != NULL; 941 si != NULL;
942 si = si->nextSibling()) 942 si = si->nextSibling())
943 { 943 {
944 qWarning (si->text(0)); 944 owarn << si->text(0) << oendl;
945 if (si->isSelected()) 945 if (si->isSelected())
946 si->setSelected(FALSE); 946 si->setSelected(FALSE);
947 // ListView->repaintItem(si); 947 // ListView->repaintItem(si);
948 948
949 bool n=TRUE; 949 bool n=TRUE;
950 bool u=TRUE; 950 bool u=TRUE;
951 bool c=TRUE; 951 bool c=TRUE;
952 if (!name.isEmpty()) 952 if (!name.isEmpty())
953 n = (si->text(0)).contains (name, FALSE); 953 n = (si->text(0)).contains (name, FALSE);
954 if (!username.isEmpty()) 954 if (!username.isEmpty())
955 u = (si->text(1)).contains (username, FALSE); 955 u = (si->text(1)).contains (username, FALSE);
956 if (!comment.isEmpty()) 956 if (!comment.isEmpty())
957 c = (si->text(3)).contains (comment, FALSE); 957 c = (si->text(3)).contains (comment, FALSE);
958 958
959 if ((n && u && c ) && !found) 959 if ((n && u && c ) && !found)
960 { 960 {
961 qWarning ("Found"); 961 owarn << "Found" << oendl;
962 selectedItem = si; 962 selectedItem = si;
963 si->setSelected(TRUE); 963 si->setSelected(TRUE);
964 ListView->setCurrentItem(si); 964 ListView->setCurrentItem(si);
965 ListView->ensureItemVisible(si); 965 ListView->ensureItemVisible(si);
966 ListView->triggerUpdate(); 966 ListView->triggerUpdate();
967 967
968 lastSearchedCategory = i; 968 lastSearchedCategory = i;
969 // set to the next item 969 // set to the next item
970 lastSearchedItem = si->nextSibling(); 970 lastSearchedItem = si->nextSibling();
971 if (!lastSearchedItem) 971 if (!lastSearchedItem)
972 { 972 {
973 // no next item within category -> set next category 973 // no next item within category -> set next category
974 lastSearchedCategory = i->nextSibling(); 974 lastSearchedCategory = i->nextSibling();
975 if (!lastSearchedCategory) 975 if (!lastSearchedCategory)
976 lastSearchedItem = NULL; // END 976 lastSearchedItem = NULL; // END
977 } 977 }
978 978
979 found = TRUE; 979 found = TRUE;
980 delete dialog; 980 delete dialog;
981 update(); 981 update();
982 return; 982 return;
983 } 983 }
984 } 984 }
985 lastSearchedCategory = i->nextSibling(); 985 lastSearchedCategory = i->nextSibling();
@@ -1207,224 +1207,221 @@ void ZSafe::removeAsciiFile()
1207 QString::null, 1207 QString::null,
1208 mimeTypes, 1208 mimeTypes,
1209 this, 1209 this,
1210 tr ("Remove text file")); 1210 tr ("Remove text file"));
1211#else 1211#else
1212 QString fn = ScQtFileEdit::getOpenFileName(this, 1212 QString fn = ScQtFileEdit::getOpenFileName(this,
1213 tr ("Remove text file"), 1213 tr ("Remove text file"),
1214 QDir::homeDirPath() + "/Documents/application/zsafe", 1214 QDir::homeDirPath() + "/Documents/application/zsafe",
1215 "*.txt"); 1215 "*.txt");
1216#endif 1216#endif
1217#else 1217#else
1218 QString fn = QFileDialog::getOpenFileName( 1218 QString fn = QFileDialog::getOpenFileName(
1219 QDir::homeDirPath() + "/Documents/application/zsafe", 1219 QDir::homeDirPath() + "/Documents/application/zsafe",
1220 "ZSafe (*.txt)", 1220 "ZSafe (*.txt)",
1221 this, 1221 this,
1222 "ZSafe File Dialog" 1222 "ZSafe File Dialog"
1223 "Choose a text file" ); 1223 "Choose a text file" );
1224#endif 1224#endif
1225 1225
1226 if (fn && fn.length() > 0 ) 1226 if (fn && fn.length() > 0 )
1227 { 1227 {
1228 QFile f( fn ); 1228 QFile f( fn );
1229 if ( !f.remove() ) 1229 if ( !f.remove() )
1230 { 1230 {
1231 qWarning( QString("Could not remove file %1").arg(fn), 1231 owarn << "Could not remove file " << fn << oendl;
1232 2000 );
1233 QMessageBox::critical( 0, tr("ZSafe"), 1232 QMessageBox::critical( 0, tr("ZSafe"),
1234 tr("Could not remove text file.") ); 1233 tr("Could not remove text file.") );
1235 return; 1234 return;
1236 } 1235 }
1237 } 1236 }
1238} 1237}
1239 1238
1240void ZSafe::writeAllEntries() 1239void ZSafe::writeAllEntries()
1241{ 1240{
1242 if (filename.isEmpty()) 1241 if (filename.isEmpty())
1243 { 1242 {
1244 QMessageBox::critical( 0, tr("ZSafe"), 1243 QMessageBox::critical( 0, tr("ZSafe"),
1245 tr("No document defined.\nYou have to create a new document")); 1244 tr("No document defined.\nYou have to create a new document"));
1246 return; 1245 return;
1247 } 1246 }
1248 1247
1249 // open the file dialog 1248 // open the file dialog
1250#ifndef DESKTOP 1249#ifndef DESKTOP
1251#ifndef NO_OPIE 1250#ifndef NO_OPIE
1252 QMap<QString, QStringList> mimeTypes; 1251 QMap<QString, QStringList> mimeTypes;
1253 mimeTypes.insert(tr("All"), QStringList() ); 1252 mimeTypes.insert(tr("All"), QStringList() );
1254 mimeTypes.insert(tr("Text"), "text/*" ); 1253 mimeTypes.insert(tr("Text"), "text/*" );
1255 QString fn = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL, 1254 QString fn = OFileDialog::getSaveFileName( OFileSelector::EXTENDED_ALL,
1256 QDir::homeDirPath() + "/Documents/application/zsafe", 1255 QDir::homeDirPath() + "/Documents/application/zsafe",
1257 QString::null, 1256 QString::null,
1258 mimeTypes, 1257 mimeTypes,
1259 this, 1258 this,
1260 tr ("Export text file")); 1259 tr ("Export text file"));
1261#else 1260#else
1262 QString fn = ScQtFileEdit::getSaveAsFileName(this, 1261 QString fn = ScQtFileEdit::getSaveAsFileName(this,
1263 tr ("Export text file"), 1262 tr ("Export text file"),
1264 QDir::homeDirPath() + "/Documents/application/zsafe", 1263 QDir::homeDirPath() + "/Documents/application/zsafe",
1265 "*.txt"); 1264 "*.txt");
1266#endif 1265#endif
1267#else 1266#else
1268 QString fn = QFileDialog::getSaveFileName( 1267 QString fn = QFileDialog::getSaveFileName(
1269 QDir::homeDirPath() + "/Documents/application/zsafe", 1268 QDir::homeDirPath() + "/Documents/application/zsafe",
1270 "ZSafe (*.txt)", 1269 "ZSafe (*.txt)",
1271 this, 1270 this,
1272 "ZSafe File Dialog" 1271 "ZSafe File Dialog"
1273 "Choose a text file" ); 1272 "Choose a text file" );
1274#endif 1273#endif
1275 1274
1276 // open the new document 1275 // open the new document
1277 if (fn && fn.length() > 0 ) 1276 if (fn && fn.length() > 0 )
1278 { 1277 {
1279 QFile f( fn ); 1278 QFile f( fn );
1280 if ( !f.open( IO_WriteOnly ) ) { 1279 if ( !f.open( IO_WriteOnly ) ) {
1281 qWarning( QString("Could not write to file %1").arg(fn), 1280 owarn << "Could not write to file " << fn << oendl;
1282 2000 );
1283 QMessageBox::critical( 0, "ZSafe", 1281 QMessageBox::critical( 0, "ZSafe",
1284 QString("Could not export to text file.") ); 1282 QString("Could not export to text file.") );
1285 return; 1283 return;
1286 } 1284 }
1287 QTextStream t( &f ); 1285 QTextStream t( &f );
1288 1286
1289 QListViewItem *i; 1287 QListViewItem *i;
1290 // step through all categories 1288 // step through all categories
1291 for (i = ListView->firstChild(); 1289 for (i = ListView->firstChild();
1292 i != NULL; 1290 i != NULL;
1293 i = i->nextSibling()) 1291 i = i->nextSibling())
1294 { 1292 {
1295 // step through all subitems 1293 // step through all subitems
1296 QListViewItem *si; 1294 QListViewItem *si;
1297 for (si = i->firstChild(); 1295 for (si = i->firstChild();
1298 si != NULL; 1296 si != NULL;
1299 si = si->nextSibling()) 1297 si = si->nextSibling())
1300 { 1298 {
1301 QString oneEntry; 1299 QString oneEntry;
1302 oneEntry += "\""; 1300 oneEntry += "\"";
1303 oneEntry += i->text(0); 1301 oneEntry += i->text(0);
1304 oneEntry += "\";"; 1302 oneEntry += "\";";
1305 oneEntry += "\""; 1303 oneEntry += "\"";
1306 oneEntry += si->text(0); 1304 oneEntry += si->text(0);
1307 oneEntry += "\";"; 1305 oneEntry += "\";";
1308 oneEntry += "\""; 1306 oneEntry += "\"";
1309 oneEntry += si->text(1); 1307 oneEntry += si->text(1);
1310 oneEntry += "\";"; 1308 oneEntry += "\";";
1311 oneEntry += "\""; 1309 oneEntry += "\"";
1312 oneEntry += si->text(2); 1310 oneEntry += si->text(2);
1313 oneEntry += "\";"; 1311 oneEntry += "\";";
1314 oneEntry += "\""; 1312 oneEntry += "\"";
1315 QString comment = si->text(3); 1313 QString comment = si->text(3);
1316 comment.replace (QRegExp("\n"), "<br>"); 1314 comment.replace (QRegExp("\n"), "<br>");
1317 oneEntry += comment; 1315 oneEntry += comment;
1318 oneEntry += "\";"; 1316 oneEntry += "\";";
1319 oneEntry += "\""; 1317 oneEntry += "\"";
1320 oneEntry += si->text(4); 1318 oneEntry += si->text(4);
1321 oneEntry += "\";"; 1319 oneEntry += "\";";
1322 oneEntry += "\""; 1320 oneEntry += "\"";
1323 oneEntry += si->text(5); 1321 oneEntry += si->text(5);
1324 oneEntry += "\""; 1322 oneEntry += "\"";
1325 // qWarning (oneEntry); 1323 // owarn << oneEntry << oendl;
1326 t << oneEntry << endl; 1324 t << oneEntry << endl;
1327 1325
1328 // qWarning (si->text(0)); 1326 // owarn << si->text(0) << oendl;
1329 } 1327 }
1330 } 1328 }
1331 f.close(); 1329 f.close();
1332 } 1330 }
1333} 1331}
1334 1332
1335void ZSafe::readAllEntries() 1333void ZSafe::readAllEntries()
1336{ 1334{
1337 if (filename.isEmpty()) 1335 if (filename.isEmpty())
1338 { 1336 {
1339 QMessageBox::critical( 0, tr("ZSafe"), 1337 QMessageBox::critical( 0, tr("ZSafe"),
1340 tr("No document defined.\nYou have to create a new document")); 1338 tr("No document defined.\nYou have to create a new document"));
1341 return; 1339 return;
1342 } 1340 }
1343 1341
1344 // open the file dialog 1342 // open the file dialog
1345#ifndef DESKTOP 1343#ifndef DESKTOP
1346#ifndef NO_OPIE 1344#ifndef NO_OPIE
1347 QMap<QString, QStringList> mimeTypes; 1345 QMap<QString, QStringList> mimeTypes;
1348 mimeTypes.insert(tr("All"), QStringList() ); 1346 mimeTypes.insert(tr("All"), QStringList() );
1349 mimeTypes.insert(tr("Text"), "text/*" ); 1347 mimeTypes.insert(tr("Text"), "text/*" );
1350 QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, 1348 QString fn = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL,
1351 QDir::homeDirPath() + "/Documents/application/zsafe", 1349 QDir::homeDirPath() + "/Documents/application/zsafe",
1352 QString::null, 1350 QString::null,
1353 mimeTypes, 1351 mimeTypes,
1354 this, 1352 this,
1355 tr ("Import text file")); 1353 tr ("Import text file"));
1356#else 1354#else
1357 QString fn = ScQtFileEdit::getOpenFileName(this, 1355 QString fn = ScQtFileEdit::getOpenFileName(this,
1358 tr ("Import text file"), 1356 tr ("Import text file"),
1359 QDir::homeDirPath() + "/Documents/application/zsafe", 1357 QDir::homeDirPath() + "/Documents/application/zsafe",
1360 "*.txt"); 1358 "*.txt");
1361#endif 1359#endif
1362#else 1360#else
1363 QString fn = QFileDialog::getOpenFileName( 1361 QString fn = QFileDialog::getOpenFileName(
1364 QDir::homeDirPath() + "/Documents/application/zsafe", 1362 QDir::homeDirPath() + "/Documents/application/zsafe",
1365 "ZSafe (*.txt)", 1363 "ZSafe (*.txt)",
1366 this, 1364 this,
1367 "ZSafe File Dialog" 1365 "ZSafe File Dialog"
1368 "Choose a text file" ); 1366 "Choose a text file" );
1369#endif 1367#endif
1370 1368
1371 if (fn && fn.length() > 0 ) 1369 if (fn && fn.length() > 0 )
1372 { 1370 {
1373 QFile f( fn ); 1371 QFile f( fn );
1374 if ( !f.open( IO_ReadOnly ) ) 1372 if ( !f.open( IO_ReadOnly ) )
1375 { 1373 {
1376 qWarning( QString("Could not read file %1").arg(fn), 1374 owarn << "Could not read file " << fn << oendl;
1377 2000 );
1378 QMessageBox::critical( 0, "ZSafe", 1375 QMessageBox::critical( 0, "ZSafe",
1379 QString("Could not import text file.") ); 1376 QString("Could not import text file.") );
1380 return; 1377 return;
1381 } 1378 }
1382 1379
1383 modified = true; 1380 modified = true;
1384 1381
1385 // clear the password list 1382 // clear the password list
1386 selectedItem = NULL; 1383 selectedItem = NULL;
1387 QListViewItem *i; 1384 QListViewItem *i;
1388 // step through all categories 1385 // step through all categories
1389 for (i = ListView->firstChild(); 1386 for (i = ListView->firstChild();
1390 i != NULL; 1387 i != NULL;
1391 i = i->nextSibling()) 1388 i = i->nextSibling())
1392 { 1389 {
1393 // step through all subitems 1390 // step through all subitems
1394 QListViewItem *si; 1391 QListViewItem *si;
1395 for (si = i->firstChild(); 1392 for (si = i->firstChild();
1396 si != NULL; ) 1393 si != NULL; )
1397 // si = si->nextSibling()) 1394 // si = si->nextSibling())
1398 { 1395 {
1399 QListViewItem *_si = si; 1396 QListViewItem *_si = si;
1400 si = si->nextSibling(); 1397 si = si->nextSibling();
1401 i->takeItem(_si); // remove from view list 1398 i->takeItem(_si); // remove from view list
1402 if (_si) delete _si; 1399 if (_si) delete _si;
1403 } 1400 }
1404 } 1401 }
1405 1402
1406 qWarning ("ReadAllEntries(): "); 1403 owarn << "ReadAllEntries(): " << oendl;
1407 1404
1408 QTextStream t(&f); 1405 QTextStream t(&f);
1409 while ( !t.eof() ) 1406 while ( !t.eof() )
1410 { 1407 {
1411 QString s = t.readLine(); 1408 QString s = t.readLine();
1412 s.replace (QRegExp("\";\""), "\"|\""); 1409 s.replace (QRegExp("\";\""), "\"|\"");
1413 // char buffer[1024]; 1410 // char buffer[1024];
1414#ifndef WIN32 1411#ifndef WIN32
1415 char buffer[s.length()+1]; 1412 char buffer[s.length()+1];
1416#else 1413#else
1417 char buffer[4048]; 1414 char buffer[4048];
1418#endif 1415#endif
1419 1416
1420 1417
1421 /* modify QString -> QCString::utf8 */ 1418 /* modify QString -> QCString::utf8 */
1422 1419
1423 strcpy (buffer, s.utf8()); 1420 strcpy (buffer, s.utf8());
1424 1421
1425 QString name; 1422 QString name;
1426 QString user; 1423 QString user;
1427 QString password; 1424 QString password;
1428 QString comment; 1425 QString comment;
1429 QString field5=""; 1426 QString field5="";
1430 QString field6=""; 1427 QString field6="";
@@ -1533,133 +1530,131 @@ void ZSafe::readAllEntries()
1533 c1->setIcon (*getPredefinedIcon(category)); 1530 c1->setIcon (*getPredefinedIcon(category));
1534 } 1531 }
1535 c1->setListItem (catI); 1532 c1->setListItem (catI);
1536 c1->initListItem(); 1533 c1->initListItem();
1537 categories.insert (c1->getCategoryName(), c1); 1534 categories.insert (c1->getCategoryName(), c1);
1538 } 1535 }
1539 1536
1540 } 1537 }
1541 f.close(); 1538 f.close();
1542 1539
1543 } 1540 }
1544 else 1541 else
1545 { 1542 {
1546 } 1543 }
1547 1544
1548} 1545}
1549 1546
1550#ifdef UNUSED 1547#ifdef UNUSED
1551void ZSafe::writeAllEntries() 1548void ZSafe::writeAllEntries()
1552{ 1549{
1553 // open the file for writing 1550 // open the file for writing
1554 QString fn = filename + ".txt"; 1551 QString fn = filename + ".txt";
1555 QFile f( fn ); 1552 QFile f( fn );
1556 if ( !f.open( IO_WriteOnly ) ) { 1553 if ( !f.open( IO_WriteOnly ) ) {
1557 qWarning( QString("Could not write to file %1").arg(fn), 1554 owarn << "Could not write to file " << fn << oendl;
1558 2000 );
1559 QMessageBox::critical( 0, tr("ZSafe"), 1555 QMessageBox::critical( 0, tr("ZSafe"),
1560 tr("Could not export to text file.") ); 1556 tr("Could not export to text file.") );
1561 return; 1557 return;
1562 } 1558 }
1563 QTextStream t( &f ); 1559 QTextStream t( &f );
1564 1560
1565 QListViewItem *i; 1561 QListViewItem *i;
1566 // step through all categories 1562 // step through all categories
1567 for (i = ListView->firstChild(); 1563 for (i = ListView->firstChild();
1568 i != NULL; 1564 i != NULL;
1569 i = i->nextSibling()) 1565 i = i->nextSibling())
1570 { 1566 {
1571 // step through all subitems 1567 // step through all subitems
1572 QListViewItem *si; 1568 QListViewItem *si;
1573 for (si = i->firstChild(); 1569 for (si = i->firstChild();
1574 si != NULL; 1570 si != NULL;
1575 si = si->nextSibling()) 1571 si = si->nextSibling())
1576 { 1572 {
1577 QString oneEntry; 1573 QString oneEntry;
1578 oneEntry += "\""; 1574 oneEntry += "\"";
1579 oneEntry += i->text(0); 1575 oneEntry += i->text(0);
1580 oneEntry += "\";"; 1576 oneEntry += "\";";
1581 oneEntry += "\""; 1577 oneEntry += "\"";
1582 oneEntry += si->text(0); 1578 oneEntry += si->text(0);
1583 oneEntry += "\";"; 1579 oneEntry += "\";";
1584 oneEntry += "\""; 1580 oneEntry += "\"";
1585 oneEntry += si->text(1); 1581 oneEntry += si->text(1);
1586 oneEntry += "\";"; 1582 oneEntry += "\";";
1587 oneEntry += "\""; 1583 oneEntry += "\"";
1588 oneEntry += si->text(2); 1584 oneEntry += si->text(2);
1589 oneEntry += "\";"; 1585 oneEntry += "\";";
1590 oneEntry += "\""; 1586 oneEntry += "\"";
1591 // oneEntry += si->text(3); 1587 // oneEntry += si->text(3);
1592 QString comment = si->text(3); 1588 QString comment = si->text(3);
1593 comment.replace (QRegExp("\n"), "<br>"); 1589 comment.replace (QRegExp("\n"), "<br>");
1594 oneEntry += comment; 1590 oneEntry += comment;
1595 oneEntry += "\""; 1591 oneEntry += "\"";
1596 // qWarning (oneEntry); 1592 // owarn << oneEntry << oendl;
1597 t << oneEntry << endl; 1593 t << oneEntry << endl;
1598 1594
1599 // qWarning (si->text(0)); 1595 // owarn << si->text(0) << oendl;
1600 } 1596 }
1601 } 1597 }
1602 f.close(); 1598 f.close();
1603} 1599}
1604 1600
1605void ZSafe::readAllEntries() 1601void ZSafe::readAllEntries()
1606{ 1602{
1607 QString fn = filename + ".txt"; 1603 QString fn = filename + ".txt";
1608 QFile f( fn ); 1604 QFile f( fn );
1609 if ( !f.open( IO_ReadOnly ) ) 1605 if ( !f.open( IO_ReadOnly ) )
1610 { 1606 {
1611 qWarning( QString("Could not read file %1").arg(fn), 1607 owarn << "Could not read file " << fn << oendl;
1612 2000 );
1613 QMessageBox::critical( 0, tr("ZSafe"), 1608 QMessageBox::critical( 0, tr("ZSafe"),
1614 tr("Could not import text file.") ); 1609 tr("Could not import text file.") );
1615 return; 1610 return;
1616 } 1611 }
1617 1612
1618 modified = true; 1613 modified = true;
1619 1614
1620 // clear the password list 1615 // clear the password list
1621 selectedItem = NULL; 1616 selectedItem = NULL;
1622 QListViewItem *i; 1617 QListViewItem *i;
1623 // step through all categories 1618 // step through all categories
1624 for (i = ListView->firstChild(); 1619 for (i = ListView->firstChild();
1625 i != NULL; 1620 i != NULL;
1626 i = i->nextSibling()) 1621 i = i->nextSibling())
1627 { 1622 {
1628 // step through all subitems 1623 // step through all subitems
1629 QListViewItem *si; 1624 QListViewItem *si;
1630 for (si = i->firstChild(); 1625 for (si = i->firstChild();
1631 si != NULL; ) 1626 si != NULL; )
1632 // si = si->nextSibling()) 1627 // si = si->nextSibling())
1633 { 1628 {
1634 QListViewItem *_si = si; 1629 QListViewItem *_si = si;
1635 si = si->nextSibling(); 1630 si = si->nextSibling();
1636 i->takeItem(_si); // remove from view list 1631 i->takeItem(_si); // remove from view list
1637 if (_si) delete _si; 1632 if (_si) delete _si;
1638 } 1633 }
1639 } 1634 }
1640 1635
1641 qWarning ("ReadAllEntries(): "); 1636 owarn << "ReadAllEntries(): " << oendl;
1642 1637
1643 QTextStream t(&f); 1638 QTextStream t(&f);
1644 while ( !t.eof() ) 1639 while ( !t.eof() )
1645 { 1640 {
1646 QString s = t.readLine(); 1641 QString s = t.readLine();
1647 s.replace (QRegExp("\";\""), "\"|\""); 1642 s.replace (QRegExp("\";\""), "\"|\"");
1648 // char buffer[1024]; 1643 // char buffer[1024];
1649 int len=s.length()+1; 1644 int len=s.length()+1;
1650#ifdef WIN32 1645#ifdef WIN32
1651 char buffer[512]; 1646 char buffer[512];
1652#else 1647#else
1653 char buffer[len]; 1648 char buffer[len];
1654#endif 1649#endif
1655 strcpy (buffer, s); 1650 strcpy (buffer, s);
1656 1651
1657 QString name; 1652 QString name;
1658 QString user; 1653 QString user;
1659 QString password; 1654 QString password;
1660 QString comment; 1655 QString comment;
1661 1656
1662 // separete the entries 1657 // separete the entries
1663 char *i = strtok (buffer, "|"); 1658 char *i = strtok (buffer, "|");
1664 QString category(&i[1]); 1659 QString category(&i[1]);
1665 category.truncate(category.length() -1); 1660 category.truncate(category.length() -1);
@@ -1741,49 +1736,49 @@ void ZSafe::readAllEntries()
1741 QImage img = pix->convertToImage(); 1736 QImage img = pix->convertToImage();
1742 pix->convertFromImage(img.smoothScale(14,14)); 1737 pix->convertFromImage(img.smoothScale(14,14));
1743 c1->setIconName (icon); 1738 c1->setIconName (icon);
1744 c1->setIcon (*pix); 1739 c1->setIcon (*pix);
1745 isIconAv = true; 1740 isIconAv = true;
1746 } 1741 }
1747 } 1742 }
1748 if (!isIconAv) 1743 if (!isIconAv)
1749 { 1744 {
1750 c1->setIcon (*getPredefinedIcon(category)); 1745 c1->setIcon (*getPredefinedIcon(category));
1751 } 1746 }
1752 c1->setListItem (catI); 1747 c1->setListItem (catI);
1753 c1->initListItem(); 1748 c1->initListItem();
1754 categories.insert (c1->getCategoryName(), c1); 1749 categories.insert (c1->getCategoryName(), c1);
1755 } 1750 }
1756 1751
1757 } 1752 }
1758 f.close(); 1753 f.close();
1759 1754
1760} 1755}
1761#endif // UNUSED 1756#endif // UNUSED
1762 1757
1763void ZSafe::resume(int) 1758void ZSafe::resume(int)
1764{ 1759{
1765 qWarning ("Resume"); 1760 owarn << "Resume" << oendl;
1766 // hide the main window 1761 // hide the main window
1767 1762
1768 infoForm->hide(); 1763 infoForm->hide();
1769 // open zsafe again 1764 // open zsafe again
1770 m_password = ""; 1765 m_password = "";
1771 selectedItem = NULL; 1766 selectedItem = NULL;
1772 1767
1773 // clear the password list 1768 // clear the password list
1774 QListViewItem *i; 1769 QListViewItem *i;
1775 // step through all categories 1770 // step through all categories
1776 for (i = ListView->firstChild(); 1771 for (i = ListView->firstChild();
1777 i != NULL; 1772 i != NULL;
1778 i = i->nextSibling()) 1773 i = i->nextSibling())
1779 { 1774 {
1780 // step through all subitems 1775 // step through all subitems
1781 QListViewItem *si; 1776 QListViewItem *si;
1782 for (si = i->firstChild(); 1777 for (si = i->firstChild();
1783 si != NULL; ) 1778 si != NULL; )
1784 { 1779 {
1785 QListViewItem *_si = si; 1780 QListViewItem *_si = si;
1786 si = si->nextSibling(); 1781 si = si->nextSibling();
1787 i->takeItem(_si); // remove from view list 1782 i->takeItem(_si); // remove from view list
1788 if (_si) delete _si; 1783 if (_si) delete _si;
1789 } 1784 }
@@ -1797,58 +1792,58 @@ void ZSafe::resume(int)
1797 1792
1798 1793
1799bool ZSafe::openDocument(const char* _filename, const char* ) 1794bool ZSafe::openDocument(const char* _filename, const char* )
1800{ 1795{
1801 int retval; 1796 int retval;
1802 char* entry[FIELD_SIZE]; 1797 char* entry[FIELD_SIZE];
1803// #ifndef WIN32 1798// #ifndef WIN32
1804 int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1); 1799 int validationFlag = conf->readNumEntry(APP_KEY+"valzsafe", 1);
1805// #else 1800// #else
1806 // int validationFlag = 1; 1801 // int validationFlag = 1;
1807// #endif 1802// #endif
1808 1803
1809 int pwdOk = 0; 1804 int pwdOk = 0;
1810 int numberOfTries = 3; 1805 int numberOfTries = 3;
1811 for (int i=0; i < numberOfTries; i++) 1806 for (int i=0; i < numberOfTries; i++)
1812 { 1807 {
1813 QFile f(_filename); 1808 QFile f(_filename);
1814 if (f.exists()) 1809 if (f.exists())
1815 { 1810 {
1816 // ask with a dialog for the password 1811 // ask with a dialog for the password
1817 if (m_password.isEmpty()) 1812 if (m_password.isEmpty())
1818 getDocPassword(tr("Enter Password")); 1813 getDocPassword(tr("Enter Password"));
1819 if (m_password.isEmpty() && validationFlag == 0) 1814 if (m_password.isEmpty() && validationFlag == 0)
1820 { 1815 {
1821 qWarning ("Wrong password"); 1816 owarn << "Wrong password" << oendl;
1822 QMessageBox::critical( 0, tr("ZSafe"), 1817 QMessageBox::critical( 0, tr("ZSafe"),
1823 tr("Wrong password.\n\nZSafe will now exit.") ); 1818 tr("Wrong password.\n\nZSafe will now exit.") );
1824 exitZs (1); 1819 exitZs (1);
1825 } 1820 }
1826 1821
1827 retval = loadInit(_filename, m_password); 1822 retval = loadInit(_filename, m_password);
1828 if (retval != PWERR_GOOD) 1823 if (retval != PWERR_GOOD)
1829 { 1824 {
1830 qWarning ("Error loading Document"); 1825 owarn << "Error loading Document" << oendl;
1831 return false; 1826 return false;
1832 } 1827 }
1833 } 1828 }
1834 else 1829 else
1835 { 1830 {
1836#ifdef WIN32 1831#ifdef WIN32
1837 this->setCaption("Qt ZSafe"); 1832 this->setCaption("Qt ZSafe");
1838#else 1833#else
1839 this->setCaption("ZSafe"); 1834 this->setCaption("ZSafe");
1840#endif 1835#endif
1841 filename = ""; 1836 filename = "";
1842 return false; 1837 return false;
1843 } 1838 }
1844 1839
1845 1840
1846 // load the validation entry 1841 // load the validation entry
1847 if (validationFlag == 0) 1842 if (validationFlag == 0)
1848 { 1843 {
1849 pwdOk = 1; 1844 pwdOk = 1;
1850 break; 1845 break;
1851 } 1846 }
1852 1847
1853 retval = loadEntry(entry); 1848 retval = loadEntry(entry);
1854 if (retval == 1 && 1849 if (retval == 1 &&
@@ -2280,49 +2275,49 @@ bool ZSafe::saveDocument(const char* _filename,
2280 } 2275 }
2281 2276
2282 if (saveFinalize() == PWERR_DATA) { 2277 if (saveFinalize() == PWERR_DATA) {
2283 owarn << "2: Error writing file, contents not saved" << oendl; 2278 owarn << "2: Error writing file, contents not saved" << oendl;
2284 return false; 2279 return false;
2285 } else { 2280 } else {
2286#ifndef DESKTOP 2281#ifndef DESKTOP
2287 Global::statusMessage (tr("Password file saved.")); 2282 Global::statusMessage (tr("Password file saved."));
2288#endif 2283#endif
2289 modified = false; 2284 modified = false;
2290 return true; 2285 return true;
2291 } 2286 }
2292} 2287}
2293 2288
2294PasswordForm *newPwdDialog; 2289PasswordForm *newPwdDialog;
2295bool newPwdDialogResult = false; 2290bool newPwdDialogResult = false;
2296void ZSafe::setPasswordDialogDone() 2291void ZSafe::setPasswordDialogDone()
2297{ 2292{
2298 newPwdDialogResult = true; 2293 newPwdDialogResult = true;
2299 newPwdDialog->close(); 2294 newPwdDialog->close();
2300} 2295}
2301 2296
2302void ZSafe::getDocPassword(QString title) 2297void ZSafe::getDocPassword(QString title)
2303{ 2298{
2304qWarning ("getDocPassword"); 2299 owarn << "getDocPassword" << oendl;
2305 // open the 'Password' dialog 2300 // open the 'Password' dialog
2306 PasswordForm *dialog = new PasswordForm(this, title, TRUE); 2301 PasswordForm *dialog = new PasswordForm(this, title, TRUE);
2307 newPwdDialog = dialog; 2302 newPwdDialog = dialog;
2308 newPwdDialogResult = false; 2303 newPwdDialogResult = false;
2309 2304
2310 connect( dialog->PasswordField, SIGNAL( returnPressed() ), 2305 connect( dialog->PasswordField, SIGNAL( returnPressed() ),
2311 this, SLOT( setPasswordDialogDone() ) ); 2306 this, SLOT( setPasswordDialogDone() ) );
2312 2307
2313 // CS: !!! 2308 // CS: !!!
2314 // int pos = filename.findRev ('/'); 2309 // int pos = filename.findRev ('/');
2315 QString ti = filename.right (filename.length() - filename.findRev ('/') - 1); 2310 QString ti = filename.right (filename.length() - filename.findRev ('/') - 1);
2316#ifdef WIN32 2311#ifdef WIN32
2317 dialog->setCaption("Qt " + ti); 2312 dialog->setCaption("Qt " + ti);
2318#else 2313#else
2319 dialog->setCaption(ti); 2314 dialog->setCaption(ti);
2320#endif 2315#endif
2321 // dialog->setCaption(title); 2316 // dialog->setCaption(title);
2322 2317
2323 dialog->PasswordField->setFocus(); 2318 dialog->PasswordField->setFocus();
2324 DialogCode result = (DialogCode) dialog->exec(); 2319 DialogCode result = (DialogCode) dialog->exec();
2325#ifdef DESKTOP 2320#ifdef DESKTOP
2326 result = Accepted; 2321 result = Accepted;
2327#endif 2322#endif
2328 2323
@@ -2459,49 +2454,49 @@ int ZSafe::saveFinalize(void)
2459 * over, leaving us 3 short, so we fill it in with 3's. 2454 * over, leaving us 3 short, so we fill it in with 3's.
2460 * 2455 *
2461 * If we come out even, we fill it with 8 8s 2456 * If we come out even, we fill it with 8 8s
2462 * 2457 *
2463 * um, except that in this instance we are using 4 shorts instead of 8 bytes. 2458 * um, except that in this instance we are using 4 shorts instead of 8 bytes.
2464 * so, half everything 2459 * so, half everything
2465 */ 2460 */
2466 for (count1 = bufferIndex; count1 < 4; count1++) { 2461 for (count1 = bufferIndex; count1 < 4; count1++) {
2467 plaintext[count1] = (4 - bufferIndex); 2462 plaintext[count1] = (4 - bufferIndex);
2468 } 2463 }
2469 krc2->rc2_encrypt (plaintext); 2464 krc2->rc2_encrypt (plaintext);
2470 for (count1 = 0; count1 < 4; count1++) { 2465 for (count1 = 0; count1 < 4; count1++) {
2471 ciphertext[count1] = iv[count1] ^ plaintext[count1]; 2466 ciphertext[count1] = iv[count1] ^ plaintext[count1];
2472 if (putc ((unsigned char) (ciphertext[count1] >> 8), fd) == EOF) retval = PWERR_DATA; 2467 if (putc ((unsigned char) (ciphertext[count1] >> 8), fd) == EOF) retval = PWERR_DATA;
2473 if (putc ((unsigned char) (ciphertext[count1] & 0xff), fd) == EOF) retval = PWERR_DATA; 2468 if (putc ((unsigned char) (ciphertext[count1] & 0xff), fd) == EOF) retval = PWERR_DATA;
2474 } 2469 }
2475 2470
2476 fclose (fd); 2471 fclose (fd);
2477 free(buffer); 2472 free(buffer);
2478 return retval; 2473 return retval;
2479} 2474}
2480 2475
2481void ZSafe::quitMe () 2476void ZSafe::quitMe ()
2482{ 2477{
2483 qWarning ("QUIT..."); 2478 owarn << "QUIT..." << oendl;
2484 2479
2485 if (modified) 2480 if (modified)
2486 { 2481 {
2487 switch( QMessageBox::information( this, tr("ZSafe"), 2482 switch( QMessageBox::information( this, tr("ZSafe"),
2488 tr("Do you want to save\nbefore exiting?"), 2483 tr("Do you want to save\nbefore exiting?"),
2489 tr("&Save"), 2484 tr("&Save"),
2490 tr("S&ave with\nnew\npassword"), 2485 tr("S&ave with\nnew\npassword"),
2491 tr("&Don't Save"), 2486 tr("&Don't Save"),
2492 0 // Enter == button 0 2487 0 // Enter == button 0
2493 ) ) 2488 ) )
2494 { // Escape == button 2 2489 { // Escape == button 2
2495 case 0: // Save clicked, Alt-S or Enter pressed. 2490 case 0: // Save clicked, Alt-S or Enter pressed.
2496 // save 2491 // save
2497 modified = false; 2492 modified = false;
2498 saveDocument(filename, FALSE); 2493 saveDocument(filename, FALSE);
2499 exitZs (1); 2494 exitZs (1);
2500 break; 2495 break;
2501 case 1: // 2496 case 1: //
2502 // Save with new password 2497 // Save with new password
2503 modified = false; 2498 modified = false;
2504 saveDocument(filename, TRUE); 2499 saveDocument(filename, TRUE);
2505 exitZs (1); 2500 exitZs (1);
2506 break; 2501 break;
2507 case 2: // Don't Save clicked or Alt-D pressed 2502 case 2: // Don't Save clicked or Alt-D pressed
@@ -2663,49 +2658,49 @@ void ZSafe::addCategory()
2663 waitDialog.hide(); 2658 waitDialog.hide();
2664 } 2659 }
2665 2660
2666#ifndef WIN32 2661#ifndef WIN32
2667 dialog->show(); 2662 dialog->show();
2668#endif 2663#endif
2669#ifndef DESKTOP 2664#ifndef DESKTOP
2670 // dialog->move (20, 100); 2665 // dialog->move (20, 100);
2671#endif 2666#endif
2672 DialogCode result = (DialogCode) dialog->exec(); 2667 DialogCode result = (DialogCode) dialog->exec();
2673#ifdef DESKTOP 2668#ifdef DESKTOP
2674 result = Accepted; 2669 result = Accepted;
2675#endif 2670#endif
2676 2671
2677 QString category; 2672 QString category;
2678 QString icon; 2673 QString icon;
2679 QString fullIconPath; 2674 QString fullIconPath;
2680 QPixmap *pix; 2675 QPixmap *pix;
2681 if (result == Accepted) 2676 if (result == Accepted)
2682 { 2677 {
2683 modified = true; 2678 modified = true;
2684 category = dialog->CategoryField->currentText(); 2679 category = dialog->CategoryField->currentText();
2685 icon = dialog->IconField->currentText()+".png"; 2680 icon = dialog->IconField->currentText()+".png";
2686 2681
2687 qWarning (category); 2682 owarn << category << oendl;
2688 2683
2689 QListViewItem *li = new ShadedListItem( 1, ListView ); 2684 QListViewItem *li = new ShadedListItem( 1, ListView );
2690 Category *c1 = new Category(); 2685 Category *c1 = new Category();
2691 c1->setCategoryName(category); 2686 c1->setCategoryName(category);
2692 2687
2693 // if (!icon.isEmpty() && !icon.isNull()) 2688 // if (!icon.isEmpty() && !icon.isNull())
2694 if (icon != "predefined.png") 2689 if (icon != "predefined.png")
2695 { 2690 {
2696 // build the full path 2691 // build the full path
2697 fullIconPath = iconPath + icon; 2692 fullIconPath = iconPath + icon;
2698 pix = new QPixmap (fullIconPath); 2693 pix = new QPixmap (fullIconPath);
2699 // pix->resize(14, 14); 2694 // pix->resize(14, 14);
2700 if (pix) 2695 if (pix)
2701 { 2696 {
2702 // save the full pixmap name into the config file 2697 // save the full pixmap name into the config file
2703// #ifndef WIN32 2698// #ifndef WIN32
2704 conf->writeEntry(APP_KEY+category, icon); 2699 conf->writeEntry(APP_KEY+category, icon);
2705// #endif 2700// #endif
2706 saveConf(); 2701 saveConf();
2707 QImage img = pix->convertToImage(); 2702 QImage img = pix->convertToImage();
2708 pix->convertFromImage(img.smoothScale(14,14)); 2703 pix->convertFromImage(img.smoothScale(14,14));
2709 c1->setIcon (*pix); 2704 c1->setIcon (*pix);
2710 c1->setIconName(icon); 2705 c1->setIconName(icon);
2711 } 2706 }
@@ -3171,49 +3166,49 @@ void ZSafe::editCategory()
3171 // save the full pixmap name into the config file 3166 // save the full pixmap name into the config file
3172// #ifndef WIN32 3167// #ifndef WIN32
3173 conf->writeEntry(APP_KEY+category, icon); 3168 conf->writeEntry(APP_KEY+category, icon);
3174// #endif 3169// #endif
3175 saveConf(); 3170 saveConf();
3176 QImage img = pix->convertToImage(); 3171 QImage img = pix->convertToImage();
3177 pix->convertFromImage(img.smoothScale(14,14)); 3172 pix->convertFromImage(img.smoothScale(14,14));
3178 cat->setIconName (icon); 3173 cat->setIconName (icon);
3179 cat->setIcon (*pix); 3174 cat->setIcon (*pix);
3180 } 3175 }
3181 } 3176 }
3182 else 3177 else
3183 { 3178 {
3184// #ifndef WIN32 3179// #ifndef WIN32
3185 conf->removeEntry (category); 3180 conf->removeEntry (category);
3186// #endif 3181// #endif
3187 saveConf(); 3182 saveConf();
3188 cat->setIcon (*getPredefinedIcon(category)); 3183 cat->setIcon (*getPredefinedIcon(category));
3189 } 3184 }
3190 3185
3191 // change the category name of the selected category 3186 // change the category name of the selected category
3192 QListViewItem *catItem = cat->getListItem(); 3187 QListViewItem *catItem = cat->getListItem();
3193 if (catItem) 3188 if (catItem)
3194 { 3189 {
3195 qWarning (category); 3190 owarn << category << oendl;
3196 catItem->setText( 0, tr( category ) ); 3191 catItem->setText( 0, tr( category ) );
3197 cat->setCategoryName (tr(category)); 3192 cat->setCategoryName (tr(category));
3198 3193
3199 cat->initListItem(); 3194 cat->initListItem();
3200 categories.insert (category, cat); 3195 categories.insert (category, cat);
3201 } 3196 }
3202 } 3197 }
3203 saveCategoryDialogFields(dialog); 3198 saveCategoryDialogFields(dialog);
3204 } 3199 }
3205 else 3200 else
3206 { 3201 {
3207 // delete dialog; 3202 // delete dialog;
3208 dialog->hide(); 3203 dialog->hide();
3209 return; 3204 return;
3210 } 3205 }
3211 3206
3212 } 3207 }
3213} 3208}
3214 3209
3215void ZSafe::cutItem() 3210void ZSafe::cutItem()
3216{ 3211{
3217 if (!selectedItem) 3212 if (!selectedItem)
3218 return; 3213 return;
3219 if (!isCategory(selectedItem)) 3214 if (!isCategory(selectedItem))
@@ -3572,49 +3567,49 @@ void ZSafe::setExpandFlag()
3572 file->setItemChecked('o', expandTree); 3567 file->setItemChecked('o', expandTree);
3573#ifndef DESKTOP 3568#ifndef DESKTOP
3574 conf->setGroup ("zsafePrefs"); 3569 conf->setGroup ("zsafePrefs");
3575#endif 3570#endif
3576// #ifndef WIN32 3571// #ifndef WIN32
3577 conf->writeEntry (APP_KEY+"expandTree", expandTree); 3572 conf->writeEntry (APP_KEY+"expandTree", expandTree);
3578// #endif 3573// #endif
3579 saveConf(); 3574 saveConf();
3580 3575
3581} 3576}
3582 3577
3583void ZSafe::paintEvent( QPaintEvent * ) 3578void ZSafe::paintEvent( QPaintEvent * )
3584{ 3579{
3585 if (raiseFlag) 3580 if (raiseFlag)
3586 { 3581 {
3587 raiseFlag = false; 3582 raiseFlag = false;
3588 raiseTimer.start (1, true); 3583 raiseTimer.start (1, true);
3589 if (infoForm->isVisible()) 3584 if (infoForm->isVisible())
3590 infoForm->raise(); 3585 infoForm->raise();
3591 } 3586 }
3592} 3587}
3593 3588
3594void ZSafe::resizeEvent ( QResizeEvent * ) 3589void ZSafe::resizeEvent ( QResizeEvent * )
3595{ 3590{
3596 // qWarning ("resizeEvent"); 3591 // owarn << "resizeEvent" << oendl;
3597#ifndef DESKTOP 3592#ifndef DESKTOP
3598 DeskW = appl->desktop()->width(); 3593 DeskW = appl->desktop()->width();
3599 DeskH = appl->desktop()->height(); 3594 DeskH = appl->desktop()->height();
3600#else 3595#else
3601 DeskW = this->width(); 3596 DeskW = this->width();
3602 DeskH = this->height(); 3597 DeskH = this->height();
3603#endif 3598#endif
3604 3599
3605 if (New) 3600 if (New)
3606 New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) ); 3601 New->setGeometry ( QRect( DeskW-84, 2, 20, 20 ) );
3607 if (Edit) 3602 if (Edit)
3608 Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) ); 3603 Edit->setGeometry ( QRect( DeskW-64, 2, 20, 20 ) );
3609 if (Delete) 3604 if (Delete)
3610 Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) ); 3605 Delete->setGeometry( QRect( DeskW-44, 2, 20, 20 ) );
3611 if (Find) 3606 if (Find)
3612 Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) ); 3607 Find->setGeometry ( QRect( DeskW-24, 2, 20, 20 ) );
3613} 3608}
3614 3609
3615void ZSafe::slotRaiseTimer() 3610void ZSafe::slotRaiseTimer()
3616{ 3611{
3617 if (infoForm->isVisible()) 3612 if (infoForm->isVisible())
3618 infoForm->raise(); 3613 infoForm->raise();
3619 raiseFlag = true; 3614 raiseFlag = true;
3620} 3615}
diff --git a/noncore/comm/keypebble/krfbdecoder.cpp b/noncore/comm/keypebble/krfbdecoder.cpp
index d61433f..837fcc5 100644
--- a/noncore/comm/keypebble/krfbdecoder.cpp
+++ b/noncore/comm/keypebble/krfbdecoder.cpp
@@ -4,51 +4,51 @@
4#include "krfbbuffer.h" 4#include "krfbbuffer.h"
5 5
6/* OPIE */ 6/* OPIE */
7#include <opie2/odebug.h> 7#include <opie2/odebug.h>
8using namespace Opie::Core; 8using namespace Opie::Core;
9 9
10/* QT */ 10/* QT */
11#include <qpixmap.h> 11#include <qpixmap.h>
12 12
13/* STD */ 13/* STD */
14#include <assert.h> 14#include <assert.h>
15 15
16// 16//
17// Endian stuff 17// Endian stuff
18// 18//
19//#ifndef OPIE_NO_DEBUG 19//#ifndef OPIE_NO_DEBUG
20const int endianTest = 1; 20const int endianTest = 1;
21//#endif 21//#endif
22 22
23#define Swap16IfLE(s) \ 23#define Swap16IfLE(s) \
24 (*(char *)&endianTest ? ((((s) & 0xff) << 8) | (((s) >> 8) & 0xff)) : (s)) 24 (*(char *)&endianTest ? ((((s) & 0xff) << 8) | (((s) >> 8) & 0xff)) : (s))
25 25
26#define Swap32IfLE(l) \ 26#define Swap32IfLE(l) \
27 (*(char *)&endianTest ? ((((l) & 0xff000000) >> 24) | \ 27 (*(char *)&endianTest ? ((((l) & 0xff000000) >> 24) | \
28 (((l) & 0x00ff0000) >> 8) | \ 28 (((l) & 0x00ff0000) >> 8) | \
29 (((l) & 0x0000ff00) << 8) | \ 29 (((l) & 0x0000ff00) << 8) | \
30 (((l) & 0x000000ff) << 24)) : (l)) 30 (((l) & 0x000000ff) << 24)) : (l))
31 31
32// 32//
33// The lengths of the messages we need to wait for 33// The lengths of the messages we need to wait for
34// 34//
35const int ServerInitLength = 24; 35const int ServerInitLength = 24;
36const int UpdateHeaderLength = 4; 36const int UpdateHeaderLength = 4;
37const int RectHeaderLength = 12; 37const int RectHeaderLength = 12;
38const int RectChunkSize = 4; 38const int RectChunkSize = 4;
39const int CopyRectPosLength = 4; 39const int CopyRectPosLength = 4;
40const int ServerCutLenLength = 7; 40const int ServerCutLenLength = 7;
41 41
42// 42//
43// Client -> Server Message Identifiers 43// Client -> Server Message Identifiers
44// 44//
45static CARD8 SetPixelFormatId = 0; 45static CARD8 SetPixelFormatId = 0;
46//static CARD8 FixColourMapEntriesId = 1; // Not used 46//static CARD8 FixColourMapEntriesId = 1; // Not used
47static CARD8 SetEncodingsId = 2; 47static CARD8 SetEncodingsId = 2;
48static CARD8 UpdateRequestId = 3; 48static CARD8 UpdateRequestId = 3;
49static CARD8 KeyEventId = 4; 49static CARD8 KeyEventId = 4;
50static CARD8 PointerEventId = 5; 50static CARD8 PointerEventId = 5;
51static CARD8 ClientCutTextId = 6; 51static CARD8 ClientCutTextId = 6;
52 52
53// 53//
54// Server -> Client Message Identifiers 54// Server -> Client Message Identifiers
@@ -119,178 +119,174 @@ KRFBDecoder::KRFBDecoder( KRFBConnection *con )
119 this->info = 0; 119 this->info = 0;
120 this->format = 0; 120 this->format = 0;
121 this->buttonMask = 0; 121 this->buttonMask = 0;
122 currentState = Idle; 122 currentState = Idle;
123} 123}
124 124
125KRFBDecoder::~KRFBDecoder() 125KRFBDecoder::~KRFBDecoder()
126{ 126{
127 if ( info ) 127 if ( info )
128 delete info; 128 delete info;
129 if ( format ) 129 if ( format )
130 delete format; 130 delete format;
131} 131}
132 132
133void KRFBDecoder::start() 133void KRFBDecoder::start()
134{ 134{
135 sendClientInit(); 135 sendClientInit();
136} 136}
137 137
138void KRFBDecoder::sendClientInit() 138void KRFBDecoder::sendClientInit()
139{ 139{
140 con->write( &( con->options()->shared ), 1 ); 140 con->write( &( con->options()->shared ), 1 );
141 141
142 // Wait for server init 142 // Wait for server init
143 owarn << "Waiting for server init" << oendl; 143 owarn << "Waiting for server init" << oendl;
144 144
145 static QString statusMsg = tr( "Waiting for server initialization..." ); 145 static QString statusMsg = tr( "Waiting for server initialization..." );
146 emit status( statusMsg ); 146 emit status( statusMsg );
147 147
148 currentState = AwaitingServerInit; 148 currentState = AwaitingServerInit;
149 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerInit() ) ); 149 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerInit() ) );
150 con->waitForData( ServerInitLength ); 150 con->waitForData( ServerInitLength );
151} 151}
152 152
153void KRFBDecoder::gotServerInit() 153void KRFBDecoder::gotServerInit()
154{ 154{
155 owarn << "Got server init" << oendl; 155 owarn << "Got server init" << oendl;
156 disconnect( con, SIGNAL( gotEnoughData() ), this, SLOT( gotServerInit() ) ); 156 disconnect( con, SIGNAL( gotEnoughData() ), this, SLOT( gotServerInit() ) );
157 157
158 if ( info ) 158 if ( info )
159 delete info; 159 delete info;
160 info = new KRFBServerInfo; 160 info = new KRFBServerInfo;
161 CHECK_PTR( info ); 161 CHECK_PTR( info );
162 162
163 con->read( &(info->width), 2 ); 163 con->read( &(info->width), 2 );
164 info->width = Swap16IfLE( info->width ); 164 info->width = Swap16IfLE( info->width );
165 con->read( &info->height, 2 ); 165 con->read( &info->height, 2 );
166 info->height = Swap16IfLE( info->height ); 166 info->height = Swap16IfLE( info->height );
167 167
168 con->read( &(info->bpp), 1 ); 168 con->read( &(info->bpp), 1 );
169 con->read( &(info->depth), 1 ); 169 con->read( &(info->depth), 1 );
170 con->read( &(info->bigEndian), 1 ); 170 con->read( &(info->bigEndian), 1 );
171 con->read( &(info->trueColor), 1 ); 171 con->read( &(info->trueColor), 1 );
172 172
173 con->read( &(info->redMax), 2 ); 173 con->read( &(info->redMax), 2 );
174 info->redMax = Swap16IfLE( info->redMax ); 174 info->redMax = Swap16IfLE( info->redMax );
175 con->read( &(info->greenMax), 2 ); 175 con->read( &(info->greenMax), 2 );
176 info->greenMax = Swap16IfLE( info->greenMax ); 176 info->greenMax = Swap16IfLE( info->greenMax );
177 con->read( &(info->blueMax), 2 ); 177 con->read( &(info->blueMax), 2 );
178 info->blueMax = Swap16IfLE( info->blueMax ); 178 info->blueMax = Swap16IfLE( info->blueMax );
179 179
180 con->read( &(info->redShift), 1 ); 180 con->read( &(info->redShift), 1 );
181 con->read( &(info->greenShift), 1 ); 181 con->read( &(info->greenShift), 1 );
182 con->read( &(info->blueShift), 1 ); 182 con->read( &(info->blueShift), 1 );
183 183
184 con->read( info->padding, 3 ); 184 con->read( info->padding, 3 );
185 185
186 con->read( &(info->nameLength), 4 ); 186 con->read( &(info->nameLength), 4 );
187 info->nameLength = Swap32IfLE( info->nameLength ); 187 info->nameLength = Swap32IfLE( info->nameLength );
188 188
189 owarn << "Width = " << info->width << ", Height = " << info->height << "" << oendl; 189 owarn << "Width = " << info->width << ", Height = " << info->height << "" << oendl;
190 qWarning( "Bpp = %d, Depth = %d, Big = %d, True = %d", 190 owarn << "Bpp = " << info->bpp << ", Depth = " << info->depth << ", Big = " << info->bigEndian
191 info->bpp, info->depth, info->bigEndian, info->trueColor ); 191 << ", True = " << info->trueColor << oendl;
192 qWarning( "RedMax = %d, GreenMax = %d, BlueMax = %d", 192 owarn << "RedMax = " << info->redMax << ", GreenMax = " << info->greenMax << ", BlueMax = " << info->blueMax << oendl;
193 info->redMax, info->greenMax, info->blueMax ); 193 owarn << "RedShift = " << info->redShift << ", GreenShift = " << info->greenShift
194 qWarning( "RedShift = %d, GreenShift = %d, BlueShift = %d", 194 << ", BlueShift = " << info-> blueShift << oendl;
195 info->redShift, info->greenShift,info-> blueShift );
196 195
197 buf->resize( info->width/con->options()->scaleFactor, info->height /con->options()->scaleFactor); 196 buf->resize( info->width/con->options()->scaleFactor, info->height /con->options()->scaleFactor);
198 197
199 // Wait for desktop name 198 // Wait for desktop name
200 owarn << "Waiting for desktop name" << oendl; 199 owarn << "Waiting for desktop name" << oendl;
201 200
202 static QString statusMsg = tr( "Waiting for desktop name..." ); 201 static QString statusMsg = tr( "Waiting for desktop name..." );
203 emit status( statusMsg ); 202 emit status( statusMsg );
204 203
205 currentState = AwaitingDesktopName; 204 currentState = AwaitingDesktopName;
206 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotDesktopName() ) ); 205 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotDesktopName() ) );
207 con->waitForData( info->nameLength ); 206 con->waitForData( info->nameLength );
208} 207}
209 208
210void KRFBDecoder::gotDesktopName() 209void KRFBDecoder::gotDesktopName()
211{ 210{
212 assert( info ); 211 assert( info );
213 assert( currentState == AwaitingDesktopName ); 212 assert( currentState == AwaitingDesktopName );
214 213
215 owarn << "Got desktop name" << oendl; 214 owarn << "Got desktop name" << oendl;
216 215
217 disconnect( con, SIGNAL( gotEnoughData() ), 216 disconnect( con, SIGNAL( gotEnoughData() ),
218 this, SLOT( gotDesktopName() ) ); 217 this, SLOT( gotDesktopName() ) );
219 218
220 char *buf = new char[ info->nameLength + 1 ]; 219 char *buf = new char[ info->nameLength + 1 ];
221 CHECK_PTR( buf ); 220 CHECK_PTR( buf );
222 221
223 con->read( buf, info->nameLength ); 222 con->read( buf, info->nameLength );
224 buf[ info->nameLength ] = '\0'; 223 buf[ info->nameLength ] = '\0';
225 info->name = buf; 224 info->name = buf;
226 225
227 owarn << "Desktop: " << info->name.latin1() << "" << oendl; 226 owarn << "Desktop: " << info->name.latin1() << "" << oendl;
228 227
229 delete buf; 228 delete buf;
230 229
231 // Get the format we'll really use and tell the server 230 // Get the format we'll really use and tell the server
232 decidePixelFormat(); 231 decidePixelFormat();
233 sendPixelFormat(); 232 sendPixelFormat();
234 sendAllowedEncodings(); 233 sendAllowedEncodings();
235 currentState = Idle; 234 currentState = Idle;
236 235
237 QString msg; 236 QString msg;
238 msg = tr( "Connected to %1" ); 237 msg = tr( "Connected to %1" );
239 msg = msg.arg( info->name ); 238 msg = msg.arg( info->name );
240 emit status( msg ); 239 emit status( msg );
241 240
242 sendUpdateRequest( false ); 241 sendUpdateRequest( false );
243} 242}
244 243
245void KRFBDecoder::decidePixelFormat() 244void KRFBDecoder::decidePixelFormat()
246{ 245{
247 assert( info ); 246 assert( info );
248 247
249 if ( format ) 248 if ( format )
250 delete format; 249 delete format;
251 format = new KRFBPixelFormat; 250 format = new KRFBPixelFormat;
252 CHECK_PTR( format ); 251 CHECK_PTR( format );
253 252
254 // What depth do we want? 253 // What depth do we want?
255 // 254 //
256 // We'll use the minimum of the remote and local depths, UNLESS an 255 // We'll use the minimum of the remote and local depths, UNLESS an
257 // eight bit session has been specifically requested by the user. 256 // eight bit session has been specifically requested by the user.
258 int screenDepth = QPixmap::defaultDepth(); 257 int screenDepth = QPixmap::defaultDepth();
259 int bestDepth = ( screenDepth > info->depth ) ? info->depth : screenDepth; 258 int bestDepth = ( screenDepth > info->depth ) ? info->depth : screenDepth;
260 int chosenDepth; 259 int chosenDepth;
261 260
262 if ( con->options()->colors256 ) 261 if ( con->options()->colors256 )
263 chosenDepth = 8; 262 chosenDepth = 8;
264 else 263 else
265 chosenDepth = bestDepth; 264 chosenDepth = bestDepth;
266 265
267 qWarning( "Screen depth=%d, server depth=%d, best depth=%d, " \ 266 owarn << "Screen depth=" << screenDepth << ", server depth=" << info->depth
268 "eight bit %d, chosenDepth=%d", 267 << ", best depth=" << bestDepth << "eight bit " << con->options()->colors256
269 screenDepth, 268 << ", chosenDepth=" << chosenDepth << oendl;
270 info->depth,
271 bestDepth,
272 con->options()->colors256, chosenDepth );
273 269
274 format->depth = chosenDepth; 270 format->depth = chosenDepth;
275 271
276 // If we're using the servers native depth 272 // If we're using the servers native depth
277 if ( chosenDepth == info->depth ) { 273 if ( chosenDepth == info->depth ) {
278 // Use the servers native format 274 // Use the servers native format
279 format->bpp = info->bpp; 275 format->bpp = info->bpp;
280 // format->bigEndian = info->bigEndian; 276 // format->bigEndian = info->bigEndian;
281 format->bigEndian = true; 277 format->bigEndian = true;
282 format->trueColor = info->trueColor; 278 format->trueColor = info->trueColor;
283 format->redMax = info->redMax; 279 format->redMax = info->redMax;
284 format->greenMax = info->greenMax; 280 format->greenMax = info->greenMax;
285 format->blueMax = info->blueMax; 281 format->blueMax = info->blueMax;
286 format->redShift = info->redShift; 282 format->redShift = info->redShift;
287 format->greenShift = info->greenShift; 283 format->greenShift = info->greenShift;
288 format->blueShift = info->blueShift; 284 format->blueShift = info->blueShift;
289 } 285 }
290 else { 286 else {
291 if ( chosenDepth == 8 ) { 287 if ( chosenDepth == 8 ) {
292 format->bpp = 8; 288 format->bpp = 8;
293 format->bigEndian = true; 289 format->bigEndian = true;
294 format->trueColor = true; 290 format->trueColor = true;
295 format->redMax = 7; 291 format->redMax = 7;
296 format->greenMax = 7; 292 format->greenMax = 7;
@@ -355,436 +351,436 @@ void KRFBDecoder::sendUpdateRequest( bool incremental )
355 return; 351 return;
356 352
357 con->write( &UpdateRequestId, 1 ); 353 con->write( &UpdateRequestId, 1 );
358 con->write( &incremental, 1 ); 354 con->write( &incremental, 1 );
359 355
360 static CARD16 x = 0, y = 0; 356 static CARD16 x = 0, y = 0;
361 static CARD16 w = Swap16IfLE( info->width ); 357 static CARD16 w = Swap16IfLE( info->width );
362 static CARD16 h = Swap16IfLE( info->height ); 358 static CARD16 h = Swap16IfLE( info->height );
363 359
364 con->write( &x, 2 ); 360 con->write( &x, 2 );
365 con->write( &y, 2 ); 361 con->write( &y, 2 );
366 con->write( &w, 2 ); 362 con->write( &w, 2 );
367 con->write( &h, 2 ); 363 con->write( &h, 2 );
368 364
369 // Now wait for the update 365 // Now wait for the update
370 currentState = AwaitingUpdate; 366 currentState = AwaitingUpdate;
371 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) ); 367 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) );
372 con->waitForData( UpdateHeaderLength ); 368 con->waitForData( UpdateHeaderLength );
373} 369}
374 370
375void KRFBDecoder::gotUpdateHeader() 371void KRFBDecoder::gotUpdateHeader()
376{ 372{
377 assert( currentState == AwaitingUpdate ); 373 assert( currentState == AwaitingUpdate );
378 374
379 // owarn << "Got update header" << oendl; 375 // owarn << "Got update header" << oendl;
380 376
381 disconnect( con, SIGNAL( gotEnoughData() ), 377 disconnect( con, SIGNAL( gotEnoughData() ),
382 this, SLOT( gotUpdateHeader() ) ); 378 this, SLOT( gotUpdateHeader() ) );
383 379
384 CARD8 msgType; 380 CARD8 msgType;
385 con->read( &msgType, 1 ); 381 con->read( &msgType, 1 );
386 382
387 if ( msgType != UpdateId ) { 383 if ( msgType != UpdateId ) {
388 // We might have a bell or server cut 384 // We might have a bell or server cut
389 if ( msgType == ServerCutId ) { 385 if ( msgType == ServerCutId ) {
390 oldState = currentState; 386 oldState = currentState;
391 gotServerCut(); 387 gotServerCut();
392 } 388 }
393 else if ( msgType == BellId ) { 389 else if ( msgType == BellId ) {
394 oldState = currentState; 390 oldState = currentState;
395 gotBell(); 391 gotBell();
396 } 392 }
397 else { 393 else {
398 int msg = msgType; 394 int msg = msgType;
399 QString protocolError = tr( "Protocol Error: Message Id %1 was " 395 QString protocolError = tr( "Protocol Error: Message Id %1 was "
400 "found when expecting an update " 396 "found when expecting an update "
401 "message." ).arg( msg ); 397 "message." ).arg( msg );
402 currentState = Error; 398 currentState = Error;
403 emit error( protocolError ); 399 emit error( protocolError );
404 } 400 }
405 return; 401 return;
406 } 402 }
407 403
408 CARD8 padding; 404 CARD8 padding;
409 con->read( &padding, 1 ); 405 con->read( &padding, 1 );
410 406
411 con->read( &noRects, 2 ); 407 con->read( &noRects, 2 );
412 noRects = Swap16IfLE( noRects ); 408 noRects = Swap16IfLE( noRects );
413 409
414 // owarn << "Expecting " << noRects << " rects" << oendl; 410 // owarn << "Expecting " << noRects << " rects" << oendl;
415 411
416 // Now wait for the data 412 // Now wait for the data
417 currentState = AwaitingRectHeader; 413 currentState = AwaitingRectHeader;
418 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) ); 414 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) );
419 con->waitForData( RectHeaderLength ); 415 con->waitForData( RectHeaderLength );
420} 416}
421 417
422void KRFBDecoder::gotRectHeader() 418void KRFBDecoder::gotRectHeader()
423{ 419{
424 assert( currentState == AwaitingRectHeader ); 420 assert( currentState == AwaitingRectHeader );
425 421
426 // owarn << "Got rect header" << oendl; 422 // owarn << "Got rect header" << oendl;
427 423
428 disconnect( con, SIGNAL( gotEnoughData() ), 424 disconnect( con, SIGNAL( gotEnoughData() ),
429 this, SLOT( gotRectHeader() ) ); 425 this, SLOT( gotRectHeader() ) );
430 426
431 con->read( &x, 2 ); 427 con->read( &x, 2 );
432 x = Swap16IfLE( x ); 428 x = Swap16IfLE( x );
433 con->read( &y, 2 ); 429 con->read( &y, 2 );
434 y = Swap16IfLE( y ); 430 y = Swap16IfLE( y );
435 431
436 con->read( &w, 2 ); 432 con->read( &w, 2 );
437 w = Swap16IfLE( w ); 433 w = Swap16IfLE( w );
438 con->read( &h, 2 ); 434 con->read( &h, 2 );
439 h = Swap16IfLE( h ); 435 h = Swap16IfLE( h );
440 436
441 con->read( &encoding, 4 ); 437 con->read( &encoding, 4 );
442 438
443 // CARD32 encodingLocal = Swap32IfLE( encoding ); 439 // CARD32 encodingLocal = Swap32IfLE( encoding );
444 // qWarning( "Rect: x=%d, y= %d, w=%d, h=%d, encoding=%ld", 440 // owarn << "Rect: x=" << x << ", y= " << y << ", w=" << w << ", h=" << h
445 // x, y, w, h, encodingLocal ); 441 // << ", encoding= " << encodingLocal << oendl;
446 442
447 // 443 //
448 // Each encoding needs to be handled differently. Some require 444 // Each encoding needs to be handled differently. Some require
449 // waiting for more data, but others like a copyrect do not. 445 // waiting for more data, but others like a copyrect do not.
450 // Our constants have already been byte swapped, so we use 446 // Our constants have already been byte swapped, so we use
451 // the remote value as is. 447 // the remote value as is.
452 // 448 //
453 if ( encoding == RawEncoding ) { 449 if ( encoding == RawEncoding ) {
454 // owarn << "Raw encoding" << oendl; 450 // owarn << "Raw encoding" << oendl;
455 handleRawRect(); 451 handleRawRect();
456 } 452 }
457 else if ( encoding == CopyRectEncoding ) { 453 else if ( encoding == CopyRectEncoding ) {
458// owarn << "CopyRect encoding" << oendl; 454// owarn << "CopyRect encoding" << oendl;
459 handleCopyRect(); 455 handleCopyRect();
460 } 456 }
461 else if ( encoding == RreEncoding ) { 457 else if ( encoding == RreEncoding ) {
462 owarn << "RRE encoding" << oendl; 458 owarn << "RRE encoding" << oendl;
463 handleRRERect(); 459 handleRRERect();
464 } 460 }
465 else if ( encoding == CorreEncoding ) { 461 else if ( encoding == CorreEncoding ) {
466 owarn << "CoRRE encoding" << oendl; 462 owarn << "CoRRE encoding" << oendl;
467 handleCoRRERect(); 463 handleCoRRERect();
468 } 464 }
469 else if ( encoding == HexTileEncoding ) { 465 else if ( encoding == HexTileEncoding ) {
470 owarn << "HexTile encoding" << oendl; 466 owarn << "HexTile encoding" << oendl;
471 handleHexTileRect(); 467 handleHexTileRect();
472 } 468 }
473 else { 469 else {
474 int msg = Swap32IfLE( encoding ); 470 int msg = Swap32IfLE( encoding );
475 QString protocolError = tr( "Protocol Error: An unknown encoding was " 471 QString protocolError = tr( "Protocol Error: An unknown encoding was "
476 "used by the server %1" ).arg( msg ); 472 "used by the server %1" ).arg( msg );
477 currentState = Error; 473 currentState = Error;
478 owarn << "Unknown encoding, " << msg << "" << oendl; 474 owarn << "Unknown encoding, " << msg << "" << oendl;
479 emit error( protocolError ); 475 emit error( protocolError );
480 return; 476 return;
481 } 477 }
482} 478}
483 479
484// 480//
485// Raw Encoding 481// Raw Encoding
486// 482//
487 483
488void KRFBDecoder::handleRawRect() 484void KRFBDecoder::handleRawRect()
489{ 485{
490 // We need something a bit cleverer here to handle large 486 // We need something a bit cleverer here to handle large
491 // rectanges nicely. The chunking should be based on the 487 // rectanges nicely. The chunking should be based on the
492 // overall size (but has to be in complete lines). 488 // overall size (but has to be in complete lines).
493 489
494 // owarn << "Handling a raw rect chunk" << oendl; 490 // owarn << "Handling a raw rect chunk" << oendl;
495 491
496 // CARD32 lineCount = w * format->bpp / 8; 492 // CARD32 lineCount = w * format->bpp / 8;
497 493
498 if ( h > RectChunkSize ) { 494 if ( h > RectChunkSize ) {
499 // if ( con->sock->size() / lineCount ) { 495 // if ( con->sock->size() / lineCount ) {
500 // getRawRectChunk( con->sock->size() / lineCount ); 496 // getRawRectChunk( con->sock->size() / lineCount );
501 // } 497 // }
502 // else { 498 // else {
503 getRawRectChunk( RectChunkSize ); 499 getRawRectChunk( RectChunkSize );
504 // } 500 // }
505 } 501 }
506 else { 502 else {
507 getRawRectChunk( h ); 503 getRawRectChunk( h );
508 } 504 }
509} 505}
510 506
511void KRFBDecoder::getRawRectChunk( int lines ) 507void KRFBDecoder::getRawRectChunk( int lines )
512{ 508{
513 this->lines = lines; 509 this->lines = lines;
514 CARD32 count = lines * w * format->bpp / 8; 510 CARD32 count = lines * w * format->bpp / 8;
515 511
516 // Wait for server init 512 // Wait for server init
517 // owarn << "Waiting for raw rect chunk, " << count << "" << oendl; 513 // owarn << "Waiting for raw rect chunk, " << count << "" << oendl;
518 514
519 currentState = AwaitingRawRectChunk; 515 currentState = AwaitingRawRectChunk;
520 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRawRectChunk() ) ); 516 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRawRectChunk() ) );
521 con->waitForData( count ); 517 con->waitForData( count );
522} 518}
523 519
524void KRFBDecoder::gotRawRectChunk() 520void KRFBDecoder::gotRawRectChunk()
525{ 521{
526 assert( currentState == AwaitingRawRectChunk ); 522 assert( currentState == AwaitingRawRectChunk );
527 523
528 disconnect( con, SIGNAL( gotEnoughData() ), 524 disconnect( con, SIGNAL( gotEnoughData() ),
529 this, SLOT( gotRawRectChunk() ) ); 525 this, SLOT( gotRawRectChunk() ) );
530 526
531 // owarn << "Got raw rect chunk" << oendl; 527 // owarn << "Got raw rect chunk" << oendl;
532 528
533 // 529 //
534 // Read the rect data and copy it to the buffer. 530 // Read the rect data and copy it to the buffer.
535 // 531 //
536 532
537 // TODO: Replace this! 533 // TODO: Replace this!
538 int count = lines * w * format->bpp / 8; 534 int count = lines * w * format->bpp / 8;
539 char *hack = new char[ count ]; 535 char *hack = new char[ count ];
540 con->read( hack, count ); 536 con->read( hack, count );
541 buf->drawRawRectChunk( hack, x, y, w, lines ); 537 buf->drawRawRectChunk( hack, x, y, w, lines );
542 delete hack; 538 delete hack;
543 // /TODO: 539 // /TODO:
544 540
545 h = h - lines; 541 h = h - lines;
546 y = y + lines; 542 y = y + lines;
547 543
548 if ( h > 0 ) { 544 if ( h > 0 ) {
549 handleRawRect(); 545 handleRawRect();
550 } 546 }
551 else { 547 else {
552 noRects--; 548 noRects--;
553 549
554 // owarn << "There are " << noRects << " rects left" << oendl; 550 // owarn << "There are " << noRects << " rects left" << oendl;
555 551
556 if ( noRects ) { 552 if ( noRects ) {
557 currentState = AwaitingRectHeader; 553 currentState = AwaitingRectHeader;
558 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) ); 554 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) );
559 con->waitForData( RectHeaderLength ); 555 con->waitForData( RectHeaderLength );
560 } 556 }
561 else { 557 else {
562 // we are now ready for the next update - no need to wait for the timer 558 // we are now ready for the next update - no need to wait for the timer
563 currentState = Idle; 559 currentState = Idle;
564 sendUpdateRequest (1); 560 sendUpdateRequest (1);
565 } 561 }
566 } 562 }
567} 563}
568 564
569// 565//
570// Copy Rectangle Encoding 566// Copy Rectangle Encoding
571// 567//
572 568
573void KRFBDecoder::handleCopyRect() 569void KRFBDecoder::handleCopyRect()
574{ 570{
575 currentState = AwaitingCopyRectPos; 571 currentState = AwaitingCopyRectPos;
576 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotCopyRectPos() ) ); 572 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotCopyRectPos() ) );
577 con->waitForData( CopyRectPosLength ); 573 con->waitForData( CopyRectPosLength );
578} 574}
579 575
580void KRFBDecoder::gotCopyRectPos() 576void KRFBDecoder::gotCopyRectPos()
581{ 577{
582 disconnect( con, SIGNAL( gotEnoughData() ), 578 disconnect( con, SIGNAL( gotEnoughData() ),
583 this, SLOT( gotCopyRectPos() ) ); 579 this, SLOT( gotCopyRectPos() ) );
584 580
585 CARD16 srcX; 581 CARD16 srcX;
586 CARD16 srcY; 582 CARD16 srcY;
587 583
588 con->read( &srcX, 2 ); 584 con->read( &srcX, 2 );
589 con->read( &srcY, 2 ); 585 con->read( &srcY, 2 );
590 586
591 srcX = Swap16IfLE( srcX ); 587 srcX = Swap16IfLE( srcX );
592 srcY = Swap16IfLE( srcY ); 588 srcY = Swap16IfLE( srcY );
593 589
594 buf->copyRect( srcX, srcY, x, y, w, h ); 590 buf->copyRect( srcX, srcY, x, y, w, h );
595 591
596 noRects--; 592 noRects--;
597 593
598 // owarn << "There are " << noRects << " rects left" << oendl; 594 // owarn << "There are " << noRects << " rects left" << oendl;
599 595
600 if ( noRects ) { 596 if ( noRects ) {
601 currentState = AwaitingRectHeader; 597 currentState = AwaitingRectHeader;
602 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) ); 598 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotRectHeader() ) );
603 con->waitForData( RectHeaderLength ); 599 con->waitForData( RectHeaderLength );
604 } 600 }
605 else 601 else
606 currentState = Idle; 602 currentState = Idle;
607} 603}
608 604
609void KRFBDecoder::handleRRERect() 605void KRFBDecoder::handleRRERect()
610{ 606{
611 owarn << "RRE not implemented" << oendl; 607 owarn << "RRE not implemented" << oendl;
612} 608}
613 609
614void KRFBDecoder::handleCoRRERect() 610void KRFBDecoder::handleCoRRERect()
615{ 611{
616 owarn << "CoRRE not implemented" << oendl; 612 owarn << "CoRRE not implemented" << oendl;
617} 613}
618 614
619void KRFBDecoder::handleHexTileRect() 615void KRFBDecoder::handleHexTileRect()
620{ 616{
621 owarn << "HexTile not implemented" << oendl; 617 owarn << "HexTile not implemented" << oendl;
622} 618}
623 619
624void KRFBDecoder::sendMouseEvent( QMouseEvent *e ) 620void KRFBDecoder::sendMouseEvent( QMouseEvent *e )
625{ 621{
626 // Deal with the buttons 622 // Deal with the buttons
627 if ( e->type() != QEvent::MouseMove ) { 623 if ( e->type() != QEvent::MouseMove ) {
628 buttonMask = 0; 624 buttonMask = 0;
629 if ( e->type() == QEvent::MouseButtonPress ) { 625 if ( e->type() == QEvent::MouseButtonPress ) {
630 if ( e->button() & LeftButton ) 626 if ( e->button() & LeftButton )
631 buttonMask |= 0x01; 627 buttonMask |= 0x01;
632 if ( e->button() & MidButton ) 628 if ( e->button() & MidButton )
633 buttonMask |= 0x04; 629 buttonMask |= 0x04;
634 if ( e->button() & RightButton ) 630 if ( e->button() & RightButton )
635 buttonMask |= 0x02; 631 buttonMask |= 0x02;
636 } 632 }
637 else if ( e->type() == QEvent::MouseButtonRelease ) { 633 else if ( e->type() == QEvent::MouseButtonRelease ) {
638 if ( e->button() & LeftButton ) 634 if ( e->button() & LeftButton )
639 buttonMask &= 0x06; 635 buttonMask &= 0x06;
640 if ( e->button() & MidButton ) 636 if ( e->button() & MidButton )
641 buttonMask |= 0x03; 637 buttonMask |= 0x03;
642 if ( e->button() & RightButton ) 638 if ( e->button() & RightButton )
643 buttonMask |= 0x05; 639 buttonMask |= 0x05;
644 } 640 }
645 } 641 }
646 642
647 // HACK: Scaling 643 // HACK: Scaling
648 CARD16 x = Swap16IfLE( e->x() * con->options()->scaleFactor ); 644 CARD16 x = Swap16IfLE( e->x() * con->options()->scaleFactor );
649 CARD16 y = Swap16IfLE( e->y() *con->options()->scaleFactor ); 645 CARD16 y = Swap16IfLE( e->y() * con->options()->scaleFactor );
650 646
651 con->write( &PointerEventId, 1 ); 647 con->write( &PointerEventId, 1 );
652 con->write( &buttonMask, 1 ); 648 con->write( &buttonMask, 1 );
653 con->write( &x, 2 ); 649 con->write( &x, 2 );
654 con->write( &y, 2 ); 650 con->write( &y, 2 );
655} 651}
656 652
657 653
658void KRFBDecoder::sendCutEvent( const QString &unicode ) 654void KRFBDecoder::sendCutEvent( const QString &unicode )
659{ 655{
660 // 656 //
661 // Warning: There is a bug in the RFB protocol because there is no way to find 657 // Warning: There is a bug in the RFB protocol because there is no way to find
662 // out the codepage in use on the remote machine. This could be fixed by requiring 658 // out the codepage in use on the remote machine. This could be fixed by requiring
663 // the remote server to use utf8 etc. but for now we have to assume they're the 659 // the remote server to use utf8 etc. but for now we have to assume they're the
664 // same. I've reported this problem to the ORL guys, but they apparantly have no 660 // same. I've reported this problem to the ORL guys, but they apparantly have no
665 // immediate plans to fix the issue. :-( (rich) 661 // immediate plans to fix the issue. :-( (rich)
666 // 662 //
667 663
668 CARD8 padding[3]; 664 CARD8 padding[3];
669 QCString text = unicode.local8Bit(); 665 QCString text = unicode.local8Bit();
670 CARD32 length = text.length(); 666 CARD32 length = text.length();
671 length = Swap32IfLE( length ); 667 length = Swap32IfLE( length );
672 668
673 con->write( &ClientCutTextId, 1 ); 669 con->write( &ClientCutTextId, 1 );
674 con->write( &padding, 3 ); 670 con->write( &padding, 3 );
675 con->write( &length, 4 ); 671 con->write( &length, 4 );
676 con->write( text.data(), length ); 672 con->write( text.data(), length );
677} 673}
678 674
679void KRFBDecoder::gotServerCut() 675void KRFBDecoder::gotServerCut()
680{ 676{
681 owarn << "Got server cut" << oendl; 677 owarn << "Got server cut" << oendl;
682 678
683 currentState = AwaitingServerCutLength; 679 currentState = AwaitingServerCutLength;
684 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerCutLength() ) ); 680 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerCutLength() ) );
685 con->waitForData( ServerCutLenLength ); 681 con->waitForData( ServerCutLenLength );
686} 682}
687 683
688void KRFBDecoder::gotServerCutLength() 684void KRFBDecoder::gotServerCutLength()
689{ 685{
690 assert( currentState = AwaitingServerCutLength ); 686 assert( currentState = AwaitingServerCutLength );
691 disconnect( con, SIGNAL( gotEnoughData() ), 687 disconnect( con, SIGNAL( gotEnoughData() ),
692 this, SLOT( gotServerCutLength() ) ); 688 this, SLOT( gotServerCutLength() ) );
693 689
694 CARD8 padding[3]; 690 CARD8 padding[3];
695 con->read( padding, 3 ); 691 con->read( padding, 3 );
696 692
697 con->read( &serverCutTextLen, 4 ); 693 con->read( &serverCutTextLen, 4 );
698 serverCutTextLen = Swap32IfLE( serverCutTextLen ); 694 serverCutTextLen = Swap32IfLE( serverCutTextLen );
699 695
700 currentState = AwaitingServerCutText; 696 currentState = AwaitingServerCutText;
701 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerCutText() ) ); 697 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotServerCutText() ) );
702 con->waitForData( serverCutTextLen ); 698 con->waitForData( serverCutTextLen );
703} 699}
704 700
705void KRFBDecoder::gotServerCutText() 701void KRFBDecoder::gotServerCutText()
706{ 702{
707 assert( currentState = AwaitingServerCutText ); 703 assert( currentState = AwaitingServerCutText );
708 704
709 disconnect( con, SIGNAL( gotEnoughData() ), 705 disconnect( con, SIGNAL( gotEnoughData() ),
710 this, SLOT( gotServerCutText() ) ); 706 this, SLOT( gotServerCutText() ) );
711 707
712 708
713 // 709 //
714 // Warning: There is a bug in the RFB protocol because there is no way to find 710 // Warning: There is a bug in the RFB protocol because there is no way to find
715 // out the codepage in use on the remote machine. This could be fixed by requiring 711 // out the codepage in use on the remote machine. This could be fixed by requiring
716 // the remote server to use utf8 etc. but for now we have to assume they're the 712 // the remote server to use utf8 etc. but for now we have to assume they're the
717 // same. I've reported this problem to the ORL guys, but they apparantly have no 713 // same. I've reported this problem to the ORL guys, but they apparantly have no
718 // immediate plans to fix the issue. :-( (rich) 714 // immediate plans to fix the issue. :-( (rich)
719 // 715 //
720 716
721 char *cutbuf = new char[ serverCutTextLen + 1 ]; 717 char *cutbuf = new char[ serverCutTextLen + 1 ];
722 CHECK_PTR( cutbuf ); 718 CHECK_PTR( cutbuf );
723 719
724 con->read( cutbuf, serverCutTextLen ); 720 con->read( cutbuf, serverCutTextLen );
725 cutbuf[ serverCutTextLen ] = '\0'; 721 cutbuf[ serverCutTextLen ] = '\0';
726 722
727 /* For some reason QApplication::clipboard()->setText() segfaults when called 723 /* For some reason QApplication::clipboard()->setText() segfaults when called
728 * from within keypebble's mass of signals and slots 724 * from within keypebble's mass of signals and slots
729 owarn << "Server cut: " << cutbuf << "" << oendl; 725 owarn << "Server cut: " << cutbuf << "" << oendl;
730 726
731 QString cutText( cutbuf ); // DANGER!! 727 QString cutText( cutbuf ); // DANGER!!
732 qApp->clipboard()->setText( cutText ); 728 qApp->clipboard()->setText( cutText );
733 */ 729 */
734 730
735 delete cutbuf; 731 delete cutbuf;
736 // Now wait for the update (again) 732 // Now wait for the update (again)
737 if ( oldState == AwaitingUpdate ) { 733 if ( oldState == AwaitingUpdate ) {
738 currentState = AwaitingUpdate; 734 currentState = AwaitingUpdate;
739 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) ); 735 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) );
740 con->waitForData( UpdateHeaderLength ); 736 con->waitForData( UpdateHeaderLength );
741 } 737 }
742 else if ( oldState == Idle ) { 738 else if ( oldState == Idle ) {
743 currentState = Idle; 739 currentState = Idle;
744 } 740 }
745 else { 741 else {
746 owarn << "Async handled in weird state" << oendl; 742 owarn << "Async handled in weird state" << oendl;
747 currentState = oldState; 743 currentState = oldState;
748 }; 744 };
749} 745}
750 746
751void KRFBDecoder::gotBell() 747void KRFBDecoder::gotBell()
752{ 748{
753 owarn << "Got server bell" << oendl; 749 owarn << "Got server bell" << oendl;
754 buf->soundBell(); 750 buf->soundBell();
755 751
756 // Now wait for the update (again) 752 // Now wait for the update (again)
757 if ( oldState == AwaitingUpdate ) { 753 if ( oldState == AwaitingUpdate ) {
758 currentState = AwaitingUpdate; 754 currentState = AwaitingUpdate;
759 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) ); 755 connect( con, SIGNAL( gotEnoughData() ), SLOT( gotUpdateHeader() ) );
760 con->waitForData( UpdateHeaderLength ); 756 con->waitForData( UpdateHeaderLength );
761 } 757 }
762 else if ( oldState == Idle ) { 758 else if ( oldState == Idle ) {
763 currentState = Idle; 759 currentState = Idle;
764 } 760 }
765 else { 761 else {
766 owarn << "Async handled in weird state" << oendl; 762 owarn << "Async handled in weird state" << oendl;
767 currentState = oldState; 763 currentState = oldState;
768 }; 764 };
769} 765}
770 766
771void KRFBDecoder::sendKeyPressEvent( QKeyEvent *event ) 767void KRFBDecoder::sendKeyPressEvent( QKeyEvent *event )
772{ 768{
773 int key; 769 int key;
774 key = toKeySym( event ); 770 key = toKeySym( event );
775 if ( key ) { 771 if ( key ) {
776 key = Swap32IfLE( key ); 772 key = Swap32IfLE( key );
777 773
778 CARD8 mask = true; 774 CARD8 mask = true;
779 775
780 CARD16 padding = 0; 776 CARD16 padding = 0;
781 con->write( &KeyEventId, 1 ); 777 con->write( &KeyEventId, 1 );
782 con->write( &mask, 1 ); 778 con->write( &mask, 1 );
783 con->write( &padding, 2 ); 779 con->write( &padding, 2 );
784 con->write( &key, 4 ); 780 con->write( &key, 4 );
785 } 781 }
786} 782}
787 783
788void KRFBDecoder::sendKeyReleaseEvent( QKeyEvent *event ) 784void KRFBDecoder::sendKeyReleaseEvent( QKeyEvent *event )
789{ 785{
790 int key; 786 int key;
@@ -798,38 +794,38 @@ void KRFBDecoder::sendKeyReleaseEvent( QKeyEvent *event )
798 con->write( &KeyEventId, 1 ); 794 con->write( &KeyEventId, 1 );
799 con->write( &mask, 1 ); 795 con->write( &mask, 1 );
800 con->write( &padding, 2 ); 796 con->write( &padding, 2 );
801 con->write( &key, 4 ); 797 con->write( &key, 4 );
802 } 798 }
803} 799}
804 800
805 801
806 802
807 803
808// 804//
809// The RFB protocol spec says 'For most ordinary keys, the 'keysym' 805// The RFB protocol spec says 'For most ordinary keys, the 'keysym'
810// is the same as the corresponding ASCII value.', but doesn't 806// is the same as the corresponding ASCII value.', but doesn't
811// elaborate what the most ordinary keys are. The spec also lists 807// elaborate what the most ordinary keys are. The spec also lists
812// a set (possibly subset, it's unspecified) of mappings for 808// a set (possibly subset, it's unspecified) of mappings for
813// "other common keys" (backspace, tab, return, escape, etc). 809// "other common keys" (backspace, tab, return, escape, etc).
814// 810//
815int KRFBDecoder::toKeySym( QKeyEvent *k ) 811int KRFBDecoder::toKeySym( QKeyEvent *k )
816{ 812{
817 813
818 // 814 //
819 // Try and map these "other common keys" first. 815 // Try and map these "other common keys" first.
820 // 816 //
821 if ((k->key() >= Qt::Key_Escape) && (k->key() <= Qt::Key_F12)) { 817 if ((k->key() >= Qt::Key_Escape) && (k->key() <= Qt::Key_F12)) {
822 for(int i = 0; keyMap[i].keycode != 0; i++) { 818 for(int i = 0; keyMap[i].keycode != 0; i++) {
823 if (k->key() == keyMap[i].keycode) { 819 if (k->key() == keyMap[i].keycode) {
824 return keyMap[i].keysym; 820 return keyMap[i].keysym;
825 } 821 }
826 } 822 }
827 } 823 }
828 824
829 // 825 //
830 // If these keys aren't matched, return the ascii code and let the 826 // If these keys aren't matched, return the ascii code and let the
831 // server figure it out. We don't return k->key(), as the data in 827 // server figure it out. We don't return k->key(), as the data in
832 // key differs between input methods, and we don't want special cases. 828 // key differs between input methods, and we don't want special cases.
833 // 829 //
834 return k->ascii(); 830 return k->ascii();
835} 831}
diff --git a/noncore/graphics/opie-eye/gui/iconview.cpp b/noncore/graphics/opie-eye/gui/iconview.cpp
index 6c5f5ea..211314b 100644
--- a/noncore/graphics/opie-eye/gui/iconview.cpp
+++ b/noncore/graphics/opie-eye/gui/iconview.cpp
@@ -89,51 +89,51 @@ namespace {
89 89
90 IconViewItem::IconViewItem( QIconView* view,const QString& path, 90 IconViewItem::IconViewItem( QIconView* view,const QString& path,
91 const QString& name, bool isDir ) 91 const QString& name, bool isDir )
92 : QIconViewItem( view, name ), m_path( path ), m_isDir( isDir ), 92 : QIconViewItem( view, name ), m_path( path ), m_isDir( isDir ),
93 m_noInfo( false ),m_textOnly(false),m_Pixset(false) 93 m_noInfo( false ),m_textOnly(false),m_Pixset(false)
94 { 94 {
95 if ( isDir && !_dirPix ) 95 if ( isDir && !_dirPix )
96 _dirPix = new QPixmap( Resource::loadPixmap("advancedfm/FileBrowser")); 96 _dirPix = new QPixmap( Resource::loadPixmap("advancedfm/FileBrowser"));
97 else if ( !isDir && !_unkPix ) 97 else if ( !isDir && !_unkPix )
98 _unkPix = new QPixmap( Resource::loadPixmap( "UnknownDocument" ) ); 98 _unkPix = new QPixmap( Resource::loadPixmap( "UnknownDocument" ) );
99 } 99 }
100 100
101 inline void IconViewItem::setPixmap( const QPixmap & icon, bool recalc, bool redraw) 101 inline void IconViewItem::setPixmap( const QPixmap & icon, bool recalc, bool redraw)
102 { 102 {
103 m_Pixset = true; 103 m_Pixset = true;
104 calcRect(text()); 104 calcRect(text());
105 } 105 }
106 inline void IconViewItem::setPixmap( const QPixmap & icon) 106 inline void IconViewItem::setPixmap( const QPixmap & icon)
107 { 107 {
108 m_Pixset = true; 108 m_Pixset = true;
109 calcRect(text()); 109 calcRect(text());
110 } 110 }
111 111
112 inline QPixmap* IconViewItem::pixmap()const { 112 inline QPixmap* IconViewItem::pixmap()const {
113// qWarning( "Name is " + m_path.right( 15 ) + " rect is %d %d %d %d | %d %d", 113// owarn << "Name is " << m_path.right( 15 ) << " rect is " << rect().x() << " " << rect().y()
114// rect().x(),rect().y(),rect().width(),rect().height(), 114// << " " << rect().width() << " " << rect().height() << " | " << iconView()->contentsX()
115// iconView()->contentsX(), iconView()->contentsY()); 115// << " " << iconView()->contentsY() << oendl;
116 116
117 if (textOnly()&&!m_isDir) { 117 if (textOnly()&&!m_isDir) {
118 if (!_emptyPix) _emptyPix = new QPixmap(0,0,1); 118 if (!_emptyPix) _emptyPix = new QPixmap(0,0,1);
119 return _emptyPix; 119 return _emptyPix;
120 } 120 }
121 if ( m_isDir ) 121 if ( m_isDir )
122 return _dirPix; 122 return _dirPix;
123 else{ 123 else{
124 if (!m_noInfo && !g_stringInf.contains( m_path ) ) { 124 if (!m_noInfo && !g_stringInf.contains( m_path ) ) {
125 currentView()->dirLister()->imageInfo( m_path ); 125 currentView()->dirLister()->imageInfo( m_path );
126 g_stringInf.insert( m_path, const_cast<IconViewItem*>(this)); 126 g_stringInf.insert( m_path, const_cast<IconViewItem*>(this));
127 } 127 }
128 128
129 m_pix = PPixmapCache::self()->cachedImage( m_path, 64, 64 ); 129 m_pix = PPixmapCache::self()->cachedImage( m_path, 64, 64 );
130 if (!m_pix && !g_stringPix.contains( m_path )) { 130 if (!m_pix && !g_stringPix.contains( m_path )) {
131 currentView()->dirLister()->thumbNail( m_path, 64, 64 ); 131 currentView()->dirLister()->thumbNail( m_path, 64, 64 );
132 g_stringPix.insert( m_path, const_cast<IconViewItem*>(this)); 132 g_stringPix.insert( m_path, const_cast<IconViewItem*>(this));
133 } 133 }
134 return m_pix ? m_pix : _unkPix; 134 return m_pix ? m_pix : _unkPix;
135 } 135 }
136 } 136 }
137 inline void IconViewItem::setText( const QString& str ) { 137 inline void IconViewItem::setText( const QString& str ) {
138 QString text = QIconViewItem::text()+"\n"+str; 138 QString text = QIconViewItem::text()+"\n"+str;
139 m_noInfo = true; 139 m_noInfo = true;
diff --git a/noncore/graphics/opie-eye/gui/viewmodebutton.cpp b/noncore/graphics/opie-eye/gui/viewmodebutton.cpp
index 36e5dcf..aa15d31 100644
--- a/noncore/graphics/opie-eye/gui/viewmodebutton.cpp
+++ b/noncore/graphics/opie-eye/gui/viewmodebutton.cpp
@@ -1,45 +1,48 @@
1#include "viewmodebutton.h" 1#include "viewmodebutton.h"
2 2
3/* OPIE */
3#include <opie2/odebug.h> 4#include <opie2/odebug.h>
5using namespace Opie::Core;
4 6
7/* QT */
5#include <qtoolbar.h> 8#include <qtoolbar.h>
6#include <qpopupmenu.h> 9#include <qpopupmenu.h>
7 10
8ViewModeButton::ViewModeButton( QToolBar* bar,int def ) 11ViewModeButton::ViewModeButton( QToolBar* bar,int def )
9 : QToolButton( bar ) 12 : QToolButton( bar )
10{ 13{
11 slotChange( def ); 14 slotChange( def );
12 QPopupMenu *pop= new QPopupMenu( this ); 15 QPopupMenu *pop= new QPopupMenu( this );
13 pop->setCheckable( true ); 16 pop->setCheckable( true );
14 pop->insertItem( tr("Thumbnail and Imageinfo"), 1 ); 17 pop->insertItem( tr("Thumbnail and Imageinfo"), 1 );
15 pop->insertItem( tr("Thumbnail and Name" ), 2 ); 18 pop->insertItem( tr("Thumbnail and Name" ), 2 );
16 pop->insertItem( tr("Name Only" ), 3 ); 19 pop->insertItem( tr("Name Only" ), 3 );
17 connect(pop, SIGNAL(activated(int)), 20 connect(pop, SIGNAL(activated(int)),
18 this, SIGNAL(changeMode(int)) ); 21 this, SIGNAL(changeMode(int)) );
19 connect(pop, SIGNAL(activated(int)), 22 connect(pop, SIGNAL(activated(int)),
20 this, SLOT(slotChange(int)) ); 23 this, SLOT(slotChange(int)) );
21 24
22 25
23 setPopup( pop ); 26 setPopup( pop );
24} 27}
25 28
26ViewModeButton::~ViewModeButton() { 29ViewModeButton::~ViewModeButton() {
27} 30}
28 31
29void ViewModeButton::slotChange( int i ) { 32void ViewModeButton::slotChange( int i ) {
30 QString name; 33 QString name;
31 switch( i ) { 34 switch( i ) {
32 case 1: 35 case 1:
33 name = "opie-eye/opie-eye-thumb"; 36 name = "opie-eye/opie-eye-thumb";
34 break; 37 break;
35 case 2: 38 case 2:
36 name = "opie-eye/opie-eye-thumbonly"; 39 name = "opie-eye/opie-eye-thumbonly";
37 break; 40 break;
38 case 3: 41 case 3:
39 name = "opie-eye/opie-eye-textview"; 42 name = "opie-eye/opie-eye-textview";
40 break; 43 break;
41 } 44 }
42 45
43 qWarning("foo %d" +name, i ); 46 owarn << "foo " << name << oendl;
44 setIconSet( Resource::loadIconSet( name ) ); 47 setIconSet( Resource::loadIconSet( name ) );
45} 48}
diff --git a/noncore/net/opietooth/lib/device.cc b/noncore/net/opietooth/lib/device.cc
index 04c50d9..f81066e 100644
--- a/noncore/net/opietooth/lib/device.cc
+++ b/noncore/net/opietooth/lib/device.cc
@@ -1,152 +1,157 @@
1 1
2#include <signal.h> 2#include "device.h"
3 3
4/* OPIE */
4#include <opie2/oprocess.h> 5#include <opie2/oprocess.h>
6#include <opie2/odebug.h>
7using namespace Opie::Core;
8
9/* STD */
10#include <signal.h>
5 11
6#include "device.h"
7 12
8using namespace OpieTooth; 13using namespace OpieTooth;
9 14
10using Opie::Core::OProcess; 15using Opie::Core::OProcess;
11namespace { 16namespace {
12 int parsePid( const QCString& par ){ 17 int parsePid( const QCString& par ){
13 int id=0; 18 int id=0;
14 QString string( par ); 19 QString string( par );
15 QStringList list = QStringList::split( '\n', string ); 20 QStringList list = QStringList::split( '\n', string );
16 for( QStringList::Iterator it = list.begin(); it != list.end(); ++it ){ 21 for( QStringList::Iterator it = list.begin(); it != list.end(); ++it ){
17 qWarning("parsePID: %s", (*it).latin1() ); 22 owarn << "parsePID: " << (*it).latin1() << oendl;
18 if( !(*it).startsWith("CSR") ){ 23 if( !(*it).startsWith("CSR") ){
19 id = (*it).toInt(); 24 id = (*it).toInt();
20 break; 25 break;
21 } 26 }
22 } 27 }
23 return id; 28 return id;
24 } 29 }
25} 30}
26 31
27Device::Device(const QString &device, const QString &mode, const QString &speed ) 32Device::Device(const QString &device, const QString &mode, const QString &speed )
28 : QObject(0, "device") { 33 : QObject(0, "device") {
29 34
30 qWarning("OpieTooth::Device create" ); 35 owarn << "OpieTooth::Device create" << oendl;
31 m_hci = 0; 36 m_hci = 0;
32 m_process = 0; 37 m_process = 0;
33 m_attached = false; 38 m_attached = false;
34 m_device = device; 39 m_device = device;
35 m_mode = mode; 40 m_mode = mode;
36 m_speed = speed; 41 m_speed = speed;
37 attach(); 42 attach();
38} 43}
39Device::~Device(){ 44Device::~Device(){
40 detach(); 45 detach();
41} 46}
42void Device::attach(){ 47void Device::attach(){
43 qWarning("attaching %s %s %s", m_device.latin1(), m_mode.latin1(), m_speed.latin1() ); 48 owarn << "attaching " << m_device.latin1() << " " << m_mode.latin1() << " " << m_speed.latin1() << oendl;
44 if(m_process == 0 ){ 49 if(m_process == 0 ){
45 m_output.resize(0); 50 m_output.resize(0);
46 qWarning("new process to create" ); 51 owarn << "new process to create" << oendl;
47 m_process = new OProcess(); 52 m_process = new OProcess();
48 *m_process << "hciattach"; 53 *m_process << "hciattach";
49 *m_process << "-p"; 54 *m_process << "-p";
50 *m_process << m_device << m_mode << m_speed; 55 *m_process << m_device << m_mode << m_speed;
51 connect(m_process, SIGNAL( processExited(Opie::Core::OProcess*) ), 56 connect(m_process, SIGNAL( processExited(Opie::Core::OProcess*) ),
52 this, SLOT( slotExited(Opie::Core::OProcess* ) ) ); 57 this, SLOT( slotExited(Opie::Core::OProcess* ) ) );
53 connect(m_process, SIGNAL( receivedStdout(Opie::Core::OProcess*, char*, int) ), 58 connect(m_process, SIGNAL( receivedStdout(Opie::Core::OProcess*, char*, int) ),
54 this, SLOT(slotStdOut(Opie::Core::OProcess*,char*,int ) ) ); 59 this, SLOT(slotStdOut(Opie::Core::OProcess*,char*,int ) ) );
55 connect(m_process, SIGNAL(receivedStderr(Opie::Core::OProcess*, char*, int ) ), 60 connect(m_process, SIGNAL(receivedStderr(Opie::Core::OProcess*, char*, int ) ),
56 this, SLOT(slotStdErr(Opie::Core::OProcess*,char*,int) ) ); 61 this, SLOT(slotStdErr(Opie::Core::OProcess*,char*,int) ) );
57 if(!m_process->start(OProcess::NotifyOnExit, OProcess::AllOutput ) ){ 62 if(!m_process->start(OProcess::NotifyOnExit, OProcess::AllOutput ) ){
58 qWarning("Could not start" ); 63 owarn << "Could not start" << oendl;
59 delete m_process; 64 delete m_process;
60 m_process = 0; 65 m_process = 0;
61 } 66 }
62 }; 67 };
63} 68}
64void Device::detach(){ 69void Device::detach(){
65 delete m_hci; 70 delete m_hci;
66 delete m_process; 71 delete m_process;
67 // kill the pid we got 72 // kill the pid we got
68 if(m_attached ){ 73 if(m_attached ){
69 //kill the pid 74 //kill the pid
70 qWarning( "killing" ); 75 warn << "killing" << oendl;
71 kill(pid, 9); 76 kill(pid, 9);
72 } 77 }
73 qWarning("detached" ); 78 owarn << "detached" << oendl;
74} 79}
75bool Device::isLoaded()const{ 80bool Device::isLoaded()const{
76 return m_attached; 81 return m_attached;
77} 82}
78QString Device::devName()const { 83QString Device::devName()const {
79 return QString::fromLatin1("hci0"); 84 return QString::fromLatin1("hci0");
80}; 85};
81void Device::slotExited( OProcess* proc) 86void Device::slotExited( OProcess* proc)
82{ 87{
83 qWarning("prcess exited" ); 88 owarn << "prcess exited" << oendl;
84 if(proc== m_process ){ 89 if(proc== m_process ){
85 qWarning("proc == m_process" ); 90 owarn << "proc == m_process" << oendl;
86 if( m_process->normalExit() ){ // normal exit 91 if( m_process->normalExit() ){ // normal exit
87 qWarning("normalExit" ); 92 owarn << "normalExit" << oendl;
88 int ret = m_process->exitStatus(); 93 int ret = m_process->exitStatus();
89 if( ret == 0 ){ // attached 94 if( ret == 0 ){ // attached
90 qWarning("attached" ); 95 owarn << "attached" << oendl;
91 qWarning("Output: %s", m_output.data() ); 96 owarn << "Output: " << m_output.data() << oendl;
92 pid = parsePid( m_output ); 97 pid = parsePid( m_output );
93 qWarning("Pid = %d", pid ); 98 owarn << "Pid = " << pid << oendl;
94 // now hciconfig hci0 up ( determine hciX FIXME) 99 // now hciconfig hci0 up ( determine hciX FIXME)
95 // and call hciconfig hci0 up 100 // and call hciconfig hci0 up
96 // FIXME hardcoded to hci0 now :( 101 // FIXME hardcoded to hci0 now :(
97 m_hci = new OProcess( ); 102 m_hci = new OProcess( );
98 *m_hci << "hciconfig"; 103 *m_hci << "hciconfig";
99 *m_hci << "hci0 up"; 104 *m_hci << "hci0 up";
100 connect(m_hci, SIGNAL( processExited(Opie::Core::OProcess*) ), 105 connect(m_hci, SIGNAL( processExited(Opie::Core::OProcess*) ),
101 this, SLOT( slotExited(Opie::Core::OProcess* ) ) ); 106 this, SLOT( slotExited(Opie::Core::OProcess* ) ) );
102 if(!m_hci->start() ){ 107 if(!m_hci->start() ){
103 qWarning("could not start" ); 108 owarn << "could not start" << oendl;
104 m_attached = false; 109 m_attached = false;
105 emit device("hci0", false ); 110 emit device("hci0", false );
106 } 111 }
107 }else{ 112 }else{
108 qWarning("crass" ); 113 owarn << "crass" << oendl;
109 m_attached = false; 114 m_attached = false;
110 emit device("hci0", false ); 115 emit device("hci0", false );
111 116
112 } 117 }
113 } 118 }
114 delete m_process; 119 delete m_process;
115 m_process = 0; 120 m_process = 0;
116 }else if(proc== m_hci ){ 121 }else if(proc== m_hci ){
117 qWarning("M HCI exited" ); 122 owarn << "M HCI exited" << oendl;
118 if( m_hci->normalExit() ){ 123 if( m_hci->normalExit() ){
119 qWarning("normal exit" ); 124 owarn << "normal exit" << oendl;
120 int ret = m_hci->exitStatus(); 125 int ret = m_hci->exitStatus();
121 if( ret == 0 ){ 126 if( ret == 0 ){
122 qWarning("attached really really attached" ); 127 owarn << "attached really really attached" << oendl;
123 m_attached = true; 128 m_attached = true;
124 emit device("hci0", true ); 129 emit device("hci0", true );
125 }else{ 130 }else{
126 qWarning( "failed" ); 131 owarn << "failed" << oendl;
127 emit device("hci0", false ); 132 emit device("hci0", false );
128 m_attached = false; 133 m_attached = false;
129 } 134 }
130 }// normal exit 135 }// normal exit
131 delete m_hci; 136 delete m_hci;
132 m_hci = 0; 137 m_hci = 0;
133 } 138 }
134} 139}
135void Device::slotStdOut(OProcess* proc, char* chars, int len) 140void Device::slotStdOut(OProcess* proc, char* chars, int len)
136{ 141{
137 qWarning("std out" ); 142 owarn << "std out" << oendl;
138 if( len <1 ){ 143 if( len <1 ){
139 qWarning( "len < 1 " ); 144 owarn << "len < 1 " << oendl;
140 return; 145 return;
141 } 146 }
142 if(proc == m_process ){ 147 if(proc == m_process ){
143 QCString string( chars, len+1 ); // \0 == +1 148 QCString string( chars, len+1 ); // \0 == +1
144 qWarning("output: %s", string.data() ); 149 owarn << "output: " << string.data() << oendl;
145 m_output.append( string.data() ); 150 m_output.append( string.data() );
146 } 151 }
147} 152}
148void Device::slotStdErr(OProcess* proc, char* chars, int len) 153void Device::slotStdErr(OProcess* proc, char* chars, int len)
149{ 154{
150 qWarning("std err" ); 155 owarn << "std err" << oendl;
151 slotStdOut( proc, chars, len ); 156 slotStdOut( proc, chars, len );
152} 157}
diff --git a/noncore/net/opietooth/lib/manager.cc b/noncore/net/opietooth/lib/manager.cc
index 18e1df9..76d9127 100644
--- a/noncore/net/opietooth/lib/manager.cc
+++ b/noncore/net/opietooth/lib/manager.cc
@@ -1,316 +1,317 @@
1 1
2
3#include <opie2/oprocess.h>
4
5#include "parser.h" 2#include "parser.h"
6#include "manager.h" 3#include "manager.h"
7 4
5#include <opie2/oprocess.h>
6#include <opie2/odebug.h>
7using namespace Opie::Core;
8
8 9
9using namespace OpieTooth; 10using namespace OpieTooth;
10 11
11using Opie::Core::OProcess; 12using Opie::Core::OProcess;
12Manager::Manager( const QString& dev ) 13Manager::Manager( const QString& dev )
13 : QObject() 14 : QObject()
14{ 15{
15 qWarning("created"); 16 owarn << "created" << oendl;
16 m_device = dev; 17 m_device = dev;
17 m_hcitool = 0; 18 m_hcitool = 0;
18 m_sdp = 0; 19 m_sdp = 0;
19} 20}
20Manager::Manager( Device* /*dev*/ ) 21Manager::Manager( Device* /*dev*/ )
21 : QObject() 22 : QObject()
22{ 23{
23 m_hcitool = 0; 24 m_hcitool = 0;
24 m_sdp = 0; 25 m_sdp = 0;
25} 26}
26Manager::Manager() 27Manager::Manager()
27 : QObject() 28 : QObject()
28{ 29{
29 m_hcitool = 0; 30 m_hcitool = 0;
30 m_sdp = 0; 31 m_sdp = 0;
31} 32}
32Manager::~Manager(){ 33Manager::~Manager(){
33 delete m_hcitool; 34 delete m_hcitool;
34 delete m_sdp; 35 delete m_sdp;
35} 36}
36void Manager::setDevice( const QString& dev ){ 37void Manager::setDevice( const QString& dev ){
37 m_device = dev; 38 m_device = dev;
38} 39}
39void Manager::setDevice( Device* /*dev*/ ){ 40void Manager::setDevice( Device* /*dev*/ ){
40 41
41} 42}
42void Manager::isAvailable( const QString& device ){ 43void Manager::isAvailable( const QString& device ){
43 OProcess* l2ping = new OProcess(); 44 OProcess* l2ping = new OProcess();
44 l2ping->setName( device.latin1() ); 45 l2ping->setName( device.latin1() );
45 *l2ping << "l2ping" << "-c1" << device; 46 *l2ping << "l2ping" << "-c1" << device;
46 connect(l2ping, SIGNAL(processExited(Opie::Core::OProcess* ) ), 47 connect(l2ping, SIGNAL(processExited(Opie::Core::OProcess* ) ),
47 this, SLOT(slotProcessExited(Opie::Core::OProcess*) ) ); 48 this, SLOT(slotProcessExited(Opie::Core::OProcess*) ) );
48 if (!l2ping->start() ) { 49 if (!l2ping->start() ) {
49 emit available( device, false ); 50 emit available( device, false );
50 delete l2ping; 51 delete l2ping;
51 } 52 }
52 53
53} 54}
54 55
55void Manager::isAvailable( Device* /*dev*/ ){ 56void Manager::isAvailable( Device* /*dev*/ ){
56 57
57 58
58} 59}
59void Manager::searchDevices( const QString& device ){ 60void Manager::searchDevices( const QString& device ){
60 qWarning("search devices"); 61 owarn << "search devices" << oendl;
61 OProcess* hcitool = new OProcess(); 62 OProcess* hcitool = new OProcess();
62 hcitool->setName( device.isEmpty() ? "hci0" : device.latin1() ); 63 hcitool->setName( device.isEmpty() ? "hci0" : device.latin1() );
63 *hcitool << "hcitool" << "scan"; 64 *hcitool << "hcitool" << "scan";
64 connect( hcitool, SIGNAL(processExited(Opie::Core::OProcess*) ) , 65 connect( hcitool, SIGNAL(processExited(Opie::Core::OProcess*) ) ,
65 this, SLOT(slotHCIExited(Opie::Core::OProcess* ) ) ); 66 this, SLOT(slotHCIExited(Opie::Core::OProcess* ) ) );
66 connect( hcitool, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int ) ), 67 connect( hcitool, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int ) ),
67 this, SLOT(slotHCIOut(Opie::Core::OProcess*, char*, int ) ) ); 68 this, SLOT(slotHCIOut(Opie::Core::OProcess*, char*, int ) ) );
68 if (!hcitool->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) { 69 if (!hcitool->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) {
69 qWarning("could not start"); 70 owarn << "could not start" << oendl;
70 RemoteDevice::ValueList list; 71 RemoteDevice::ValueList list;
71 emit foundDevices( device, list ); 72 emit foundDevices( device, list );
72 delete hcitool; 73 delete hcitool;
73 } 74 }
74} 75}
75 76
76void Manager::searchDevices(Device* /*d*/ ){ 77void Manager::searchDevices(Device* /*d*/ ){
77 78
78 79
79} 80}
80void Manager::addService(const QString& name ){ 81void Manager::addService(const QString& name ){
81 OProcess proc; 82 OProcess proc;
82 proc << "sdptool" << "add" << name; 83 proc << "sdptool" << "add" << name;
83 bool bo = true; 84 bool bo = true;
84 if (!proc.start(OProcess::DontCare ) ) 85 if (!proc.start(OProcess::DontCare ) )
85 bo = false; 86 bo = false;
86 emit addedService( name, bo ); 87 emit addedService( name, bo );
87} 88}
88void Manager::addServices(const QStringList& list){ 89void Manager::addServices(const QStringList& list){
89 QStringList::ConstIterator it; 90 QStringList::ConstIterator it;
90 for (it = list.begin(); it != list.end(); ++it ) 91 for (it = list.begin(); it != list.end(); ++it )
91 addService( (*it) ); 92 addService( (*it) );
92} 93}
93void Manager::removeService( const QString& name ){ 94void Manager::removeService( const QString& name ){
94 OProcess prc; 95 OProcess prc;
95 prc << "sdptool" << "del" << name; 96 prc << "sdptool" << "del" << name;
96 bool bo = true; 97 bool bo = true;
97 if (!prc.start(OProcess::DontCare ) ) 98 if (!prc.start(OProcess::DontCare ) )
98 bo = false; 99 bo = false;
99 emit removedService( name, bo ); 100 emit removedService( name, bo );
100} 101}
101void Manager::removeServices( const QStringList& list){ 102void Manager::removeServices( const QStringList& list){
102 QStringList::ConstIterator it; 103 QStringList::ConstIterator it;
103 for (it = list.begin(); it != list.end(); ++it ) 104 for (it = list.begin(); it != list.end(); ++it )
104 removeService( (*it) ); 105 removeService( (*it) );
105} 106}
106void Manager::searchServices( const QString& remDevice ){ 107void Manager::searchServices( const QString& remDevice ){
107 OProcess *m_sdp =new OProcess(); 108 OProcess *m_sdp =new OProcess();
108 *m_sdp << "sdptool" << "browse" << remDevice; 109 *m_sdp << "sdptool" << "browse" << remDevice;
109 m_sdp->setName( remDevice.latin1() ); 110 m_sdp->setName( remDevice.latin1() );
110 qWarning("search Services for %s", remDevice.latin1() ); 111 owarn << "search Services for " << remDevice.latin1() << oendl;
111 connect(m_sdp, SIGNAL(processExited(Opie::Core::OProcess*) ), 112 connect(m_sdp, SIGNAL(processExited(Opie::Core::OProcess*) ),
112 this, SLOT(slotSDPExited(Opie::Core::OProcess* ) ) ); 113 this, SLOT(slotSDPExited(Opie::Core::OProcess* ) ) );
113 connect(m_sdp, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int ) ), 114 connect(m_sdp, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int ) ),
114 this, SLOT(slotSDPOut(Opie::Core::OProcess*, char*, int) ) ); 115 this, SLOT(slotSDPOut(Opie::Core::OProcess*, char*, int) ) );
115 if (!m_sdp->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) { 116 if (!m_sdp->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) {
116 qWarning("could not start sdptool" ); 117 owarn << "could not start sdptool" << oendl;
117 delete m_sdp; 118 delete m_sdp;
118 Services::ValueList list; 119 Services::ValueList list;
119 emit foundServices( remDevice, list ); 120 emit foundServices( remDevice, list );
120 } 121 }
121} 122}
122void Manager::searchServices( const RemoteDevice& dev){ 123void Manager::searchServices( const RemoteDevice& dev){
123 searchServices( dev.mac() ); 124 searchServices( dev.mac() );
124} 125}
125QString Manager::toDevice( const QString& /*mac*/ ){ 126QString Manager::toDevice( const QString& /*mac*/ ){
126 return QString::null; 127 return QString::null;
127} 128}
128QString Manager::toMac( const QString &/*device*/ ){ 129QString Manager::toMac( const QString &/*device*/ ){
129 return QString::null; 130 return QString::null;
130} 131}
131void Manager::slotProcessExited(OProcess* proc ) { 132void Manager::slotProcessExited(OProcess* proc ) {
132 bool conn= false; 133 bool conn= false;
133 if (proc->normalExit() && proc->exitStatus() == 0 ) 134 if (proc->normalExit() && proc->exitStatus() == 0 )
134 conn = true; 135 conn = true;
135 136
136 QString name = QString::fromLatin1(proc->name() ); 137 QString name = QString::fromLatin1(proc->name() );
137 emit available( name, conn ); 138 emit available( name, conn );
138 delete proc; 139 delete proc;
139} 140}
140void Manager::slotSDPOut(OProcess* proc, char* ch, int len) 141void Manager::slotSDPOut(OProcess* proc, char* ch, int len)
141{ 142{
142 QCString str(ch, len+1 ); 143 QCString str(ch, len+1 );
143 qWarning("SDP:%s", str.data() ); 144 owarn << "SDP:" << str.data() << oendl;
144 QMap<QString, QString>::Iterator it; 145 QMap<QString, QString>::Iterator it;
145 it = m_out.find(proc->name() ); 146 it = m_out.find(proc->name() );
146 QString string; 147 QString string;
147 if ( it != m_out.end() ) { 148 if ( it != m_out.end() ) {
148 string = it.data(); 149 string = it.data();
149 } 150 }
150 string.append( str ); 151 string.append( str );
151 m_out.replace( proc->name(), string ); 152 m_out.replace( proc->name(), string );
152 153
153} 154}
154void Manager::slotSDPExited( OProcess* proc) 155void Manager::slotSDPExited( OProcess* proc)
155{ 156{
156 qWarning("proc name %s", proc->name() ); 157 owarn << "proc name " << proc->name() << oendl;
157 Services::ValueList list; 158 Services::ValueList list;
158 if (proc->normalExit() ) { 159 if (proc->normalExit() ) {
159 QMap<QString, QString>::Iterator it = m_out.find( proc->name() ); 160 QMap<QString, QString>::Iterator it = m_out.find( proc->name() );
160 if ( it != m_out.end() ) { 161 if ( it != m_out.end() ) {
161 qWarning("found process" ); 162 owarn << "found process" << oendl;
162 list = parseSDPOutput( it.data() ); 163 list = parseSDPOutput( it.data() );
163 m_out.remove( it ); 164 m_out.remove( it );
164 } 165 }
165 } 166 }
166 emit foundServices( proc->name(), list ); 167 emit foundServices( proc->name(), list );
167 delete proc; 168 delete proc;
168} 169}
169Services::ValueList Manager::parseSDPOutput( const QString& out ) { 170Services::ValueList Manager::parseSDPOutput( const QString& out ) {
170 Services::ValueList list; 171 Services::ValueList list;
171 qWarning("parsing output" ); 172 owarn << "parsing output" << oendl;
172 Parser parser( out ); 173 Parser parser( out );
173 list = parser.services(); 174 list = parser.services();
174 return list; 175 return list;
175} 176}
176 177
177void Manager::slotHCIExited(OProcess* proc ) { 178void Manager::slotHCIExited(OProcess* proc ) {
178 qWarning("process exited"); 179 owarn << "process exited" << oendl;
179 RemoteDevice::ValueList list; 180 RemoteDevice::ValueList list;
180 if (proc->normalExit() ) { 181 if (proc->normalExit() ) {
181 qWarning("normalExit %s", proc->name() ); 182 owarn << "normalExit " << proc->name() << oendl;
182 QMap<QString, QString>::Iterator it = m_devices.find(proc->name() ); 183 QMap<QString, QString>::Iterator it = m_devices.find(proc->name() );
183 if (it != m_devices.end() ) { 184 if (it != m_devices.end() ) {
184 qWarning("!= end ;)"); 185 owarn << "!= end ;)" << oendl;
185 list = parseHCIOutput( it.data() ); 186 list = parseHCIOutput( it.data() );
186 m_devices.remove( it ); 187 m_devices.remove( it );
187 } 188 }
188 } 189 }
189 emit foundDevices( proc->name(), list ); 190 emit foundDevices( proc->name(), list );
190 delete proc; 191 delete proc;
191} 192}
192void Manager::slotHCIOut(OProcess* proc, char* ch, int len) { 193void Manager::slotHCIOut(OProcess* proc, char* ch, int len) {
193 QCString str( ch, len+1 ); 194 QCString str( ch, len+1 );
194 qWarning("hci: %s", str.data() ); 195 owarn << "hci: " << str.data() oendl;
195 QMap<QString, QString>::Iterator it; 196 QMap<QString, QString>::Iterator it;
196 it = m_devices.find( proc->name() ); 197 it = m_devices.find( proc->name() );
197 qWarning("proc->name %s", proc->name() ); 198 owarn << "proc->name " << proc->name() << oendl;
198 QString string; 199 QString string;
199 if (it != m_devices.end() ) { 200 if (it != m_devices.end() ) {
200 qWarning("slotHCIOut "); 201 owarn << "slotHCIOut " << oendl;
201 string = it.data(); 202 string = it.data();
202 } 203 }
203 string.append( str ); 204 string.append( str );
204 205
205 m_devices.replace( proc->name(), string ); 206 m_devices.replace( proc->name(), string );
206} 207}
207RemoteDevice::ValueList Manager::parseHCIOutput(const QString& output ) { 208RemoteDevice::ValueList Manager::parseHCIOutput(const QString& output ) {
208 qWarning("parseHCI %s", output.latin1() ); 209 owarn << "parseHCI " << output.latin1() << oendl;
209 RemoteDevice::ValueList list; 210 RemoteDevice::ValueList list;
210 QStringList strList = QStringList::split('\n', output ); 211 QStringList strList = QStringList::split('\n', output );
211 QStringList::Iterator it; 212 QStringList::Iterator it;
212 QString str; 213 QString str;
213 for ( it = strList.begin(); it != strList.end(); ++it ) { 214 for ( it = strList.begin(); it != strList.end(); ++it ) {
214 str = (*it).stripWhiteSpace(); 215 str = (*it).stripWhiteSpace();
215 qWarning("OpieTooth %s", str.latin1() ); 216 owarn << "OpieTooth " << str.latin1() << oendl;
216 int pos = str.findRev(':' ); 217 int pos = str.findRev(':' );
217 if ( pos > 0 ) { 218 if ( pos > 0 ) {
218 QString mac = str.left(17 ); 219 QString mac = str.left(17 );
219 str.remove( 0, 17 ); 220 str.remove( 0, 17 );
220 qWarning("mac %s", mac.latin1() ); 221 owarn << "mac " << mac.latin1() << oendl;
221 qWarning("rest:%s", str.latin1() ); 222 owarn << "rest: " << str.latin1() << oendl;
222 RemoteDevice rem( mac , str.stripWhiteSpace() ); 223 RemoteDevice rem( mac , str.stripWhiteSpace() );
223 list.append( rem ); 224 list.append( rem );
224 } 225 }
225 } 226 }
226 return list; 227 return list;
227} 228}
228 229
229////// hcitool cc and hcitool con 230////// hcitool cc and hcitool con
230 231
231/** 232/**
232 * Create it on the stack as don't care 233 * Create it on the stack as don't care
233 * so we don't need to care for it 234 * so we don't need to care for it
234 * cause hcitool gets reparented 235 * cause hcitool gets reparented
235 */ 236 */
236void Manager::connectTo( const QString& mac) { 237void Manager::connectTo( const QString& mac) {
237 OProcess proc; 238 OProcess proc;
238 proc << "hcitool"; 239 proc << "hcitool";
239 proc << "cc"; 240 proc << "cc";
240 proc << mac; 241 proc << mac;
241 proc.start(OProcess::DontCare); // the lib does not care at this point 242 proc.start(OProcess::DontCare); // the lib does not care at this point
242} 243}
243 244
244 245
245void Manager::searchConnections() { 246void Manager::searchConnections() {
246 qWarning("searching connections?"); 247 owarn << "searching connections?" << oendl;
247 OProcess* proc = new OProcess(); 248 OProcess* proc = new OProcess();
248 m_hcitoolCon = QString::null; 249 m_hcitoolCon = QString::null;
249 250
250 connect(proc, SIGNAL(processExited(Opie::Core::OProcess*) ), 251 connect(proc, SIGNAL(processExited(Opie::Core::OProcess*) ),
251 this, SLOT(slotConnectionExited( Opie::Core::OProcess*) ) ); 252 this, SLOT(slotConnectionExited( Opie::Core::OProcess*) ) );
252 connect(proc, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int) ), 253 connect(proc, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int) ),
253 this, SLOT(slotConnectionOutput(Opie::Core::OProcess*, char*, int) ) ); 254 this, SLOT(slotConnectionOutput(Opie::Core::OProcess*, char*, int) ) );
254 *proc << "hcitool"; 255 *proc << "hcitool";
255 *proc << "con"; 256 *proc << "con";
256 257
257 if (!proc->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) { 258 if (!proc->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) {
258 ConnectionState::ValueList list; 259 ConnectionState::ValueList list;
259 emit connections( list ); 260 emit connections( list );
260 delete proc; 261 delete proc;
261 } 262 }
262} 263}
263void Manager::slotConnectionExited( OProcess* proc ) { 264void Manager::slotConnectionExited( OProcess* proc ) {
264 ConnectionState::ValueList list; 265 ConnectionState::ValueList list;
265 list = parseConnections( m_hcitoolCon ); 266 list = parseConnections( m_hcitoolCon );
266 emit connections(list ); 267 emit connections(list );
267 delete proc; 268 delete proc;
268} 269}
269void Manager::slotConnectionOutput(OProcess* /*proc*/, char* cha, int len) { 270void Manager::slotConnectionOutput(OProcess* /*proc*/, char* cha, int len) {
270 QCString str(cha, len ); 271 QCString str(cha, len );
271 m_hcitoolCon.append( str ); 272 m_hcitoolCon.append( str );
272 //delete proc; 273 //delete proc;
273} 274}
274ConnectionState::ValueList Manager::parseConnections( const QString& out ) { 275ConnectionState::ValueList Manager::parseConnections( const QString& out ) {
275 ConnectionState::ValueList list2; 276 ConnectionState::ValueList list2;
276 QStringList list = QStringList::split('\n', out ); 277 QStringList list = QStringList::split('\n', out );
277 QStringList::Iterator it; 278 QStringList::Iterator it;
278 // remove the first line ( "Connections:") 279 // remove the first line ( "Connections:")
279 it = list.begin(); 280 it = list.begin();
280 it = list.remove( it ); 281 it = list.remove( it );
281 for (; it != list.end(); ++it ) { 282 for (; it != list.end(); ++it ) {
282 QString row = (*it).stripWhiteSpace(); 283 QString row = (*it).stripWhiteSpace();
283 QStringList value = QStringList::split(' ', row ); 284 QStringList value = QStringList::split(' ', row );
284 qWarning("0: %s", value[0].latin1() ); 285 owan << "0: %s" << value[0].latin1() << oendl;
285 qWarning("1: %s", value[1].latin1() ); 286 owan << "1: %s" << value[1].latin1() << oendl;
286 qWarning("2: %s", value[2].latin1() ); 287 owan << "2: %s" << value[2].latin1() << oendl;
287 qWarning("3: %s", value[3].latin1() ); 288 owan << "3: %s" << value[3].latin1() << oendl;
288 qWarning("4: %s", value[4].latin1() ); 289 owan << "4: %s" << value[4].latin1() << oendl;
289 qWarning("5: %s", value[5].latin1() ); 290 owan << "5: %s" << value[5].latin1() << oendl;
290 qWarning("6: %s", value[6].latin1() ); 291 owan << "6: %s" << value[6].latin1() << oendl;
291 qWarning("7: %s", value[7].latin1() ); 292 owan << "7: %s" << value[7].latin1() << oendl;
292 qWarning("8: %s", value[8].latin1() ); 293 owan << "8: %s" << value[8].latin1() << oendl;
293 ConnectionState con; 294 ConnectionState con;
294 con.setDirection( value[0] == QString::fromLatin1("<") ? Outgoing : Incoming ); 295 con.setDirection( value[0] == QString::fromLatin1("<") ? Outgoing : Incoming );
295 con.setConnectionMode( value[1] ); 296 con.setConnectionMode( value[1] );
296 con.setMac( value[2] ); 297 con.setMac( value[2] );
297 con.setHandle( value[4].toInt() ); 298 con.setHandle( value[4].toInt() );
298 con.setState( value[6].toInt() ); 299 con.setState( value[6].toInt() );
299 con.setLinkMode( value[8] == QString::fromLatin1("MASTER") ? Master : Client ); 300 con.setLinkMode( value[8] == QString::fromLatin1("MASTER") ? Master : Client );
300 list2.append( con ); 301 list2.append( con );
301 } 302 }
302 return list2; 303 return list2;
303} 304}
304 305
305void Manager::signalStrength( const QString &mac ) { 306void Manager::signalStrength( const QString &mac ) {
306 307
307 OProcess* sig_proc = new OProcess(); 308 OProcess* sig_proc = new OProcess();
308 309
309 connect(sig_proc, SIGNAL(processExited(Opie::Core::OProcess*) ), 310 connect(sig_proc, SIGNAL(processExited(Opie::Core::OProcess*) ),
310 this, SLOT(slotSignalStrengthExited( Opie::Core::OProcess*) ) ); 311 this, SLOT(slotSignalStrengthExited( Opie::Core::OProcess*) ) );
311 connect(sig_proc, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int) ), 312 connect(sig_proc, SIGNAL(receivedStdout(Opie::Core::OProcess*, char*, int) ),
312 this, SLOT(slotSignalStrengthOutput(Opie::Core::OProcess*, char*, int) ) ); 313 this, SLOT(slotSignalStrengthOutput(Opie::Core::OProcess*, char*, int) ) );
313 *sig_proc << "hcitool"; 314 *sig_proc << "hcitool";
314 *sig_proc << "lq"; 315 *sig_proc << "lq";
315 *sig_proc << mac; 316 *sig_proc << mac;
316 317
diff --git a/noncore/net/opietooth/lib/parser.cc b/noncore/net/opietooth/lib/parser.cc
index 8baf284..7e95907 100644
--- a/noncore/net/opietooth/lib/parser.cc
+++ b/noncore/net/opietooth/lib/parser.cc
@@ -1,199 +1,205 @@
1 1
2#include "parser.h"
3
4/* OPIE */
5#include <opie2/odebug.h>
6using namespace Opie::Core;
7
8/* QT */
2#include <qstringlist.h> 9#include <qstringlist.h>
3 10
4#include "parser.h"
5 11
6using namespace OpieTooth; 12using namespace OpieTooth;
7 13
8namespace { 14namespace {
9 15
10 16
11 // "Test Foo Bar" (0x3456) 17 // "Test Foo Bar" (0x3456)
12 // @param ret Test Foo Bar 18 // @param ret Test Foo Bar
13 // @eturn 13398 19 // @eturn 13398
14 // tactic find " ( 20 // tactic find " (
15int convert( const QString& line, QString& ret ) { 21int convert( const QString& line, QString& ret ) {
16// qWarning("called"); 22// owarn << "called" << oendl;
17 ret = QString::null; 23 ret = QString::null;
18 int i = 0; 24 int i = 0;
19 int pos = line.findRev("\" ("); 25 int pos = line.findRev("\" (");
20 if ( pos > 0 ) { // it shouldn't be at pos 0 26 if ( pos > 0 ) { // it shouldn't be at pos 0
21 ret = line.left(pos ).stripWhiteSpace(); 27 ret = line.left(pos ).stripWhiteSpace();
22 // qWarning("ret: %s", ret.latin1() ); 28 // owarn << "ret: " << ret.latin1() << oendl;
23 ret = ret.replace(QRegExp("[\"]"), ""); 29 ret = ret.replace(QRegExp("[\"]"), "");
24 //qWarning("ret: %s", ret.latin1() ); 30 //owarn << "ret: " << ret.latin1() << oendl;
25 QString dummy = line.mid(pos + 5 ); 31 QString dummy = line.mid(pos + 5 );
26 //qWarning("dummy: %s", dummy.latin1() ); 32 //owarn << "dummy: " << dummy.latin1() << oendl;
27 dummy = dummy.replace(QRegExp("[)]"), ""); 33 dummy = dummy.replace(QRegExp("[)]"), "");
28 //qWarning("dummy: %s", dummy.latin1() ); 34 //owarn << "dummy: " << dummy.latin1() << oendl;
29// dummy = dummy.remove( dummy.length() -2, 1 ); // remove the ) 35// dummy = dummy.remove( dummy.length() -2, 1 ); // remove the )
30 bool ok; 36 bool ok;
31 i = dummy.toInt(&ok, 16 ); 37 i = dummy.toInt(&ok, 16 );
32 //if (ok ) { 38 //if (ok ) {
33 // qWarning("converted %d", i); 39 // owarn << "converted " << i << oendl;
34 //}else qWarning("failed" ); 40 //}else owarn << "failed" << oendl;
35 //qWarning("exiting"); 41 //owarn << "exiting" << oendl;
36 return i; 42 return i;
37 } 43 }
38 //qWarning("output %d", i ); 44 //owarn << "output " << i << oendl;
39 return i; 45 return i;
40} 46}
41 47
42}; 48};
43 49
44 50
45Parser::Parser(const QString& output ) { 51Parser::Parser(const QString& output ) {
46 parse( output ); 52 parse( output );
47} 53}
48void Parser::setText(const QString& output) { 54void Parser::setText(const QString& output) {
49 parse( output ); 55 parse( output );
50} 56}
51Services::ValueList Parser::services() const { 57Services::ValueList Parser::services() const {
52 return m_list; 58 return m_list;
53} 59}
54void Parser::parse( const QString& string) { 60void Parser::parse( const QString& string) {
55 m_list.clear(); 61 m_list.clear();
56 m_complete = true; 62 m_complete = true;
57 QStringList list = QStringList::split('\n', string,TRUE ); 63 QStringList list = QStringList::split('\n', string,TRUE );
58 QStringList::Iterator it; 64 QStringList::Iterator it;
59 for (it = list.begin(); it != list.end(); ++it ) { 65 for (it = list.begin(); it != list.end(); ++it ) {
60 //qWarning("line:%s:line", (*it).latin1() ); 66 //owarn << "line:" << (*it).latin1() << oendl;
61 if ( (*it).startsWith("Browsing") ) continue; 67 if ( (*it).startsWith("Browsing") ) continue;
62 68
63 if ( (*it).stripWhiteSpace().isEmpty() ) { // line is empty because a new Service begins 69 if ( (*it).stripWhiteSpace().isEmpty() ) { // line is empty because a new Service begins
64 qWarning("could add"); 70 owarn << "could add" << oendl;
65 // now see if complete and add 71 // now see if complete and add
66 if (m_complete ) { 72 if (m_complete ) {
67 if (!m_item.serviceName().isEmpty() ) 73 if (!m_item.serviceName().isEmpty() )
68 m_list.append( m_item ); 74 m_list.append( m_item );
69 Services serv; 75 Services serv;
70 m_item = serv; 76 m_item = serv;
71 m_complete = true; 77 m_complete = true;
72 continue; 78 continue;
73 } 79 }
74 } 80 }
75 if (parseName( (*it) ) ) ;//continue; 81 if (parseName( (*it) ) ) ;//continue;
76 if (parseRecHandle( (*it) ) ) ;//continue; 82 if (parseRecHandle( (*it) ) ) ;//continue;
77 if (parseClassId( (*it) ) ) ;//continue; 83 if (parseClassId( (*it) ) ) ;//continue;
78 if (parseProtocol( (*it) ) ) ;//continue; 84 if (parseProtocol( (*it) ) ) ;//continue;
79 if (parseProfile( (*it) ) ) ;//continue; 85 if (parseProfile( (*it) ) ) ;//continue;
80 } 86 }
81 // missed the last one 87 // missed the last one
82 if (m_complete) { 88 if (m_complete) {
83// qWarning("adding"); 89// owarn << "adding" << oendl;
84 if (!m_item.serviceName().isEmpty() ) 90 if (!m_item.serviceName().isEmpty() )
85 m_list.append(m_item ); 91 m_list.append(m_item );
86 } 92 }
87 QValueList<Services>::Iterator it2; 93 QValueList<Services>::Iterator it2;
88 94
89 if (m_list.isEmpty() ) 95 if (m_list.isEmpty() )
90 qWarning("m_list is empty"); 96 owarn << "m_list is empty" << oendl;
91 for (it2 = m_list.begin(); it2 != m_list.end(); ++it2 ) { 97 for (it2 = m_list.begin(); it2 != m_list.end(); ++it2 ) {
92 qWarning("name %s", (*it2).serviceName().latin1() ); 98 owarn << "name " << (*it2).serviceName().latin1() << oendl;
93 } 99 }
94} 100}
95bool Parser::parseName( const QString& str) { 101bool Parser::parseName( const QString& str) {
96 if (str.startsWith("Service Name:") ) { 102 if (str.startsWith("Service Name:") ) {
97 m_item.setServiceName( str.mid(13).stripWhiteSpace() ); 103 m_item.setServiceName( str.mid(13).stripWhiteSpace() );
98 qWarning(m_item.serviceName() ); 104 owarn << m_item.serviceName() << oendl;
99 return true; 105 return true;
100 } 106 }
101 return false; 107 return false;
102} 108}
103bool Parser::parseRecHandle( const QString& str) { 109bool Parser::parseRecHandle( const QString& str) {
104 if (str.startsWith("Service RecHandle:" ) ) { 110 if (str.startsWith("Service RecHandle:" ) ) {
105 QString out = str.mid(18 ).stripWhiteSpace(); 111 QString out = str.mid(18 ).stripWhiteSpace();
106 qWarning("out %s", out.latin1() ); 112 owarn << "out " << out.latin1() << oendl;
107 int value = out.mid(2).toInt(&m_ok, 16 ); 113 int value = out.mid(2).toInt(&m_ok, 16 );
108 if (m_ok && (value != -1) ) 114 if (m_ok && (value != -1) )
109 m_complete = true; 115 m_complete = true;
110 else 116 else
111 m_complete = false; 117 m_complete = false;
112 qWarning("rec handle %d", value); 118 owarn << "rec handle " << value << oendl;
113 m_item.setRecHandle( value ); 119 m_item.setRecHandle( value );
114 return true; 120 return true;
115 121
116 } 122 }
117 return false; 123 return false;
118} 124}
119bool Parser::parseClassId( const QString& str) { 125bool Parser::parseClassId( const QString& str) {
120 if (str.startsWith("Service Class ID List:") ) { 126 if (str.startsWith("Service Class ID List:") ) {
121 qWarning("found class id" ); 127 owarn << "found class id" << oendl;
122 qWarning("line:%s", str.latin1() ); 128 owarn << "line: " << str.latin1() << oendl;
123 m_classOver = true; 129 m_classOver = true;
124 return true; 130 return true;
125 }else if ( m_classOver && str.startsWith(" " ) ){ // ok now are the informations in place 131 }else if ( m_classOver && str.startsWith(" " ) ){ // ok now are the informations in place
126 qWarning("line with class id" ); 132 owarn << "line with class id" << oendl;
127 qWarning("%s",str.latin1() ); 133 owarn << str.latin1() << oendl;
128 134
129 // "Obex Object Push" (0x1105) 135 // "Obex Object Push" (0x1105)
130 // find backwards the " and the from 0 to pos and the mid pos+1 136 // find backwards the " and the from 0 to pos and the mid pos+1
131 // then stripWhiteSpace add name replace '"' with "" 137 // then stripWhiteSpace add name replace '"' with ""
132 // and then convert 0x1105 toInt() 138 // and then convert 0x1105 toInt()
133 QString classes; 139 QString classes;
134 int ids; 140 int ids;
135 ids = convert( str, classes ); 141 ids = convert( str, classes );
136 qWarning("ids %d", ids ); 142 owarn << "ids " << ids << oendl;
137 m_item.insertClassId( ids, classes ); 143 m_item.insertClassId( ids, classes );
138 144
139 return true; 145 return true;
140 }else{ 146 }else{
141 qWarning("Else %d", m_classOver ); 147 owarn << "Else " << m_classOver << oendl;
142 m_classOver = false; 148 m_classOver = false;
143 } 149 }
144 return false; 150 return false;
145} 151}
146bool Parser::parseProtocol( const QString& str) { 152bool Parser::parseProtocol( const QString& str) {
147 if (str.startsWith("Protocol Descriptor List:") ) { 153 if (str.startsWith("Protocol Descriptor List:") ) {
148 m_protocolOver = true; 154 m_protocolOver = true;
149 m_protocolAdded = false; 155 m_protocolAdded = false;
150 return true; 156 return true;
151 157
152 }else if (m_protocolOver && str.startsWith(" ") ) { // "L2CAP" (0x0100) 158 }else if (m_protocolOver && str.startsWith(" ") ) { // "L2CAP" (0x0100)
153 qWarning("double protocol filter"); 159 owarn << "double protocol filter" << oendl;
154 160
155 if (!m_protocolAdded ) { // the protocol does neither supply a channel nor port so add it now 161 if (!m_protocolAdded ) { // the protocol does neither supply a channel nor port so add it now
156 Services::ProtocolDescriptor desc( m_protName, m_protId ); 162 Services::ProtocolDescriptor desc( m_protName, m_protId );
157 m_item.insertProtocolDescriptor( desc ); 163 m_item.insertProtocolDescriptor( desc );
158 } 164 }
159 m_protocolAdded = false; 165 m_protocolAdded = false;
160 { // the find function 166 { // the find function
161 m_protId = convert(str, m_protName ); 167 m_protId = convert(str, m_protName );
162 } 168 }
163 return true; 169 return true;
164 }else if (m_protocolOver && str.startsWith(" ") ) { 170 }else if (m_protocolOver && str.startsWith(" ") ) {
165 qWarning("tripple protocol filter"); 171 owarn << "tripple protocol filter" << oendl;
166 m_protocolAdded = true; 172 m_protocolAdded = true;
167 QString dummy = str.stripWhiteSpace(); 173 QString dummy = str.stripWhiteSpace();
168 int pos = dummy.findRev(':'); 174 int pos = dummy.findRev(':');
169 if ( pos > -1 ) { 175 if ( pos > -1 ) {
170 int port = dummy.mid(pos+1 ).stripWhiteSpace().toInt(); 176 int port = dummy.mid(pos+1 ).stripWhiteSpace().toInt();
171 Services::ProtocolDescriptor desc( m_protName, m_protId, port ); 177 Services::ProtocolDescriptor desc( m_protName, m_protId, port );
172 m_item.insertProtocolDescriptor( desc ); 178 m_item.insertProtocolDescriptor( desc );
173 } 179 }
174 return true; 180 return true;
175 }else if (m_protocolOver ) { 181 }else if (m_protocolOver ) {
176 m_protocolOver = false; 182 m_protocolOver = false;
177 } 183 }
178 return false; 184 return false;
179} 185}
180bool Parser::parseProfile( const QString& str) { 186bool Parser::parseProfile( const QString& str) {
181 if (str.startsWith("Profile Descriptor List:") ) { 187 if (str.startsWith("Profile Descriptor List:") ) {
182 m_profOver = true; 188 m_profOver = true;
183 }else if ( m_profOver && str.startsWith(" ") ) { 189 }else if ( m_profOver && str.startsWith(" ") ) {
184 m_profId = convert( str, m_profName ); 190 m_profId = convert( str, m_profName );
185 }else if ( m_profOver && str.startsWith(" ") ) { 191 }else if ( m_profOver && str.startsWith(" ") ) {
186 // now find 192 // now find
187 int pos = str.findRev(':'); 193 int pos = str.findRev(':');
188 if ( pos > 0 ) { 194 if ( pos > 0 ) {
189 int dummy = str.mid(pos+1 ).stripWhiteSpace().toInt(); 195 int dummy = str.mid(pos+1 ).stripWhiteSpace().toInt();
190 qWarning("dummyInt:%d", dummy ); 196 owarn << "dummyInt: " << dummy << oendl;
191 Services::ProfileDescriptor desc( m_profName, m_profId, dummy ); 197 Services::ProfileDescriptor desc( m_profName, m_profId, dummy );
192 m_item.insertProfileDescriptor(desc); 198 m_item.insertProfileDescriptor(desc);
193 } 199 }
194 }else 200 }else
195 m_profOver = false; 201 m_profOver = false;
196 202
197 203
198 return false; 204 return false;
199} 205}
diff --git a/noncore/settings/mediummount/mediumglobal.cc b/noncore/settings/mediummount/mediumglobal.cc
index ab0b3af..0c6cf12 100644
--- a/noncore/settings/mediummount/mediumglobal.cc
+++ b/noncore/settings/mediummount/mediumglobal.cc
@@ -1,38 +1,43 @@
1 1
2#include "mediumglobal.h"
3
4/* OPIE */
5#include <opie2/odebug.h>
6using namespace Opie::Core;
7#include <qpe/config.h>
2 8
9/* QT */
3#include <qlineedit.h> 10#include <qlineedit.h>
4#include <qcheckbox.h> 11#include <qcheckbox.h>
5#include <qlabel.h> 12#include <qlabel.h>
6#include <qabstractlayout.h> // spacer item 13#include <qabstractlayout.h> // spacer item
7#include <qlayout.h> 14#include <qlayout.h>
8#include <qframe.h> 15#include <qframe.h>
9#include <qgroupbox.h> 16#include <qgroupbox.h>
10#include <qwhatsthis.h> 17#include <qwhatsthis.h>
11 18
12#include <qpe/config.h>
13 19
14#include "mediumglobal.h"
15 20
16using namespace MediumMountSetting; 21using namespace MediumMountSetting;
17 22
18/* TRANSLATOR MediumMountSetting::MediumGlobalWidget */ 23/* TRANSLATOR MediumMountSetting::MediumGlobalWidget */
19 24
20MediumGlobalWidget::MediumGlobalWidget(QWidget *wid, const char *name ) 25MediumGlobalWidget::MediumGlobalWidget(QWidget *wid, const char *name )
21 : QWidget( wid, name, WStyle_ContextHelp ) 26 : QWidget( wid, name, WStyle_ContextHelp )
22{ 27{
23 m_config = 0; 28 m_config = 0;
24 initGUI(); 29 initGUI();
25 readConfig(); 30 readConfig();
26 31
27} 32}
28void MediumGlobalWidget::initGUI() 33void MediumGlobalWidget::initGUI()
29{ 34{
30 m_layout = new QVBoxLayout(this ); 35 m_layout = new QVBoxLayout(this );
31 m_layout->setMargin( 4 ); 36 m_layout->setMargin( 4 );
32 // m_layout->setSpacing( 10 ); 37 // m_layout->setSpacing( 10 );
33 38
34 39
35 m_label = new QLabel( this ); 40 m_label = new QLabel( this );
36 m_label->setTextFormat( Qt::RichText ); 41 m_label->setTextFormat( Qt::RichText );
37 m_label->setText( tr("") ); 42 m_label->setText( tr("") );
38 QWhatsThis::add( this, tr("If a medium gets inserted into this device Opie " 43 QWhatsThis::add( this, tr("If a medium gets inserted into this device Opie "
@@ -131,49 +136,49 @@ void MediumGlobalWidget::writeConfig()
131 m_config->setGroup( "main" ); 136 m_config->setGroup( "main" );
132 m_config->writeEntry("global", m_useglobal->isChecked() ); 137 m_config->writeEntry("global", m_useglobal->isChecked() );
133 m_config->writeEntry("use", m_check->isChecked() ); 138 m_config->writeEntry("use", m_check->isChecked() );
134 139
135 m_config->setGroup("mimetypes" ); 140 m_config->setGroup("mimetypes" );
136 141
137 m_config->writeEntry("all", m_all->isChecked() ); 142 m_config->writeEntry("all", m_all->isChecked() );
138 m_config->writeEntry("audio", m_audio->isChecked() ); 143 m_config->writeEntry("audio", m_audio->isChecked() );
139 m_config->writeEntry("video", m_video->isChecked() ); 144 m_config->writeEntry("video", m_video->isChecked() );
140 m_config->writeEntry("text", m_text->isChecked() ); 145 m_config->writeEntry("text", m_text->isChecked() );
141 m_config->writeEntry("image", m_image->isChecked() ); 146 m_config->writeEntry("image", m_image->isChecked() );
142} 147}
143MediumGlobalWidget::~MediumGlobalWidget() 148MediumGlobalWidget::~MediumGlobalWidget()
144{ 149{
145 delete m_config; 150 delete m_config;
146} 151}
147void MediumGlobalWidget::slotGlobalChanged() 152void MediumGlobalWidget::slotGlobalChanged()
148{ 153{
149 int mode = GLOBAL_DISABLED; 154 int mode = GLOBAL_DISABLED;
150 bool enabled = false; 155 bool enabled = false;
151 if( ( enabled =m_useglobal->isChecked() ) ){ 156 if( ( enabled =m_useglobal->isChecked() ) ){
152 mode = GLOBAL_ENABLED; 157 mode = GLOBAL_ENABLED;
153 }else 158 }else
154 mode = GLOBAL_DISABLED; 159 mode = GLOBAL_DISABLED;
155 qWarning("enabled = %d", enabled ); 160 owarn << "enabled = " << enabled << oendl;
156 m_all->setEnabled ( enabled ); 161 m_all->setEnabled ( enabled );
157 m_audio->setEnabled( enabled ); 162 m_audio->setEnabled( enabled );
158 m_image->setEnabled( enabled ); 163 m_image->setEnabled( enabled );
159 m_text->setEnabled ( enabled ); 164 m_text->setEnabled ( enabled );
160 m_video->setEnabled ( enabled ); 165 m_video->setEnabled ( enabled );
161 slotAllChanged(); 166 slotAllChanged();
162 167
163 emit globalStateChanged( mode ); 168 emit globalStateChanged( mode );
164} 169}
165void MediumGlobalWidget::slotEnableChecking() 170void MediumGlobalWidget::slotEnableChecking()
166{ 171{
167 int mode = ENABLE_CHECKS; 172 int mode = ENABLE_CHECKS;
168 bool enabled = false; 173 bool enabled = false;
169 if( ( enabled = m_check->isChecked() ) ){ 174 if( ( enabled = m_check->isChecked() ) ){
170 mode = ENABLE_CHECKS; 175 mode = ENABLE_CHECKS;
171 }else{ 176 }else{
172 mode = DISABLE_CHECKS; 177 mode = DISABLE_CHECKS;
173 } 178 }
174 m_frame->setEnabled( enabled ); 179 m_frame->setEnabled( enabled );
175 slotGlobalChanged(); 180 slotGlobalChanged();
176 emit enableStateChanged( mode ); 181 emit enableStateChanged( mode );
177} 182}
178void MediumGlobalWidget::slotAllChanged() 183void MediumGlobalWidget::slotAllChanged()
179{ 184{
diff --git a/noncore/styles/theme/othemebase.h b/noncore/styles/theme/othemebase.h
index e691692..5519798 100644
--- a/noncore/styles/theme/othemebase.h
+++ b/noncore/styles/theme/othemebase.h
@@ -1,739 +1,744 @@
1/* This file is part of the KDE libraries 1/* This file is part of the KDE libraries
2 Copyright (C) 1999 Daniel M. Duley <mosfet@kde.org> 2 Copyright (C) 1999 Daniel M. Duley <mosfet@kde.org>
3 3
4 This library is free software; you can redistribute it and/or 4 This library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Library General Public 5 modify it under the terms of the GNU Library General Public
6 License version 2 as published by the Free Software Foundation. 6 License version 2 as published by the Free Software Foundation.
7 7
8 This library is distributed in the hope that it will be useful, 8 This library is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY; without even the implied warranty of 9 but WITHOUT ANY WARRANTY; without even the implied warranty of
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 Library General Public License for more details. 11 Library General Public License for more details.
12 12
13 You should have received a copy of the GNU Library General Public License 13 You should have received a copy of the GNU Library General Public License
14 along with this library; see the file COPYING.LIB. If not, write to 14 along with this library; see the file COPYING.LIB. If not, write to
15 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, 15 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
16 Boston, MA 02111-1307, USA. 16 Boston, MA 02111-1307, USA.
17*/ 17*/
18#ifndef __OTHEMEBASE_H 18#ifndef __OTHEMEBASE_H
19#define __OTHEMEBASE_H 19#define __OTHEMEBASE_H
20 20
21/* OPIE */
22#include <opie2/odebug.h>
23using namespace Opie::Core;
24
25/* QT */
21#include <qdatetime.h> 26#include <qdatetime.h>
22#include <qtimer.h> 27#include <qtimer.h>
23#include <qwindowsstyle.h> 28#include <qwindowsstyle.h>
24#include <qpixmap.h> 29#include <qpixmap.h>
25#include <qpe/config.h> 30#include <qpe/config.h>
26#include <qimage.h> 31#include <qimage.h>
27#include <qintcache.h> 32#include <qintcache.h>
28#include <qstring.h> 33#include <qstring.h>
29#include <qpalette.h> 34#include <qpalette.h>
30 35
31#define WIDGETS 54 36#define WIDGETS 54
32 37
33/** 38/**
34 * This class adds simple time management to QPixmap for use in flushing 39 * This class adds simple time management to QPixmap for use in flushing
35 * OThemeCache. 40 * OThemeCache.
36 * 41 *
37 * @author Daniel M. Duley <mosfet@kde.org> 42 * @author Daniel M. Duley <mosfet@kde.org>
38 */ 43 */
39class OThemePixmap : public QPixmap 44class OThemePixmap : public QPixmap
40{ 45{
41public: 46public:
42 enum BorderType{Top = 0, Bottom, Left, Right, TopLeft, TopRight, BottomLeft, 47 enum BorderType{Top = 0, Bottom, Left, Right, TopLeft, TopRight, BottomLeft,
43 BottomRight}; 48 BottomRight};
44 49
45 OThemePixmap( bool timer = true ); 50 OThemePixmap( bool timer = true );
46 OThemePixmap( const OThemePixmap &p ); 51 OThemePixmap( const OThemePixmap &p );
47 ~OThemePixmap(); 52 ~OThemePixmap();
48 QPixmap* border( BorderType type ); 53 QPixmap* border( BorderType type );
49 void setBorder( BorderType type, const QPixmap &p ); 54 void setBorder( BorderType type, const QPixmap &p );
50 void updateAccessed(); 55 void updateAccessed();
51 bool isOld(); 56 bool isOld();
52protected: 57protected:
53 QTime *t; 58 QTime *t;
54 QPixmap *b[ 8 ]; 59 QPixmap *b[ 8 ];
55 60
56private: 61private:
57 class OThemePixmapPrivate; 62 class OThemePixmapPrivate;
58 OThemePixmapPrivate *d; 63 OThemePixmapPrivate *d;
59}; 64};
60 65
61inline QPixmap* OThemePixmap::border( BorderType type ) 66inline QPixmap* OThemePixmap::border( BorderType type )
62{ 67{
63 return ( b[ type ] ); 68 return ( b[ type ] );
64} 69}
65 70
66inline void OThemePixmap::setBorder( BorderType type, const QPixmap &p ) 71inline void OThemePixmap::setBorder( BorderType type, const QPixmap &p )
67{ 72{
68 if ( b[ type ] ) { 73 if ( b[ type ] ) {
69 qWarning( "OThemePixmap: Overwriting existing border!" ); 74 owarn << "OThemePixmap: Overwriting existing border!" << oendl;
70 delete( b[ type ] ); 75 delete( b[ type ] );
71 } 76 }
72 b[ type ] = new QPixmap( p ); 77 b[ type ] = new QPixmap( p );
73} 78}
74 79
75inline void OThemePixmap::updateAccessed() 80inline void OThemePixmap::updateAccessed()
76{ 81{
77 if (t) 82 if (t)
78 t->start(); 83 t->start();
79} 84}
80 85
81inline bool OThemePixmap::isOld() 86inline bool OThemePixmap::isOld()
82{ 87{
83 return ( t ? t->elapsed() >= 300000 : false ); 88 return ( t ? t->elapsed() >= 300000 : false );
84} 89}
85 90
86/** 91/**
87 * A very simple pixmap cache for theme plugins. QPixmapCache is not used 92 * A very simple pixmap cache for theme plugins. QPixmapCache is not used
88 * since it uses QString keys which are not needed. All the information we 93 * since it uses QString keys which are not needed. All the information we
89 * need can be encoded in a numeric key. Using QIntCache instead allows us to 94 * need can be encoded in a numeric key. Using QIntCache instead allows us to
90 * skip the string operations. 95 * skip the string operations.
91 * 96 *
92 * This class is mostly just inline methods that do bit operations on a key 97 * This class is mostly just inline methods that do bit operations on a key
93 * composed of the widget ID, width and/or height, and then calls 98 * composed of the widget ID, width and/or height, and then calls
94 * QIntCache::find(). 99 * QIntCache::find().
95 * 100 *
96 * One other thing to note is that full, horizontal, and vertically scaled 101 * One other thing to note is that full, horizontal, and vertically scaled
97 * pixmaps are not used interchangeably. For example, if you insert a fully 102 * pixmaps are not used interchangeably. For example, if you insert a fully
98 * scaled pixmap that is 32x32 then request a horizontally scaled pixmap with 103 * scaled pixmap that is 32x32 then request a horizontally scaled pixmap with
99 * a width of 32, they will not match. This is because a pixmap that has been 104 * a width of 32, they will not match. This is because a pixmap that has been
100 * inserted into the cache has already been scaled at some point and it is 105 * inserted into the cache has already been scaled at some point and it is
101 * very likely the vertical height was not originally 32. Thus the pixmap 106 * very likely the vertical height was not originally 32. Thus the pixmap
102 * will be wrong when drawn, even though the horizontal width matches. 107 * will be wrong when drawn, even though the horizontal width matches.
103 * 108 *
104 * @author Daniel M. Duley <mosfet@kde.org> 109 * @author Daniel M. Duley <mosfet@kde.org>
105 * 110 *
106 */ 111 */
107class OThemeCache : public QObject 112class OThemeCache : public QObject
108{ 113{
109 Q_OBJECT 114 Q_OBJECT
110public: 115public:
111 /** 116 /**
112 * The scale hints supported by the cache. Note that Tiled is not here 117 * The scale hints supported by the cache. Note that Tiled is not here
113 * since tiled pixmaps are kept only once in OThemeBase. 118 * since tiled pixmaps are kept only once in OThemeBase.
114 */ 119 */
115 enum ScaleHint{FullScale, HorizontalScale, VerticalScale}; 120 enum ScaleHint{FullScale, HorizontalScale, VerticalScale};
116 /** 121 /**
117 * The constructor. 122 * The constructor.
118 * 123 *
119 * @param maxSize The maximum size of the cache in kilobytes. 124 * @param maxSize The maximum size of the cache in kilobytes.
120 */ 125 */
121 OThemeCache( int maxSize, QObject *parent = 0, const char *name = 0 ); 126 OThemeCache( int maxSize, QObject *parent = 0, const char *name = 0 );
122 /** 127 /**
123 * Inserts a new pixmap into the cache. 128 * Inserts a new pixmap into the cache.
124 * 129 *
125 * @param pixmap The pixmap to insert. 130 * @param pixmap The pixmap to insert.
126 * @param scale The scaling type of the pixmap. 131 * @param scale The scaling type of the pixmap.
127 * @param widgetID The widget ID of the pixmap, usually from OThemeBase's 132 * @param widgetID The widget ID of the pixmap, usually from OThemeBase's
128 * WidgetType enum. 133 * WidgetType enum.
129 * 134 *
130 * @return True if the insert was successful, false otherwise. 135 * @return True if the insert was successful, false otherwise.
131 */ 136 */
132 bool insert( OThemePixmap *pixmap, ScaleHint scale, int widgetID, 137 bool insert( OThemePixmap *pixmap, ScaleHint scale, int widgetID,
133 bool border = false, bool mask = false ); 138 bool border = false, bool mask = false );
134 /** 139 /**
135 * Returns a fully scaled pixmap. 140 * Returns a fully scaled pixmap.
136 * 141 *
137 * @param w The pixmap width to search for. 142 * @param w The pixmap width to search for.
138 * @param h The pixmap height to search for. 143 * @param h The pixmap height to search for.
139 * @param widgetID The widget ID to search for. 144 * @param widgetID The widget ID to search for.
140 * 145 *
141 * @return True if a pixmap matching the width, height, and widget ID of 146 * @return True if a pixmap matching the width, height, and widget ID of
142 * the pixmap exists, NULL otherwise. 147 * the pixmap exists, NULL otherwise.
143 */ 148 */
144 OThemePixmap* pixmap( int w, int h, int widgetID, bool border = false, 149 OThemePixmap* pixmap( int w, int h, int widgetID, bool border = false,
145 bool mask = false ); 150 bool mask = false );
146 /** 151 /**
147 * Returns a horizontally scaled pixmap. 152 * Returns a horizontally scaled pixmap.
148 * 153 *
149 * @param w The pixmap width to search for. 154 * @param w The pixmap width to search for.
150 * @param widgetID The widget ID to search for. 155 * @param widgetID The widget ID to search for.
151 * 156 *
152 * @return True if a pixmap matching the width and widget ID of 157 * @return True if a pixmap matching the width and widget ID of
153 * the pixmap exists, NULL otherwise. 158 * the pixmap exists, NULL otherwise.
154 */ 159 */
155 OThemePixmap* horizontalPixmap( int w, int widgetID ); 160 OThemePixmap* horizontalPixmap( int w, int widgetID );
156 /** 161 /**
157 * Returns a vertically scaled pixmap. 162 * Returns a vertically scaled pixmap.
158 * 163 *
159 * @param h The pixmap height to search for. 164 * @param h The pixmap height to search for.
160 * @param widgetID The widget ID to search for. 165 * @param widgetID The widget ID to search for.
161 * 166 *
162 * @return True if a pixmap matching the height and widget ID of 167 * @return True if a pixmap matching the height and widget ID of
163 * the pixmap exists, NULL otherwise. 168 * the pixmap exists, NULL otherwise.
164 */ 169 */
165 OThemePixmap* verticalPixmap( int h, int widgetID ); 170 OThemePixmap* verticalPixmap( int h, int widgetID );
166protected slots: 171protected slots:
167 void flushTimeout(); 172 void flushTimeout();
168protected: 173protected:
169 QIntCache<OThemePixmap> cache; 174 QIntCache<OThemePixmap> cache;
170 QTimer flushTimer; 175 QTimer flushTimer;
171 176
172private: 177private:
173 class OThemeCachePrivate; 178 class OThemeCachePrivate;
174 OThemeCachePrivate *d; 179 OThemeCachePrivate *d;
175}; 180};
176 181
177 182
178/** 183/**
179 * This is a base class for KDE themed styles. It implements a cache, 184 * This is a base class for KDE themed styles. It implements a cache,
180 * configuration file parsing, pixmap scaling, gradients, and a lot 185 * configuration file parsing, pixmap scaling, gradients, and a lot
181 * of inline methods for accessing user specified parameters. 186 * of inline methods for accessing user specified parameters.
182 * 187 *
183 * Note that this class *does not* actually implement any themes. It just 188 * Note that this class *does not* actually implement any themes. It just
184 * provides the groundwork for doing so. The only reason to use this class 189 * provides the groundwork for doing so. The only reason to use this class
185 * directly is if you plan to reimplement all of the widgets. Otherwise, 190 * directly is if you plan to reimplement all of the widgets. Otherwise,
186 * refer to OThemeStyle for a fully themed style you can derive from. 191 * refer to OThemeStyle for a fully themed style you can derive from.
187 * 192 *
188 * @author Daniel M. Duley <mosfet@kde.org> 193 * @author Daniel M. Duley <mosfet@kde.org>
189 */ 194 */
190class OThemeBase: public QWindowsStyle 195class OThemeBase: public QWindowsStyle
191{ 196{
192 Q_OBJECT 197 Q_OBJECT
193public: 198public:
194 /** 199 /**
195 * Constructs a new OThemeBase object. 200 * Constructs a new OThemeBase object.
196 */ 201 */
197 OThemeBase( const QString &configFile ); 202 OThemeBase( const QString &configFile );
198 ~OThemeBase(); 203 ~OThemeBase();
199 /** 204 /**
200 * Describes if a pixmap should be scaled fully, horizontally, vertically, 205 * Describes if a pixmap should be scaled fully, horizontally, vertically,
201 * or not at all and tiled. 206 * or not at all and tiled.
202 */ 207 */
203 enum ScaleHint{FullScale, HorizontalScale, VerticalScale, TileScale}; 208 enum ScaleHint{FullScale, HorizontalScale, VerticalScale, TileScale};
204 /** 209 /**
205 * The default arrow types. 210 * The default arrow types.
206 */ 211 */
207 enum ArrowStyle{MotifArrow, LargeArrow, SmallArrow}; 212 enum ArrowStyle{MotifArrow, LargeArrow, SmallArrow};
208 /** 213 /**
209 * The default frame shading styles. 214 * The default frame shading styles.
210 */ 215 */
211 enum ShadeStyle{Motif, Windows, Next, KDE}; 216 enum ShadeStyle{Motif, Windows, Next, KDE};
212 /** 217 /**
213 * The default scrollbar button layout. BottomLeft is like what Next 218 * The default scrollbar button layout. BottomLeft is like what Next
214 * uses, BottomRight is like Platinum, and Opposite it like Windows and 219 * uses, BottomRight is like Platinum, and Opposite it like Windows and
215 * Motif. 220 * Motif.
216 */ 221 */
217 enum SButton{SBBottomLeft, SBBottomRight, SBOpposite}; 222 enum SButton{SBBottomLeft, SBBottomRight, SBOpposite};
218 /** 223 /**
219 * The gradient types. Horizontal is left to right, Vertical is top to 224 * The gradient types. Horizontal is left to right, Vertical is top to
220 * bottom, and diagonal is upper-left to bottom-right. 225 * bottom, and diagonal is upper-left to bottom-right.
221 */ 226 */
222 enum Gradient{GrNone, GrHorizontal, GrVertical, GrDiagonal, GrPyramid, 227 enum Gradient{GrNone, GrHorizontal, GrVertical, GrDiagonal, GrPyramid,
223 GrRectangle, GrElliptic, GrReverseBevel}; 228 GrRectangle, GrElliptic, GrReverseBevel};
224 /** 229 /**
225 * This provides a list of widget types that OThemeBase recognizes. 230 * This provides a list of widget types that OThemeBase recognizes.
226 */ 231 */
227 /* Internal note: The order here is important. Some widgets inherit 232 /* Internal note: The order here is important. Some widgets inherit
228 * properties. This is usually for when you have two settings for the 233 * properties. This is usually for when you have two settings for the
229 * same widget, ie: on(sunken), and off. The on settings will inherit 234 * same widget, ie: on(sunken), and off. The on settings will inherit
230 * the properties of the off one when nothing is specified in the config. 235 * the properties of the off one when nothing is specified in the config.
231 * 236 *
232 * In order to be able to handle this while still having everything in 237 * In order to be able to handle this while still having everything in
233 * one group that is easy to loop from we have the following order: 238 * one group that is easy to loop from we have the following order:
234 * unsunked(off) items, sunken(on)items, and then the ones that don't 239 * unsunked(off) items, sunken(on)items, and then the ones that don't
235 * matter. INHERIT_ITEMS define the number of widgets that have inheritence 240 * matter. INHERIT_ITEMS define the number of widgets that have inheritence
236 * so if 0 == PushButtonOff then INHERIT_ITEMS should == PushButtonOn 241 * so if 0 == PushButtonOff then INHERIT_ITEMS should == PushButtonOn
237 * and so on. WIDGETS define the total number of widgets. 242 * and so on. WIDGETS define the total number of widgets.
238 */ 243 */
239 enum WidgetType{ 244 enum WidgetType{
240 // Off (unsunken widgets) 245 // Off (unsunken widgets)
241 PushButton = 0, ComboBox, HScrollBarSlider, VScrollBarSlider, Bevel, 246 PushButton = 0, ComboBox, HScrollBarSlider, VScrollBarSlider, Bevel,
242 ToolButton, ScrollButton, HScrollDeco, VScrollDeco, 247 ToolButton, ScrollButton, HScrollDeco, VScrollDeco,
243 ComboDeco, MenuItem, InactiveTab, ArrowUp, ArrowDown, ArrowLeft, 248 ComboDeco, MenuItem, InactiveTab, ArrowUp, ArrowDown, ArrowLeft,
244 ArrowRight, 249 ArrowRight,
245 // On (sunken widgets) 250 // On (sunken widgets)
246 PushButtonDown, ComboBoxDown, HScrollBarSliderDown, 251 PushButtonDown, ComboBoxDown, HScrollBarSliderDown,
247 VScrollBarSliderDown, BevelDown, ToolButtonDown, ScrollButtonDown, 252 VScrollBarSliderDown, BevelDown, ToolButtonDown, ScrollButtonDown,
248 HScrollDecoDown, VScrollDecoDown, ComboDecoDown, MenuItemDown, 253 HScrollDecoDown, VScrollDecoDown, ComboDecoDown, MenuItemDown,
249 ActiveTab, SunkenArrowUp, SunkenArrowDown, SunkenArrowLeft, 254 ActiveTab, SunkenArrowUp, SunkenArrowDown, SunkenArrowLeft,
250 SunkenArrowRight, 255 SunkenArrowRight,
251 // Everything else (indicators must have separate settings) 256 // Everything else (indicators must have separate settings)
252 HScrollGroove, VScrollGroove, Slider, SliderGroove, IndicatorOn, 257 HScrollGroove, VScrollGroove, Slider, SliderGroove, IndicatorOn,
253 IndicatorOff, ExIndicatorOn, ExIndicatorOff, HBarHandle, VBarHandle, 258 IndicatorOff, ExIndicatorOn, ExIndicatorOff, HBarHandle, VBarHandle,
254 ToolBar, Splitter, CheckMark, MenuBar, DisArrowUp, DisArrowDown, 259 ToolBar, Splitter, CheckMark, MenuBar, DisArrowUp, DisArrowDown,
255 DisArrowLeft, DisArrowRight, ProgressBar, ProgressBg, MenuBarItem, 260 DisArrowLeft, DisArrowRight, ProgressBar, ProgressBg, MenuBarItem,
256 Background}; 261 Background};
257 262
258 /** 263 /**
259 * The scaling type specified by the Config file. 264 * The scaling type specified by the Config file.
260 * 265 *
261 * @param widget A Widgets enum value. 266 * @param widget A Widgets enum value.
262 * 267 *
263 * @return A ScaleHint enum value. 268 * @return A ScaleHint enum value.
264 */ 269 */
265 ScaleHint scaleHint( WidgetType widget ) const; 270 ScaleHint scaleHint( WidgetType widget ) const;
266 /** 271 /**
267 * The gradient type specified by the KConfig file. 272 * The gradient type specified by the KConfig file.
268 * 273 *
269 * @param widget A Widgets enum value. 274 * @param widget A Widgets enum value.
270 * 275 *
271 * @return A Gradient enum value. 276 * @return A Gradient enum value.
272 */ 277 */
273 Gradient gradientHint( WidgetType widget ) const; 278 Gradient gradientHint( WidgetType widget ) const;
274 /** 279 /**
275 * The color group specified for a given widget. 280 * The color group specified for a given widget.
276 * If a color group is set in the theme configuration 281 * If a color group is set in the theme configuration
277 * that is used, otherwise defaultColor is returned. 282 * that is used, otherwise defaultColor is returned.
278 * 283 *
279 * @param defaultColor The colorGroup to set if one is available. 284 * @param defaultColor The colorGroup to set if one is available.
280 * 285 *
281 * @param widget The widget whose color group to retrieve. 286 * @param widget The widget whose color group to retrieve.
282 * 287 *
283 */ 288 */
284 const QColorGroup* colorGroup( const QColorGroup &defaultGroup, 289 const QColorGroup* colorGroup( const QColorGroup &defaultGroup,
285 WidgetType widget ) const; 290 WidgetType widget ) const;
286 291
287 QBrush pixmapBrush( const QColorGroup &group, QColorGroup::ColorRole role, 292 QBrush pixmapBrush( const QColorGroup &group, QColorGroup::ColorRole role,
288 int w, int h, WidgetType widget ); 293 int w, int h, WidgetType widget );
289 /** 294 /**
290 * True if the widget has a pixmap or gradient specified. 295 * True if the widget has a pixmap or gradient specified.
291 */ 296 */
292 bool isPixmap( WidgetType widget ) const; 297 bool isPixmap( WidgetType widget ) const;
293 /** 298 /**
294 * True if the widget has a color group specified. 299 * True if the widget has a color group specified.
295 */ 300 */
296 bool isColor( WidgetType widget ) const; 301 bool isColor( WidgetType widget ) const;
297 /** 302 /**
298 * True if the user specified a 3D focus rectangle 303 * True if the user specified a 3D focus rectangle
299 */ 304 */
300 bool is3DFocus() const; 305 bool is3DFocus() const;
301 /** 306 /**
302 * If the user specified a 3D focus rectangle, they may also specify an 307 * If the user specified a 3D focus rectangle, they may also specify an
303 * offset from the default rectangle to use when drawing it. This returns 308 * offset from the default rectangle to use when drawing it. This returns
304 * the specified offset. 309 * the specified offset.
305 */ 310 */
306 int focusOffset() const; 311 int focusOffset() const;
307 /** 312 /**
308 * The border width of the specified widget. 313 * The border width of the specified widget.
309 */ 314 */
310 int borderWidth( WidgetType widget ) const; 315 int borderWidth( WidgetType widget ) const;
311 /** 316 /**
312 * Pixmap border width of the specified widget. 317 * Pixmap border width of the specified widget.
313 */ 318 */
314 int pixBorderWidth( WidgetType widget ) const; 319 int pixBorderWidth( WidgetType widget ) const;
315 /** 320 /**
316 * Returns the border pixmap if enabled for the specified widget. This 321 * Returns the border pixmap if enabled for the specified widget. This
317 * will contain the originial pixmap, plus the edges separated in 322 * will contain the originial pixmap, plus the edges separated in
318 * OThemePixmap::border() if valid. If invalid it will return NULL. 323 * OThemePixmap::border() if valid. If invalid it will return NULL.
319 */ 324 */
320 OThemePixmap* borderPixmap( WidgetType widget ); 325 OThemePixmap* borderPixmap( WidgetType widget );
321 /** 326 /**
322 * The highlight width of the specified widget. 327 * The highlight width of the specified widget.
323 */ 328 */
324 int highlightWidth( WidgetType widget ) const; 329 int highlightWidth( WidgetType widget ) const;
325 /** 330 /**
326 * The border plus highlight width of the widget. 331 * The border plus highlight width of the widget.
327 */ 332 */
328 int decoWidth( WidgetType widget ) const; 333 int decoWidth( WidgetType widget ) const;
329 /** 334 /**
330 * The extent (width for vertical, height for horizontal) requested 335 * The extent (width for vertical, height for horizontal) requested
331 * for the scrollbars. 336 * for the scrollbars.
332 */ 337 */
333 int getSBExtent() const; 338 int getSBExtent() const;
334 /** 339 /**
335 * The scrollbar button layout. 340 * The scrollbar button layout.
336 */ 341 */
337 SButton scrollBarLayout() const; 342 SButton scrollBarLayout() const;
338 /** 343 /**
339 * The arrow type. 344 * The arrow type.
340 */ 345 */
341 ArrowStyle arrowType() const; 346 ArrowStyle arrowType() const;
342 /** 347 /**
343 * The shading type. 348 * The shading type.
344 */ 349 */
345 ShadeStyle shade() const; 350 ShadeStyle shade() const;
346 /** 351 /**
347 * The frame width. 352 * The frame width.
348 */ 353 */
349 int frameWidth() const; 354 int frameWidth() const;
350 /** 355 /**
351 * The splitter width. 356 * The splitter width.
352 */ 357 */
353 int splitWidth() const; 358 int splitWidth() const;
354 /** 359 /**
355 * The contrast for some bevel effects such as reverse gradient. 360 * The contrast for some bevel effects such as reverse gradient.
356 */ 361 */
357 int bevelContrast( WidgetType widget ) const; 362 int bevelContrast( WidgetType widget ) const;
358 /** 363 /**
359 * The button text X shift. 364 * The button text X shift.
360 */ 365 */
361 int buttonXShift() const; 366 int buttonXShift() const;
362 /** 367 /**
363 * The button text Y shift. 368 * The button text Y shift.
364 */ 369 */
365 int buttonYShift() const; 370 int buttonYShift() const;
366 /** 371 /**
367 * Returns either the slider length of the slider pixmap if available, 372 * Returns either the slider length of the slider pixmap if available,
368 * otherwise the length specified in the config file. 373 * otherwise the length specified in the config file.
369 */ 374 */
370 int sliderButtonLength() const; 375 int sliderButtonLength() const;
371 /** 376 /**
372 * True if rounded buttons are requested. 377 * True if rounded buttons are requested.
373 */ 378 */
374 bool roundButton() const; 379 bool roundButton() const;
375 /** 380 /**
376 * True if rounded comboboxes are requested. 381 * True if rounded comboboxes are requested.
377 */ 382 */
378 bool roundComboBox() const; 383 bool roundComboBox() const;
379 /** 384 /**
380 * True if rounded slider grooves are requested. 385 * True if rounded slider grooves are requested.
381 */ 386 */
382 bool roundSlider() const; 387 bool roundSlider() const;
383 /** 388 /**
384 * True if a line should be drawn on the bottom of active tabs. 389 * True if a line should be drawn on the bottom of active tabs.
385 */ 390 */
386 bool activeTabLine() const; 391 bool activeTabLine() const;
387 /** 392 /**
388 * True if a line should be drawn on the bottom of inactive tabs. 393 * True if a line should be drawn on the bottom of inactive tabs.
389 */ 394 */
390 bool inactiveTabLine() const; 395 bool inactiveTabLine() const;
391 /** 396 /**
392 * Returns the current uncached pixmap for the given widget. This will 397 * Returns the current uncached pixmap for the given widget. This will
393 * usually be either the last scaled or gradient pixmap if those have 398 * usually be either the last scaled or gradient pixmap if those have
394 * been specified in the config file, the original pixmap if not, or NULL 399 * been specified in the config file, the original pixmap if not, or NULL
395 * if no pixmap has been specified. 400 * if no pixmap has been specified.
396 */ 401 */
397 OThemePixmap* uncached( WidgetType widget ) const; 402 OThemePixmap* uncached( WidgetType widget ) const;
398 /** 403 /**
399 * Returns the pixmap for the given widget at the specified width and 404 * Returns the pixmap for the given widget at the specified width and
400 * height. This will return NULL if no pixmap or gradient is specified. 405 * height. This will return NULL if no pixmap or gradient is specified.
401 * It may also return a different sized pixmap if the scaling 406 * It may also return a different sized pixmap if the scaling
402 * is set to Tiled. When using this method, you should call it using 407 * is set to Tiled. When using this method, you should call it using
403 * the needed width and height then use QPainter::drawTiledPixmap to 408 * the needed width and height then use QPainter::drawTiledPixmap to
404 * paint it. Doing this, if the pixmap is scaled it will be the proper 409 * paint it. Doing this, if the pixmap is scaled it will be the proper
405 * size, otherwise it will be tiled. 410 * size, otherwise it will be tiled.
406 * 411 *
407 * @param w Requested width. 412 * @param w Requested width.
408 * @param h Requested height. 413 * @param h Requested height.
409 * @param widget Widget type. 414 * @param widget Widget type.
410 * @return The pixmap or NULL if one is not specified. 415 * @return The pixmap or NULL if one is not specified.
411 */ 416 */
412 virtual OThemePixmap *scalePixmap( int w, int h, WidgetType widget ); 417 virtual OThemePixmap *scalePixmap( int w, int h, WidgetType widget );
413 /** 418 /**
414 * This method reads a configuration file and applies it to the user's 419 * This method reads a configuration file and applies it to the user's
415 * kstylerc file. It does not signal applications to reload via the 420 * kstylerc file. It does not signal applications to reload via the
416 * KDEChangeGeneral atom, if you want to do this you must do so yourself. 421 * KDEChangeGeneral atom, if you want to do this you must do so yourself.
417 * See kcmdisplay's general.cpp for an example. 422 * See kcmdisplay's general.cpp for an example.
418 * 423 *
419 * @param file The configuration file to apply. 424 * @param file The configuration file to apply.
420 */ 425 */
421 static void applyConfigFile( const QString &file ); 426 static void applyConfigFile( const QString &file );
422protected: 427protected:
423 /** 428 /**
424 * Returns a QImage for the given widget if the widget is scaled, NULL 429 * Returns a QImage for the given widget if the widget is scaled, NULL
425 * otherwise. QImages of the original pixmap are stored for scaled 430 * otherwise. QImages of the original pixmap are stored for scaled
426 * widgets in order to facilitate fast and accurate smooth-scaling. This 431 * widgets in order to facilitate fast and accurate smooth-scaling. This
427 * also saves us a conversion from a pixmap to an image then back again. 432 * also saves us a conversion from a pixmap to an image then back again.
428 */ 433 */
429 QImage* image( WidgetType widget ) const; 434 QImage* image( WidgetType widget ) const;
430 /** 435 /**
431 * Returns the gradient high color if one is specified, NULL otherwise. 436 * Returns the gradient high color if one is specified, NULL otherwise.
432 */ 437 */
433 QColor* gradientHigh( WidgetType widget ) const; 438 QColor* gradientHigh( WidgetType widget ) const;
434 /** 439 /**
435 * Returns the gradient low color if one is specified, NULL otherwise. 440 * Returns the gradient low color if one is specified, NULL otherwise.
436 */ 441 */
437 QColor* gradientLow( WidgetType widget ) const; 442 QColor* gradientLow( WidgetType widget ) const;
438 /** 443 /**
439 * Reads in all the configuration file entries supported. 444 * Reads in all the configuration file entries supported.
440 * 445 *
441 * @param colorStyle The style for the color groups. In KDE, colors were 446 * @param colorStyle The style for the color groups. In KDE, colors were
442 * calculated a little differently for Motif vs Windows styles. This 447 * calculated a little differently for Motif vs Windows styles. This
443 * is obsolete. 448 * is obsolete.
444 */ 449 */
445 void readConfig( Qt::GUIStyle colorStyle = Qt::WindowsStyle ); 450 void readConfig( Qt::GUIStyle colorStyle = Qt::WindowsStyle );
446 void readWidgetConfig( int i, Config *config, QString *pixnames, 451 void readWidgetConfig( int i, Config *config, QString *pixnames,
447 QString *brdnames, bool *loadArray ); 452 QString *brdnames, bool *loadArray );
448 void copyWidgetConfig( int sourceID, int destID, QString *pixnames, 453 void copyWidgetConfig( int sourceID, int destID, QString *pixnames,
449 QString *brdnames ); 454 QString *brdnames );
450 /** 455 /**
451 * Makes a full color group based on the given foreground and background 456 * Makes a full color group based on the given foreground and background
452 * colors. This is the same code used by KDE (kapp.cpp) in previous 457 * colors. This is the same code used by KDE (kapp.cpp) in previous
453 * versions. 458 * versions.
454 */ 459 */
455 QColorGroup* makeColorGroup( QColor &fg, QColor &bg, 460 QColorGroup* makeColorGroup( QColor &fg, QColor &bg,
456 Qt::GUIStyle style = Qt::WindowsStyle ); 461 Qt::GUIStyle style = Qt::WindowsStyle );
457 OThemePixmap* scale( int w, int h, WidgetType widget ); 462 OThemePixmap* scale( int w, int h, WidgetType widget );
458 OThemePixmap* scaleBorder( int w, int h, WidgetType type ); 463 OThemePixmap* scaleBorder( int w, int h, WidgetType type );
459 OThemePixmap* gradient( int w, int h, WidgetType widget ); 464 OThemePixmap* gradient( int w, int h, WidgetType widget );
460 OThemePixmap* blend( WidgetType widget ); 465 OThemePixmap* blend( WidgetType widget );
461 void generateBorderPix( int i ); 466 void generateBorderPix( int i );
462 void applyResourceGroup( Config *config, int i, QString *copyfrom, QString *pixnames, QString *brdnames ); 467 void applyResourceGroup( Config *config, int i, QString *copyfrom, QString *pixnames, QString *brdnames );
463 void applyMiscResourceGroup( Config *config ); 468 void applyMiscResourceGroup( Config *config );
464 void readResourceGroup( int i, QString *copyfrom, QString *pixnames, QString *brdnames, 469 void readResourceGroup( int i, QString *copyfrom, QString *pixnames, QString *brdnames,
465 bool *loadArray ); 470 bool *loadArray );
466 void readMiscResourceGroup(); 471 void readMiscResourceGroup();
467 /** 472 /**
468 * Attempts to load a pixmap from the default OThemeBase locations. 473 * Attempts to load a pixmap from the default OThemeBase locations.
469 */ 474 */
470 OThemePixmap* loadPixmap( QString &name ); 475 OThemePixmap* loadPixmap( QString &name );
471 /** 476 /**
472 * Attempts to load a image from the default OThemeBase locations. 477 * Attempts to load a image from the default OThemeBase locations.
473 */ 478 */
474 QImage* loadImage( QString &name ); 479 QImage* loadImage( QString &name );
475private: 480private:
476 SButton sbPlacement; 481 SButton sbPlacement;
477 ArrowStyle arrowStyle; 482 ArrowStyle arrowStyle;
478 ShadeStyle shading; 483 ShadeStyle shading;
479 int defaultFrame; 484 int defaultFrame;
480 int btnXShift, btnYShift; 485 int btnXShift, btnYShift;
481 int sliderLen; 486 int sliderLen;
482 int splitterWidth; 487 int splitterWidth;
483 int focus3DOffset; 488 int focus3DOffset;
484 int sbExtent; 489 int sbExtent;
485 bool smallGroove; 490 bool smallGroove;
486 bool roundedButton, roundedCombo, roundedSlider; 491 bool roundedButton, roundedCombo, roundedSlider;
487 bool aTabLine, iTabLine; 492 bool aTabLine, iTabLine;
488 bool focus3D; 493 bool focus3D;
489 OThemeCache *cache; 494 OThemeCache *cache;
490 int cacheSize; 495 int cacheSize;
491 QString configFileName; 496 QString configFileName;
492 QString configFilePath; 497 QString configFilePath;
493 498
494protected: 499protected:
495 QColor fgcolor, bgcolor, selfgcolor, selbgcolor, winfgcolor, winbgcolor; 500 QColor fgcolor, bgcolor, selfgcolor, selbgcolor, winfgcolor, winbgcolor;
496 501
497private: 502private:
498 /** 503 /**
499 * The theme pixmaps. Many of these may be NULL if no pixmap is specified. 504 * The theme pixmaps. Many of these may be NULL if no pixmap is specified.
500 * There may also be duplicate pixmap pointers if more than one widget 505 * There may also be duplicate pixmap pointers if more than one widget
501 * uses the same tiled pixmap. If a pixmap is tiled, it is kept here and 506 * uses the same tiled pixmap. If a pixmap is tiled, it is kept here and
502 * this acts as a cache. Otherwise this will hold whatever the last scaled 507 * this acts as a cache. Otherwise this will hold whatever the last scaled
503 * pixmap was. 508 * pixmap was.
504 */ 509 */
505 OThemePixmap *pixmaps[ WIDGETS ]; 510 OThemePixmap *pixmaps[ WIDGETS ];
506 /** 511 /**
507 * The theme images. These are for scaled images and are kept in order 512 * The theme images. These are for scaled images and are kept in order
508 * to maintain fast smoothscaling. 513 * to maintain fast smoothscaling.
509 */ 514 */
510 QImage *images[ WIDGETS ]; 515 QImage *images[ WIDGETS ];
511 /** 516 /**
512 * The border widths 517 * The border widths
513 */ 518 */
514 unsigned char borders[ WIDGETS ]; 519 unsigned char borders[ WIDGETS ];
515 /** 520 /**
516 * The highlight widths 521 * The highlight widths
517 */ 522 */
518 unsigned char highlights[ WIDGETS ]; 523 unsigned char highlights[ WIDGETS ];
519 /** 524 /**
520 * The scale hints for pixmaps and gradients. 525 * The scale hints for pixmaps and gradients.
521 */ 526 */
522 ScaleHint scaleHints[ WIDGETS ]; 527 ScaleHint scaleHints[ WIDGETS ];
523 /** 528 /**
524 * All the color groups. 529 * All the color groups.
525 */ 530 */
526 QColorGroup *colors[ WIDGETS ]; 531 QColorGroup *colors[ WIDGETS ];
527 /** 532 /**
528 * Gradient low colors (or blend background). 533 * Gradient low colors (or blend background).
529 */ 534 */
530 QColor *grLowColors[ WIDGETS ]; 535 QColor *grLowColors[ WIDGETS ];
531 /** 536 /**
532 * Gradient high colors. 537 * Gradient high colors.
533 */ 538 */
534 QColor *grHighColors[ WIDGETS ]; 539 QColor *grHighColors[ WIDGETS ];
535 /** 540 /**
536 * Gradient types. 541 * Gradient types.
537 */ 542 */
538 Gradient gradients[ WIDGETS ]; 543 Gradient gradients[ WIDGETS ];
539 /** 544 /**
540 * Blend intensity factors 545 * Blend intensity factors
541 */ 546 */
542 float blends[ WIDGETS ]; 547 float blends[ WIDGETS ];
543 /** 548 /**
544 * Bevel contrasts 549 * Bevel contrasts
545 */ 550 */
546 unsigned char bContrasts[ WIDGETS ]; 551 unsigned char bContrasts[ WIDGETS ];
547 /** 552 /**
548 * Duplicate pixmap entries (used during destruction). 553 * Duplicate pixmap entries (used during destruction).
549 */ 554 */
550 bool duplicate[ WIDGETS ]; 555 bool duplicate[ WIDGETS ];
551 /** 556 /**
552 * Pixmapped border widths 557 * Pixmapped border widths
553 */ 558 */
554 int pbWidth[ WIDGETS ]; 559 int pbWidth[ WIDGETS ];
555 /** 560 /**
556 * Pixmapped borders 561 * Pixmapped borders
557 */ 562 */
558 OThemePixmap *pbPixmaps[ WIDGETS ]; 563 OThemePixmap *pbPixmaps[ WIDGETS ];
559 /** 564 /**
560 * Duplicate border pixmapped border entries 565 * Duplicate border pixmapped border entries
561 */ 566 */
562 bool pbDuplicate[ WIDGETS ]; 567 bool pbDuplicate[ WIDGETS ];
563 568
564private: 569private:
565 class OThemeBasePrivate; 570 class OThemeBasePrivate;
566 OThemeBasePrivate *d; 571 OThemeBasePrivate *d;
567 572
568}; 573};
569 574
570inline bool OThemeBase::isPixmap( WidgetType widget ) const 575inline bool OThemeBase::isPixmap( WidgetType widget ) const
571{ 576{
572 return ( pixmaps[ widget ] != NULL || gradients[ widget ] != GrNone ); 577 return ( pixmaps[ widget ] != NULL || gradients[ widget ] != GrNone );
573} 578}
574 579
575inline bool OThemeBase::isColor( WidgetType widget ) const 580inline bool OThemeBase::isColor( WidgetType widget ) const
576{ 581{
577 return ( colors[ widget ] != NULL ); 582 return ( colors[ widget ] != NULL );
578} 583}
579 584
580inline bool OThemeBase::is3DFocus() const 585inline bool OThemeBase::is3DFocus() const
581{ 586{
582 return ( focus3D ); 587 return ( focus3D );
583} 588}
584 589
585inline int OThemeBase::focusOffset() const 590inline int OThemeBase::focusOffset() const
586{ 591{
587 return ( focus3DOffset ); 592 return ( focus3DOffset );
588} 593}
589 594
590inline int OThemeBase::bevelContrast( WidgetType widget ) const 595inline int OThemeBase::bevelContrast( WidgetType widget ) const
591{ 596{
592 return ( bContrasts[ widget ] ); 597 return ( bContrasts[ widget ] );
593} 598}
594 599
595inline OThemeBase::ScaleHint OThemeBase::scaleHint( WidgetType widget ) const 600inline OThemeBase::ScaleHint OThemeBase::scaleHint( WidgetType widget ) const
596{ 601{
597 return ( ( widget < WIDGETS ) ? scaleHints[ widget ] : TileScale ); 602 return ( ( widget < WIDGETS ) ? scaleHints[ widget ] : TileScale );
598} 603}
599 604
600inline OThemeBase::Gradient OThemeBase::gradientHint( WidgetType widget ) const 605inline OThemeBase::Gradient OThemeBase::gradientHint( WidgetType widget ) const
601{ 606{
602 return ( ( widget < WIDGETS ) ? gradients[ widget ] : GrNone ); 607 return ( ( widget < WIDGETS ) ? gradients[ widget ] : GrNone );
603} 608}
604 609
605inline OThemePixmap* OThemeBase::uncached( WidgetType widget ) const 610inline OThemePixmap* OThemeBase::uncached( WidgetType widget ) const
606{ 611{
607 return ( pixmaps[ widget ] ); 612 return ( pixmaps[ widget ] );
608} 613}
609 614
610inline QBrush OThemeBase::pixmapBrush( const QColorGroup &group, 615inline QBrush OThemeBase::pixmapBrush( const QColorGroup &group,
611 QColorGroup::ColorRole role, 616 QColorGroup::ColorRole role,
612 int w, int h, WidgetType widget ) 617 int w, int h, WidgetType widget )
613{ 618{
614 if ( pixmaps[ widget ] || images[ widget ] ) 619 if ( pixmaps[ widget ] || images[ widget ] )
615 return ( QBrush( group.color( role ), *scalePixmap( w, h, widget ) ) ); 620 return ( QBrush( group.color( role ), *scalePixmap( w, h, widget ) ) );
616 else 621 else
617 return ( group.color( role ) ); 622 return ( group.color( role ) );
618} 623}
619 624
620inline const QColorGroup* OThemeBase::colorGroup( const QColorGroup &defaultGroup, 625inline const QColorGroup* OThemeBase::colorGroup( const QColorGroup &defaultGroup,
621 WidgetType widget ) const 626 WidgetType widget ) const
622{ 627{
623 return ( ( colors[ widget ] ) ? colors[ widget ] : &defaultGroup ); 628 return ( ( colors[ widget ] ) ? colors[ widget ] : &defaultGroup );
624} 629}
625 630
626inline int OThemeBase::borderWidth( WidgetType widget ) const 631inline int OThemeBase::borderWidth( WidgetType widget ) const
627{ 632{
628 return ( pbWidth[ widget ] ? pbWidth[ widget ] : borders[ widget ] ); 633 return ( pbWidth[ widget ] ? pbWidth[ widget ] : borders[ widget ] );
629} 634}
630 635
631inline int OThemeBase::pixBorderWidth( WidgetType widget ) const 636inline int OThemeBase::pixBorderWidth( WidgetType widget ) const
632{ 637{
633 return ( pbWidth[ widget ] ); 638 return ( pbWidth[ widget ] );
634} 639}
635 640
636inline int OThemeBase::highlightWidth( WidgetType widget ) const 641inline int OThemeBase::highlightWidth( WidgetType widget ) const
637{ 642{
638 return ( pbWidth[ widget ] ? 0 : highlights[ widget ] ); 643 return ( pbWidth[ widget ] ? 0 : highlights[ widget ] );
639} 644}
640 645
641inline int OThemeBase::decoWidth( WidgetType widget ) const 646inline int OThemeBase::decoWidth( WidgetType widget ) const
642{ 647{
643 return ( pbWidth[ widget ] ? pbWidth[ widget ] : borders[ widget ] + highlights[ widget ] ); 648 return ( pbWidth[ widget ] ? pbWidth[ widget ] : borders[ widget ] + highlights[ widget ] );
644} 649}
645 650
646inline QColor* OThemeBase::gradientHigh( WidgetType widget ) const 651inline QColor* OThemeBase::gradientHigh( WidgetType widget ) const
647{ 652{
648 return ( grHighColors[ widget ] ); 653 return ( grHighColors[ widget ] );
649} 654}
650 655
651inline QColor* OThemeBase::gradientLow( WidgetType widget ) const 656inline QColor* OThemeBase::gradientLow( WidgetType widget ) const
652{ 657{
653 return ( grLowColors[ widget ] ); 658 return ( grLowColors[ widget ] );
654} 659}
655 660
656inline QImage* OThemeBase::image( WidgetType widget ) const 661inline QImage* OThemeBase::image( WidgetType widget ) const
657{ 662{
658 return ( images[ widget ] ); 663 return ( images[ widget ] );
659} 664}
660 665
661inline OThemeBase::SButton OThemeBase::scrollBarLayout() const 666inline OThemeBase::SButton OThemeBase::scrollBarLayout() const
662{ 667{
663 return ( sbPlacement ); 668 return ( sbPlacement );
664} 669}
665 670
666inline OThemeBase::ArrowStyle OThemeBase::arrowType() const 671inline OThemeBase::ArrowStyle OThemeBase::arrowType() const
667{ 672{
668 return ( arrowStyle ); 673 return ( arrowStyle );
669} 674}
670 675
671inline OThemeBase::ShadeStyle OThemeBase::shade() const 676inline OThemeBase::ShadeStyle OThemeBase::shade() const
672{ 677{
673 return ( shading ); 678 return ( shading );
674} 679}
675 680
676inline int OThemeBase::frameWidth() const 681inline int OThemeBase::frameWidth() const
677{ 682{
678 return ( defaultFrame ); 683 return ( defaultFrame );
679} 684}
680 685
681inline int OThemeBase::buttonXShift() const 686inline int OThemeBase::buttonXShift() const
682{ 687{
683 return ( btnXShift ); 688 return ( btnXShift );
684} 689}
685 690
686inline int OThemeBase::splitWidth() const 691inline int OThemeBase::splitWidth() const
687{ 692{
688 return ( splitterWidth ); 693 return ( splitterWidth );
689} 694}
690 695
691inline int OThemeBase::buttonYShift() const 696inline int OThemeBase::buttonYShift() const
692{ 697{
693 return ( btnYShift ); 698 return ( btnYShift );
694} 699}
695 700
696inline int OThemeBase::sliderButtonLength() const 701inline int OThemeBase::sliderButtonLength() const
697{ 702{
698 if ( isPixmap( Slider ) ) 703 if ( isPixmap( Slider ) )
699 return ( uncached( Slider ) ->width() ); 704 return ( uncached( Slider ) ->width() );
700 else 705 else
701 return ( sliderLen ); 706 return ( sliderLen );
702} 707}
703 708
704inline bool OThemeBase::roundButton() const 709inline bool OThemeBase::roundButton() const
705{ 710{
706 return ( roundedButton ); 711 return ( roundedButton );
707} 712}
708 713
709inline bool OThemeBase::roundComboBox() const 714inline bool OThemeBase::roundComboBox() const
710{ 715{
711 return ( roundedCombo ); 716 return ( roundedCombo );
712} 717}
713 718
714inline bool OThemeBase::roundSlider() const 719inline bool OThemeBase::roundSlider() const
715{ 720{
716 return ( roundedSlider ); 721 return ( roundedSlider );
717} 722}
718 723
719inline bool OThemeBase::activeTabLine() const 724inline bool OThemeBase::activeTabLine() const
720{ 725{
721 return ( aTabLine ); 726 return ( aTabLine );
722} 727}
723 728
724inline bool OThemeBase::inactiveTabLine() const 729inline bool OThemeBase::inactiveTabLine() const
725{ 730{
726 return ( iTabLine ); 731 return ( iTabLine );
727} 732}
728 733
729inline int OThemeBase::getSBExtent() const 734inline int OThemeBase::getSBExtent() const
730{ 735{
731 return ( sbExtent ); 736 return ( sbExtent );
732} 737}
733 738
734inline OThemePixmap* OThemeBase::borderPixmap( WidgetType widget ) 739inline OThemePixmap* OThemeBase::borderPixmap( WidgetType widget )
735{ 740{
736 return ( pbPixmaps[ widget ] ); 741 return ( pbPixmaps[ widget ] );
737} 742}
738 743
739#endif 744#endif