-rw-r--r-- | library/tzselect.cpp | 125 |
1 files changed, 63 insertions, 62 deletions
diff --git a/library/tzselect.cpp b/library/tzselect.cpp index 6cc0bea..e16b8d4 100644 --- a/library/tzselect.cpp +++ b/library/tzselect.cpp | |||
@@ -43,39 +43,39 @@ TZCombo::TZCombo( QWidget *p, const char* n ) | |||
43 | : QComboBox( p, n ) | 43 | : QComboBox( p, n ) |
44 | { | 44 | { |
45 | updateZones(); | 45 | updateZones(); |
46 | // check to see if TZ is set, if it is set the current item to that | 46 | // check to see if TZ is set, if it is set the current item to that |
47 | QString tz = getenv("TZ"); | 47 | QString tz = getenv("TZ"); |
48 | if (parent()->inherits("TimeZoneSelector")) { | 48 | if (parent()->inherits("TimeZoneSelector")) { |
49 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { | 49 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { |
50 | // overide to the 'local' type. | 50 | // overide to the 'local' type. |
51 | tz = "None"; | 51 | tz = "None"; |
52 | } | 52 | } |
53 | } | 53 | } |
54 | if ( !tz.isNull() ) { | 54 | if ( !tz.isNull() ) { |
55 | int n = 0, | 55 | int n = 0, |
56 | index = 0; | 56 | index = 0; |
57 | for ( QStringList::Iterator it=identifiers.begin(); | 57 | for ( QStringList::Iterator it=identifiers.begin(); |
58 | it!=identifiers.end(); ++it) { | 58 | it!=identifiers.end(); ++it) { |
59 | if ( *it == tz ) | 59 | if ( *it == tz ) |
60 | index = n; | 60 | index = n; |
61 | n++; | 61 | n++; |
62 | } | 62 | } |
63 | setCurrentItem(index); | 63 | setCurrentItem(index); |
64 | } else { | 64 | } else { |
65 | setCurrentItem(0); | 65 | setCurrentItem(0); |
66 | } | 66 | } |
67 | 67 | ||
68 | 68 | ||
69 | 69 | ||
70 | // listen on QPE/System | 70 | // listen on QPE/System |
71 | #if defined(Q_WS_QWS) | 71 | #if defined(Q_WS_QWS) |
72 | #if !defined(QT_NO_COP) | 72 | #if !defined(QT_NO_COP) |
73 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); | 73 | QCopChannel *channel = new QCopChannel( "QPE/System", this ); |
74 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 74 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
75 | this, SLOT(handleSystemChannel(const QCString&, const QByteArray&)) ); | 75 | this, SLOT(handleSystemChannel(const QCString&, const QByteArray&)) ); |
76 | #endif | 76 | #endif |
77 | #endif | 77 | #endif |
78 | 78 | ||
79 | 79 | ||
80 | } | 80 | } |
81 | 81 | ||
@@ -92,65 +92,65 @@ void TZCombo::updateZones() | |||
92 | QString tz = getenv("TZ"); | 92 | QString tz = getenv("TZ"); |
93 | bool tzFound = FALSE; | 93 | bool tzFound = FALSE; |
94 | Config cfg("WorldTime"); | 94 | Config cfg("WorldTime"); |
95 | cfg.setGroup("TimeZones"); | 95 | cfg.setGroup("TimeZones"); |
96 | int listIndex = 0; | 96 | int listIndex = 0; |
97 | if (parent()->inherits("TimeZoneSelector")) { | 97 | if (parent()->inherits("TimeZoneSelector")) { |
98 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { | 98 | if ( ((TimeZoneSelector *)parent())->localIncluded() ) { |
99 | // overide to the 'local' type. | 99 | // overide to the 'local' type. |
100 | identifiers.append( "None" ); | 100 | identifiers.append( "None" ); |
101 | insertItem( tr("None") ); | 101 | insertItem( tr("None") ); |
102 | if ( cur == tr("None")) | 102 | if ( cur == tr("None")) |
103 | curix = 0; | 103 | curix = 0; |
104 | listIndex++; | 104 | listIndex++; |
105 | } | 105 | } |
106 | } | 106 | } |
107 | int cfgIndex = 0; | 107 | int cfgIndex = 0; |
108 | while (1) { | 108 | while (1) { |
109 | QString zn = cfg.readEntry("Zone"+QString::number(cfgIndex), QString::null); | 109 | QString zn = cfg.readEntry("Zone"+QString::number(cfgIndex), QString::null); |
110 | if ( zn.isNull() ) | 110 | if ( zn.isNull() ) |
111 | break; | 111 | break; |
112 | if ( zn == tz ) | 112 | if ( zn == tz ) |
113 | tzFound = TRUE; | 113 | tzFound = TRUE; |
114 | QString nm = cfg.readEntry("ZoneName"+QString::number(cfgIndex)); | 114 | QString nm = cfg.readEntry("ZoneName"+QString::number(cfgIndex)); |
115 | identifiers.append(zn); | 115 | identifiers.append(zn); |
116 | insertItem(nm); | 116 | insertItem(nm); |
117 | if ( nm == cur ) | 117 | if ( nm == cur ) |
118 | curix = listIndex; | 118 | curix = listIndex; |
119 | ++cfgIndex; | 119 | ++cfgIndex; |
120 | ++listIndex; | 120 | ++listIndex; |
121 | } | 121 | } |
122 | if ( !listIndex ) { | 122 | if ( !listIndex ) { |
123 | QStringList list = timezoneDefaults(); | 123 | QStringList list = timezoneDefaults(); |
124 | for ( QStringList::Iterator it = list.begin(); it!=list.end(); ++it ) { | 124 | for ( QStringList::Iterator it = list.begin(); it!=list.end(); ++it ) { |
125 | QString zn = *it; | 125 | QString zn = *it; |
126 | QString nm = *++it; | 126 | QString nm = *++it; |
127 | if ( zn == tz ) | 127 | if ( zn == tz ) |
128 | tzFound = TRUE; | 128 | tzFound = TRUE; |
129 | if ( nm == cur ) | 129 | if ( nm == cur ) |
130 | curix = listIndex; | 130 | curix = listIndex; |
131 | identifiers.append(zn); | 131 | identifiers.append(zn); |
132 | insertItem(nm); | 132 | insertItem(nm); |
133 | ++listIndex; | 133 | ++listIndex; |
134 | } | 134 | } |
135 | } | 135 | } |
136 | for (QStringList::Iterator it=extras.begin(); it!=extras.end(); ++it) { | 136 | for (QStringList::Iterator it=extras.begin(); it!=extras.end(); ++it) { |
137 | insertItem(*it); | 137 | insertItem(*it); |
138 | identifiers.append(*it); | 138 | identifiers.append(*it); |
139 | if ( *it == cur ) | 139 | if ( *it == cur ) |
140 | curix = listIndex; | 140 | curix = listIndex; |
141 | ++listIndex; | 141 | ++listIndex; |
142 | } | 142 | } |
143 | if ( !tzFound && !tz.isEmpty()) { | 143 | if ( !tzFound && !tz.isEmpty()) { |
144 | int i = tz.find( '/' ); | 144 | int i = tz.find( '/' ); |
145 | QString nm = tz.mid( i+1 ).replace(QRegExp("_"), " "); | 145 | QString nm = tz.mid( i+1 ).replace(QRegExp("_"), " "); |
146 | identifiers.append(tz); | 146 | identifiers.append(tz); |
147 | insertItem(nm); | 147 | insertItem(nm); |
148 | if ( nm == cur ) | 148 | if ( nm == cur ) |
149 | curix = listIndex; | 149 | curix = listIndex; |
150 | ++listIndex; | 150 | ++listIndex; |
151 | } | 151 | } |
152 | setCurrentItem(curix); | 152 | setCurrentItem(curix); |
153 | } | 153 | } |
154 | 154 | ||
155 | 155 | ||
156 | void TZCombo::keyPressEvent( QKeyEvent *e ) | 156 | void TZCombo::keyPressEvent( QKeyEvent *e ) |
@@ -172,29 +172,29 @@ QString TZCombo::currZone() const | |||
172 | return identifiers[currentItem()]; | 172 | return identifiers[currentItem()]; |
173 | } | 173 | } |
174 | 174 | ||
175 | void TZCombo::setCurrZone( const QString& id ) | 175 | void TZCombo::setCurrZone( const QString& id ) |
176 | { | 176 | { |
177 | for (int i=0; i< count(); i++) { | 177 | for (int i=0; i< count(); i++) { |
178 | if ( identifiers[i] == id ) { | 178 | if ( identifiers[i] == id ) { |
179 | setCurrentItem(i); | 179 | setCurrentItem(i); |
180 | return; | 180 | return; |
181 | } | 181 | } |
182 | } | 182 | } |
183 | insertItem(id); | 183 | insertItem(id); |
184 | setCurrentItem( count() - 1); | 184 | setCurrentItem( count() - 1); |
185 | identifiers.append(id); | 185 | identifiers.append(id); |
186 | extras.append(id); | 186 | extras.append(id); |
187 | } | 187 | } |
188 | 188 | ||
189 | 189 | ||
190 | 190 | ||
191 | void TZCombo::handleSystemChannel(const QCString&msg, const QByteArray&) | 191 | void TZCombo::handleSystemChannel(const QCString&msg, const QByteArray&) |
192 | { | 192 | { |
193 | if ( msg == "timeZoneListChange()" ) { | 193 | if ( msg == "timeZoneListChange()" ) { |
194 | updateZones(); | 194 | updateZones(); |
195 | } | 195 | } |
196 | } | 196 | } |
197 | 197 | ||
198 | 198 | ||
199 | TimeZoneSelector::TimeZoneSelector(QWidget* p, const char* n) : | 199 | TimeZoneSelector::TimeZoneSelector(QWidget* p, const char* n) : |
200 | QHBox(p,n) | 200 | QHBox(p,n) |
@@ -246,29 +246,30 @@ void TimeZoneSelector::slotTzActive( int ) | |||
246 | emit signalNewTz( cmbTz->currZone() ); | 246 | emit signalNewTz( cmbTz->currZone() ); |
247 | } | 247 | } |
248 | 248 | ||
249 | void TimeZoneSelector::slotExecute( void ) | 249 | void TimeZoneSelector::slotExecute( void ) |
250 | { | 250 | { |
251 | // execute the world time application... | 251 | // execute the world time application... |
252 | Global::execute( "worldtime" ); | 252 | Global::execute( "citytime" ); |
253 | } | 253 | } |
254 | 254 | ||
255 | QStringList timezoneDefaults( void ) | 255 | QStringList timezoneDefaults( void ) |
256 | { | 256 | { |
257 | QStringList tzs; | 257 | QStringList tzs; |
258 | // load up the list just like the file format (citytime.cpp) | 258 | // load up the list just like the file format (citytime.cpp) |
259 | tzs.append( "America/New_York" ); | 259 | tzs.append( "America/New_York" ); |
260 | tzs.append( "New York" ); | 260 | tzs.append( "New York" ); |
261 | tzs.append( "America/Los_Angeles" ); | 261 | tzs.append( "America/Los_Angeles" ); |
262 | tzs.append( "Los Angeles" ); | 262 | tzs.append( "Los Angeles" ); |
263 | tzs.append( "Australia/Brisbane" ); | 263 | tzs.append( "Australia/Brisbane" ); |
264 | tzs.append( "Brisbane" ); | 264 | tzs.append( "Brisbane" ); |
265 | tzs.append( "Europe/Oslo" ); | 265 | tzs.append( "Europe/Berlin" ); |
266 | tzs.append( "Oslo" ); | 266 | tzs.append( "Berlin" ); |
267 | tzs.append( "Asia/Tokyo" ); | 267 | tzs.append( "Asia/Tokyo" ); |
268 | tzs.append( "Tokyo" ); | 268 | tzs.append( "Tokyo" ); |
269 | tzs.append( "Asia/Hong_Kong" ); | 269 | tzs.append( "America/Denver" ); |
270 | tzs.append( "Hong Kong" ); | 270 | tzs.append( "Denver" ); |
271 | |||
271 | return tzs; | 272 | return tzs; |
272 | } | 273 | } |
273 | 274 | ||
274 | 275 | ||