author | zecke <zecke> | 2002-10-16 01:09:22 (UTC) |
---|---|---|
committer | zecke <zecke> | 2002-10-16 01:09:22 (UTC) |
commit | 543e54de7170c606b6883ac4152567e7faf13182 (patch) (unidiff) | |
tree | 8a7d623e96cab0135a2f7cb11aa9f7491bfda9a2 /library | |
parent | 3e973543b77631d053a9616b5540966dbe51ab47 (diff) | |
download | opie-543e54de7170c606b6883ac4152567e7faf13182.zip opie-543e54de7170c606b6883ac4152567e7faf13182.tar.gz opie-543e54de7170c606b6883ac4152567e7faf13182.tar.bz2 |
Remove #ifdef QWS HELL
a Platform which is not supporting IPC compatible
to QCopChannel/Envelope is not of much use nowadays..
so be sure your platform is supporting it
-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,161 +1,159 @@ | |||
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 | { |
130 | //read autosave file and put events in timerEventList | 128 | //read autosave file and put events in timerEventList |
131 | 129 | ||
132 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); | 130 | QString savefilename = Global::applicationFileName( "AlarmServer", "saveFile" ); |
133 | 131 | ||
134 | QFile savefile(savefilename); | 132 | QFile savefile(savefilename); |
135 | if ( savefile.open(IO_ReadOnly) ) { | 133 | if ( savefile.open(IO_ReadOnly) ) { |
136 | QDataStream ds( &savefile ); | 134 | QDataStream ds( &savefile ); |
137 | while ( !ds.atEnd() ) { | 135 | while ( !ds.atEnd() ) { |
138 | timerEventItem *newTimerEventItem = new timerEventItem; | 136 | timerEventItem *newTimerEventItem = new timerEventItem; |
139 | ds >> newTimerEventItem->UTCtime; | 137 | ds >> newTimerEventItem->UTCtime; |
140 | ds >> newTimerEventItem->channel; | 138 | ds >> newTimerEventItem->channel; |
141 | ds >> newTimerEventItem->message; | 139 | ds >> newTimerEventItem->message; |
142 | ds >> newTimerEventItem->data; | 140 | ds >> newTimerEventItem->data; |
143 | timerEventList.append( newTimerEventItem ); | 141 | timerEventList.append( newTimerEventItem ); |
144 | } | 142 | } |
145 | savefile.close(); | 143 | savefile.close(); |
146 | if (!timerEventReceiver) | 144 | if (!timerEventReceiver) |
147 | timerEventReceiver = new TimerReceiverObject; | 145 | timerEventReceiver = new TimerReceiverObject; |
148 | setNearestTimerEvent(); | 146 | setNearestTimerEvent(); |
149 | } | 147 | } |
150 | } | 148 | } |
151 | 149 | ||
152 | 150 | ||
153 | 151 | ||
154 | 152 | ||
155 | static const char* atdir = "/var/spool/at/"; | 153 | static const char* atdir = "/var/spool/at/"; |
156 | 154 | ||
157 | static bool triggerAtd( bool writeHWClock = FALSE ) | 155 | static bool triggerAtd( bool writeHWClock = FALSE ) |
158 | { | 156 | { |
159 | QFile trigger(QString(atdir) + "trigger"); | 157 | QFile trigger(QString(atdir) + "trigger"); |
160 | if ( trigger.open(IO_WriteOnly|IO_Raw) ) { | 158 | if ( trigger.open(IO_WriteOnly|IO_Raw) ) { |
161 | 159 | ||
diff --git a/library/applnk.cpp b/library/applnk.cpp index a56da5d..5763c62 100644 --- a/library/applnk.cpp +++ b/library/applnk.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_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 | ||
142 | \target Types | 138 | \target Types |
143 | \section1 Types | 139 | \section1 Types |
144 | 140 | ||
145 | Every AppLnk object has a \e type. For applications, games and | 141 | Every AppLnk object has a \e type. For applications, games and |
146 | settings the type is \c Application; for documents the | 142 | settings the type is \c Application; for documents the |
147 | type is the document's MIME type. | 143 | type is the document's MIME type. |
148 | 144 | ||
149 | \target files-and-links | 145 | \target files-and-links |
150 | \section1 Files and Links | 146 | \section1 Files and Links |
151 | 147 | ||
152 | When you create an AppLnk (or more likely, a \link doclnk.html | 148 | When you create an AppLnk (or more likely, a \link doclnk.html |
153 | DocLnk\endlink), you don't deal directly with filenames in the | 149 | DocLnk\endlink), you don't deal directly with filenames in the |
154 | filesystem. Instead you do this: | 150 | filesystem. Instead you do this: |
155 | \code | 151 | \code |
156 | DocLnk d; | 152 | DocLnk d; |
157 | d.setType("text/plain"); | 153 | d.setType("text/plain"); |
158 | d.setName("My Nicely Named Document / Whatever"); // Yes, "/" is legal. | 154 | d.setName("My Nicely Named Document / Whatever"); // Yes, "/" is legal. |
159 | \endcode | 155 | \endcode |
160 | At this point, the file() and linkFile() are unknown. Normally | 156 | At this point, the file() and linkFile() are unknown. Normally |
161 | this is uninteresting, and the names become automatically known, | 157 | this is uninteresting, and the names become automatically known, |
162 | and more importantly, becomes reserved, when you ask what they are: | 158 | and more importantly, becomes reserved, when you ask what they are: |
163 | 159 | ||
164 | \code | 160 | \code |
165 | QString fn = d.file(); | 161 | QString fn = d.file(); |
166 | \endcode | 162 | \endcode |
167 | This invents a filename, and creates the file on disk (an empty | 163 | This invents a filename, and creates the file on disk (an empty |
168 | reservation file) to prevent the name being used by another | 164 | reservation file) to prevent the name being used by another |
169 | application. | 165 | application. |
170 | 166 | ||
171 | In some circumstances, you don't want to create the file if it | 167 | In some circumstances, you don't want to create the file if it |
172 | doesn't already exist (e.g. in the Document tab, some of the \link | 168 | doesn't already exist (e.g. in the Document tab, some of the \link |
173 | doclnk.html DocLnk\endlink objects represented by icons are | 169 | doclnk.html DocLnk\endlink objects represented by icons are |
diff --git a/library/fileselector.cpp b/library/fileselector.cpp index 052a29e..4039243 100644 --- a/library/fileselector.cpp +++ b/library/fileselector.cpp | |||
@@ -1,163 +1,161 @@ | |||
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 | } |
132 | for (it = filters.begin(); it!=filters.end(); ++it) { | 130 | for (it = filters.begin(); it!=filters.end(); ++it) { |
133 | typelist.append( *it ); | 131 | typelist.append( *it ); |
134 | int pos = (*it).find( '/' ); | 132 | int pos = (*it).find( '/' ); |
135 | if ( pos >= 0 ) { | 133 | if ( pos >= 0 ) { |
136 | QString maj = (*it).left( pos ); | 134 | QString maj = (*it).left( pos ); |
137 | maj[0] = maj[0].upper(); | 135 | maj[0] = maj[0].upper(); |
138 | types << tr("All %1 files").arg(maj); | 136 | types << tr("All %1 files").arg(maj); |
139 | } | 137 | } |
140 | } | 138 | } |
141 | if ( filters.count() > 1 ) { | 139 | if ( filters.count() > 1 ) { |
142 | typelist.append( filter ); | 140 | typelist.append( filter ); |
143 | types << tr("All files"); | 141 | types << tr("All files"); |
144 | } | 142 | } |
145 | prev = currentText(); | 143 | prev = currentText(); |
146 | clear(); | 144 | clear(); |
147 | insertStringList(types); | 145 | insertStringList(types); |
148 | for (int i=0; i<count(); i++) { | 146 | for (int i=0; i<count(); i++) { |
149 | if ( text(i) == prev ) { | 147 | if ( text(i) == prev ) { |
150 | setCurrentItem(i); | 148 | setCurrentItem(i); |
151 | break; | 149 | break; |
152 | } | 150 | } |
153 | } | 151 | } |
154 | if ( prev.isNull() ) | 152 | if ( prev.isNull() ) |
155 | setCurrentItem(count()-1); | 153 | setCurrentItem(count()-1); |
156 | setEnabled( TRUE ); | 154 | setEnabled( TRUE ); |
157 | } | 155 | } |
158 | 156 | ||
159 | 157 | ||
160 | //=========================================================================== | 158 | //=========================================================================== |
161 | 159 | ||
162 | FileSelectorItem::FileSelectorItem( QListView *parent, const DocLnk &f ) | 160 | FileSelectorItem::FileSelectorItem( QListView *parent, const DocLnk &f ) |
163 | : QListViewItem( parent ), fl( f ) | 161 | : QListViewItem( parent ), fl( f ) |
diff --git a/library/fontdatabase.cpp b/library/fontdatabase.cpp index 2b5e0d2..147134c 100644 --- a/library/fontdatabase.cpp +++ b/library/fontdatabase.cpp | |||
@@ -1,157 +1,155 @@ | |||
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 | */ |
126 | QValueList<int> FontDatabase::standardSizes() | 124 | QValueList<int> FontDatabase::standardSizes() |
127 | { | 125 | { |
128 | static int s[]={ 8, 9, 10, 11, 12, 14, 16, 18, 20, 22, 24, 26, 28, | 126 | static int s[]={ 8, 9, 10, 11, 12, 14, 16, 18, 20, 22, 24, 26, 28, |
129 | 36, 48, 72, 0 }; | 127 | 36, 48, 72, 0 }; |
130 | static bool first = TRUE; | 128 | static bool first = TRUE; |
131 | static QValueList<int> sList; | 129 | static QValueList<int> sList; |
132 | if ( first ) { | 130 | if ( first ) { |
133 | first = FALSE; | 131 | first = FALSE; |
134 | int i = 0; | 132 | int i = 0; |
135 | while( s[i] ) | 133 | while( s[i] ) |
136 | sList.append( s[i++] ); | 134 | sList.append( s[i++] ); |
137 | } | 135 | } |
138 | return sList; | 136 | return sList; |
139 | } | 137 | } |
140 | 138 | ||
141 | #endif | 139 | #endif |
142 | 140 | ||
143 | /*! | 141 | /*! |
144 | Load any font renderer plugins that are available and make the fonts | 142 | Load any font renderer plugins that are available and make the fonts |
145 | that the plugins can read available. | 143 | that the plugins can read available. |
146 | */ | 144 | */ |
147 | void FontDatabase::loadRenderers() | 145 | void FontDatabase::loadRenderers() |
148 | { | 146 | { |
149 | #ifndef QT_NO_COMPONENT | 147 | #ifndef QT_NO_COMPONENT |
150 | if ( !factoryList ) | 148 | if ( !factoryList ) |
151 | factoryList = new QValueList<FontFactory>; | 149 | factoryList = new QValueList<FontFactory>; |
152 | 150 | ||
153 | QValueList<FontFactory>::Iterator mit; | 151 | QValueList<FontFactory>::Iterator mit; |
154 | for ( mit = factoryList->begin(); mit != factoryList->end(); ++mit ) { | 152 | for ( mit = factoryList->begin(); mit != factoryList->end(); ++mit ) { |
155 | qt_fontmanager->factories.setAutoDelete( false ); | 153 | qt_fontmanager->factories.setAutoDelete( false ); |
156 | qt_fontmanager->factories.removeRef( (*mit).factory ); | 154 | qt_fontmanager->factories.removeRef( (*mit).factory ); |
157 | qt_fontmanager->factories.setAutoDelete( true ); | 155 | qt_fontmanager->factories.setAutoDelete( true ); |
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,247 +1,241 @@ | |||
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 |
216 | shell. The stringQuote() function backslash escapes '\' and '"' | 210 | shell. The stringQuote() function backslash escapes '\' and '"' |
217 | characters. | 211 | characters. |
218 | 212 | ||
219 | \section1 Hardware | 213 | \section1 Hardware |
220 | 214 | ||
221 | The writeHWClock() function sets the hardware clock to the system | 215 | The writeHWClock() function sets the hardware clock to the system |
222 | clock's date and time. | 216 | clock's date and time. |
223 | 217 | ||
224 | \ingroup qtopiaemb | 218 | \ingroup qtopiaemb |
225 | */ | 219 | */ |
226 | 220 | ||
227 | /*! | 221 | /*! |
228 | \internal | 222 | \internal |
229 | */ | 223 | */ |
230 | Global::Global() | 224 | Global::Global() |
231 | { | 225 | { |
232 | } | 226 | } |
233 | 227 | ||
234 | /*! | 228 | /*! |
235 | Returns the unchangeable QDawg that contains general | 229 | Returns the unchangeable QDawg that contains general |
236 | words for the current locale. | 230 | words for the current locale. |
237 | 231 | ||
238 | \sa addedDawg() | 232 | \sa addedDawg() |
239 | */ | 233 | */ |
240 | const QDawg& Global::fixedDawg() | 234 | const QDawg& Global::fixedDawg() |
241 | { | 235 | { |
242 | if ( !fixed_dawg ) { | 236 | if ( !fixed_dawg ) { |
243 | if ( !docDirCreated ) | 237 | if ( !docDirCreated ) |
244 | createDocDir(); | 238 | createDocDir(); |
245 | 239 | ||
246 | fixed_dawg = new QDawg; | 240 | fixed_dawg = new QDawg; |
247 | QString dawgfilename = dictDir() + "/dawg"; | 241 | QString dawgfilename = dictDir() + "/dawg"; |
@@ -268,540 +262,540 @@ const QDawg& Global::fixedDawg() | |||
268 | fixed_dawg->createFromWords(&in); | 262 | fixed_dawg->createFromWords(&in); |
269 | dawgfile.open(IO_WriteOnly); | 263 | dawgfile.open(IO_WriteOnly); |
270 | fixed_dawg->write(&dawgfile); | 264 | fixed_dawg->write(&dawgfile); |
271 | dawgfile.close(); | 265 | dawgfile.close(); |
272 | } | 266 | } |
273 | } else { | 267 | } else { |
274 | fixed_dawg->readFile(dawgfilename); | 268 | fixed_dawg->readFile(dawgfilename); |
275 | } | 269 | } |
276 | } | 270 | } |
277 | 271 | ||
278 | return *fixed_dawg; | 272 | return *fixed_dawg; |
279 | } | 273 | } |
280 | 274 | ||
281 | /*! | 275 | /*! |
282 | Returns the changeable QDawg that contains general | 276 | Returns the changeable QDawg that contains general |
283 | words for the current locale. | 277 | words for the current locale. |
284 | 278 | ||
285 | \sa fixedDawg() | 279 | \sa fixedDawg() |
286 | */ | 280 | */ |
287 | const QDawg& Global::addedDawg() | 281 | const QDawg& Global::addedDawg() |
288 | { | 282 | { |
289 | return dawg("local"); | 283 | return dawg("local"); |
290 | } | 284 | } |
291 | 285 | ||
292 | /*! | 286 | /*! |
293 | Returns the QDawg with the given \a name. | 287 | Returns the QDawg with the given \a name. |
294 | This is an application-specific word list. | 288 | This is an application-specific word list. |
295 | 289 | ||
296 | \a name should not contain "/". | 290 | \a name should not contain "/". |
297 | */ | 291 | */ |
298 | const QDawg& Global::dawg(const QString& name) | 292 | const QDawg& Global::dawg(const QString& name) |
299 | { | 293 | { |
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); |
776 | } | 770 | } |
777 | } | 771 | } |
778 | } | 772 | } |
779 | 773 | ||
780 | QStringList Global::languageList() | 774 | QStringList Global::languageList() |
781 | { | 775 | { |
782 | QString lang = getenv("LANG"); | 776 | QString lang = getenv("LANG"); |
783 | QStringList langs; | 777 | QStringList langs; |
784 | langs.append(lang); | 778 | langs.append(lang); |
785 | int i = lang.find("."); | 779 | int i = lang.find("."); |
786 | if ( i > 0 ) | 780 | if ( i > 0 ) |
787 | lang = lang.left( i ); | 781 | lang = lang.left( i ); |
788 | i = lang.find( "_" ); | 782 | i = lang.find( "_" ); |
789 | if ( i > 0 ) | 783 | if ( i > 0 ) |
790 | langs.append(lang.left(i)); | 784 | langs.append(lang.left(i)); |
791 | return langs; | 785 | return langs; |
792 | } | 786 | } |
793 | 787 | ||
794 | QStringList Global::helpPath() | 788 | QStringList Global::helpPath() |
795 | { | 789 | { |
796 | QStringList path; | 790 | QStringList path; |
797 | QStringList langs = Global::languageList(); | 791 | QStringList langs = Global::languageList(); |
798 | for (QStringList::ConstIterator it = langs.fromLast(); it!=langs.end(); --it) { | 792 | for (QStringList::ConstIterator it = langs.fromLast(); it!=langs.end(); --it) { |
799 | QString lang = *it; | 793 | QString lang = *it; |
800 | if ( !lang.isEmpty() ) | 794 | if ( !lang.isEmpty() ) |
801 | path += QPEApplication::qpeDir() + "/help/" + lang + "/html"; | 795 | path += QPEApplication::qpeDir() + "/help/" + lang + "/html"; |
802 | } | 796 | } |
803 | path += QPEApplication::qpeDir() + "/pics"; | 797 | path += QPEApplication::qpeDir() + "/pics"; |
804 | path += QPEApplication::qpeDir() + "/help/html"; | 798 | path += QPEApplication::qpeDir() + "/help/html"; |
805 | path += QPEApplication::qpeDir() + "/docs"; | 799 | path += QPEApplication::qpeDir() + "/docs"; |
806 | 800 | ||
807 | 801 | ||
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,163 +1,161 @@ | |||
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 |
132 | 130 | ||
133 | currentLocation = 0; // apps not movable (yet) | 131 | currentLocation = 0; // apps not movable (yet) |
134 | } | 132 | } |
135 | } | 133 | } |
136 | 134 | ||
137 | LnkProperties::~LnkProperties() | 135 | LnkProperties::~LnkProperties() |
138 | { | 136 | { |
139 | } | 137 | } |
140 | 138 | ||
141 | void LnkProperties::unlinkLnk() | 139 | void LnkProperties::unlinkLnk() |
142 | { | 140 | { |
143 | if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) { | 141 | if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) { |
144 | lnk->removeFiles(); | 142 | lnk->removeFiles(); |
145 | if ( QFile::exists(lnk->file()) ) { | 143 | if ( QFile::exists(lnk->file()) ) { |
146 | QMessageBox::warning( this, tr("Delete"), tr("File deletion failed.") ); | 144 | QMessageBox::warning( this, tr("Delete"), tr("File deletion failed.") ); |
147 | } else { | 145 | } else { |
148 | reject(); | 146 | reject(); |
149 | } | 147 | } |
150 | } | 148 | } |
151 | } | 149 | } |
152 | 150 | ||
153 | void LnkProperties::setupLocations() | 151 | void LnkProperties::setupLocations() |
154 | { | 152 | { |
155 | QFileInfo fi( lnk->file() ); | 153 | QFileInfo fi( lnk->file() ); |
156 | fileSize = fi.size(); | 154 | fileSize = fi.size(); |
157 | StorageInfo storage; | 155 | StorageInfo storage; |
158 | const QList<FileSystem> &fs = storage.fileSystems(); | 156 | const QList<FileSystem> &fs = storage.fileSystems(); |
159 | QListIterator<FileSystem> it ( fs ); | 157 | QListIterator<FileSystem> it ( fs ); |
160 | QString s; | 158 | QString s; |
161 | QString homeDir = getenv("HOME"); | 159 | QString homeDir = getenv("HOME"); |
162 | QString hardDiskHome; | 160 | QString hardDiskHome; |
163 | QString hardDiskPath; | 161 | QString hardDiskPath; |
diff --git a/library/network.cpp b/library/network.cpp index 185b147..3568809 100644 --- a/library/network.cpp +++ b/library/network.cpp | |||
@@ -1,158 +1,156 @@ | |||
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"); |
127 | } | 125 | } |
128 | 126 | ||
129 | #ifndef QT_NO_COP | 127 | #ifndef QT_NO_COP |
130 | /*! | 128 | /*! |
131 | \internal | 129 | \internal |
132 | */ | 130 | */ |
133 | QStringList Network::choices(QListBox* lb, const QString& dir) | 131 | QStringList Network::choices(QListBox* lb, const QString& dir) |
134 | { | 132 | { |
135 | QStringList list; | 133 | QStringList list; |
136 | 134 | ||
137 | if ( lb ) | 135 | if ( lb ) |
138 | lb->clear(); | 136 | lb->clear(); |
139 | 137 | ||
140 | QString adir = dir.isEmpty() ? settingsDir() : dir; | 138 | QString adir = dir.isEmpty() ? settingsDir() : dir; |
141 | QDir settingsdir(adir); | 139 | QDir settingsdir(adir); |
142 | settingsdir.mkdir(adir); | 140 | settingsdir.mkdir(adir); |
143 | 141 | ||
144 | QStringList files = settingsdir.entryList("*.conf"); | 142 | QStringList files = settingsdir.entryList("*.conf"); |
145 | for (QStringList::ConstIterator it=files.begin(); it!=files.end(); ++it ) { | 143 | for (QStringList::ConstIterator it=files.begin(); it!=files.end(); ++it ) { |
146 | QString filename = settingsdir.filePath(*it); | 144 | QString filename = settingsdir.filePath(*it); |
147 | Config cfg(filename, Config::File); | 145 | Config cfg(filename, Config::File); |
148 | cfg.setGroup("Info"); | 146 | cfg.setGroup("Info"); |
149 | if ( lb ) | 147 | if ( lb ) |
150 | lb->insertItem(Resource::loadPixmap("Network/" + cfg.readEntry("Type")), | 148 | lb->insertItem(Resource::loadPixmap("Network/" + cfg.readEntry("Type")), |
151 | cfg.readEntry("Name")); | 149 | cfg.readEntry("Name")); |
152 | list.append(filename); | 150 | list.append(filename); |
153 | } | 151 | } |
154 | 152 | ||
155 | return list; | 153 | return list; |
156 | } | 154 | } |
157 | 155 | ||
158 | class NetworkServer : public QCopChannel { | 156 | class NetworkServer : public QCopChannel { |
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,160 +1,158 @@ | |||
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 | ||
129 | /*! | 127 | /*! |
130 | \reimp | 128 | \reimp |
131 | */ | 129 | */ |
132 | 130 | ||
133 | void PasswordDialog::keyPressEvent( QKeyEvent * ) | 131 | void PasswordDialog::keyPressEvent( QKeyEvent * ) |
134 | { | 132 | { |
135 | #if 0 | 133 | #if 0 |
136 | if ( e->key() == Key_Enter || e->key() == Key_Return ) | 134 | if ( e->key() == Key_Enter || e->key() == Key_Return ) |
137 | emit passwordEntered( text ); | 135 | emit passwordEntered( text ); |
138 | else | 136 | else |
139 | input( e->text() ); | 137 | input( e->text() ); |
140 | #endif | 138 | #endif |
141 | } | 139 | } |
142 | 140 | ||
143 | 141 | ||
144 | /*! | 142 | /*! |
145 | 143 | ||
146 | */ | 144 | */ |
147 | 145 | ||
148 | void PasswordDialog::input( QString c ) | 146 | void PasswordDialog::input( QString c ) |
149 | { | 147 | { |
150 | text += c; | 148 | text += c; |
151 | display->setText( text ); | 149 | display->setText( text ); |
152 | } | 150 | } |
153 | 151 | ||
154 | /*! | 152 | /*! |
155 | 153 | ||
156 | */ | 154 | */ |
157 | 155 | ||
158 | void PasswordDialog::setPrompt( const QString& s ) | 156 | void PasswordDialog::setPrompt( const QString& s ) |
159 | { | 157 | { |
160 | prompt->setText( s ); | 158 | prompt->setText( s ); |
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,148 +1,147 @@ | |||
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 | ||
117 | class TLWidget : public QWidget | 116 | class TLWidget : public QWidget |
118 | { | 117 | { |
119 | public: | 118 | public: |
120 | QWSManager *manager() | 119 | QWSManager *manager() |
121 | { | 120 | { |
122 | return topData()->qwsManager; | 121 | return topData()->qwsManager; |
123 | } | 122 | } |
124 | 123 | ||
125 | QTLWExtra *topExtra() | 124 | QTLWExtra *topExtra() |
126 | { | 125 | { |
127 | return topData(); | 126 | return topData(); |
128 | } | 127 | } |
129 | 128 | ||
130 | void setWState( uint s ) { QWidget::setWState( s ); } | 129 | void setWState( uint s ) { QWidget::setWState( s ); } |
131 | void clearWState( uint s ) { QWidget::clearWState( s ); } | 130 | void clearWState( uint s ) { QWidget::clearWState( s ); } |
132 | }; | 131 | }; |
133 | 132 | ||
134 | 133 | ||
135 | QPEManager::QPEManager( QPEDecoration *d, QObject *parent ) | 134 | QPEManager::QPEManager( QPEDecoration *d, QObject *parent ) |
136 | : QObject( parent ), decoration( d ), helpState(0), inWhatsThis(FALSE) | 135 | : QObject( parent ), decoration( d ), helpState(0), inWhatsThis(FALSE) |
137 | { | 136 | { |
138 | wtTimer = new QTimer( this ); | 137 | wtTimer = new QTimer( this ); |
139 | connect( wtTimer, SIGNAL(timeout()), this, SLOT(whatsThisTimeout()) ); | 138 | connect( wtTimer, SIGNAL(timeout()), this, SLOT(whatsThisTimeout()) ); |
140 | } | 139 | } |
141 | 140 | ||
142 | 141 | ||
143 | void QPEManager::updateActive() | 142 | void QPEManager::updateActive() |
144 | { | 143 | { |
145 | QWidget *newActive = qApp->activeWindow(); | 144 | QWidget *newActive = qApp->activeWindow(); |
146 | if ( newActive && (QWidget*)active == newActive ) | 145 | if ( newActive && (QWidget*)active == newActive ) |
147 | return; | 146 | return; |
148 | 147 | ||
@@ -786,129 +785,128 @@ void QPEDecoration::paintButton(QPainter *painter, const QWidget *w, | |||
786 | if ( ((HackWidget *)w)->needsOk() ) | 785 | if ( ((HackWidget *)w)->needsOk() ) |
787 | b = WindowDecorationInterface::OK; | 786 | b = WindowDecorationInterface::OK; |
788 | else if ( helpExists ) | 787 | else if ( helpExists ) |
789 | b = WindowDecorationInterface::Help; | 788 | b = WindowDecorationInterface::Help; |
790 | else | 789 | else |
791 | return; | 790 | return; |
792 | break; | 791 | break; |
793 | case Help: | 792 | case Help: |
794 | b = WindowDecorationInterface::Help; | 793 | b = WindowDecorationInterface::Help; |
795 | break; | 794 | break; |
796 | case Maximize: | 795 | case Maximize: |
797 | b = WindowDecorationInterface::Maximize; | 796 | b = WindowDecorationInterface::Maximize; |
798 | break; | 797 | break; |
799 | default: | 798 | default: |
800 | return; | 799 | return; |
801 | } | 800 | } |
802 | 801 | ||
803 | WindowDecorationInterface::WindowData wd; | 802 | WindowDecorationInterface::WindowData wd; |
804 | windowData( w, wd ); | 803 | windowData( w, wd ); |
805 | 804 | ||
806 | int titleHeight = wdiface->metric(WindowDecorationInterface::TitleHeight,&wd); | 805 | int titleHeight = wdiface->metric(WindowDecorationInterface::TitleHeight,&wd); |
807 | QRect rect(w->rect()); | 806 | QRect rect(w->rect()); |
808 | QRect tr( rect.left(), rect.top() - titleHeight, rect.width(), titleHeight ); | 807 | QRect tr( rect.left(), rect.top() - titleHeight, rect.width(), titleHeight ); |
809 | QRect brect(region(w, w->rect(), type).boundingRect()); | 808 | QRect brect(region(w, w->rect(), type).boundingRect()); |
810 | 809 | ||
811 | const QColorGroup &cg = w->palette().active(); | 810 | const QColorGroup &cg = w->palette().active(); |
812 | if ( wd.flags & WindowDecorationInterface::WindowData::Active ) | 811 | if ( wd.flags & WindowDecorationInterface::WindowData::Active ) |
813 | painter->setPen( cg.color(QColorGroup::HighlightedText) ); | 812 | painter->setPen( cg.color(QColorGroup::HighlightedText) ); |
814 | else | 813 | else |
815 | painter->setPen( cg.color(QColorGroup::Text) ); | 814 | painter->setPen( cg.color(QColorGroup::Text) ); |
816 | 815 | ||
817 | QRegion oldClip = painter->clipRegion(); | 816 | QRegion oldClip = painter->clipRegion(); |
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,205 +1,201 @@ | |||
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 | } |
174 | 170 | ||
175 | void TZCombo::setCurrZone( const QString& id ) | 171 | void TZCombo::setCurrZone( const QString& id ) |
176 | { | 172 | { |
177 | for (int i=0; i< count(); i++) { | 173 | for (int i=0; i< count(); i++) { |
178 | if ( identifiers[i] == id ) { | 174 | if ( identifiers[i] == id ) { |
179 | setCurrentItem(i); | 175 | setCurrentItem(i); |
180 | return; | 176 | return; |
181 | } | 177 | } |
182 | } | 178 | } |
183 | insertItem(id); | 179 | insertItem(id); |
184 | setCurrentItem( count() - 1); | 180 | setCurrentItem( count() - 1); |
185 | identifiers.append(id); | 181 | identifiers.append(id); |
186 | extras.append(id); | 182 | extras.append(id); |
187 | } | 183 | } |
188 | 184 | ||
189 | 185 | ||
190 | 186 | ||
191 | void TZCombo::handleSystemChannel(const QCString&msg, const QByteArray&) | 187 | void TZCombo::handleSystemChannel(const QCString&msg, const QByteArray&) |
192 | { | 188 | { |
193 | if ( msg == "timeZoneListChange()" ) { | 189 | if ( msg == "timeZoneListChange()" ) { |
194 | updateZones(); | 190 | updateZones(); |
195 | } | 191 | } |
196 | } | 192 | } |
197 | 193 | ||
198 | 194 | ||
199 | TimeZoneSelector::TimeZoneSelector(QWidget* p, const char* n) : | 195 | TimeZoneSelector::TimeZoneSelector(QWidget* p, const char* n) : |
200 | QHBox(p,n) | 196 | QHBox(p,n) |
201 | { | 197 | { |
202 | d = new TimeZoneSelectorPrivate(); | 198 | d = new TimeZoneSelectorPrivate(); |
203 | // build the combobox before we do any updates... | 199 | // build the combobox before we do any updates... |
204 | cmbTz = new TZCombo( this, "timezone combo" ); | 200 | cmbTz = new TZCombo( this, "timezone combo" ); |
205 | 201 | ||