-rw-r--r-- | library/alarmserver.cpp | 2 | ||||
-rw-r--r-- | library/applnk.cpp | 4 | ||||
-rw-r--r-- | library/fileselector.cpp | 2 | ||||
-rw-r--r-- | library/fontdatabase.cpp | 2 | ||||
-rw-r--r-- | library/fontmanager.cpp | 2 | ||||
-rw-r--r-- | library/global.cpp | 28 | ||||
-rw-r--r-- | library/ir.cpp | 2 | ||||
-rw-r--r-- | library/lnkproperties.cpp | 2 | ||||
-rw-r--r-- | library/network.cpp | 2 | ||||
-rw-r--r-- | library/networkinterface.cpp | 2 | ||||
-rw-r--r-- | library/password.cpp | 2 | ||||
-rw-r--r-- | library/qpedecoration_qws.cpp | 2 | ||||
-rw-r--r-- | library/tzselect.cpp | 4 |
13 files changed, 11 insertions, 45 deletions
diff --git a/library/alarmserver.cpp b/library/alarmserver.cpp index 177a0cb..02bca3d 100644 --- a/library/alarmserver.cpp +++ b/library/alarmserver.cpp | |||
@@ -1,129 +1,127 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #include <qdir.h> | 21 | #include <qdir.h> |
22 | #include <qfile.h> | 22 | #include <qfile.h> |
23 | #include <qmessagebox.h> | 23 | #include <qmessagebox.h> |
24 | #include <qtextstream.h> | 24 | #include <qtextstream.h> |
25 | 25 | ||
26 | 26 | ||
27 | #include <qpe/qpeapplication.h> | 27 | #include <qpe/qpeapplication.h> |
28 | #include "global.h" | 28 | #include "global.h" |
29 | #include "resource.h" | 29 | #include "resource.h" |
30 | 30 | ||
31 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | ||
32 | #include <qpe/qcopenvelope_qws.h> | 31 | #include <qpe/qcopenvelope_qws.h> |
33 | #endif | ||
34 | #include "alarmserver.h" | 32 | #include "alarmserver.h" |
35 | #include <qpe/timeconversion.h> | 33 | #include <qpe/timeconversion.h> |
36 | 34 | ||
37 | #include <sys/types.h> | 35 | #include <sys/types.h> |
38 | #include <sys/stat.h> | 36 | #include <sys/stat.h> |
39 | 37 | ||
40 | #include <stdlib.h> | 38 | #include <stdlib.h> |
41 | #include <unistd.h> | 39 | #include <unistd.h> |
42 | 40 | ||
43 | struct timerEventItem { | 41 | struct timerEventItem { |
44 | time_t UTCtime; | 42 | time_t UTCtime; |
45 | QCString channel, message; | 43 | QCString channel, message; |
46 | int data; | 44 | int data; |
47 | bool operator==( const timerEventItem &right ) const | 45 | bool operator==( const timerEventItem &right ) const |
48 | { | 46 | { |
49 | return ( UTCtime == right.UTCtime | 47 | return ( UTCtime == right.UTCtime |
50 | && channel == right.channel | 48 | && channel == right.channel |
51 | && message == right.message | 49 | && message == right.message |
52 | && data == right.data ); | 50 | && data == right.data ); |
53 | } | 51 | } |
54 | }; | 52 | }; |
55 | 53 | ||
56 | class TimerReceiverObject : public QObject | 54 | class TimerReceiverObject : public QObject |
57 | { | 55 | { |
58 | public: | 56 | public: |
59 | TimerReceiverObject() { } | 57 | TimerReceiverObject() { } |
60 | ~TimerReceiverObject() { } | 58 | ~TimerReceiverObject() { } |
61 | void resetTimer(); | 59 | void resetTimer(); |
62 | void setTimerEventItem(); | 60 | void setTimerEventItem(); |
63 | void deleteTimer(); | 61 | void deleteTimer(); |
64 | protected: | 62 | protected: |
65 | void timerEvent( QTimerEvent *te ); | 63 | void timerEvent( QTimerEvent *te ); |
66 | private: | 64 | private: |
67 | QString atfilename; | 65 | QString atfilename; |
68 | }; | 66 | }; |
69 | 67 | ||
70 | TimerReceiverObject *timerEventReceiver = NULL; | 68 | TimerReceiverObject *timerEventReceiver = NULL; |
71 | QList<timerEventItem> timerEventList; | 69 | QList<timerEventItem> timerEventList; |
72 | timerEventItem *nearestTimerEvent = NULL; | 70 | timerEventItem *nearestTimerEvent = NULL; |
73 | 71 | ||
74 | 72 | ||
75 | // set the timer to go off on the next event in the list | 73 | // set the timer to go off on the next event in the list |
76 | void setNearestTimerEvent() | 74 | void setNearestTimerEvent() |
77 | { | 75 | { |
78 | nearestTimerEvent = NULL; | 76 | nearestTimerEvent = NULL; |
79 | QListIterator<timerEventItem> it( timerEventList ); | 77 | QListIterator<timerEventItem> it( timerEventList ); |
80 | if ( *it ) | 78 | if ( *it ) |
81 | nearestTimerEvent = *it; | 79 | nearestTimerEvent = *it; |
82 | for ( ; *it; ++it ) | 80 | for ( ; *it; ++it ) |
83 | if ( (*it)->UTCtime < nearestTimerEvent->UTCtime ) | 81 | if ( (*it)->UTCtime < nearestTimerEvent->UTCtime ) |
84 | nearestTimerEvent = *it; | 82 | nearestTimerEvent = *it; |
85 | if (nearestTimerEvent) | 83 | if (nearestTimerEvent) |
86 | timerEventReceiver->resetTimer(); | 84 | timerEventReceiver->resetTimer(); |
87 | else | 85 | else |
88 | timerEventReceiver->deleteTimer(); | 86 | timerEventReceiver->deleteTimer(); |
89 | } | 87 | } |
90 | 88 | ||
91 | 89 | ||
92 | //store current state to file | 90 | //store current state to file |
93 | //Simple implementation. Should run on a timer. | 91 | //Simple implementation. Should run on a timer. |
94 | 92 | ||
95 | static void saveState() | 93 | static void saveState() |
96 | { | 94 | { |
97 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); | 95 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); |
98 | if ( timerEventList.isEmpty() ) { | 96 | if ( timerEventList.isEmpty() ) { |
99 | unlink( savefilename ); | 97 | unlink( savefilename ); |
100 | return; | 98 | return; |
101 | } | 99 | } |
102 | 100 | ||
103 | QFile savefile(savefilename+".new"); | 101 | QFile savefile(savefilename+".new"); |
104 | if ( savefile.open(IO_WriteOnly) ) { | 102 | if ( savefile.open(IO_WriteOnly) ) { |
105 | QDataStream ds( &savefile ); | 103 | QDataStream ds( &savefile ); |
106 | 104 | ||
107 | //save | 105 | //save |
108 | 106 | ||
109 | QListIterator<timerEventItem> it( timerEventList ); | 107 | QListIterator<timerEventItem> it( timerEventList ); |
110 | for ( ; *it; ++it ) { | 108 | for ( ; *it; ++it ) { |
111 | ds << it.current()->UTCtime; | 109 | ds << it.current()->UTCtime; |
112 | ds << it.current()->channel; | 110 | ds << it.current()->channel; |
113 | ds << it.current()->message; | 111 | ds << it.current()->message; |
114 | ds << it.current()->data; | 112 | ds << it.current()->data; |
115 | } | 113 | } |
116 | 114 | ||
117 | 115 | ||
118 | savefile.close(); | 116 | savefile.close(); |
119 | unlink( savefilename ); | 117 | unlink( savefilename ); |
120 | QDir d; d.rename(savefilename+".new",savefilename); | 118 | QDir d; d.rename(savefilename+".new",savefilename); |
121 | 119 | ||
122 | } | 120 | } |
123 | } | 121 | } |
124 | 122 | ||
125 | /*! | 123 | /*! |
126 | Sets up the alarm server. Restoring to previous state (session management). | 124 | Sets up the alarm server. Restoring to previous state (session management). |
127 | */ | 125 | */ |
128 | void AlarmServer::initialize() | 126 | void AlarmServer::initialize() |
129 | { | 127 | { |
diff --git a/library/applnk.cpp b/library/applnk.cpp index a56da5d..5763c62 100644 --- a/library/applnk.cpp +++ b/library/applnk.cpp | |||
@@ -1,141 +1,137 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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_MIMEEXT | 21 | #define QTOPIA_INTERNAL_MIMEEXT |
22 | #define QTOPIA_INTERNAL_PRELOADACCESS | 22 | #define QTOPIA_INTERNAL_PRELOADACCESS |
23 | #define QTOPIA_INTERNAL_APPLNKASSIGN | 23 | #define QTOPIA_INTERNAL_APPLNKASSIGN |
24 | 24 | ||
25 | #include "applnk.h" | 25 | #include "applnk.h" |
26 | 26 | ||
27 | #include <qpe/qpeapplication.h> | 27 | #include <qpe/qpeapplication.h> |
28 | #include <qpe/categories.h> | 28 | #include <qpe/categories.h> |
29 | #include <qpe/categoryselect.h> | 29 | #include <qpe/categoryselect.h> |
30 | #ifdef QWS | ||
31 | #include <qpe/qcopenvelope_qws.h> | 30 | #include <qpe/qcopenvelope_qws.h> |
32 | #endif | ||
33 | #include <qpe/global.h> | 31 | #include <qpe/global.h> |
34 | #include <qpe/mimetype.h> | 32 | #include <qpe/mimetype.h> |
35 | #include <qpe/config.h> | 33 | #include <qpe/config.h> |
36 | #include <qpe/storage.h> | 34 | #include <qpe/storage.h> |
37 | #include <qpe/resource.h> | 35 | #include <qpe/resource.h> |
38 | 36 | ||
39 | #include <qdict.h> | 37 | #include <qdict.h> |
40 | #include <qdir.h> | 38 | #include <qdir.h> |
41 | #include <qregexp.h> | 39 | #include <qregexp.h> |
42 | 40 | ||
43 | #ifdef Q_WS_QWS | ||
44 | #include <qgfx_qws.h> | 41 | #include <qgfx_qws.h> |
45 | #endif | ||
46 | 42 | ||
47 | #include <stdlib.h> | 43 | #include <stdlib.h> |
48 | 44 | ||
49 | int AppLnk::lastId = 5000; | 45 | int AppLnk::lastId = 5000; |
50 | 46 | ||
51 | static int smallSize = 14; | 47 | static int smallSize = 14; |
52 | static int bigSize = 32; | 48 | static int bigSize = 32; |
53 | 49 | ||
54 | static QString safeFileName(const QString& n) | 50 | static QString safeFileName(const QString& n) |
55 | { | 51 | { |
56 | QString safename=n; | 52 | QString safename=n; |
57 | safename.replace(QRegExp("[^0-9A-Za-z.]"),"_"); | 53 | safename.replace(QRegExp("[^0-9A-Za-z.]"),"_"); |
58 | safename.replace(QRegExp("^[^A-Za-z]*"),""); | 54 | safename.replace(QRegExp("^[^A-Za-z]*"),""); |
59 | if ( safename.isEmpty() ) | 55 | if ( safename.isEmpty() ) |
60 | safename = "_"; | 56 | safename = "_"; |
61 | return safename; | 57 | return safename; |
62 | } | 58 | } |
63 | 59 | ||
64 | static bool prepareDirectories(const QString& lf) | 60 | static bool prepareDirectories(const QString& lf) |
65 | { | 61 | { |
66 | if ( !QFile::exists(lf) ) { | 62 | if ( !QFile::exists(lf) ) { |
67 | // May need to create directories | 63 | // May need to create directories |
68 | QFileInfo fi(lf); | 64 | QFileInfo fi(lf); |
69 | if ( system(("mkdir -p "+fi.dirPath(TRUE))) ) | 65 | if ( system(("mkdir -p "+fi.dirPath(TRUE))) ) |
70 | return FALSE; | 66 | return FALSE; |
71 | } | 67 | } |
72 | return TRUE; | 68 | return TRUE; |
73 | } | 69 | } |
74 | 70 | ||
75 | class AppLnkPrivate | 71 | class AppLnkPrivate |
76 | { | 72 | { |
77 | public: | 73 | public: |
78 | /* the size of the Pixmap */ | 74 | /* the size of the Pixmap */ |
79 | enum Size {Normal = 0, Big }; | 75 | enum Size {Normal = 0, Big }; |
80 | AppLnkPrivate() { | 76 | AppLnkPrivate() { |
81 | /* we want one normal and one big item */ | 77 | /* we want one normal and one big item */ |
82 | 78 | ||
83 | QPixmap pix; | 79 | QPixmap pix; |
84 | mPixmaps.insert(0, pix ); | 80 | mPixmaps.insert(0, pix ); |
85 | mPixmaps.insert(1, pix); | 81 | mPixmaps.insert(1, pix); |
86 | } | 82 | } |
87 | 83 | ||
88 | QStringList mCatList; // always correct | 84 | QStringList mCatList; // always correct |
89 | QArray<int> mCat; // cached value; correct if not empty | 85 | QArray<int> mCat; // cached value; correct if not empty |
90 | QMap<int, QPixmap> mPixmaps; | 86 | QMap<int, QPixmap> mPixmaps; |
91 | 87 | ||
92 | void updateCatListFromArray() | 88 | void updateCatListFromArray() |
93 | { | 89 | { |
94 | Categories cat( 0 ); | 90 | Categories cat( 0 ); |
95 | cat.load( categoryFileName() ); | 91 | cat.load( categoryFileName() ); |
96 | mCatList = cat.labels("Document View",mCat); | 92 | mCatList = cat.labels("Document View",mCat); |
97 | } | 93 | } |
98 | 94 | ||
99 | void setCatArrayDirty() | 95 | void setCatArrayDirty() |
100 | { | 96 | { |
101 | mCat.resize(0); | 97 | mCat.resize(0); |
102 | } | 98 | } |
103 | 99 | ||
104 | void ensureCatArray() | 100 | void ensureCatArray() |
105 | { | 101 | { |
106 | if ( mCat.count() > 0 || mCatList.count()==0 ) | 102 | if ( mCat.count() > 0 || mCatList.count()==0 ) |
107 | return; | 103 | return; |
108 | 104 | ||
109 | Categories cat( 0 ); | 105 | Categories cat( 0 ); |
110 | cat.load( categoryFileName() ); | 106 | cat.load( categoryFileName() ); |
111 | mCat.resize( mCatList.count() ); | 107 | mCat.resize( mCatList.count() ); |
112 | int i; | 108 | int i; |
113 | QStringList::ConstIterator it; | 109 | QStringList::ConstIterator it; |
114 | for ( i = 0, it = mCatList.begin(); it != mCatList.end(); | 110 | for ( i = 0, it = mCatList.begin(); it != mCatList.end(); |
115 | ++it, i++ ) { | 111 | ++it, i++ ) { |
116 | 112 | ||
117 | bool number; | 113 | bool number; |
118 | int id = (*it).toInt( &number ); | 114 | int id = (*it).toInt( &number ); |
119 | if ( !number ) { | 115 | if ( !number ) { |
120 | id = cat.id( "Document View", *it ); | 116 | id = cat.id( "Document View", *it ); |
121 | if ( id == 0 ) | 117 | if ( id == 0 ) |
122 | id = cat.addCategory( "Document View", *it ); | 118 | id = cat.addCategory( "Document View", *it ); |
123 | } | 119 | } |
124 | mCat[i] = id; | 120 | mCat[i] = id; |
125 | } | 121 | } |
126 | } | 122 | } |
127 | }; | 123 | }; |
128 | 124 | ||
129 | /*! | 125 | /*! |
130 | \class AppLnk applnk.h | 126 | \class AppLnk applnk.h |
131 | \brief The AppLnk class represents an application available on the system. | 127 | \brief The AppLnk class represents an application available on the system. |
132 | 128 | ||
133 | Every Qtopia application \e app has a corresponding \e app.desktop | 129 | Every Qtopia application \e app has a corresponding \e app.desktop |
134 | file. When one of these files is read its data is stored as an | 130 | file. When one of these files is read its data is stored as an |
135 | AppLnk object. | 131 | AppLnk object. |
136 | 132 | ||
137 | The AppLnk class introduces some Qtopia-specific concepts, and | 133 | The AppLnk class introduces some Qtopia-specific concepts, and |
138 | provides a variety of functions, as described in the following | 134 | provides a variety of functions, as described in the following |
139 | sections. | 135 | sections. |
140 | \tableofcontents | 136 | \tableofcontents |
141 | 137 | ||
diff --git a/library/fileselector.cpp b/library/fileselector.cpp index 052a29e..4039243 100644 --- a/library/fileselector.cpp +++ b/library/fileselector.cpp | |||
@@ -1,131 +1,129 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT | 21 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT |
22 | // have this class. | 22 | // have this class. |
23 | #define QTOPIA_INTERNAL_FSLP | 23 | #define QTOPIA_INTERNAL_FSLP |
24 | 24 | ||
25 | #include "fileselector.h" | 25 | #include "fileselector.h" |
26 | #include "fileselector_p.h" | 26 | #include "fileselector_p.h" |
27 | #include "global.h" | 27 | #include "global.h" |
28 | #include "resource.h" | 28 | #include "resource.h" |
29 | #include "config.h" | 29 | #include "config.h" |
30 | #include "applnk.h" | 30 | #include "applnk.h" |
31 | #include "storage.h" | 31 | #include "storage.h" |
32 | #include "qpemenubar.h" | 32 | #include "qpemenubar.h" |
33 | #ifdef QWS | ||
34 | #include <qcopchannel_qws.h> | 33 | #include <qcopchannel_qws.h> |
35 | #endif | ||
36 | #include "lnkproperties.h" | 34 | #include "lnkproperties.h" |
37 | #include "applnk.h" | 35 | #include "applnk.h" |
38 | #include <qpe/qpeapplication.h> | 36 | #include <qpe/qpeapplication.h> |
39 | #include "categorymenu.h" | 37 | #include "categorymenu.h" |
40 | #include "categoryselect.h" | 38 | #include "categoryselect.h" |
41 | #include "mimetype.h" | 39 | #include "mimetype.h" |
42 | #include <qpe/categories.h> | 40 | #include <qpe/categories.h> |
43 | 41 | ||
44 | #include <stdlib.h> | 42 | #include <stdlib.h> |
45 | 43 | ||
46 | #include <qdir.h> | 44 | #include <qdir.h> |
47 | #include <qwidget.h> | 45 | #include <qwidget.h> |
48 | #include <qpopupmenu.h> | 46 | #include <qpopupmenu.h> |
49 | #include <qtoolbutton.h> | 47 | #include <qtoolbutton.h> |
50 | #include <qpushbutton.h> | 48 | #include <qpushbutton.h> |
51 | #include <qheader.h> | 49 | #include <qheader.h> |
52 | #include <qtooltip.h> | 50 | #include <qtooltip.h> |
53 | #include <qwhatsthis.h> | 51 | #include <qwhatsthis.h> |
54 | 52 | ||
55 | class TypeCombo : public QComboBox | 53 | class TypeCombo : public QComboBox |
56 | { | 54 | { |
57 | Q_OBJECT | 55 | Q_OBJECT |
58 | public: | 56 | public: |
59 | TypeCombo( QWidget *parent, const char *name=0 ) | 57 | TypeCombo( QWidget *parent, const char *name=0 ) |
60 | : QComboBox( parent, name ) | 58 | : QComboBox( parent, name ) |
61 | { | 59 | { |
62 | connect( this, SIGNAL(activated(int)), this, SLOT(selectType(int)) ); | 60 | connect( this, SIGNAL(activated(int)), this, SLOT(selectType(int)) ); |
63 | } | 61 | } |
64 | 62 | ||
65 | void reread( DocLnkSet &files, const QString &filter ); | 63 | void reread( DocLnkSet &files, const QString &filter ); |
66 | 64 | ||
67 | signals: | 65 | signals: |
68 | void selected( const QString & ); | 66 | void selected( const QString & ); |
69 | 67 | ||
70 | protected slots: | 68 | protected slots: |
71 | void selectType( int idx ) { | 69 | void selectType( int idx ) { |
72 | emit selected( typelist[idx] ); | 70 | emit selected( typelist[idx] ); |
73 | } | 71 | } |
74 | 72 | ||
75 | protected: | 73 | protected: |
76 | QStringList typelist; | 74 | QStringList typelist; |
77 | QString prev; | 75 | QString prev; |
78 | }; | 76 | }; |
79 | 77 | ||
80 | void TypeCombo::reread( DocLnkSet &files, const QString &filter ) | 78 | void TypeCombo::reread( DocLnkSet &files, const QString &filter ) |
81 | { | 79 | { |
82 | typelist.clear(); | 80 | typelist.clear(); |
83 | QStringList filters = QStringList::split( ';', filter ); | 81 | QStringList filters = QStringList::split( ';', filter ); |
84 | int pos = filter.find( '/' ); | 82 | int pos = filter.find( '/' ); |
85 | //### do for each filter | 83 | //### do for each filter |
86 | if ( filters.count() == 1 && pos >= 0 && filter[pos+1] != '*' ) { | 84 | if ( filters.count() == 1 && pos >= 0 && filter[pos+1] != '*' ) { |
87 | typelist.append( filter ); | 85 | typelist.append( filter ); |
88 | clear(); | 86 | clear(); |
89 | QString minor = filter.mid( pos+1 ); | 87 | QString minor = filter.mid( pos+1 ); |
90 | minor[0] = minor[0].upper(); | 88 | minor[0] = minor[0].upper(); |
91 | insertItem( tr("%1 files").arg(minor) ); | 89 | insertItem( tr("%1 files").arg(minor) ); |
92 | setCurrentItem(0); | 90 | setCurrentItem(0); |
93 | setEnabled( FALSE ); | 91 | setEnabled( FALSE ); |
94 | return; | 92 | return; |
95 | } | 93 | } |
96 | 94 | ||
97 | QListIterator<DocLnk> dit( files.children() ); | 95 | QListIterator<DocLnk> dit( files.children() ); |
98 | for ( ; dit.current(); ++dit ) { | 96 | for ( ; dit.current(); ++dit ) { |
99 | if ( !typelist.contains( (*dit)->type() ) ) | 97 | if ( !typelist.contains( (*dit)->type() ) ) |
100 | typelist.append( (*dit)->type() ); | 98 | typelist.append( (*dit)->type() ); |
101 | } | 99 | } |
102 | 100 | ||
103 | QStringList types; | 101 | QStringList types; |
104 | QStringList::ConstIterator it; | 102 | QStringList::ConstIterator it; |
105 | for (it = typelist.begin(); it!=typelist.end(); ++it) { | 103 | for (it = typelist.begin(); it!=typelist.end(); ++it) { |
106 | QString t = *it; | 104 | QString t = *it; |
107 | if ( t.left(12) == "application/" ) { | 105 | if ( t.left(12) == "application/" ) { |
108 | MimeType mt(t); | 106 | MimeType mt(t); |
109 | const AppLnk* app = mt.application(); | 107 | const AppLnk* app = mt.application(); |
110 | if ( app ) | 108 | if ( app ) |
111 | t = app->name(); | 109 | t = app->name(); |
112 | else | 110 | else |
113 | t = t.mid(12); | 111 | t = t.mid(12); |
114 | } else { | 112 | } else { |
115 | QString major, minor; | 113 | QString major, minor; |
116 | int pos = t.find( '/' ); | 114 | int pos = t.find( '/' ); |
117 | if ( pos >= 0 ) { | 115 | if ( pos >= 0 ) { |
118 | major = t.left( pos ); | 116 | major = t.left( pos ); |
119 | minor = t.mid( pos+1 ); | 117 | minor = t.mid( pos+1 ); |
120 | } | 118 | } |
121 | if ( minor.find( "x-" ) == 0 ) | 119 | if ( minor.find( "x-" ) == 0 ) |
122 | minor = minor.mid( 2 ); | 120 | minor = minor.mid( 2 ); |
123 | minor[0] = minor[0].upper(); | 121 | minor[0] = minor[0].upper(); |
124 | major[0] = major[0].upper(); | 122 | major[0] = major[0].upper(); |
125 | if ( filters.count() > 1 ) | 123 | if ( filters.count() > 1 ) |
126 | t = tr("%1 %2", "minor mimetype / major mimetype").arg(minor).arg(major); | 124 | t = tr("%1 %2", "minor mimetype / major mimetype").arg(minor).arg(major); |
127 | else | 125 | else |
128 | t = minor; | 126 | t = minor; |
129 | } | 127 | } |
130 | types += tr("%1 files").arg(t); | 128 | types += tr("%1 files").arg(t); |
131 | } | 129 | } |
diff --git a/library/fontdatabase.cpp b/library/fontdatabase.cpp index 2b5e0d2..147134c 100644 --- a/library/fontdatabase.cpp +++ b/library/fontdatabase.cpp | |||
@@ -1,125 +1,123 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #include <qpe/qpeapplication.h> | 21 | #include <qpe/qpeapplication.h> |
22 | #include "fontfactoryinterface.h" | 22 | #include "fontfactoryinterface.h" |
23 | #include "fontdatabase.h" | 23 | #include "fontdatabase.h" |
24 | 24 | ||
25 | #include <qpe/qlibrary.h> | 25 | #include <qpe/qlibrary.h> |
26 | 26 | ||
27 | #ifdef QWS | ||
28 | #include <qfontmanager_qws.h> | 27 | #include <qfontmanager_qws.h> |
29 | #endif | ||
30 | #include <qdir.h> | 28 | #include <qdir.h> |
31 | #include <qdict.h> | 29 | #include <qdict.h> |
32 | #include <stdio.h> | 30 | #include <stdio.h> |
33 | #include <stdlib.h> | 31 | #include <stdlib.h> |
34 | 32 | ||
35 | static QString fontDir() | 33 | static QString fontDir() |
36 | { | 34 | { |
37 | QString qtdir = getenv("QTDIR"); | 35 | QString qtdir = getenv("QTDIR"); |
38 | if ( qtdir.isEmpty() ) qtdir = "/usr/local/qt-embedded"; | 36 | if ( qtdir.isEmpty() ) qtdir = "/usr/local/qt-embedded"; |
39 | return qtdir+"/lib/fonts/"; | 37 | return qtdir+"/lib/fonts/"; |
40 | } | 38 | } |
41 | 39 | ||
42 | #ifdef QT_NO_FONTDATABASE | 40 | #ifdef QT_NO_FONTDATABASE |
43 | static QString fontFamily( const QString& key ) | 41 | static QString fontFamily( const QString& key ) |
44 | { | 42 | { |
45 | int u0 = key.find('_'); | 43 | int u0 = key.find('_'); |
46 | int u1 = key.find('_',u0+1); | 44 | int u1 = key.find('_',u0+1); |
47 | int u2 = key.find('_',u1+1); | 45 | int u2 = key.find('_',u1+1); |
48 | QString family = key.left(u0); | 46 | QString family = key.left(u0); |
49 | //int pointSize = key.mid(u0+1,u1-u0-1).toInt(); | 47 | //int pointSize = key.mid(u0+1,u1-u0-1).toInt(); |
50 | //int weight = key.mid(u1+1,u2-u1-1).toInt(); | 48 | //int weight = key.mid(u1+1,u2-u1-1).toInt(); |
51 | //bool italic = key.mid(u2-1,1) == "i"; | 49 | //bool italic = key.mid(u2-1,1) == "i"; |
52 | // #### ignores _t and _I fields | 50 | // #### ignores _t and _I fields |
53 | return family; | 51 | return family; |
54 | } | 52 | } |
55 | #endif | 53 | #endif |
56 | 54 | ||
57 | QValueList<FontFactory> *FontDatabase::factoryList = 0; | 55 | QValueList<FontFactory> *FontDatabase::factoryList = 0; |
58 | 56 | ||
59 | /*! | 57 | /*! |
60 | \class FontDatabase fontdatabase.h | 58 | \class FontDatabase fontdatabase.h |
61 | \brief The FontDatabase class provides information about available fonts. | 59 | \brief The FontDatabase class provides information about available fonts. |
62 | 60 | ||
63 | Most often you will simply want to query the database for the | 61 | Most often you will simply want to query the database for the |
64 | available font families(). | 62 | available font families(). |
65 | 63 | ||
66 | Use FontDatabase rather than QFontDatabase when you may need access | 64 | Use FontDatabase rather than QFontDatabase when you may need access |
67 | to fonts that are not normally available. For example, if the | 65 | to fonts that are not normally available. For example, if the |
68 | freetype library and the Qtopia freetype plugin are installed, | 66 | freetype library and the Qtopia freetype plugin are installed, |
69 | TrueType fonts will be available to your application. Font renderer | 67 | TrueType fonts will be available to your application. Font renderer |
70 | plugins have greater resource requirements than system fonts so they | 68 | plugins have greater resource requirements than system fonts so they |
71 | should be used only when necessary. You can force the loading of | 69 | should be used only when necessary. You can force the loading of |
72 | font renderer plugins with loadRenderers(). | 70 | font renderer plugins with loadRenderers(). |
73 | 71 | ||
74 | \ingroup qtopiaemb | 72 | \ingroup qtopiaemb |
75 | */ | 73 | */ |
76 | 74 | ||
77 | /*! | 75 | /*! |
78 | Constructs a FontDatabase object. | 76 | Constructs a FontDatabase object. |
79 | */ | 77 | */ |
80 | FontDatabase::FontDatabase() | 78 | FontDatabase::FontDatabase() |
81 | #ifndef QT_NO_FONTDATABASE | 79 | #ifndef QT_NO_FONTDATABASE |
82 | : QFontDatabase() | 80 | : QFontDatabase() |
83 | #endif | 81 | #endif |
84 | { | 82 | { |
85 | if ( !factoryList ) | 83 | if ( !factoryList ) |
86 | loadRenderers(); | 84 | loadRenderers(); |
87 | } | 85 | } |
88 | 86 | ||
89 | /*! | 87 | /*! |
90 | Returns a list of names of all the available font families. | 88 | Returns a list of names of all the available font families. |
91 | */ | 89 | */ |
92 | QStringList FontDatabase::families() const | 90 | QStringList FontDatabase::families() const |
93 | { | 91 | { |
94 | #ifndef QT_NO_FONTDATABASE | 92 | #ifndef QT_NO_FONTDATABASE |
95 | return QFontDatabase::families(); | 93 | return QFontDatabase::families(); |
96 | #else | 94 | #else |
97 | QStringList list; | 95 | QStringList list; |
98 | QDict<void> familyDict; | 96 | QDict<void> familyDict; |
99 | QDiskFont *qdf; | 97 | QDiskFont *qdf; |
100 | for ( qdf=qt_fontmanager->diskfonts.first(); qdf!=0; | 98 | for ( qdf=qt_fontmanager->diskfonts.first(); qdf!=0; |
101 | qdf=qt_fontmanager->diskfonts.next()) { | 99 | qdf=qt_fontmanager->diskfonts.next()) { |
102 | QString familyname = qdf->name; | 100 | QString familyname = qdf->name; |
103 | if ( !familyDict.find( familyname ) ) { | 101 | if ( !familyDict.find( familyname ) ) { |
104 | familyDict.insert( familyname, (void *)1 ); | 102 | familyDict.insert( familyname, (void *)1 ); |
105 | list.append( familyname ); | 103 | list.append( familyname ); |
106 | } | 104 | } |
107 | } | 105 | } |
108 | 106 | ||
109 | QDir dir(fontDir(),"*.qpf"); | 107 | QDir dir(fontDir(),"*.qpf"); |
110 | for (int i=0; i<(int)dir.count(); i++) { | 108 | for (int i=0; i<(int)dir.count(); i++) { |
111 | QString familyname = fontFamily(dir[i]); | 109 | QString familyname = fontFamily(dir[i]); |
112 | if ( !familyDict.find( familyname ) ) { | 110 | if ( !familyDict.find( familyname ) ) { |
113 | familyDict.insert( familyname, (void *)1 ); | 111 | familyDict.insert( familyname, (void *)1 ); |
114 | list.append( familyname ); | 112 | list.append( familyname ); |
115 | } | 113 | } |
116 | } | 114 | } |
117 | 115 | ||
118 | return list; | 116 | return list; |
119 | #endif | 117 | #endif |
120 | } | 118 | } |
121 | 119 | ||
122 | #ifdef QT_NO_FONTDATABASE | 120 | #ifdef QT_NO_FONTDATABASE |
123 | /*! | 121 | /*! |
124 | Returns a list of standard fontsizes. | 122 | Returns a list of standard fontsizes. |
125 | */ | 123 | */ |
diff --git a/library/fontmanager.cpp b/library/fontmanager.cpp index 28a5212..c854133 100644 --- a/library/fontmanager.cpp +++ b/library/fontmanager.cpp | |||
@@ -1,103 +1,101 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #ifdef QWS | ||
22 | #include "fontmanager.h" | 21 | #include "fontmanager.h" |
23 | #include <qfile.h> | 22 | #include <qfile.h> |
24 | #include <stdlib.h> | 23 | #include <stdlib.h> |
25 | #include <qgfx_qws.h> | 24 | #include <qgfx_qws.h> |
26 | 25 | ||
27 | 26 | ||
28 | 27 | ||
29 | /* | 28 | /* |
30 | QFontInfo doesn't work in QWS at the moment, | 29 | QFontInfo doesn't work in QWS at the moment, |
31 | otherwise we would just have used that to check | 30 | otherwise we would just have used that to check |
32 | the real values | 31 | the real values |
33 | 32 | ||
34 | For now, there are only two Unicode fonts in | 33 | For now, there are only two Unicode fonts in |
35 | the known universe... | 34 | the known universe... |
36 | 35 | ||
37 | */ | 36 | */ |
38 | 37 | ||
39 | bool FontManager::hasUnicodeFont() | 38 | bool FontManager::hasUnicodeFont() |
40 | { | 39 | { |
41 | QString fontDir = getenv("QTDIR") + QString("/lib/fonts/"); | 40 | QString fontDir = getenv("QTDIR") + QString("/lib/fonts/"); |
42 | 41 | ||
43 | QString suffix; | 42 | QString suffix; |
44 | if ( qt_screen->isTransformed() ) { | 43 | if ( qt_screen->isTransformed() ) { |
45 | suffix += "_t"; | 44 | suffix += "_t"; |
46 | QPoint a = qt_screen->mapToDevice(QPoint(0,0),QSize(2,2)); | 45 | QPoint a = qt_screen->mapToDevice(QPoint(0,0),QSize(2,2)); |
47 | QPoint b = qt_screen->mapToDevice(QPoint(1,1),QSize(2,2)); | 46 | QPoint b = qt_screen->mapToDevice(QPoint(1,1),QSize(2,2)); |
48 | suffix += QString::number( a.x()*8+a.y()*4+(1-b.x())*2+(1-b.y()) ); | 47 | suffix += QString::number( a.x()*8+a.y()*4+(1-b.x())*2+(1-b.y()) ); |
49 | } | 48 | } |
50 | suffix += ".qpf"; | 49 | suffix += ".qpf"; |
51 | 50 | ||
52 | return QFile::exists( fontDir+"cyberbit_120_50"+suffix ) | 51 | return QFile::exists( fontDir+"cyberbit_120_50"+suffix ) |
53 | || QFile::exists( fontDir+"unifont_160_50"+suffix ) || | 52 | || QFile::exists( fontDir+"unifont_160_50"+suffix ) || |
54 | QFile::exists( fontDir+"arial_140_50" + suffix ); | 53 | QFile::exists( fontDir+"arial_140_50" + suffix ); |
55 | } | 54 | } |
56 | 55 | ||
57 | QFont FontManager::unicodeFont( Spacing sp ) | 56 | QFont FontManager::unicodeFont( Spacing sp ) |
58 | { | 57 | { |
59 | QString key; | 58 | QString key; |
60 | QString fontName; | 59 | QString fontName; |
61 | QString fontDir = getenv("QTDIR") + QString("/lib/fonts/"); | 60 | QString fontDir = getenv("QTDIR") + QString("/lib/fonts/"); |
62 | 61 | ||
63 | int size; | 62 | int size; |
64 | if ( sp == Proportional ) { | 63 | if ( sp == Proportional ) { |
65 | fontName = "Arial"; | 64 | fontName = "Arial"; |
66 | size=14; | 65 | size=14; |
67 | key = "arial_140_50"; | 66 | key = "arial_140_50"; |
68 | } else { | 67 | } else { |
69 | fontName = "Unifont"; | 68 | fontName = "Unifont"; |
70 | size=16; | 69 | size=16; |
71 | key = "unifont_160_50"; | 70 | key = "unifont_160_50"; |
72 | } | 71 | } |
73 | 72 | ||
74 | QString suffix; | 73 | QString suffix; |
75 | if ( qt_screen->isTransformed() ) { | 74 | if ( qt_screen->isTransformed() ) { |
76 | suffix += "_t"; | 75 | suffix += "_t"; |
77 | QPoint a = qt_screen->mapToDevice(QPoint(0,0),QSize(2,2)); | 76 | QPoint a = qt_screen->mapToDevice(QPoint(0,0),QSize(2,2)); |
78 | QPoint b = qt_screen->mapToDevice(QPoint(1,1),QSize(2,2)); | 77 | QPoint b = qt_screen->mapToDevice(QPoint(1,1),QSize(2,2)); |
79 | suffix += QString::number( a.x()*8+a.y()*4+(1-b.x())*2+(1-b.y()) ); | 78 | suffix += QString::number( a.x()*8+a.y()*4+(1-b.x())*2+(1-b.y()) ); |
80 | } | 79 | } |
81 | suffix += ".qpf"; | 80 | suffix += ".qpf"; |
82 | 81 | ||
83 | // if we cannot find it, try the other one | 82 | // if we cannot find it, try the other one |
84 | 83 | ||
85 | if ( !QFile::exists(fontDir+key+suffix) ) { | 84 | if ( !QFile::exists(fontDir+key+suffix) ) { |
86 | key = (sp == Fixed ) ? "arial_140_50" : "unifont_160_50"; | 85 | key = (sp == Fixed ) ? "arial_140_50" : "unifont_160_50"; |
87 | if ( QFile::exists(fontDir+key+suffix) ) { | 86 | if ( QFile::exists(fontDir+key+suffix) ) { |
88 | fontName = (sp == Fixed) ? "Arial" : "Unifont"; | 87 | fontName = (sp == Fixed) ? "Arial" : "Unifont"; |
89 | size = (sp == Fixed) ? 14 : 16; | 88 | size = (sp == Fixed) ? 14 : 16; |
90 | } else { | 89 | } else { |
91 | key = "cyberbit_120_50"; | 90 | key = "cyberbit_120_50"; |
92 | if ( QFile::exists(fontDir+key+suffix) ) { | 91 | if ( QFile::exists(fontDir+key+suffix) ) { |
93 | fontName = "Cyberbit"; | 92 | fontName = "Cyberbit"; |
94 | size = 12; | 93 | size = 12; |
95 | } else { | 94 | } else { |
96 | fontName = "Helvetica"; | 95 | fontName = "Helvetica"; |
97 | size = 14; | 96 | size = 14; |
98 | } | 97 | } |
99 | } | 98 | } |
100 | } | 99 | } |
101 | return QFont(fontName,size); | 100 | return QFont(fontName,size); |
102 | } | 101 | } |
103 | #endif | ||
diff --git a/library/global.cpp b/library/global.cpp index 9b908bf..d02e711 100644 --- a/library/global.cpp +++ b/library/global.cpp | |||
@@ -1,215 +1,209 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #define QTOPIA_INTERNAL_LANGLIST | 20 | #define QTOPIA_INTERNAL_LANGLIST |
21 | #include <qpe/qpedebug.h> | 21 | #include <qpe/qpedebug.h> |
22 | #include <qpe/global.h> | 22 | #include <qpe/global.h> |
23 | #include <qpe/qdawg.h> | 23 | #include <qpe/qdawg.h> |
24 | #include <qpe/qpeapplication.h> | 24 | #include <qpe/qpeapplication.h> |
25 | #include <qpe/resource.h> | 25 | #include <qpe/resource.h> |
26 | #include <qpe/storage.h> | 26 | #include <qpe/storage.h> |
27 | #include <qpe/applnk.h> | 27 | #include <qpe/applnk.h> |
28 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 28 | #include <qpe/qcopenvelope_qws.h> |
29 | #include "qpe/qcopenvelope_qws.h" | ||
30 | #endif | ||
31 | 29 | ||
32 | #include <qfile.h> | 30 | #include <qfile.h> |
33 | #include <qlabel.h> | 31 | #include <qlabel.h> |
34 | #include <qtimer.h> | 32 | #include <qtimer.h> |
35 | #include <qmap.h> | 33 | #include <qmap.h> |
36 | #include <qdict.h> | 34 | #include <qdict.h> |
37 | #include <qdir.h> | 35 | #include <qdir.h> |
38 | #include <qmessagebox.h> | 36 | #include <qmessagebox.h> |
39 | #include <qregexp.h> | 37 | #include <qregexp.h> |
40 | 38 | ||
41 | #include <stdlib.h> | 39 | #include <stdlib.h> |
42 | #include <sys/stat.h> | 40 | #include <sys/stat.h> |
43 | #include <sys/wait.h> | 41 | #include <sys/wait.h> |
44 | #include <sys/types.h> | 42 | #include <sys/types.h> |
45 | #include <fcntl.h> | 43 | #include <fcntl.h> |
46 | #include <unistd.h> | 44 | #include <unistd.h> |
47 | 45 | ||
48 | #ifdef QWS | ||
49 | #include <qwindowsystem_qws.h> // for qwsServer | 46 | #include <qwindowsystem_qws.h> // for qwsServer |
50 | #endif | ||
51 | #include <qdatetime.h> | 47 | #include <qdatetime.h> |
52 | 48 | ||
53 | #include <qfile.h> | 49 | #include <qfile.h> |
54 | 50 | ||
55 | namespace { | 51 | namespace { |
56 | // checks if the storage should be searched | 52 | // checks if the storage should be searched |
57 | bool checkStorage(const QString &path ){ // this is a small Config replacement cause config is too limited -zecke | 53 | bool checkStorage(const QString &path ){ // this is a small Config replacement cause config is too limited -zecke |
58 | QFile file(path ); | 54 | QFile file(path ); |
59 | if(!file.open(IO_ReadOnly ) ) | 55 | if(!file.open(IO_ReadOnly ) ) |
60 | return true; | 56 | return true; |
61 | 57 | ||
62 | QByteArray array = file.readAll(); | 58 | QByteArray array = file.readAll(); |
63 | QStringList list = QStringList::split('\n', QString( array ) ); | 59 | QStringList list = QStringList::split('\n', QString( array ) ); |
64 | for(QStringList::Iterator it = list.begin(); it != list.end(); ++it ){ | 60 | for(QStringList::Iterator it = list.begin(); it != list.end(); ++it ){ |
65 | if( (*it).startsWith("autocheck = 0" ) ){ | 61 | if( (*it).startsWith("autocheck = 0" ) ){ |
66 | return false; | 62 | return false; |
67 | }else if( (*it).startsWith("autocheck = 1" ) ){ | 63 | }else if( (*it).startsWith("autocheck = 1" ) ){ |
68 | return true; | 64 | return true; |
69 | } | 65 | } |
70 | } | 66 | } |
71 | return true; | 67 | return true; |
72 | } | 68 | } |
73 | } | 69 | } |
74 | 70 | ||
75 | //#include "quickexec_p.h" | 71 | //#include "quickexec_p.h" |
76 | 72 | ||
77 | class Emitter : public QObject { | 73 | class Emitter : public QObject { |
78 | Q_OBJECT | 74 | Q_OBJECT |
79 | public: | 75 | public: |
80 | Emitter( QWidget* receiver, const QString& document ) | 76 | Emitter( QWidget* receiver, const QString& document ) |
81 | { | 77 | { |
82 | connect(this, SIGNAL(setDocument(const QString&)), | 78 | connect(this, SIGNAL(setDocument(const QString&)), |
83 | receiver, SLOT(setDocument(const QString&))); | 79 | receiver, SLOT(setDocument(const QString&))); |
84 | emit setDocument(document); | 80 | emit setDocument(document); |
85 | disconnect(this, SIGNAL(setDocument(const QString&)), | 81 | disconnect(this, SIGNAL(setDocument(const QString&)), |
86 | receiver, SLOT(setDocument(const QString&))); | 82 | receiver, SLOT(setDocument(const QString&))); |
87 | } | 83 | } |
88 | 84 | ||
89 | signals: | 85 | signals: |
90 | void setDocument(const QString&); | 86 | void setDocument(const QString&); |
91 | }; | 87 | }; |
92 | 88 | ||
93 | 89 | ||
94 | class StartingAppList : public QObject { | 90 | class StartingAppList : public QObject { |
95 | Q_OBJECT | 91 | Q_OBJECT |
96 | public: | 92 | public: |
97 | static void add( const QString& name ); | 93 | static void add( const QString& name ); |
98 | static bool isStarting( const QString name ); | 94 | static bool isStarting( const QString name ); |
99 | private slots: | 95 | private slots: |
100 | void handleNewChannel( const QString &); | 96 | void handleNewChannel( const QString &); |
101 | private: | 97 | private: |
102 | StartingAppList( QObject *parent=0, const char* name=0 ) ; | 98 | StartingAppList( QObject *parent=0, const char* name=0 ) ; |
103 | 99 | ||
104 | QDict<QTime> dict; | 100 | QDict<QTime> dict; |
105 | static StartingAppList *appl; | 101 | static StartingAppList *appl; |
106 | }; | 102 | }; |
107 | 103 | ||
108 | StartingAppList* StartingAppList::appl = 0; | 104 | StartingAppList* StartingAppList::appl = 0; |
109 | 105 | ||
110 | StartingAppList::StartingAppList( QObject *parent, const char* name ) | 106 | StartingAppList::StartingAppList( QObject *parent, const char* name ) |
111 | :QObject( parent, name ) | 107 | :QObject( parent, name ) |
112 | { | 108 | { |
113 | #ifdef QWS | ||
114 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 109 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
115 | connect( qwsServer, SIGNAL( newChannel(const QString&)), | 110 | connect( qwsServer, SIGNAL( newChannel(const QString&)), |
116 | this, SLOT( handleNewChannel(const QString&)) ); | 111 | this, SLOT( handleNewChannel(const QString&)) ); |
117 | dict.setAutoDelete( TRUE ); | 112 | dict.setAutoDelete( TRUE ); |
118 | #endif | 113 | #endif |
119 | #endif | ||
120 | } | 114 | } |
121 | 115 | ||
122 | void StartingAppList::add( const QString& name ) | 116 | void StartingAppList::add( const QString& name ) |
123 | { | 117 | { |
124 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 118 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
125 | if ( !appl ) | 119 | if ( !appl ) |
126 | appl = new StartingAppList; | 120 | appl = new StartingAppList; |
127 | QTime *t = new QTime; | 121 | QTime *t = new QTime; |
128 | t->start(); | 122 | t->start(); |
129 | appl->dict.insert( "QPE/Application/" + name, t ); | 123 | appl->dict.insert( "QPE/Application/" + name, t ); |
130 | #endif | 124 | #endif |
131 | } | 125 | } |
132 | 126 | ||
133 | bool StartingAppList::isStarting( const QString name ) | 127 | bool StartingAppList::isStarting( const QString name ) |
134 | { | 128 | { |
135 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 129 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
136 | if ( appl ) { | 130 | if ( appl ) { |
137 | QTime *t = appl->dict.find( "QPE/Application/" + name ); | 131 | QTime *t = appl->dict.find( "QPE/Application/" + name ); |
138 | if ( !t ) | 132 | if ( !t ) |
139 | return FALSE; | 133 | return FALSE; |
140 | if ( t->elapsed() > 10000 ) { | 134 | if ( t->elapsed() > 10000 ) { |
141 | // timeout in case of crash or something | 135 | // timeout in case of crash or something |
142 | appl->dict.remove( "QPE/Application/" + name ); | 136 | appl->dict.remove( "QPE/Application/" + name ); |
143 | return FALSE; | 137 | return FALSE; |
144 | } | 138 | } |
145 | return TRUE; | 139 | return TRUE; |
146 | } | 140 | } |
147 | #endif | 141 | #endif |
148 | return FALSE; | 142 | return FALSE; |
149 | } | 143 | } |
150 | 144 | ||
151 | void StartingAppList::handleNewChannel( const QString & name ) | 145 | void StartingAppList::handleNewChannel( const QString & name ) |
152 | { | 146 | { |
153 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 147 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
154 | dict.remove( name ); | 148 | dict.remove( name ); |
155 | #endif | 149 | #endif |
156 | } | 150 | } |
157 | 151 | ||
158 | static bool docDirCreated = FALSE; | 152 | static bool docDirCreated = FALSE; |
159 | static QDawg* fixed_dawg = 0; | 153 | static QDawg* fixed_dawg = 0; |
160 | static QDict<QDawg> *named_dawg = 0; | 154 | static QDict<QDawg> *named_dawg = 0; |
161 | 155 | ||
162 | static QString qpeDir() | 156 | static QString qpeDir() |
163 | { | 157 | { |
164 | QString dir = getenv("OPIEDIR"); | 158 | QString dir = getenv("OPIEDIR"); |
165 | if ( dir.isEmpty() ) dir = ".."; | 159 | if ( dir.isEmpty() ) dir = ".."; |
166 | return dir; | 160 | return dir; |
167 | } | 161 | } |
168 | 162 | ||
169 | static QString dictDir() | 163 | static QString dictDir() |
170 | { | 164 | { |
171 | return qpeDir() + "/etc/dict"; | 165 | return qpeDir() + "/etc/dict"; |
172 | } | 166 | } |
173 | 167 | ||
174 | /*! | 168 | /*! |
175 | \class Global global.h | 169 | \class Global global.h |
176 | \brief The Global class provides application-wide global functions. | 170 | \brief The Global class provides application-wide global functions. |
177 | 171 | ||
178 | The Global functions are grouped as follows: | 172 | The Global functions are grouped as follows: |
179 | \tableofcontents | 173 | \tableofcontents |
180 | 174 | ||
181 | \section1 User Interface | 175 | \section1 User Interface |
182 | 176 | ||
183 | The statusMessage() function provides short-duration messages to the | 177 | The statusMessage() function provides short-duration messages to the |
184 | user. The showInputMethod() function shows the current input method, | 178 | user. The showInputMethod() function shows the current input method, |
185 | and hideInputMethod() hides the input method. | 179 | and hideInputMethod() hides the input method. |
186 | 180 | ||
187 | \section1 Document related | 181 | \section1 Document related |
188 | 182 | ||
189 | The findDocuments() function creates a set of \link doclnk.html | 183 | The findDocuments() function creates a set of \link doclnk.html |
190 | DocLnk\endlink objects in a particular folder. | 184 | DocLnk\endlink objects in a particular folder. |
191 | 185 | ||
192 | \section1 Filesystem related | 186 | \section1 Filesystem related |
193 | 187 | ||
194 | Global provides an applicationFileName() function that returns the | 188 | Global provides an applicationFileName() function that returns the |
195 | full path of an application-specific file. | 189 | full path of an application-specific file. |
196 | 190 | ||
197 | The execute() function runs an application. | 191 | The execute() function runs an application. |
198 | 192 | ||
199 | \section1 Word list related | 193 | \section1 Word list related |
200 | 194 | ||
201 | A list of words relevant to the current locale is maintained by the | 195 | A list of words relevant to the current locale is maintained by the |
202 | system. The list is held in a \link qdawg.html DAWG\endlink | 196 | system. The list is held in a \link qdawg.html DAWG\endlink |
203 | (implemented by the QDawg class). This list is used, for example, by | 197 | (implemented by the QDawg class). This list is used, for example, by |
204 | the pickboard input method. | 198 | the pickboard input method. |
205 | 199 | ||
206 | The global QDawg is returned by fixedDawg(); this cannot be updated. | 200 | The global QDawg is returned by fixedDawg(); this cannot be updated. |
207 | An updatable copy of the global QDawg is returned by addedDawg(). | 201 | An updatable copy of the global QDawg is returned by addedDawg(). |
208 | Applications may have their own word lists stored in \l{QDawg}s | 202 | Applications may have their own word lists stored in \l{QDawg}s |
209 | which are returned by dawg(). Use addWords() to add words to the | 203 | which are returned by dawg(). Use addWords() to add words to the |
210 | updateable copy of the global QDawg or to named application | 204 | updateable copy of the global QDawg or to named application |
211 | \l{QDawg}s. | 205 | \l{QDawg}s. |
212 | 206 | ||
213 | \section1 Quoting | 207 | \section1 Quoting |
214 | 208 | ||
215 | The shellQuote() function quotes a string suitable for passing to a | 209 | The shellQuote() function quotes a string suitable for passing to a |
@@ -300,476 +294,476 @@ const QDawg& Global::dawg(const QString& name) | |||
300 | createDocDir(); | 294 | createDocDir(); |
301 | if ( !named_dawg ) | 295 | if ( !named_dawg ) |
302 | named_dawg = new QDict<QDawg>; | 296 | named_dawg = new QDict<QDawg>; |
303 | QDawg* r = named_dawg->find(name); | 297 | QDawg* r = named_dawg->find(name); |
304 | if ( !r ) { | 298 | if ( !r ) { |
305 | r = new QDawg; | 299 | r = new QDawg; |
306 | named_dawg->insert(name,r); | 300 | named_dawg->insert(name,r); |
307 | QString dawgfilename = applicationFileName("Dictionary", name ) + ".dawg"; | 301 | QString dawgfilename = applicationFileName("Dictionary", name ) + ".dawg"; |
308 | QFile dawgfile(dawgfilename); | 302 | QFile dawgfile(dawgfilename); |
309 | if ( dawgfile.open(IO_ReadOnly) ) | 303 | if ( dawgfile.open(IO_ReadOnly) ) |
310 | r->readFile(dawgfilename); | 304 | r->readFile(dawgfilename); |
311 | } | 305 | } |
312 | return *r; | 306 | return *r; |
313 | } | 307 | } |
314 | 308 | ||
315 | /*! | 309 | /*! |
316 | \overload | 310 | \overload |
317 | Adds \a wordlist to the addedDawg(). | 311 | Adds \a wordlist to the addedDawg(). |
318 | 312 | ||
319 | Note that the addition of words persists between program executions | 313 | Note that the addition of words persists between program executions |
320 | (they are saved in the dictionary files), so you should confirm the | 314 | (they are saved in the dictionary files), so you should confirm the |
321 | words with the user before adding them. | 315 | words with the user before adding them. |
322 | */ | 316 | */ |
323 | void Global::addWords(const QStringList& wordlist) | 317 | void Global::addWords(const QStringList& wordlist) |
324 | { | 318 | { |
325 | addWords("local",wordlist); | 319 | addWords("local",wordlist); |
326 | } | 320 | } |
327 | 321 | ||
328 | /*! | 322 | /*! |
329 | \overload | 323 | \overload |
330 | Adds \a wordlist to the addedDawg(). | 324 | Adds \a wordlist to the addedDawg(). |
331 | 325 | ||
332 | Note that the addition of words persists between program executions | 326 | Note that the addition of words persists between program executions |
333 | (they are saved in the dictionary files), so you should confirm the | 327 | (they are saved in the dictionary files), so you should confirm the |
334 | words with the user before adding them. | 328 | words with the user before adding them. |
335 | */ | 329 | */ |
336 | void Global::addWords(const QString& dictname, const QStringList& wordlist) | 330 | void Global::addWords(const QString& dictname, const QStringList& wordlist) |
337 | { | 331 | { |
338 | QDawg& d = (QDawg&)dawg(dictname); | 332 | QDawg& d = (QDawg&)dawg(dictname); |
339 | QStringList all = d.allWords() + wordlist; | 333 | QStringList all = d.allWords() + wordlist; |
340 | d.createFromWords(all); | 334 | d.createFromWords(all); |
341 | 335 | ||
342 | QString dawgfilename = applicationFileName("Dictionary", dictname) + ".dawg"; | 336 | QString dawgfilename = applicationFileName("Dictionary", dictname) + ".dawg"; |
343 | QFile dawgfile(dawgfilename); | 337 | QFile dawgfile(dawgfilename); |
344 | if ( dawgfile.open(IO_WriteOnly) ) { | 338 | if ( dawgfile.open(IO_WriteOnly) ) { |
345 | d.write(&dawgfile); | 339 | d.write(&dawgfile); |
346 | dawgfile.close(); | 340 | dawgfile.close(); |
347 | } | 341 | } |
348 | 342 | ||
349 | // #### Re-read the dawg here if we use mmap(). | 343 | // #### Re-read the dawg here if we use mmap(). |
350 | 344 | ||
351 | // #### Signal other processes to re-read. | 345 | // #### Signal other processes to re-read. |
352 | } | 346 | } |
353 | 347 | ||
354 | 348 | ||
355 | /*! | 349 | /*! |
356 | Returns the full path for the application called \a appname, with the | 350 | Returns the full path for the application called \a appname, with the |
357 | given \a filename. Returns QString::null if there was a problem creating | 351 | given \a filename. Returns QString::null if there was a problem creating |
358 | the directory tree for \a appname. | 352 | the directory tree for \a appname. |
359 | If \a filename contains "/", it is the caller's responsibility to | 353 | If \a filename contains "/", it is the caller's responsibility to |
360 | ensure that those directories exist. | 354 | ensure that those directories exist. |
361 | */ | 355 | */ |
362 | QString Global::applicationFileName(const QString& appname, const QString& filename) | 356 | QString Global::applicationFileName(const QString& appname, const QString& filename) |
363 | { | 357 | { |
364 | QDir d; | 358 | QDir d; |
365 | QString r = getenv("HOME"); | 359 | QString r = getenv("HOME"); |
366 | r += "/Applications/"; | 360 | r += "/Applications/"; |
367 | if ( !QFile::exists( r ) ) | 361 | if ( !QFile::exists( r ) ) |
368 | if ( d.mkdir(r) == false ) | 362 | if ( d.mkdir(r) == false ) |
369 | return QString::null; | 363 | return QString::null; |
370 | r += appname; | 364 | r += appname; |
371 | if ( !QFile::exists( r ) ) | 365 | if ( !QFile::exists( r ) ) |
372 | if ( d.mkdir(r) == false ) | 366 | if ( d.mkdir(r) == false ) |
373 | return QString::null; | 367 | return QString::null; |
374 | r += "/"; r += filename; | 368 | r += "/"; r += filename; |
375 | return r; | 369 | return r; |
376 | } | 370 | } |
377 | 371 | ||
378 | /*! | 372 | /*! |
379 | \internal | 373 | \internal |
380 | */ | 374 | */ |
381 | void Global::createDocDir() | 375 | void Global::createDocDir() |
382 | { | 376 | { |
383 | if ( !docDirCreated ) { | 377 | if ( !docDirCreated ) { |
384 | docDirCreated = TRUE; | 378 | docDirCreated = TRUE; |
385 | mkdir( QPEApplication::documentDir().latin1(), 0755 ); | 379 | mkdir( QPEApplication::documentDir().latin1(), 0755 ); |
386 | } | 380 | } |
387 | } | 381 | } |
388 | 382 | ||
389 | 383 | ||
390 | /*! | 384 | /*! |
391 | Displays a status \a message to the user. This usually appears | 385 | Displays a status \a message to the user. This usually appears |
392 | in the taskbar for a short amount of time, then disappears. | 386 | in the taskbar for a short amount of time, then disappears. |
393 | */ | 387 | */ |
394 | void Global::statusMessage(const QString& message) | 388 | void Global::statusMessage(const QString& message) |
395 | { | 389 | { |
396 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 390 | #if!defined(QT_NO_COP) |
397 | QCopEnvelope e( "QPE/TaskBar", "message(QString)" ); | 391 | QCopEnvelope e( "QPE/TaskBar", "message(QString)" ); |
398 | e << message; | 392 | e << message; |
399 | #endif | 393 | #endif |
400 | } | 394 | } |
401 | 395 | ||
402 | /*! | 396 | /*! |
403 | \internal | 397 | \internal |
404 | */ | 398 | */ |
405 | void Global::applyStyle() | 399 | void Global::applyStyle() |
406 | { | 400 | { |
407 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 401 | #if !defined(QT_NO_COP) |
408 | QCopChannel::send( "QPE/System", "applyStyle()" ); | 402 | QCopChannel::send( "QPE/System", "applyStyle()" ); |
409 | #else | 403 | #else |
410 | ((QPEApplication *)qApp)->applyStyle(); // apply without needing QCop for floppy version | 404 | ((QPEApplication *)qApp)->applyStyle(); // apply without needing QCop for floppy version |
411 | #endif | 405 | #endif |
412 | } | 406 | } |
413 | 407 | ||
414 | /*! | 408 | /*! |
415 | \internal | 409 | \internal |
416 | */ | 410 | */ |
417 | QWidget *Global::shutdown( bool ) | 411 | QWidget *Global::shutdown( bool ) |
418 | { | 412 | { |
419 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 413 | #if !defined(QT_NO_COP) |
420 | QCopChannel::send( "QPE/System", "shutdown()" ); | 414 | QCopChannel::send( "QPE/System", "shutdown()" ); |
421 | #endif | 415 | #endif |
422 | return 0; | 416 | return 0; |
423 | } | 417 | } |
424 | 418 | ||
425 | /*! | 419 | /*! |
426 | \internal | 420 | \internal |
427 | */ | 421 | */ |
428 | QWidget *Global::restart( bool ) | 422 | QWidget *Global::restart( bool ) |
429 | { | 423 | { |
430 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 424 | #if !defined(QT_NO_COP) |
431 | QCopChannel::send( "QPE/System", "restart()" ); | 425 | QCopChannel::send( "QPE/System", "restart()" ); |
432 | #endif | 426 | #endif |
433 | return 0; | 427 | return 0; |
434 | } | 428 | } |
435 | 429 | ||
436 | /*! | 430 | /*! |
437 | Explicitly show the current input method. | 431 | Explicitly show the current input method. |
438 | 432 | ||
439 | Input methods are indicated in the taskbar by a small icon. If the | 433 | Input methods are indicated in the taskbar by a small icon. If the |
440 | input method is activated (shown) then it takes up some proportion | 434 | input method is activated (shown) then it takes up some proportion |
441 | of the bottom of the screen, to allow the user to interact (input | 435 | of the bottom of the screen, to allow the user to interact (input |
442 | characters) with it. | 436 | characters) with it. |
443 | 437 | ||
444 | \sa hideInputMethod() | 438 | \sa hideInputMethod() |
445 | */ | 439 | */ |
446 | void Global::showInputMethod() | 440 | void Global::showInputMethod() |
447 | { | 441 | { |
448 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 442 | #if !defined(QT_NO_COP) |
449 | QCopChannel::send( "QPE/TaskBar", "showInputMethod()" ); | 443 | QCopChannel::send( "QPE/TaskBar", "showInputMethod()" ); |
450 | #endif | 444 | #endif |
451 | } | 445 | } |
452 | 446 | ||
453 | /*! | 447 | /*! |
454 | Explicitly hide the current input method. | 448 | Explicitly hide the current input method. |
455 | 449 | ||
456 | The current input method is still indicated in the taskbar, but no | 450 | The current input method is still indicated in the taskbar, but no |
457 | longer takes up screen space, and can no longer be interacted with. | 451 | longer takes up screen space, and can no longer be interacted with. |
458 | 452 | ||
459 | \sa showInputMethod() | 453 | \sa showInputMethod() |
460 | */ | 454 | */ |
461 | void Global::hideInputMethod() | 455 | void Global::hideInputMethod() |
462 | { | 456 | { |
463 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 457 | #if !defined(QT_NO_COP) |
464 | QCopChannel::send( "QPE/TaskBar", "hideInputMethod()" ); | 458 | QCopChannel::send( "QPE/TaskBar", "hideInputMethod()" ); |
465 | #endif | 459 | #endif |
466 | } | 460 | } |
467 | 461 | ||
468 | 462 | ||
469 | /*! | 463 | /*! |
470 | \internal | 464 | \internal |
471 | */ | 465 | */ |
472 | bool Global::isBuiltinCommand( const QString &name ) | 466 | bool Global::isBuiltinCommand( const QString &name ) |
473 | { | 467 | { |
474 | if(!builtin) | 468 | if(!builtin) |
475 | return FALSE; // yes, it can happen | 469 | return FALSE; // yes, it can happen |
476 | for (int i = 0; builtin[i].file; i++) { | 470 | for (int i = 0; builtin[i].file; i++) { |
477 | if ( builtin[i].file == name ) { | 471 | if ( builtin[i].file == name ) { |
478 | return TRUE; | 472 | return TRUE; |
479 | } | 473 | } |
480 | } | 474 | } |
481 | return FALSE; | 475 | return FALSE; |
482 | } | 476 | } |
483 | 477 | ||
484 | Global::Command* Global::builtin=0; | 478 | Global::Command* Global::builtin=0; |
485 | QGuardedPtr<QWidget> *Global::running=0; | 479 | QGuardedPtr<QWidget> *Global::running=0; |
486 | 480 | ||
487 | /*! | 481 | /*! |
488 | \class Global::Command | 482 | \class Global::Command |
489 | \brief The Global::Command class is internal. | 483 | \brief The Global::Command class is internal. |
490 | \internal | 484 | \internal |
491 | */ | 485 | */ |
492 | 486 | ||
493 | /*! | 487 | /*! |
494 | \internal | 488 | \internal |
495 | */ | 489 | */ |
496 | void Global::setBuiltinCommands( Command* list ) | 490 | void Global::setBuiltinCommands( Command* list ) |
497 | { | 491 | { |
498 | if ( running ) | 492 | if ( running ) |
499 | delete [] running; | 493 | delete [] running; |
500 | 494 | ||
501 | builtin = list; | 495 | builtin = list; |
502 | int count = 0; | 496 | int count = 0; |
503 | if (!builtin) | 497 | if (!builtin) |
504 | return; | 498 | return; |
505 | while ( builtin[count].file ) | 499 | while ( builtin[count].file ) |
506 | count++; | 500 | count++; |
507 | 501 | ||
508 | running = new QGuardedPtr<QWidget> [ count ]; | 502 | running = new QGuardedPtr<QWidget> [ count ]; |
509 | } | 503 | } |
510 | 504 | ||
511 | /*! | 505 | /*! |
512 | \internal | 506 | \internal |
513 | */ | 507 | */ |
514 | void Global::setDocument( QWidget* receiver, const QString& document ) | 508 | void Global::setDocument( QWidget* receiver, const QString& document ) |
515 | { | 509 | { |
516 | Emitter emitter(receiver,document); | 510 | Emitter emitter(receiver,document); |
517 | } | 511 | } |
518 | 512 | ||
519 | /*! | 513 | /*! |
520 | \internal | 514 | \internal |
521 | */ | 515 | */ |
522 | bool Global::terminateBuiltin( const QString& n ) | 516 | bool Global::terminateBuiltin( const QString& n ) |
523 | { | 517 | { |
524 | if (!builtin) | 518 | if (!builtin) |
525 | return FALSE; | 519 | return FALSE; |
526 | for (int i = 0; builtin[i].file; i++) { | 520 | for (int i = 0; builtin[i].file; i++) { |
527 | if ( builtin[i].file == n ) { | 521 | if ( builtin[i].file == n ) { |
528 | delete running[i]; | 522 | delete running[i]; |
529 | return TRUE; | 523 | return TRUE; |
530 | } | 524 | } |
531 | } | 525 | } |
532 | return FALSE; | 526 | return FALSE; |
533 | } | 527 | } |
534 | 528 | ||
535 | /*! | 529 | /*! |
536 | \internal | 530 | \internal |
537 | */ | 531 | */ |
538 | void Global::terminate( const AppLnk* app ) | 532 | void Global::terminate( const AppLnk* app ) |
539 | { | 533 | { |
540 | //if ( terminateBuiltin(app->exec()) ) return; // maybe? haven't tried this | 534 | //if ( terminateBuiltin(app->exec()) ) return; // maybe? haven't tried this |
541 | 535 | ||
542 | #ifndef QT_NO_COP | 536 | #ifndef QT_NO_COP |
543 | QCString channel = "QPE/Application/" + app->exec().utf8(); | 537 | QCString channel = "QPE/Application/" + app->exec().utf8(); |
544 | if ( QCopChannel::isRegistered(channel) ) { | 538 | if ( QCopChannel::isRegistered(channel) ) { |
545 | QCopEnvelope e(channel, "quit()"); | 539 | QCopEnvelope e(channel, "quit()"); |
546 | } | 540 | } |
547 | #endif | 541 | #endif |
548 | } | 542 | } |
549 | 543 | ||
550 | /*! | 544 | /*! |
551 | Low-level function to run command \a c. | 545 | Low-level function to run command \a c. |
552 | 546 | ||
553 | \warning Do not use this function. Use execute instead. | 547 | \warning Do not use this function. Use execute instead. |
554 | 548 | ||
555 | \sa execute() | 549 | \sa execute() |
556 | */ | 550 | */ |
557 | void Global::invoke(const QString &c) | 551 | void Global::invoke(const QString &c) |
558 | { | 552 | { |
559 | // Convert the command line in to a list of arguments | 553 | // Convert the command line in to a list of arguments |
560 | QStringList list = QStringList::split(QRegExp(" *"),c); | 554 | QStringList list = QStringList::split(QRegExp(" *"),c); |
561 | 555 | ||
562 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 556 | #if !defined(QT_NO_COP) |
563 | QString ap=list[0]; | 557 | QString ap=list[0]; |
564 | // see if the application is already running | 558 | // see if the application is already running |
565 | // XXX should lock file /tmp/qcop-msg-ap | 559 | // XXX should lock file /tmp/qcop-msg-ap |
566 | if ( QCopChannel::isRegistered( ("QPE/Application/" + ap).latin1() ) ) { | 560 | if ( QCopChannel::isRegistered( ("QPE/Application/" + ap).latin1() ) ) { |
567 | // If the channel is already register, the app is already running, so show it. | 561 | // If the channel is already register, the app is already running, so show it. |
568 | { QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } | 562 | { QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } |
569 | 563 | ||
570 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 564 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
571 | e << ap; | 565 | e << ap; |
572 | return; | 566 | return; |
573 | } | 567 | } |
574 | // XXX should unlock file /tmp/qcop-msg-ap | 568 | // XXX should unlock file /tmp/qcop-msg-ap |
575 | //see if it is being started | 569 | //see if it is being started |
576 | if ( StartingAppList::isStarting( ap ) ) { | 570 | if ( StartingAppList::isStarting( ap ) ) { |
577 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 571 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
578 | e << ap; | 572 | e << ap; |
579 | return; | 573 | return; |
580 | } | 574 | } |
581 | 575 | ||
582 | #endif | 576 | #endif |
583 | 577 | ||
584 | #ifdef QT_NO_QWS_MULTIPROCESS | 578 | #ifdef QT_NO_QWS_MULTIPROCESS |
585 | QMessageBox::warning( 0, "Error", "Could not find the application " + c, "Ok", 0, 0, 0, 1 ); | 579 | QMessageBox::warning( 0, "Error", "Could not find the application " + c, "Ok", 0, 0, 0, 1 ); |
586 | #else | 580 | #else |
587 | 581 | ||
588 | QStrList slist; | 582 | QStrList slist; |
589 | unsigned int j; | 583 | unsigned int j; |
590 | for ( j = 0; j < list.count(); j++ ) | 584 | for ( j = 0; j < list.count(); j++ ) |
591 | slist.append( list[j].utf8() ); | 585 | slist.append( list[j].utf8() ); |
592 | 586 | ||
593 | const char **args = new (const char *)[slist.count() + 1]; | 587 | const char **args = new (const char *)[slist.count() + 1]; |
594 | for ( j = 0; j < slist.count(); j++ ) | 588 | for ( j = 0; j < slist.count(); j++ ) |
595 | args[j] = slist.at(j); | 589 | args[j] = slist.at(j); |
596 | args[j] = NULL; | 590 | args[j] = NULL; |
597 | 591 | ||
598 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 592 | #if !defined(QT_NO_COP) |
599 | // an attempt to show a wait... | 593 | // an attempt to show a wait... |
600 | // more logic should be used, but this will be fine for the moment... | 594 | // more logic should be used, but this will be fine for the moment... |
601 | QCopEnvelope ( "QPE/System", "busy()" ); | 595 | QCopEnvelope ( "QPE/System", "busy()" ); |
602 | #endif | 596 | #endif |
603 | 597 | ||
604 | #ifdef HAVE_QUICKEXEC | 598 | #ifdef HAVE_QUICKEXEC |
605 | QString libexe = qpeDir()+"/binlib/lib"+args[0] + ".so"; | 599 | QString libexe = qpeDir()+"/binlib/lib"+args[0] + ".so"; |
606 | qDebug("libfile = %s", libexe.latin1() ); | 600 | qDebug("libfile = %s", libexe.latin1() ); |
607 | if ( QFile::exists( libexe ) ) { | 601 | if ( QFile::exists( libexe ) ) { |
608 | qDebug("calling quickexec %s", libexe.latin1() ); | 602 | qDebug("calling quickexec %s", libexe.latin1() ); |
609 | quickexecv( libexe.utf8().data(), (const char **)args ); | 603 | quickexecv( libexe.utf8().data(), (const char **)args ); |
610 | } else | 604 | } else |
611 | #endif | 605 | #endif |
612 | { | 606 | { |
613 | if ( !::vfork() ) { | 607 | if ( !::vfork() ) { |
614 | for ( int fd = 3; fd < 100; fd++ ) | 608 | for ( int fd = 3; fd < 100; fd++ ) |
615 | ::close( fd ); | 609 | ::close( fd ); |
616 | ::setpgid( ::getpid(), ::getppid() ); | 610 | ::setpgid( ::getpid(), ::getppid() ); |
617 | // Try bindir first, so that foo/bar works too | 611 | // Try bindir first, so that foo/bar works too |
618 | ::execv( qpeDir()+"/bin/"+args[0], (char * const *)args ); | 612 | ::execv( qpeDir()+"/bin/"+args[0], (char * const *)args ); |
619 | ::execvp( args[0], (char * const *)args ); | 613 | ::execvp( args[0], (char * const *)args ); |
620 | _exit( -1 ); | 614 | _exit( -1 ); |
621 | } | 615 | } |
622 | } | 616 | } |
623 | StartingAppList::add( list[0] ); | 617 | StartingAppList::add( list[0] ); |
624 | #endif //QT_NO_QWS_MULTIPROCESS | 618 | #endif //QT_NO_QWS_MULTIPROCESS |
625 | } | 619 | } |
626 | 620 | ||
627 | 621 | ||
628 | /*! | 622 | /*! |
629 | Executes the application identfied by \a c, passing \a | 623 | Executes the application identfied by \a c, passing \a |
630 | document if it isn't null. | 624 | document if it isn't null. |
631 | 625 | ||
632 | Note that a better approach might be to send a QCop message to the | 626 | Note that a better approach might be to send a QCop message to the |
633 | application's QPE/Application/\e{appname} channel. | 627 | application's QPE/Application/\e{appname} channel. |
634 | */ | 628 | */ |
635 | void Global::execute( const QString &c, const QString& document ) | 629 | void Global::execute( const QString &c, const QString& document ) |
636 | { | 630 | { |
637 | if ( qApp->type() != QApplication::GuiServer ) { | 631 | if ( qApp->type() != QApplication::GuiServer ) { |
638 | // ask the server to do the work | 632 | // ask the server to do the work |
639 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 633 | #if !defined(QT_NO_COP) |
640 | if ( document.isNull() ) { | 634 | if ( document.isNull() ) { |
641 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 635 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
642 | e << c; | 636 | e << c; |
643 | } else { | 637 | } else { |
644 | QCopEnvelope e( "QPE/System", "execute(QString,QString)" ); | 638 | QCopEnvelope e( "QPE/System", "execute(QString,QString)" ); |
645 | e << c << document; | 639 | e << c << document; |
646 | } | 640 | } |
647 | #endif | 641 | #endif |
648 | return; | 642 | return; |
649 | } | 643 | } |
650 | 644 | ||
651 | // Attempt to execute the app using a builtin class for the app first | 645 | // Attempt to execute the app using a builtin class for the app first |
652 | // else try and find it in the bin directory | 646 | // else try and find it in the bin directory |
653 | if (builtin) { | 647 | if (builtin) { |
654 | for (int i = 0; builtin[i].file; i++) { | 648 | for (int i = 0; builtin[i].file; i++) { |
655 | if ( builtin[i].file == c ) { | 649 | if ( builtin[i].file == c ) { |
656 | if ( running[i] ) { | 650 | if ( running[i] ) { |
657 | if ( !document.isNull() && builtin[i].documentary ) | 651 | if ( !document.isNull() && builtin[i].documentary ) |
658 | setDocument(running[i], document); | 652 | setDocument(running[i], document); |
659 | running[i]->raise(); | 653 | running[i]->raise(); |
660 | running[i]->show(); | 654 | running[i]->show(); |
661 | running[i]->setActiveWindow(); | 655 | running[i]->setActiveWindow(); |
662 | } else { | 656 | } else { |
663 | running[i] = builtin[i].func( builtin[i].maximized ); | 657 | running[i] = builtin[i].func( builtin[i].maximized ); |
664 | } | 658 | } |
665 | #ifndef QT_NO_COP | 659 | #ifndef QT_NO_COP |
666 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 660 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
667 | e << c; // that was quick ;-) | 661 | e << c; // that was quick ;-) |
668 | #endif | 662 | #endif |
669 | return; | 663 | return; |
670 | } | 664 | } |
671 | } | 665 | } |
672 | } | 666 | } |
673 | 667 | ||
674 | //Global::invoke(c, document); | 668 | //Global::invoke(c, document); |
675 | 669 | ||
676 | // Convert the command line in to a list of arguments | 670 | // Convert the command line in to a list of arguments |
677 | QStringList list = QStringList::split(QRegExp(" *"),c); | 671 | QStringList list = QStringList::split(QRegExp(" *"),c); |
678 | 672 | ||
679 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 673 | #if !defined(QT_NO_COP) |
680 | QString ap=list[0]; | 674 | QString ap=list[0]; |
681 | 675 | ||
682 | qDebug("executing %s", ap.latin1() ); | 676 | qDebug("executing %s", ap.latin1() ); |
683 | 677 | ||
684 | /* if need be, sending a qcop message will result in an invoke, see | 678 | /* if need be, sending a qcop message will result in an invoke, see |
685 | preceeding function */ | 679 | preceeding function */ |
686 | invoke( ap ); | 680 | invoke( ap ); |
687 | //{ QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } | 681 | //{ QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } |
688 | if ( !document.isEmpty() ) { | 682 | if ( !document.isEmpty() ) { |
689 | QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "setDocument(QString)" ); | 683 | QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "setDocument(QString)" ); |
690 | env << document; | 684 | env << document; |
691 | } | 685 | } |
692 | #endif | 686 | #endif |
693 | } | 687 | } |
694 | 688 | ||
695 | /*! | 689 | /*! |
696 | Returns the string \a s with the characters '\', '"', and '$' quoted | 690 | Returns the string \a s with the characters '\', '"', and '$' quoted |
697 | by a preceeding '\'. | 691 | by a preceeding '\'. |
698 | 692 | ||
699 | \sa stringQuote() | 693 | \sa stringQuote() |
700 | */ | 694 | */ |
701 | QString Global::shellQuote(const QString& s) | 695 | QString Global::shellQuote(const QString& s) |
702 | { | 696 | { |
703 | QString r="\""; | 697 | QString r="\""; |
704 | for (int i=0; i<(int)s.length(); i++) { | 698 | for (int i=0; i<(int)s.length(); i++) { |
705 | char c = s[i].latin1(); | 699 | char c = s[i].latin1(); |
706 | switch (c) { | 700 | switch (c) { |
707 | case '\\': case '"': case '$': | 701 | case '\\': case '"': case '$': |
708 | r+="\\"; | 702 | r+="\\"; |
709 | } | 703 | } |
710 | r += s[i]; | 704 | r += s[i]; |
711 | } | 705 | } |
712 | r += "\""; | 706 | r += "\""; |
713 | return r; | 707 | return r; |
714 | } | 708 | } |
715 | 709 | ||
716 | /*! | 710 | /*! |
717 | Returns the string \a s with the characters '\' and '"' quoted by a | 711 | Returns the string \a s with the characters '\' and '"' quoted by a |
718 | preceeding '\'. | 712 | preceeding '\'. |
719 | 713 | ||
720 | \sa shellQuote() | 714 | \sa shellQuote() |
721 | */ | 715 | */ |
722 | QString Global::stringQuote(const QString& s) | 716 | QString Global::stringQuote(const QString& s) |
723 | { | 717 | { |
724 | QString r="\""; | 718 | QString r="\""; |
725 | for (int i=0; i<(int)s.length(); i++) { | 719 | for (int i=0; i<(int)s.length(); i++) { |
726 | char c = s[i].latin1(); | 720 | char c = s[i].latin1(); |
727 | switch (c) { | 721 | switch (c) { |
728 | case '\\': case '"': | 722 | case '\\': case '"': |
729 | r+="\\"; | 723 | r+="\\"; |
730 | } | 724 | } |
731 | r += s[i]; | 725 | r += s[i]; |
732 | } | 726 | } |
733 | r += "\""; | 727 | r += "\""; |
734 | return r; | 728 | return r; |
735 | } | 729 | } |
736 | 730 | ||
737 | /*! | 731 | /*! |
738 | Finds all documents on the system's document directories which | 732 | Finds all documents on the system's document directories which |
739 | match the filter \a mimefilter, and appends the resulting DocLnk | 733 | match the filter \a mimefilter, and appends the resulting DocLnk |
740 | objects to \a folder. | 734 | objects to \a folder. |
741 | */ | 735 | */ |
742 | void Global::findDocuments(DocLnkSet* folder, const QString &mimefilter) | 736 | void Global::findDocuments(DocLnkSet* folder, const QString &mimefilter) |
743 | { | 737 | { |
744 | QString homedocs = QString(getenv("HOME")) + "/Documents"; | 738 | QString homedocs = QString(getenv("HOME")) + "/Documents"; |
745 | DocLnkSet d(homedocs,mimefilter); | 739 | DocLnkSet d(homedocs,mimefilter); |
746 | folder->appendFrom(d); | 740 | folder->appendFrom(d); |
747 | /** let's do intellegint way of searching these files | 741 | /** let's do intellegint way of searching these files |
748 | * a) the user don't want to check mediums global | 742 | * a) the user don't want to check mediums global |
749 | * b) the user wants to check but use the global options for it | 743 | * b) the user wants to check but use the global options for it |
750 | * c) the user wants to check it but not this medium | 744 | * c) the user wants to check it but not this medium |
751 | * d) the user wants to check and this medium as well | 745 | * d) the user wants to check and this medium as well |
752 | * | 746 | * |
753 | * In all cases we need to apply a different mimefilter to | 747 | * In all cases we need to apply a different mimefilter to |
754 | * the medium. | 748 | * the medium. |
755 | * a) mimefilter.isEmpty() we need to apply the responding filter | 749 | * a) mimefilter.isEmpty() we need to apply the responding filter |
756 | * either the global or the one on the medium | 750 | * either the global or the one on the medium |
757 | * | 751 | * |
758 | * b) mimefilter is set to an application we need to find out if the | 752 | * b) mimefilter is set to an application we need to find out if the |
759 | * mimetypes are included in the mime mask of the medium | 753 | * mimetypes are included in the mime mask of the medium |
760 | */ | 754 | */ |
761 | StorageInfo storage; | 755 | StorageInfo storage; |
762 | const QList<FileSystem> &fs = storage.fileSystems(); | 756 | const QList<FileSystem> &fs = storage.fileSystems(); |
763 | QListIterator<FileSystem> it ( fs ); | 757 | QListIterator<FileSystem> it ( fs ); |
764 | for ( ; it.current(); ++it ) { | 758 | for ( ; it.current(); ++it ) { |
765 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it | 759 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it |
766 | // this is a candidate look at the cf and see if we should search on it | 760 | // this is a candidate look at the cf and see if we should search on it |
767 | QString path = (*it)->path(); | 761 | QString path = (*it)->path(); |
768 | if( !checkStorage((*it)->path() + "/.opiestorage.cf" ) ) | 762 | if( !checkStorage((*it)->path() + "/.opiestorage.cf" ) ) |
769 | continue; | 763 | continue; |
770 | DocLnkSet ide( path, mimefilter ); | 764 | DocLnkSet ide( path, mimefilter ); |
771 | folder->appendFrom(ide); | 765 | folder->appendFrom(ide); |
772 | } else if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { | 766 | } else if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { |
773 | QString path = (*it)->path() + "/Documents"; | 767 | QString path = (*it)->path() + "/Documents"; |
774 | DocLnkSet ide( path, mimefilter ); | 768 | DocLnkSet ide( path, mimefilter ); |
775 | folder->appendFrom(ide); | 769 | folder->appendFrom(ide); |
diff --git a/library/ir.cpp b/library/ir.cpp index a7cf7b1..b5b726d 100644 --- a/library/ir.cpp +++ b/library/ir.cpp | |||
@@ -1,120 +1,118 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #include "ir.h" | 21 | #include "ir.h" |
22 | 22 | ||
23 | #include <qstring.h> | 23 | #include <qstring.h> |
24 | #ifdef QWS | ||
25 | #include "qcopenvelope_qws.h" | 24 | #include "qcopenvelope_qws.h" |
26 | #include <qcopchannel_qws.h> | 25 | #include <qcopchannel_qws.h> |
27 | #endif | ||
28 | #include "applnk.h" | 26 | #include "applnk.h" |
29 | 27 | ||
30 | /*! | 28 | /*! |
31 | \class Ir ir.h | 29 | \class Ir ir.h |
32 | \brief The Ir class implements basic support for sending objects over an | 30 | \brief The Ir class implements basic support for sending objects over an |
33 | infrared communication link. | 31 | infrared communication link. |
34 | 32 | ||
35 | Both \link doclnk.html DocLnk\endlink objects and files can be | 33 | Both \link doclnk.html DocLnk\endlink objects and files can be |
36 | sent to another device via the infrared link using the send() | 34 | sent to another device via the infrared link using the send() |
37 | function. When the send has completed the done() signal is | 35 | function. When the send has completed the done() signal is |
38 | emitted. | 36 | emitted. |
39 | 37 | ||
40 | The supported() function returns whether the device supports | 38 | The supported() function returns whether the device supports |
41 | infrared communication or not. | 39 | infrared communication or not. |
42 | 40 | ||
43 | \ingroup qtopiaemb | 41 | \ingroup qtopiaemb |
44 | */ | 42 | */ |
45 | 43 | ||
46 | /*! | 44 | /*! |
47 | Constructs an Ir object. The \a parent and \a name classes are the | 45 | Constructs an Ir object. The \a parent and \a name classes are the |
48 | standard QObject parameters. | 46 | standard QObject parameters. |
49 | */ | 47 | */ |
50 | Ir::Ir( QObject *parent, const char *name ) | 48 | Ir::Ir( QObject *parent, const char *name ) |
51 | : QObject( parent, name ) | 49 | : QObject( parent, name ) |
52 | { | 50 | { |
53 | #ifndef QT_NO_COP | 51 | #ifndef QT_NO_COP |
54 | ch = new QCopChannel( "QPE/Obex" ); | 52 | ch = new QCopChannel( "QPE/Obex" ); |
55 | connect( ch, SIGNAL(received(const QCString &, const QByteArray &)), | 53 | connect( ch, SIGNAL(received(const QCString &, const QByteArray &)), |
56 | this, SLOT(obexMessage( const QCString &, const QByteArray &)) ); | 54 | this, SLOT(obexMessage( const QCString &, const QByteArray &)) ); |
57 | #endif | 55 | #endif |
58 | } | 56 | } |
59 | 57 | ||
60 | /*! | 58 | /*! |
61 | Returns TRUE if the system supports infrared communication; | 59 | Returns TRUE if the system supports infrared communication; |
62 | otherwise returns FALSE. | 60 | otherwise returns FALSE. |
63 | */ | 61 | */ |
64 | bool Ir::supported() | 62 | bool Ir::supported() |
65 | { | 63 | { |
66 | #ifndef QT_NO_COP | 64 | #ifndef QT_NO_COP |
67 | return QCopChannel::isRegistered( "QPE/Obex" ); | 65 | return QCopChannel::isRegistered( "QPE/Obex" ); |
68 | #endif | 66 | #endif |
69 | } | 67 | } |
70 | 68 | ||
71 | /*! | 69 | /*! |
72 | Sends the object in file \a fn over the infrared link. The \a | 70 | Sends the object in file \a fn over the infrared link. The \a |
73 | description is used in the text shown to the user while sending | 71 | description is used in the text shown to the user while sending |
74 | is in progress. The optional \a mimetype parameter specifies the | 72 | is in progress. The optional \a mimetype parameter specifies the |
75 | mimetype of the object. If this parameter is not set, it is | 73 | mimetype of the object. If this parameter is not set, it is |
76 | determined by the the filename's suffix. | 74 | determined by the the filename's suffix. |
77 | 75 | ||
78 | \sa done() | 76 | \sa done() |
79 | */ | 77 | */ |
80 | void Ir::send( const QString &fn, const QString &description, const QString &mimetype) | 78 | void Ir::send( const QString &fn, const QString &description, const QString &mimetype) |
81 | { | 79 | { |
82 | if ( !filename.isEmpty() ) return; | 80 | if ( !filename.isEmpty() ) return; |
83 | filename = fn; | 81 | filename = fn; |
84 | #ifndef QT_NO_COP | 82 | #ifndef QT_NO_COP |
85 | QCopEnvelope e("QPE/Obex", "send(QString,QString,QString)"); | 83 | QCopEnvelope e("QPE/Obex", "send(QString,QString,QString)"); |
86 | e << description << filename << mimetype; | 84 | e << description << filename << mimetype; |
87 | #endif | 85 | #endif |
88 | } | 86 | } |
89 | 87 | ||
90 | /*! | 88 | /*! |
91 | \overload | 89 | \overload |
92 | 90 | ||
93 | Uses the DocLnk::file() and DocLnk::type() of \a doc. | 91 | Uses the DocLnk::file() and DocLnk::type() of \a doc. |
94 | 92 | ||
95 | \sa done() | 93 | \sa done() |
96 | */ | 94 | */ |
97 | void Ir::send( const DocLnk &doc, const QString &description ) | 95 | void Ir::send( const DocLnk &doc, const QString &description ) |
98 | { | 96 | { |
99 | send( doc.file(), description, doc.type() ); | 97 | send( doc.file(), description, doc.type() ); |
100 | } | 98 | } |
101 | 99 | ||
102 | /*! | 100 | /*! |
103 | \fn Ir::done( Ir *ir ); | 101 | \fn Ir::done( Ir *ir ); |
104 | 102 | ||
105 | This signal is emitted by \a ir, when the send comand has been processed. | 103 | This signal is emitted by \a ir, when the send comand has been processed. |
106 | */ | 104 | */ |
107 | 105 | ||
108 | /*!\internal | 106 | /*!\internal |
109 | */ | 107 | */ |
110 | void Ir::obexMessage( const QCString &msg, const QByteArray &data) | 108 | void Ir::obexMessage( const QCString &msg, const QByteArray &data) |
111 | { | 109 | { |
112 | if ( msg == "done(QString)" ) { | 110 | if ( msg == "done(QString)" ) { |
113 | QString fn; | 111 | QString fn; |
114 | QDataStream stream( data, IO_ReadOnly ); | 112 | QDataStream stream( data, IO_ReadOnly ); |
115 | stream >> fn; | 113 | stream >> fn; |
116 | if ( fn == filename ) | 114 | if ( fn == filename ) |
117 | emit done( this ); | 115 | emit done( this ); |
118 | } | 116 | } |
119 | } | 117 | } |
120 | 118 | ||
diff --git a/library/lnkproperties.cpp b/library/lnkproperties.cpp index 0b50bae..50cf5af 100644 --- a/library/lnkproperties.cpp +++ b/library/lnkproperties.cpp | |||
@@ -1,131 +1,129 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT | 21 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT |
22 | // have this class. | 22 | // have this class. |
23 | #define QTOPIA_INTERNAL_FSLP | 23 | #define QTOPIA_INTERNAL_FSLP |
24 | #include "lnkproperties.h" | 24 | #include "lnkproperties.h" |
25 | #include "lnkproperties.h" | 25 | #include "lnkproperties.h" |
26 | #include "lnkpropertiesbase_p.h" | 26 | #include "lnkpropertiesbase_p.h" |
27 | #include "ir.h" | 27 | #include "ir.h" |
28 | 28 | ||
29 | #include <qpe/qpeapplication.h> | 29 | #include <qpe/qpeapplication.h> |
30 | #include <qpe/applnk.h> | 30 | #include <qpe/applnk.h> |
31 | #include <qpe/global.h> | 31 | #include <qpe/global.h> |
32 | #include <qpe/categorywidget.h> | 32 | #include <qpe/categorywidget.h> |
33 | #ifdef QWS | ||
34 | #include <qpe/qcopenvelope_qws.h> | 33 | #include <qpe/qcopenvelope_qws.h> |
35 | #endif | ||
36 | #include <qpe/filemanager.h> | 34 | #include <qpe/filemanager.h> |
37 | #include <qpe/config.h> | 35 | #include <qpe/config.h> |
38 | #include <qpe/storage.h> | 36 | #include <qpe/storage.h> |
39 | #include <qpe/qpemessagebox.h> | 37 | #include <qpe/qpemessagebox.h> |
40 | #include <qpe/mimetype.h> | 38 | #include <qpe/mimetype.h> |
41 | 39 | ||
42 | #include <qlineedit.h> | 40 | #include <qlineedit.h> |
43 | #include <qtoolbutton.h> | 41 | #include <qtoolbutton.h> |
44 | #include <qpushbutton.h> | 42 | #include <qpushbutton.h> |
45 | #include <qgroupbox.h> | 43 | #include <qgroupbox.h> |
46 | #include <qcheckbox.h> | 44 | #include <qcheckbox.h> |
47 | #include <qlabel.h> | 45 | #include <qlabel.h> |
48 | #include <qlayout.h> | 46 | #include <qlayout.h> |
49 | #include <qfile.h> | 47 | #include <qfile.h> |
50 | #include <qfileinfo.h> | 48 | #include <qfileinfo.h> |
51 | #include <qmessagebox.h> | 49 | #include <qmessagebox.h> |
52 | #include <qsize.h> | 50 | #include <qsize.h> |
53 | #include <qcombobox.h> | 51 | #include <qcombobox.h> |
54 | #include <qregexp.h> | 52 | #include <qregexp.h> |
55 | #include <qbuttongroup.h> | 53 | #include <qbuttongroup.h> |
56 | 54 | ||
57 | #include <stdlib.h> | 55 | #include <stdlib.h> |
58 | 56 | ||
59 | LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) | 57 | LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) |
60 | : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 ) | 58 | : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 ) |
61 | { | 59 | { |
62 | setCaption( tr("Properties") ); | 60 | setCaption( tr("Properties") ); |
63 | 61 | ||
64 | QVBoxLayout *vbox = new QVBoxLayout( this ); | 62 | QVBoxLayout *vbox = new QVBoxLayout( this ); |
65 | d = new LnkPropertiesBase( this ); | 63 | d = new LnkPropertiesBase( this ); |
66 | vbox->add( d ); | 64 | vbox->add( d ); |
67 | 65 | ||
68 | d->docname->setText(l->name()); | 66 | d->docname->setText(l->name()); |
69 | QString inf; | 67 | QString inf; |
70 | if ( l->type().isEmpty() ) { | 68 | if ( l->type().isEmpty() ) { |
71 | d->type->hide(); | 69 | d->type->hide(); |
72 | d->typeLabel->hide(); | 70 | d->typeLabel->hide(); |
73 | } else { | 71 | } else { |
74 | d->type->setText( l->type() ); | 72 | d->type->setText( l->type() ); |
75 | } | 73 | } |
76 | 74 | ||
77 | if ( l->comment().isEmpty() ) { | 75 | if ( l->comment().isEmpty() ) { |
78 | d->comment->hide(); | 76 | d->comment->hide(); |
79 | d->commentLabel->hide(); | 77 | d->commentLabel->hide(); |
80 | } else { | 78 | } else { |
81 | d->comment->setText( l->comment() ); | 79 | d->comment->setText( l->comment() ); |
82 | } | 80 | } |
83 | 81 | ||
84 | connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk())); | 82 | connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk())); |
85 | if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed) | 83 | if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed) |
86 | connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk())); | 84 | connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk())); |
87 | connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk())); | 85 | connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk())); |
88 | 86 | ||
89 | d->docname->setReadOnly( FALSE ); | 87 | d->docname->setReadOnly( FALSE ); |
90 | d->preload->hide(); | 88 | d->preload->hide(); |
91 | d->rotate->hide(); | 89 | d->rotate->hide(); |
92 | d->rotateButtons->hide(); | 90 | d->rotateButtons->hide(); |
93 | d->labelspacer->hide(); | 91 | d->labelspacer->hide(); |
94 | 92 | ||
95 | // ### THIS MUST GO, FIX WIERD BUG in QLAYOUT | 93 | // ### THIS MUST GO, FIX WIERD BUG in QLAYOUT |
96 | d->categoryEdit->kludge(); | 94 | d->categoryEdit->kludge(); |
97 | 95 | ||
98 | d->categoryEdit->setCategories( lnk->categories(), | 96 | d->categoryEdit->setCategories( lnk->categories(), |
99 | "Document View", | 97 | "Document View", |
100 | tr("Document View") ); | 98 | tr("Document View") ); |
101 | setupLocations(); | 99 | setupLocations(); |
102 | } else { | 100 | } else { |
103 | d->unlink->hide(); | 101 | d->unlink->hide(); |
104 | d->duplicate->hide(); | 102 | d->duplicate->hide(); |
105 | d->beam->hide(); | 103 | d->beam->hide(); |
106 | d->hline->hide(); | 104 | d->hline->hide(); |
107 | d->locationLabel->hide(); | 105 | d->locationLabel->hide(); |
108 | d->locationCombo->hide(); | 106 | d->locationCombo->hide(); |
109 | 107 | ||
110 | // Can't edit categories, since the app .desktop files are global, | 108 | // Can't edit categories, since the app .desktop files are global, |
111 | // possibly read-only. | 109 | // possibly read-only. |
112 | d->categoryEdit->hide(); | 110 | d->categoryEdit->hide(); |
113 | 111 | ||
114 | d->docname->setReadOnly( TRUE ); | 112 | d->docname->setReadOnly( TRUE ); |
115 | 113 | ||
116 | if ( l->property("CanFastload") == "0" ) | 114 | if ( l->property("CanFastload") == "0" ) |
117 | d->preload->hide(); | 115 | d->preload->hide(); |
118 | if ( !l->property("Rotation"). isEmpty ()) { | 116 | if ( !l->property("Rotation"). isEmpty ()) { |
119 | d->rotate->setChecked ( true ); | 117 | d->rotate->setChecked ( true ); |
120 | d->rotateButtons->setButton((l->rotation().toInt()%360)/90); | 118 | d->rotateButtons->setButton((l->rotation().toInt()%360)/90); |
121 | } | 119 | } |
122 | else { | 120 | else { |
123 | d->rotateButtons->setEnabled(false); | 121 | d->rotateButtons->setEnabled(false); |
124 | } | 122 | } |
125 | 123 | ||
126 | Config cfg("Launcher"); | 124 | Config cfg("Launcher"); |
127 | cfg.setGroup("Preload"); | 125 | cfg.setGroup("Preload"); |
128 | QStringList apps = cfg.readListEntry("Apps",','); | 126 | QStringList apps = cfg.readListEntry("Apps",','); |
129 | d->preload->setChecked( apps.contains(l->exec()) ); | 127 | d->preload->setChecked( apps.contains(l->exec()) ); |
130 | if ( Global::isBuiltinCommand(lnk->exec()) ) | 128 | if ( Global::isBuiltinCommand(lnk->exec()) ) |
131 | d->preload->hide(); // builtins are always fast | 129 | d->preload->hide(); // builtins are always fast |
diff --git a/library/network.cpp b/library/network.cpp index 185b147..3568809 100644 --- a/library/network.cpp +++ b/library/network.cpp | |||
@@ -1,126 +1,124 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 "qpe/network.h" | 22 | #include "qpe/network.h" |
23 | #include "qpe/networkinterface.h" | 23 | #include "qpe/networkinterface.h" |
24 | #include "qpe/global.h" | 24 | #include "qpe/global.h" |
25 | #include "qpe/config.h" | 25 | #include "qpe/config.h" |
26 | #include "qpe/resource.h" | 26 | #include "qpe/resource.h" |
27 | #include "qpe/qpeapplication.h" | 27 | #include "qpe/qpeapplication.h" |
28 | #ifdef QWS | ||
29 | #include <qpe/qcopenvelope_qws.h> | 28 | #include <qpe/qcopenvelope_qws.h> |
30 | #endif | ||
31 | #include <qpe/qlibrary.h> | 29 | #include <qpe/qlibrary.h> |
32 | 30 | ||
33 | #include <qlistbox.h> | 31 | #include <qlistbox.h> |
34 | #include <qdir.h> | 32 | #include <qdir.h> |
35 | #include <qlayout.h> | 33 | #include <qlayout.h> |
36 | #include <qdict.h> | 34 | #include <qdict.h> |
37 | #include <qtranslator.h> | 35 | #include <qtranslator.h> |
38 | 36 | ||
39 | #include <stdlib.h> | 37 | #include <stdlib.h> |
40 | 38 | ||
41 | #ifndef QT_NO_COP | 39 | #ifndef QT_NO_COP |
42 | class NetworkEmitter : public QCopChannel { | 40 | class NetworkEmitter : public QCopChannel { |
43 | Q_OBJECT | 41 | Q_OBJECT |
44 | public: | 42 | public: |
45 | NetworkEmitter() : QCopChannel("QPE/Network",qApp) | 43 | NetworkEmitter() : QCopChannel("QPE/Network",qApp) |
46 | { | 44 | { |
47 | } | 45 | } |
48 | 46 | ||
49 | void receive(const QCString &msg, const QByteArray&) | 47 | void receive(const QCString &msg, const QByteArray&) |
50 | { | 48 | { |
51 | if ( msg == "choicesChanged()" ) | 49 | if ( msg == "choicesChanged()" ) |
52 | emit changed(); | 50 | emit changed(); |
53 | } | 51 | } |
54 | 52 | ||
55 | signals: | 53 | signals: |
56 | void changed(); | 54 | void changed(); |
57 | }; | 55 | }; |
58 | 56 | ||
59 | /*! | 57 | /*! |
60 | \internal | 58 | \internal |
61 | 59 | ||
62 | Requests that the service \a choice be started. The \a password is | 60 | Requests that the service \a choice be started. The \a password is |
63 | the password to use if required. | 61 | the password to use if required. |
64 | */ | 62 | */ |
65 | void Network::start(const QString& choice, const QString& password) | 63 | void Network::start(const QString& choice, const QString& password) |
66 | { | 64 | { |
67 | QCopEnvelope e("QPE/Network", "start(QString,QString)"); | 65 | QCopEnvelope e("QPE/Network", "start(QString,QString)"); |
68 | e << choice << password; | 66 | e << choice << password; |
69 | } | 67 | } |
70 | 68 | ||
71 | /*! | 69 | /*! |
72 | \class Network network.h | 70 | \class Network network.h |
73 | \brief The Network class provides network access functionality. | 71 | \brief The Network class provides network access functionality. |
74 | \internal | 72 | \internal |
75 | */ | 73 | */ |
76 | 74 | ||
77 | // copy the proxy settings of the active config over to the Proxies.conf file | 75 | // copy the proxy settings of the active config over to the Proxies.conf file |
78 | /*! | 76 | /*! |
79 | \internal | 77 | \internal |
80 | */ | 78 | */ |
81 | void Network::writeProxySettings( Config &cfg ) | 79 | void Network::writeProxySettings( Config &cfg ) |
82 | { | 80 | { |
83 | Config proxy( Network::settingsDir() + "/Proxies.conf", Config::File ); | 81 | Config proxy( Network::settingsDir() + "/Proxies.conf", Config::File ); |
84 | proxy.setGroup("Properties"); | 82 | proxy.setGroup("Properties"); |
85 | cfg.setGroup("Proxy"); | 83 | cfg.setGroup("Proxy"); |
86 | proxy.writeEntry("type", cfg.readEntry("type") ); | 84 | proxy.writeEntry("type", cfg.readEntry("type") ); |
87 | proxy.writeEntry("autoconfig", cfg.readEntry("autoconfig") ); | 85 | proxy.writeEntry("autoconfig", cfg.readEntry("autoconfig") ); |
88 | proxy.writeEntry("httphost", cfg.readEntry("httphost") ); | 86 | proxy.writeEntry("httphost", cfg.readEntry("httphost") ); |
89 | proxy.writeEntry("httpport", cfg.readEntry("httpport") ); | 87 | proxy.writeEntry("httpport", cfg.readEntry("httpport") ); |
90 | proxy.writeEntry("ftphost", cfg.readEntry("ftphost") ); | 88 | proxy.writeEntry("ftphost", cfg.readEntry("ftphost") ); |
91 | proxy.writeEntry("ftpport", cfg.readEntry("ftpport") ); | 89 | proxy.writeEntry("ftpport", cfg.readEntry("ftpport") ); |
92 | proxy.writeEntry("noproxies", cfg.readEntry("noproxies") ); | 90 | proxy.writeEntry("noproxies", cfg.readEntry("noproxies") ); |
93 | cfg.setGroup("Properties"); | 91 | cfg.setGroup("Properties"); |
94 | } | 92 | } |
95 | 93 | ||
96 | 94 | ||
97 | 95 | ||
98 | /*! | 96 | /*! |
99 | \internal | 97 | \internal |
100 | 98 | ||
101 | Stops the current network service. | 99 | Stops the current network service. |
102 | */ | 100 | */ |
103 | void Network::stop() | 101 | void Network::stop() |
104 | { | 102 | { |
105 | QCopEnvelope e("QPE/Network", "stop()"); | 103 | QCopEnvelope e("QPE/Network", "stop()"); |
106 | } | 104 | } |
107 | 105 | ||
108 | static NetworkEmitter *emitter = 0; | 106 | static NetworkEmitter *emitter = 0; |
109 | 107 | ||
110 | /*! | 108 | /*! |
111 | \internal | 109 | \internal |
112 | */ | 110 | */ |
113 | void Network::connectChoiceChange(QObject* receiver, const char* slot) | 111 | void Network::connectChoiceChange(QObject* receiver, const char* slot) |
114 | { | 112 | { |
115 | if ( !emitter ) | 113 | if ( !emitter ) |
116 | emitter = new NetworkEmitter; | 114 | emitter = new NetworkEmitter; |
117 | QObject::connect(emitter,SIGNAL(changed()),receiver,slot); | 115 | QObject::connect(emitter,SIGNAL(changed()),receiver,slot); |
118 | } | 116 | } |
119 | 117 | ||
120 | #endif// QT_NO_COP | 118 | #endif// QT_NO_COP |
121 | /*! | 119 | /*! |
122 | \internal | 120 | \internal |
123 | */ | 121 | */ |
124 | QString Network::settingsDir() | 122 | QString Network::settingsDir() |
125 | { | 123 | { |
126 | return Global::applicationFileName("Network", "modules"); | 124 | return Global::applicationFileName("Network", "modules"); |
diff --git a/library/networkinterface.cpp b/library/networkinterface.cpp index 2b5c77e..0ba773a 100644 --- a/library/networkinterface.cpp +++ b/library/networkinterface.cpp | |||
@@ -1,106 +1,104 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #include "networkinterface.h" | 21 | #include "networkinterface.h" |
22 | #include "network.h" | 22 | #include "network.h" |
23 | #include "config.h" | 23 | #include "config.h" |
24 | #include <stdio.h> | 24 | #include <stdio.h> |
25 | 25 | ||
26 | QString NetworkInterface::device( Config& cfg ) const | 26 | QString NetworkInterface::device( Config& cfg ) const |
27 | { | 27 | { |
28 | return cfg.readEntry("Device"); | 28 | return cfg.readEntry("Device"); |
29 | } | 29 | } |
30 | 30 | ||
31 | bool NetworkInterface::isActive( Config& cfg ) const | 31 | bool NetworkInterface::isActive( Config& cfg ) const |
32 | { | 32 | { |
33 | QString dev = device(cfg); | 33 | QString dev = device(cfg); |
34 | if ( dev.isEmpty() ) | 34 | if ( dev.isEmpty() ) |
35 | return FALSE; | 35 | return FALSE; |
36 | QString dev0 = dev+'0'; | 36 | QString dev0 = dev+'0'; |
37 | 37 | ||
38 | FILE* f; | 38 | FILE* f; |
39 | f = fopen("/proc/net/dev", "r"); | 39 | f = fopen("/proc/net/dev", "r"); |
40 | if ( f ) { | 40 | if ( f ) { |
41 | char line[1024]; | 41 | char line[1024]; |
42 | char devname[80]; | 42 | char devname[80]; |
43 | while ( fgets( line, 1024, f ) ) { | 43 | while ( fgets( line, 1024, f ) ) { |
44 | if ( sscanf(line," %[^:]:", devname)==1 ) | 44 | if ( sscanf(line," %[^:]:", devname)==1 ) |
45 | { | 45 | { |
46 | if ( devname == dev || devname == dev0 ) { | 46 | if ( devname == dev || devname == dev0 ) { |
47 | fclose(f); | 47 | fclose(f); |
48 | #ifdef QWS | ||
49 | Network::writeProxySettings( cfg ); | 48 | Network::writeProxySettings( cfg ); |
50 | #endif | ||
51 | return TRUE; | 49 | return TRUE; |
52 | } | 50 | } |
53 | } | 51 | } |
54 | } | 52 | } |
55 | fclose(f); | 53 | fclose(f); |
56 | } | 54 | } |
57 | return FALSE; | 55 | return FALSE; |
58 | } | 56 | } |
59 | 57 | ||
60 | QString NetworkInterface::cardType( Config& cfg ) const | 58 | QString NetworkInterface::cardType( Config& cfg ) const |
61 | { | 59 | { |
62 | return cfg.readEntry("CardType"); | 60 | return cfg.readEntry("CardType"); |
63 | } | 61 | } |
64 | 62 | ||
65 | bool NetworkInterface::isAvailable( Config& cfg ) const | 63 | bool NetworkInterface::isAvailable( Config& cfg ) const |
66 | { | 64 | { |
67 | QString ct = cardType(cfg); | 65 | QString ct = cardType(cfg); |
68 | if ( ct.isEmpty() ) | 66 | if ( ct.isEmpty() ) |
69 | return FALSE; | 67 | return FALSE; |
70 | 68 | ||
71 | FILE* f = fopen("/var/run/stab", "r"); | 69 | FILE* f = fopen("/var/run/stab", "r"); |
72 | if (!f) f = fopen("/var/state/pcmcia/stab", "r"); | 70 | if (!f) f = fopen("/var/state/pcmcia/stab", "r"); |
73 | if (!f) f = fopen("/var/lib/pcmcia/stab", "r"); | 71 | if (!f) f = fopen("/var/lib/pcmcia/stab", "r"); |
74 | 72 | ||
75 | if ( f ) { | 73 | if ( f ) { |
76 | char line[1024]; | 74 | char line[1024]; |
77 | char devtype[80]; | 75 | char devtype[80]; |
78 | while ( fgets( line, 1024, f ) ) { | 76 | while ( fgets( line, 1024, f ) ) { |
79 | if ( sscanf(line,"%*d %s %*s", devtype )==1 ) | 77 | if ( sscanf(line,"%*d %s %*s", devtype )==1 ) |
80 | { | 78 | { |
81 | if ( ct == devtype ) { | 79 | if ( ct == devtype ) { |
82 | fclose(f); | 80 | fclose(f); |
83 | return TRUE; | 81 | return TRUE; |
84 | } | 82 | } |
85 | } | 83 | } |
86 | } | 84 | } |
87 | fclose(f); | 85 | fclose(f); |
88 | } | 86 | } |
89 | 87 | ||
90 | return FALSE; | 88 | return FALSE; |
91 | } | 89 | } |
92 | 90 | ||
93 | bool NetworkInterface::start( Config& cfg, const QString& /*password*/ ) | 91 | bool NetworkInterface::start( Config& cfg, const QString& /*password*/ ) |
94 | { | 92 | { |
95 | return start(cfg); | 93 | return start(cfg); |
96 | } | 94 | } |
97 | 95 | ||
98 | bool NetworkInterface::needPassword( Config& ) const | 96 | bool NetworkInterface::needPassword( Config& ) const |
99 | { | 97 | { |
100 | return FALSE; | 98 | return FALSE; |
101 | } | 99 | } |
102 | 100 | ||
103 | QWidget* NetworkInterface::addStateWidget( QWidget*, Config& ) const | 101 | QWidget* NetworkInterface::addStateWidget( QWidget*, Config& ) const |
104 | { | 102 | { |
105 | return 0; | 103 | return 0; |
106 | } | 104 | } |
diff --git a/library/password.cpp b/library/password.cpp index 41b3358..4b22b65 100644 --- a/library/password.cpp +++ b/library/password.cpp | |||
@@ -1,128 +1,126 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 "password.h" | 20 | #include "password.h" |
21 | #include "config.h" | 21 | #include "config.h" |
22 | #include "global.h" | 22 | #include "global.h" |
23 | #include "backend/contact.h" | 23 | #include "backend/contact.h" |
24 | #include <qlabel.h> | 24 | #include <qlabel.h> |
25 | #include <qlineedit.h> | 25 | #include <qlineedit.h> |
26 | #include <qtextview.h> | 26 | #include <qtextview.h> |
27 | #include <qstring.h> | 27 | #include <qstring.h> |
28 | #include <qapplication.h> | 28 | #include <qapplication.h> |
29 | #include <qfile.h> | 29 | #include <qfile.h> |
30 | #ifdef QWS | ||
31 | #include <qwindowsystem_qws.h> | 30 | #include <qwindowsystem_qws.h> |
32 | #endif | ||
33 | 31 | ||
34 | #include <qdialog.h> | 32 | #include <qdialog.h> |
35 | 33 | ||
36 | #include <unistd.h> //for sleep | 34 | #include <unistd.h> //for sleep |
37 | #include "passwordbase_p.h" | 35 | #include "passwordbase_p.h" |
38 | 36 | ||
39 | class PasswordDialog : public PasswordBase | 37 | class PasswordDialog : public PasswordBase |
40 | { | 38 | { |
41 | Q_OBJECT | 39 | Q_OBJECT |
42 | 40 | ||
43 | public: | 41 | public: |
44 | PasswordDialog( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); | 42 | PasswordDialog( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); |
45 | ~PasswordDialog(); | 43 | ~PasswordDialog(); |
46 | 44 | ||
47 | void clear(); | 45 | void clear(); |
48 | void setPrompt( const QString& ); | 46 | void setPrompt( const QString& ); |
49 | 47 | ||
50 | signals: | 48 | signals: |
51 | void passwordEntered( const QString& ); | 49 | void passwordEntered( const QString& ); |
52 | 50 | ||
53 | protected: | 51 | protected: |
54 | bool eventFilter( QObject*, QEvent* ); | 52 | bool eventFilter( QObject*, QEvent* ); |
55 | void keyPressEvent( QKeyEvent * ); | 53 | void keyPressEvent( QKeyEvent * ); |
56 | 54 | ||
57 | private: | 55 | private: |
58 | void input( QString ); | 56 | void input( QString ); |
59 | friend class Password; | 57 | friend class Password; |
60 | QString text; | 58 | QString text; |
61 | }; | 59 | }; |
62 | 60 | ||
63 | 61 | ||
64 | extern "C" char *crypt(const char *key, const char *salt); | 62 | extern "C" char *crypt(const char *key, const char *salt); |
65 | static QString qcrypt(const QString& k, const char *salt) | 63 | static QString qcrypt(const QString& k, const char *salt) |
66 | { | 64 | { |
67 | return QString::fromUtf8(crypt(k.utf8(),salt)); | 65 | return QString::fromUtf8(crypt(k.utf8(),salt)); |
68 | } | 66 | } |
69 | 67 | ||
70 | /* | 68 | /* |
71 | * Constructs a PasswordDialog which is a child of 'parent', with the | 69 | * Constructs a PasswordDialog which is a child of 'parent', with the |
72 | * name 'name' and widget flags set to 'f' | 70 | * name 'name' and widget flags set to 'f' |
73 | */ | 71 | */ |
74 | PasswordDialog::PasswordDialog( QWidget* parent, const char* name, WFlags fl ) | 72 | PasswordDialog::PasswordDialog( QWidget* parent, const char* name, WFlags fl ) |
75 | : PasswordBase( parent, name, fl ) | 73 | : PasswordBase( parent, name, fl ) |
76 | { | 74 | { |
77 | QRect desk = qApp->desktop()->geometry(); | 75 | QRect desk = qApp->desktop()->geometry(); |
78 | 76 | ||
79 | if ( desk.width() < 220 ) { | 77 | if ( desk.width() < 220 ) { |
80 | QFont f( font() ); | 78 | QFont f( font() ); |
81 | f.setPointSize( 18 ); | 79 | f.setPointSize( 18 ); |
82 | setFont( f ); | 80 | setFont( f ); |
83 | f.setPointSize( 12 ); | 81 | f.setPointSize( 12 ); |
84 | prompt->setFont( f ); | 82 | prompt->setFont( f ); |
85 | } | 83 | } |
86 | 84 | ||
87 | button_0->installEventFilter( this ); | 85 | button_0->installEventFilter( this ); |
88 | button_1->installEventFilter( this ); | 86 | button_1->installEventFilter( this ); |
89 | button_2->installEventFilter( this ); | 87 | button_2->installEventFilter( this ); |
90 | button_3->installEventFilter( this ); | 88 | button_3->installEventFilter( this ); |
91 | button_4->installEventFilter( this ); | 89 | button_4->installEventFilter( this ); |
92 | button_5->installEventFilter( this ); | 90 | button_5->installEventFilter( this ); |
93 | button_6->installEventFilter( this ); | 91 | button_6->installEventFilter( this ); |
94 | button_7->installEventFilter( this ); | 92 | button_7->installEventFilter( this ); |
95 | button_8->installEventFilter( this ); | 93 | button_8->installEventFilter( this ); |
96 | button_9->installEventFilter( this ); | 94 | button_9->installEventFilter( this ); |
97 | button_OK->installEventFilter( this ); | 95 | button_OK->installEventFilter( this ); |
98 | setFocus(); | 96 | setFocus(); |
99 | } | 97 | } |
100 | 98 | ||
101 | /* | 99 | /* |
102 | * Destroys the object and frees any allocated resources | 100 | * Destroys the object and frees any allocated resources |
103 | */ | 101 | */ |
104 | PasswordDialog::~PasswordDialog() | 102 | PasswordDialog::~PasswordDialog() |
105 | { | 103 | { |
106 | // no need to delete child widgets, Qt does it all for us | 104 | // no need to delete child widgets, Qt does it all for us |
107 | } | 105 | } |
108 | 106 | ||
109 | 107 | ||
110 | 108 | ||
111 | /*! | 109 | /*! |
112 | \reimp | 110 | \reimp |
113 | */ | 111 | */ |
114 | 112 | ||
115 | bool PasswordDialog::eventFilter( QObject*o, QEvent*e ) | 113 | bool PasswordDialog::eventFilter( QObject*o, QEvent*e ) |
116 | { | 114 | { |
117 | if ( e->type() == QEvent::MouseButtonRelease ) { | 115 | if ( e->type() == QEvent::MouseButtonRelease ) { |
118 | if ( o == button_OK ) { | 116 | if ( o == button_OK ) { |
119 | emit passwordEntered( text ); | 117 | emit passwordEntered( text ); |
120 | } else { | 118 | } else { |
121 | QLabel *l = (QLabel*)o; | 119 | QLabel *l = (QLabel*)o; |
122 | input(l->text()); | 120 | input(l->text()); |
123 | } | 121 | } |
124 | } | 122 | } |
125 | return FALSE; | 123 | return FALSE; |
126 | } | 124 | } |
127 | 125 | ||
128 | 126 | ||
diff --git a/library/qpedecoration_qws.cpp b/library/qpedecoration_qws.cpp index 214c721..9cbe92b 100644 --- a/library/qpedecoration_qws.cpp +++ b/library/qpedecoration_qws.cpp | |||
@@ -1,116 +1,115 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #ifdef QWS | ||
21 | #define QTOPIA_INTERNAL_LANGLIST | 20 | #define QTOPIA_INTERNAL_LANGLIST |
22 | #include <qapplication.h> | 21 | #include <qapplication.h> |
23 | #include <qstyle.h> | 22 | #include <qstyle.h> |
24 | #include <qwidget.h> | 23 | #include <qwidget.h> |
25 | #include <qpainter.h> | 24 | #include <qpainter.h> |
26 | #include <qtimer.h> | 25 | #include <qtimer.h> |
27 | #include <qwhatsthis.h> | 26 | #include <qwhatsthis.h> |
28 | #include "qcopenvelope_qws.h" | 27 | #include "qcopenvelope_qws.h" |
29 | #include "qpedecoration_qws.h" | 28 | #include "qpedecoration_qws.h" |
30 | #include <qdialog.h> | 29 | #include <qdialog.h> |
31 | #include <qdrawutil.h> | 30 | #include <qdrawutil.h> |
32 | #include <qgfx_qws.h> | 31 | #include <qgfx_qws.h> |
33 | #include "qpeapplication.h" | 32 | #include "qpeapplication.h" |
34 | #include "resource.h" | 33 | #include "resource.h" |
35 | #include "global.h" | 34 | #include "global.h" |
36 | #include "qlibrary.h" | 35 | #include "qlibrary.h" |
37 | #include "windowdecorationinterface.h" | 36 | #include "windowdecorationinterface.h" |
38 | #include <qfile.h> | 37 | #include <qfile.h> |
39 | #include <qsignal.h> | 38 | #include <qsignal.h> |
40 | 39 | ||
41 | #include <stdlib.h> | 40 | #include <stdlib.h> |
42 | 41 | ||
43 | extern QRect qt_maxWindowRect; | 42 | extern QRect qt_maxWindowRect; |
44 | 43 | ||
45 | #define WHATSTHIS_MODE | 44 | #define WHATSTHIS_MODE |
46 | 45 | ||
47 | #ifndef QT_NO_QWS_QPE_WM_STYLE | 46 | #ifndef QT_NO_QWS_QPE_WM_STYLE |
48 | 47 | ||
49 | #ifndef QT_NO_IMAGEIO_XPM | 48 | #ifndef QT_NO_IMAGEIO_XPM |
50 | 49 | ||
51 | /* XPM */ | 50 | /* XPM */ |
52 | static const char * const qpe_close_xpm[] = { | 51 | static const char * const qpe_close_xpm[] = { |
53 | "16 16 3 1", | 52 | "16 16 3 1", |
54 | " c None", | 53 | " c None", |
55 | ". c #FFFFFF", | 54 | ". c #FFFFFF", |
56 | "+ c #000000", | 55 | "+ c #000000", |
57 | " ", | 56 | " ", |
58 | " ", | 57 | " ", |
59 | " ..... ", | 58 | " ..... ", |
60 | " ..+++++.. ", | 59 | " ..+++++.. ", |
61 | " .+++++++++. ", | 60 | " .+++++++++. ", |
62 | " .+..+++..+. ", | 61 | " .+..+++..+. ", |
63 | " .++...+...++. ", | 62 | " .++...+...++. ", |
64 | " .+++.....+++. ", | 63 | " .+++.....+++. ", |
65 | " .++++...++++. ", | 64 | " .++++...++++. ", |
66 | " .+++.....+++. ", | 65 | " .+++.....+++. ", |
67 | " .++...+...++. ", | 66 | " .++...+...++. ", |
68 | " .+..+++..+. ", | 67 | " .+..+++..+. ", |
69 | " .+++++++++. ", | 68 | " .+++++++++. ", |
70 | " ..+++++.. ", | 69 | " ..+++++.. ", |
71 | " ..... ", | 70 | " ..... ", |
72 | " "}; | 71 | " "}; |
73 | 72 | ||
74 | /* XPM */ | 73 | /* XPM */ |
75 | static const char * const qpe_accept_xpm[] = { | 74 | static const char * const qpe_accept_xpm[] = { |
76 | "16 16 3 1", | 75 | "16 16 3 1", |
77 | " c None", | 76 | " c None", |
78 | ". c #FFFFFF", | 77 | ". c #FFFFFF", |
79 | "+ c #000000", | 78 | "+ c #000000", |
80 | " ", | 79 | " ", |
81 | " ", | 80 | " ", |
82 | " ..... ", | 81 | " ..... ", |
83 | " ..+++++.. ", | 82 | " ..+++++.. ", |
84 | " .+++++++++. ", | 83 | " .+++++++++. ", |
85 | " .+++++++++. ", | 84 | " .+++++++++. ", |
86 | " .+++++++..++. ", | 85 | " .+++++++..++. ", |
87 | " .++.+++...++. ", | 86 | " .++.+++...++. ", |
88 | " .+...+...+++. ", | 87 | " .+...+...+++. ", |
89 | " .+......++++. ", | 88 | " .+......++++. ", |
90 | " .++....+++++. ", | 89 | " .++....+++++. ", |
91 | " .++..+++++. ", | 90 | " .++..+++++. ", |
92 | " .+++++++++. ", | 91 | " .+++++++++. ", |
93 | " ..+++++.. ", | 92 | " ..+++++.. ", |
94 | " ..... ", | 93 | " ..... ", |
95 | " "}; | 94 | " "}; |
96 | 95 | ||
97 | #endif // QT_NO_IMAGEIO_XPM | 96 | #endif // QT_NO_IMAGEIO_XPM |
98 | 97 | ||
99 | class HackWidget : public QWidget | 98 | class HackWidget : public QWidget |
100 | { | 99 | { |
101 | public: | 100 | public: |
102 | bool needsOk() { | 101 | bool needsOk() { |
103 | return (getWState() & WState_Reserved1 ) || | 102 | return (getWState() & WState_Reserved1 ) || |
104 | (inherits( "QDialog" ) && !inherits( "QMessageBox" ) ); | 103 | (inherits( "QDialog" ) && !inherits( "QMessageBox" ) ); |
105 | } | 104 | } |
106 | }; | 105 | }; |
107 | 106 | ||
108 | static QImage scaleButton( const QImage &img, int height ) | 107 | static QImage scaleButton( const QImage &img, int height ) |
109 | { | 108 | { |
110 | if ( img.height() != 0 && img.height() != height ) { | 109 | if ( img.height() != 0 && img.height() != height ) { |
111 | return img.smoothScale( img.width()*height/img.height(), height ); | 110 | return img.smoothScale( img.width()*height/img.height(), height ); |
112 | } else { | 111 | } else { |
113 | return img; | 112 | return img; |
114 | } | 113 | } |
115 | } | 114 | } |
116 | 115 | ||
@@ -818,97 +817,96 @@ void QPEDecoration::paintButton(QPainter *painter, const QWidget *w, | |||
818 | painter->setClipRegion( QRect(brect.x(), tr.y(), brect.width(), tr.height()) ); // reduce flicker | 817 | painter->setClipRegion( QRect(brect.x(), tr.y(), brect.width(), tr.height()) ); // reduce flicker |
819 | wdiface->drawArea( WindowDecorationInterface::Title, painter, &wd ); | 818 | wdiface->drawArea( WindowDecorationInterface::Title, painter, &wd ); |
820 | wdiface->drawButton( b, painter, &wd, brect.x(), brect.y(), brect.width(), brect.height(), (QWSButton::State)state ); | 819 | wdiface->drawButton( b, painter, &wd, brect.x(), brect.y(), brect.width(), brect.height(), (QWSButton::State)state ); |
821 | painter->setClipRegion( oldClip ); | 820 | painter->setClipRegion( oldClip ); |
822 | } | 821 | } |
823 | 822 | ||
824 | //#define QPE_DONT_SHOW_TITLEBAR | 823 | //#define QPE_DONT_SHOW_TITLEBAR |
825 | 824 | ||
826 | void QPEDecoration::maximize( QWidget *widget ) | 825 | void QPEDecoration::maximize( QWidget *widget ) |
827 | { | 826 | { |
828 | #ifdef QPE_DONT_SHOW_TITLEBAR | 827 | #ifdef QPE_DONT_SHOW_TITLEBAR |
829 | if ( !widget->inherits( "QDialog" ) ) { | 828 | if ( !widget->inherits( "QDialog" ) ) { |
830 | widget->setGeometry( qt_maxWindowRect ); | 829 | widget->setGeometry( qt_maxWindowRect ); |
831 | } else | 830 | } else |
832 | #endif | 831 | #endif |
833 | { | 832 | { |
834 | QWSDecoration::maximize( widget ); | 833 | QWSDecoration::maximize( widget ); |
835 | } | 834 | } |
836 | } | 835 | } |
837 | 836 | ||
838 | #ifndef QT_NO_DIALOG | 837 | #ifndef QT_NO_DIALOG |
839 | class HackDialog : public QDialog | 838 | class HackDialog : public QDialog |
840 | { | 839 | { |
841 | public: | 840 | public: |
842 | void acceptIt() { | 841 | void acceptIt() { |
843 | if ( isA( "QMessageBox" ) ) | 842 | if ( isA( "QMessageBox" ) ) |
844 | qApp->postEvent( this, new QKeyEvent( QEvent::KeyPress, Key_Enter, '\n', 0, "\n" ) ); | 843 | qApp->postEvent( this, new QKeyEvent( QEvent::KeyPress, Key_Enter, '\n', 0, "\n" ) ); |
845 | else | 844 | else |
846 | accept(); | 845 | accept(); |
847 | } | 846 | } |
848 | }; | 847 | }; |
849 | #endif | 848 | #endif |
850 | 849 | ||
851 | 850 | ||
852 | void QPEDecoration::minimize( QWidget *widget ) | 851 | void QPEDecoration::minimize( QWidget *widget ) |
853 | { | 852 | { |
854 | #ifndef QT_NO_DIALOG | 853 | #ifndef QT_NO_DIALOG |
855 | // We use the minimize button as an "accept" button. | 854 | // We use the minimize button as an "accept" button. |
856 | if ( widget->inherits( "QDialog" ) ) { | 855 | if ( widget->inherits( "QDialog" ) ) { |
857 | HackDialog *d = (HackDialog *)widget; | 856 | HackDialog *d = (HackDialog *)widget; |
858 | d->acceptIt(); | 857 | d->acceptIt(); |
859 | } | 858 | } |
860 | #endif | 859 | #endif |
861 | else if ( ((HackWidget *)widget)->needsOk() ) { | 860 | else if ( ((HackWidget *)widget)->needsOk() ) { |
862 | QSignal s; | 861 | QSignal s; |
863 | s.connect( widget, SLOT( accept() ) ); | 862 | s.connect( widget, SLOT( accept() ) ); |
864 | s.activate(); | 863 | s.activate(); |
865 | } else { | 864 | } else { |
866 | help( widget ); | 865 | help( widget ); |
867 | } | 866 | } |
868 | } | 867 | } |
869 | 868 | ||
870 | void QPEDecoration::help( QWidget *w ) | 869 | void QPEDecoration::help( QWidget *w ) |
871 | { | 870 | { |
872 | if ( helpExists ) { | 871 | if ( helpExists ) { |
873 | Global::execute( "helpbrowser", helpFile ); | 872 | Global::execute( "helpbrowser", helpFile ); |
874 | } else if ( w && w->testWFlags(Qt::WStyle_ContextHelp) ) { | 873 | } else if ( w && w->testWFlags(Qt::WStyle_ContextHelp) ) { |
875 | QWhatsThis::enterWhatsThisMode(); | 874 | QWhatsThis::enterWhatsThisMode(); |
876 | QWhatsThis::leaveWhatsThisMode( qApp->tr( | 875 | QWhatsThis::leaveWhatsThisMode( qApp->tr( |
877 | "<Qt>Comprehensive help is not available for this application, " | 876 | "<Qt>Comprehensive help is not available for this application, " |
878 | "however there is context-sensitive help.<p>To use context-sensitive help:<p>" | 877 | "however there is context-sensitive help.<p>To use context-sensitive help:<p>" |
879 | "<ol><li>click and hold the help button." | 878 | "<ol><li>click and hold the help button." |
880 | "<li>when the title bar shows <b>What's this...</b>, " | 879 | "<li>when the title bar shows <b>What's this...</b>, " |
881 | "click on any control.</ol></Qt>" ) ); | 880 | "click on any control.</ol></Qt>" ) ); |
882 | } | 881 | } |
883 | } | 882 | } |
884 | 883 | ||
885 | void QPEDecoration::windowData( const QWidget *w, WindowDecorationInterface::WindowData &wd ) const | 884 | void QPEDecoration::windowData( const QWidget *w, WindowDecorationInterface::WindowData &wd ) const |
886 | { | 885 | { |
887 | wd.rect = w->rect(); | 886 | wd.rect = w->rect(); |
888 | if ( qpeManager->whatsThisWidget() == w ) | 887 | if ( qpeManager->whatsThisWidget() == w ) |
889 | wd.caption = qApp->tr("What's this..." ); | 888 | wd.caption = qApp->tr("What's this..." ); |
890 | else | 889 | else |
891 | wd.caption = w->caption(); | 890 | wd.caption = w->caption(); |
892 | wd.palette = qApp->palette(); | 891 | wd.palette = qApp->palette(); |
893 | wd.flags = 0; | 892 | wd.flags = 0; |
894 | wd.flags |= w->isMaximized() ? WindowDecorationInterface::WindowData::Maximized : 0; | 893 | wd.flags |= w->isMaximized() ? WindowDecorationInterface::WindowData::Maximized : 0; |
895 | wd.flags |= w->testWFlags(Qt::WStyle_Dialog) ? WindowDecorationInterface::WindowData::Dialog : 0; | 894 | wd.flags |= w->testWFlags(Qt::WStyle_Dialog) ? WindowDecorationInterface::WindowData::Dialog : 0; |
896 | const QWidget *active = qpeManager->activeWidget(); | 895 | const QWidget *active = qpeManager->activeWidget(); |
897 | wd.flags |= w == active ? WindowDecorationInterface::WindowData::Active : 0; | 896 | wd.flags |= w == active ? WindowDecorationInterface::WindowData::Active : 0; |
898 | wd.reserved = 1; | 897 | wd.reserved = 1; |
899 | } | 898 | } |
900 | 899 | ||
901 | /* | 900 | /* |
902 | #ifndef QT_NO_POPUPMENU | 901 | #ifndef QT_NO_POPUPMENU |
903 | QPopupMenu *QPEDecoration::menu(QWSManager*, const QWidget*, const QPoint&) | 902 | QPopupMenu *QPEDecoration::menu(QWSManager*, const QWidget*, const QPoint&) |
904 | { | 903 | { |
905 | return 0; | 904 | return 0; |
906 | } | 905 | } |
907 | #endif | 906 | #endif |
908 | */ | 907 | */ |
909 | 908 | ||
910 | 909 | ||
911 | 910 | ||
912 | 911 | ||
913 | #endif // QT_NO_QWS_QPE_WM_STYLE | 912 | #endif // QT_NO_QWS_QPE_WM_STYLE |
914 | #endif | ||
diff --git a/library/tzselect.cpp b/library/tzselect.cpp index 9436867..2e5a433 100644 --- a/library/tzselect.cpp +++ b/library/tzselect.cpp | |||
@@ -1,173 +1,169 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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_TZSELECT_INC_LOCAL | 21 | #define QTOPIA_INTERNAL_TZSELECT_INC_LOCAL |
22 | 22 | ||
23 | #include "tzselect.h" | 23 | #include "tzselect.h" |
24 | #include "resource.h" | 24 | #include "resource.h" |
25 | #include "global.h" | 25 | #include "global.h" |
26 | #include "config.h" | 26 | #include "config.h" |
27 | #include <qtoolbutton.h> | 27 | #include <qtoolbutton.h> |
28 | #include <qfile.h> | 28 | #include <qfile.h> |
29 | #include <stdlib.h> | 29 | #include <stdlib.h> |
30 | 30 | ||
31 | #ifdef Q_WS_QWS | ||
32 | #include <qcopchannel_qws.h> | 31 | #include <qcopchannel_qws.h> |
33 | #endif | ||
34 | 32 | ||
35 | class TimeZoneSelectorPrivate | 33 | class TimeZoneSelectorPrivate |
36 | { | 34 | { |
37 | public: | 35 | public: |
38 | TimeZoneSelectorPrivate() : includeLocal(FALSE) {} | 36 | TimeZoneSelectorPrivate() : includeLocal(FALSE) {} |
39 | bool includeLocal; | 37 | bool includeLocal; |
40 | }; | 38 | }; |
41 | 39 | ||
42 | TZCombo::TZCombo( QWidget *p, const char* n ) | 40 | TZCombo::TZCombo( QWidget *p, const char* n ) |
43 | : QComboBox( p, n ) | 41 | : QComboBox( p, n ) |
44 | { | 42 | { |
45 | updateZones(); | 43 | updateZones(); |
46 | // check to see if TZ is set, if it is set the current item to that | 44 | // check to see if TZ is set, if it is set the current item to that |
47 | QString tz = getenv("TZ"); | 45 | QString tz = getenv("TZ"); |
48 | if (parent()->inherits("TimeZoneSelector")) { | 46 | if (parent()->inherits("TimeZoneSelector")) { |
49 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { | 47 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { |
50 | // overide to the 'local' type. | 48 | // overide to the 'local' type. |
51 | tz = "None"; | 49 | tz = "None"; |
52 | } | 50 | } |
53 | } | 51 | } |
54 | if ( !tz.isNull() ) { | 52 | if ( !tz.isNull() ) { |
55 | int n = 0, | 53 | int n = 0, |
56 | index = 0; | 54 | index = 0; |
57 | for ( QStringList::Iterator it=identifiers.begin(); | 55 | for ( QStringList::Iterator it=identifiers.begin(); |
58 | it!=identifiers.end(); ++it) { | 56 | it!=identifiers.end(); ++it) { |
59 | if ( *it == tz ) | 57 | if ( *it == tz ) |
60 | index = n; | 58 | index = n; |
61 | n++; | 59 | n++; |
62 | } | 60 | } |
63 | setCurrentItem(index); | 61 | setCurrentItem(index); |
64 | } else { | 62 | } else { |
65 | setCurrentItem(0); | 63 | setCurrentItem(0); |
66 | } | 64 | } |
67 | 65 | ||
68 | 66 | ||
69 | 67 | ||
70 | // listen on QPE/System | 68 | // listen on QPE/System |
71 | #if defined(Q_WS_QWS) | ||
72 | #if !defined(QT_NO_COP) | 69 | #if !defined(QT_NO_COP) |
73 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); | 70 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); |
74 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 71 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
75 | this, SLOT(handleSystemChannel(const QCString&, const QByteArray&)) ); | 72 | this, SLOT(handleSystemChannel(const QCString&, const QByteArray&)) ); |
76 | #endif | 73 | #endif |
77 | #endif | ||
78 | 74 | ||
79 | 75 | ||
80 | } | 76 | } |
81 | 77 | ||
82 | TZCombo::~TZCombo() | 78 | TZCombo::~TZCombo() |
83 | { | 79 | { |
84 | } | 80 | } |
85 | 81 | ||
86 | void TZCombo::updateZones() | 82 | void TZCombo::updateZones() |
87 | { | 83 | { |
88 | QString cur = currentText(); | 84 | QString cur = currentText(); |
89 | clear(); | 85 | clear(); |
90 | identifiers.clear(); | 86 | identifiers.clear(); |
91 | int curix=0; | 87 | int curix=0; |
92 | QString tz = getenv("TZ"); | 88 | QString tz = getenv("TZ"); |
93 | bool tzFound = FALSE; | 89 | bool tzFound = FALSE; |
94 | Config cfg("CityTime"); | 90 | Config cfg("CityTime"); |
95 | cfg.setGroup("TimeZones"); | 91 | cfg.setGroup("TimeZones"); |
96 | int listIndex = 0; | 92 | int listIndex = 0; |
97 | if (parent()->inherits("TimeZoneSelector")) { | 93 | if (parent()->inherits("TimeZoneSelector")) { |
98 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { | 94 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { |
99 | // overide to the 'local' type. | 95 | // overide to the 'local' type. |
100 | identifiers.append( "None" ); | 96 | identifiers.append( "None" ); |
101 | insertItem( tr("None") ); | 97 | insertItem( tr("None") ); |
102 | if ( cur == tr("None")) | 98 | if ( cur == tr("None")) |
103 | curix = 0; | 99 | curix = 0; |
104 | listIndex++; | 100 | listIndex++; |
105 | } | 101 | } |
106 | } | 102 | } |
107 | int cfgIndex = 0; | 103 | int cfgIndex = 0; |
108 | while (1) { | 104 | while (1) { |
109 | QString zn = cfg.readEntry("Zone"+QString::number(cfgIndex), QString::null); | 105 | QString zn = cfg.readEntry("Zone"+QString::number(cfgIndex), QString::null); |
110 | if ( zn.isNull() ) | 106 | if ( zn.isNull() ) |
111 | break; | 107 | break; |
112 | if ( zn == tz ) | 108 | if ( zn == tz ) |
113 | tzFound = TRUE; | 109 | tzFound = TRUE; |
114 | QString nm = cfg.readEntry("ZoneName"+QString::number(cfgIndex)); | 110 | QString nm = cfg.readEntry("ZoneName"+QString::number(cfgIndex)); |
115 | identifiers.append(zn); | 111 | identifiers.append(zn); |
116 | insertItem(nm); | 112 | insertItem(nm); |
117 | if ( nm == cur ) | 113 | if ( nm == cur ) |
118 | curix = listIndex; | 114 | curix = listIndex; |
119 | ++cfgIndex; | 115 | ++cfgIndex; |
120 | ++listIndex; | 116 | ++listIndex; |
121 | } | 117 | } |
122 | if ( !listIndex ) { | 118 | if ( !listIndex ) { |
123 | QStringList list = timezoneDefaults(); | 119 | QStringList list = timezoneDefaults(); |
124 | for ( QStringList::Iterator it = list.begin(); it!=list.end(); ++it ) { | 120 | for ( QStringList::Iterator it = list.begin(); it!=list.end(); ++it ) { |
125 | QString zn = *it; | 121 | QString zn = *it; |
126 | QString nm = *++it; | 122 | QString nm = *++it; |
127 | if ( zn == tz ) | 123 | if ( zn == tz ) |
128 | tzFound = TRUE; | 124 | tzFound = TRUE; |
129 | if ( nm == cur ) | 125 | if ( nm == cur ) |
130 | curix = listIndex; | 126 | curix = listIndex; |
131 | identifiers.append(zn); | 127 | identifiers.append(zn); |
132 | insertItem(nm); | 128 | insertItem(nm); |
133 | ++listIndex; | 129 | ++listIndex; |
134 | } | 130 | } |
135 | } | 131 | } |
136 | for (QStringList::Iterator it=extras.begin(); it!=extras.end(); ++it) { | 132 | for (QStringList::Iterator it=extras.begin(); it!=extras.end(); ++it) { |
137 | insertItem(*it); | 133 | insertItem(*it); |
138 | identifiers.append(*it); | 134 | identifiers.append(*it); |
139 | if ( *it == cur ) | 135 | if ( *it == cur ) |
140 | curix = listIndex; | 136 | curix = listIndex; |
141 | ++listIndex; | 137 | ++listIndex; |
142 | } | 138 | } |
143 | if ( !tzFound && !tz.isEmpty()) { | 139 | if ( !tzFound && !tz.isEmpty()) { |
144 | int i = tz.find( '/' ); | 140 | int i = tz.find( '/' ); |
145 | QString nm = tz.mid( i+1 ).replace(QRegExp("_"), " "); | 141 | QString nm = tz.mid( i+1 ).replace(QRegExp("_"), " "); |
146 | identifiers.append(tz); | 142 | identifiers.append(tz); |
147 | insertItem(nm); | 143 | insertItem(nm); |
148 | if ( nm == cur ) | 144 | if ( nm == cur ) |
149 | curix = listIndex; | 145 | curix = listIndex; |
150 | ++listIndex; | 146 | ++listIndex; |
151 | } | 147 | } |
152 | setCurrentItem(curix); | 148 | setCurrentItem(curix); |
153 | } | 149 | } |
154 | 150 | ||
155 | 151 | ||
156 | void TZCombo::keyPressEvent( QKeyEvent *e ) | 152 | void TZCombo::keyPressEvent( QKeyEvent *e ) |
157 | { | 153 | { |
158 | // ### should popup() in Qt 3.0 (it's virtual there) | 154 | // ### should popup() in Qt 3.0 (it's virtual there) |
159 | // updateZones(); | 155 | // updateZones(); |
160 | QComboBox::keyPressEvent(e); | 156 | QComboBox::keyPressEvent(e); |
161 | } | 157 | } |
162 | 158 | ||
163 | void TZCombo::mousePressEvent(QMouseEvent*e) | 159 | void TZCombo::mousePressEvent(QMouseEvent*e) |
164 | { | 160 | { |
165 | // ### should popup() in Qt 3.0 (it's virtual there) | 161 | // ### should popup() in Qt 3.0 (it's virtual there) |
166 | // updateZones(); | 162 | // updateZones(); |
167 | QComboBox::mousePressEvent(e); | 163 | QComboBox::mousePressEvent(e); |
168 | } | 164 | } |
169 | 165 | ||
170 | QString TZCombo::currZone() const | 166 | QString TZCombo::currZone() const |
171 | { | 167 | { |
172 | return identifiers[currentItem()]; | 168 | return identifiers[currentItem()]; |
173 | } | 169 | } |