summaryrefslogtreecommitdiff
path: root/library
authorzecke <zecke>2002-11-02 13:12:09 (UTC)
committer zecke <zecke>2002-11-02 13:12:09 (UTC)
commitc795a77698b9fc785fb5f04fab8fed33f0570c3f (patch) (unidiff)
treed34d959a2e2d3937632f1eaea10fbd72cd7ac996 /library
parent87504764286a40162d74b03f26e040d4142c0cab (diff)
downloadopie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.zip
opie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.tar.gz
opie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.tar.bz2
Actually use local time in vCal
Diffstat (limited to 'library') (more/less context) (ignore whitespace changes)
-rw-r--r--library/backend/event.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/library/backend/event.cpp b/library/backend/event.cpp
index 7ccf16b..2d02a34 100644
--- a/library/backend/event.cpp
+++ b/library/backend/event.cpp
@@ -942,395 +942,395 @@ void EffectiveEvent::setDate( const QDate &dt )
942} 942}
943 943
944/*! 944/*!
945 \internal 945 \internal
946*/ 946*/
947void EffectiveEvent::setStart( const QTime &start ) 947void EffectiveEvent::setStart( const QTime &start )
948{ 948{
949 mStart = start; 949 mStart = start;
950} 950}
951 951
952/*! 952/*!
953 \internal 953 \internal
954*/ 954*/
955void EffectiveEvent::setEnd( const QTime &end ) 955void EffectiveEvent::setEnd( const QTime &end )
956{ 956{
957 mEnd = end; 957 mEnd = end;
958} 958}
959 959
960/*! 960/*!
961 \internal 961 \internal
962*/ 962*/
963void EffectiveEvent::setEvent( Event e ) 963void EffectiveEvent::setEvent( Event e )
964{ 964{
965 mEvent = e; 965 mEvent = e;
966} 966}
967 967
968/*! 968/*!
969 \internal 969 \internal
970*/ 970*/
971bool EffectiveEvent::operator<( const EffectiveEvent &e ) const 971bool EffectiveEvent::operator<( const EffectiveEvent &e ) const
972{ 972{
973 if ( mDate < e.date() ) 973 if ( mDate < e.date() )
974 return TRUE; 974 return TRUE;
975 if ( mDate == e.date() ) 975 if ( mDate == e.date() )
976 return ( mStart < e.start() ); 976 return ( mStart < e.start() );
977 else 977 else
978 return FALSE; 978 return FALSE;
979} 979}
980 980
981/*! 981/*!
982 \internal 982 \internal
983*/ 983*/
984bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const 984bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const
985{ 985{
986 return (mDate <= e.date() ); 986 return (mDate <= e.date() );
987} 987}
988 988
989/*! 989/*!
990 \internal 990 \internal
991*/ 991*/
992bool EffectiveEvent::operator==( const EffectiveEvent &e ) const 992bool EffectiveEvent::operator==( const EffectiveEvent &e ) const
993{ 993{
994 return ( mDate == e.date() 994 return ( mDate == e.date()
995 && mStart == e.start() 995 && mStart == e.start()
996 && mEnd == e.end() 996 && mEnd == e.end()
997 && mEvent == e.event() ); 997 && mEvent == e.event() );
998} 998}
999 999
1000/*! 1000/*!
1001 \internal 1001 \internal
1002*/ 1002*/
1003bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const 1003bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const
1004{ 1004{
1005 return !(*this == e); 1005 return !(*this == e);
1006} 1006}
1007 1007
1008/*! 1008/*!
1009 \internal 1009 \internal
1010*/ 1010*/
1011bool EffectiveEvent::operator>( const EffectiveEvent &e ) const 1011bool EffectiveEvent::operator>( const EffectiveEvent &e ) const
1012{ 1012{
1013 return !(*this <= e ); 1013 return !(*this <= e );
1014} 1014}
1015 1015
1016/*! 1016/*!
1017 \internal 1017 \internal
1018*/ 1018*/
1019bool EffectiveEvent::operator>=(const EffectiveEvent &e) const 1019bool EffectiveEvent::operator>=(const EffectiveEvent &e) const
1020{ 1020{
1021 return !(*this < e); 1021 return !(*this < e);
1022} 1022}
1023 1023
1024/*! 1024/*!
1025 \internal 1025 \internal
1026*/ 1026*/
1027void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to ) 1027void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to )
1028{ 1028{
1029 if ( !from.isValid() ) { 1029 if ( !from.isValid() ) {
1030 delete d; 1030 delete d;
1031 d = 0; 1031 d = 0;
1032 return; 1032 return;
1033 } 1033 }
1034 if ( !d ) 1034 if ( !d )
1035 d = new EffectiveEventPrivate; 1035 d = new EffectiveEventPrivate;
1036 d->startDate = from; 1036 d->startDate = from;
1037 d->endDate = to; 1037 d->endDate = to;
1038} 1038}
1039 1039
1040/*! 1040/*!
1041 \internal 1041 \internal
1042*/ 1042*/
1043QDate EffectiveEvent::startDate() const 1043QDate EffectiveEvent::startDate() const
1044{ 1044{
1045 if ( d ) 1045 if ( d )
1046 return d->startDate; 1046 return d->startDate;
1047 else if ( mEvent.hasRepeat() ) 1047 else if ( mEvent.hasRepeat() )
1048 return mDate; // single day, since multi-day should have a d pointer 1048 return mDate; // single day, since multi-day should have a d pointer
1049 else 1049 else
1050 return mEvent.start().date(); 1050 return mEvent.start().date();
1051} 1051}
1052 1052
1053/*! 1053/*!
1054 \internal 1054 \internal
1055*/ 1055*/
1056QDate EffectiveEvent::endDate() const 1056QDate EffectiveEvent::endDate() const
1057{ 1057{
1058 if ( d ) 1058 if ( d )
1059 return d->endDate; 1059 return d->endDate;
1060 else if ( mEvent.hasRepeat() ) 1060 else if ( mEvent.hasRepeat() )
1061 return mDate; // single day, since multi-day should have a d pointer 1061 return mDate; // single day, since multi-day should have a d pointer
1062 else 1062 else
1063 return mEvent.end().date(); 1063 return mEvent.end().date();
1064} 1064}
1065 1065
1066/*! 1066/*!
1067 \internal 1067 \internal
1068*/ 1068*/
1069int EffectiveEvent::size() const 1069int EffectiveEvent::size() const
1070{ 1070{
1071 return ( mEnd.hour() - mStart.hour() ) * 3600 1071 return ( mEnd.hour() - mStart.hour() ) * 3600
1072 + (mEnd.minute() - mStart.minute() * 60 1072 + (mEnd.minute() - mStart.minute() * 60
1073 + mEnd.second() - mStart.second() ); 1073 + mEnd.second() - mStart.second() );
1074} 1074}
1075 1075
1076 1076
1077// vcal conversion code 1077// vcal conversion code
1078static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value ) 1078static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value )
1079{ 1079{
1080 VObject *ret = 0; 1080 VObject *ret = 0;
1081 if ( o && !value.isEmpty() ) 1081 if ( o && !value.isEmpty() )
1082 ret = addPropValue( o, prop, value.latin1() ); 1082 ret = addPropValue( o, prop, value.latin1() );
1083 return ret; 1083 return ret;
1084} 1084}
1085 1085
1086static inline VObject *safeAddProp( VObject *o, const char *prop) 1086static inline VObject *safeAddProp( VObject *o, const char *prop)
1087{ 1087{
1088 VObject *ret = 0; 1088 VObject *ret = 0;
1089 if ( o ) 1089 if ( o )
1090 ret = addProp( o, prop ); 1090 ret = addProp( o, prop );
1091 return ret; 1091 return ret;
1092} 1092}
1093 1093
1094/* 1094/*
1095 * Until we support vCal/iCal right 1095 * Until we support vCal/iCal right
1096 * we will make DTSTART and other things 1096 * we will make DTSTART and other things
1097 * be floating in the sense of 1097 * be floating in the sense of
1098 * RFC 2445 1098 * RFC 2445
1099 */ 1099 */
1100namespace { 1100namespace {
1101/* 1101/*
1102 * Convert QDateTime to iso8601 but take 1102 * Convert QDateTime to iso8601 but take
1103 * local time and do not use the Z at the end 1103 * local time and do not use the Z at the end
1104 * 1104 *
1105 */ 1105 */
1106 QCString toISOLocal( const QDateTime& dt ) { 1106 QCString toISOLocal( const QDateTime& dt ) {
1107 QCString str; 1107 QCString str;
1108 /* 1108 /*
1109 * year month day T Hour Minute Second 1109 * year month day T Hour Minute Second
1110 * 4 2 2 2 2 2 digits 1110 * 4 2 2 2 2 2 digits
1111 */ 1111 */
1112 str.sprintf("%04d%02d%02dT%02d%02d%02d", 1112 str.sprintf("%04d%02d%02dT%02d%02d%02d",
1113 dt.date().year(), 1113 dt.date().year(),
1114 dt.date().month(), 1114 dt.date().month(),
1115 dt.date().year(), 1115 dt.date().year(),
1116 dt.time().hour(), 1116 dt.time().hour(),
1117 dt.time().minute(), 1117 dt.time().minute(),
1118 dt.time().second() ); 1118 dt.time().second() );
1119 1119
1120 1120
1121 1121
1122 return str; 1122 return str;
1123 } 1123 }
1124 1124
1125 1125
1126}; 1126};
1127 1127
1128static VObject *createVObject( const Event &e ) 1128static VObject *createVObject( const Event &e )
1129{ 1129{
1130 VObject *vcal = newVObject( VCCalProp ); 1130 VObject *vcal = newVObject( VCCalProp );
1131 safeAddPropValue( vcal, VCVersionProp, "1.0" ); 1131 safeAddPropValue( vcal, VCVersionProp, "1.0" );
1132 VObject *event = safeAddProp( vcal, VCEventProp ); 1132 VObject *event = safeAddProp( vcal, VCEventProp );
1133 1133
1134 safeAddPropValue( event, VCDTstartProp, TimeConversion::toISO8601( e.start() ) ); 1134 safeAddPropValue( event, VCDTstartProp, toISOLocal( e.start() ) );
1135 safeAddPropValue( event, VCDTendProp, TimeConversion::toISO8601( e.end() ) ); 1135 safeAddPropValue( event, VCDTendProp, toISOLocal( e.end() ) );
1136 safeAddPropValue( event, "X-Qtopia-NOTES", e.description() ); 1136 safeAddPropValue( event, "X-Qtopia-NOTES", e.description() );
1137 safeAddPropValue( event, VCDescriptionProp, e.description() ); 1137 safeAddPropValue( event, VCDescriptionProp, e.description() );
1138 safeAddPropValue( event, VCLocationProp, e.location() ); 1138 safeAddPropValue( event, VCLocationProp, e.location() );
1139 1139
1140 if ( e.hasAlarm() ) { 1140 if ( e.hasAlarm() ) {
1141 VObject *alarm = safeAddProp( event, VCAAlarmProp ); 1141 VObject *alarm = safeAddProp( event, VCAAlarmProp );
1142 QDateTime dt = e.start(); 1142 QDateTime dt = e.start();
1143 dt = dt.addSecs( -e.alarmTime()*60 ); 1143 dt = dt.addSecs( -e.alarmTime()*60 );
1144 safeAddPropValue( alarm, VCRunTimeProp, TimeConversion::toISO8601( dt ) ); 1144 safeAddPropValue( alarm, VCRunTimeProp, toISOLocal( dt ) );
1145 safeAddPropValue( alarm, VCAudioContentProp, 1145 safeAddPropValue( alarm, VCAudioContentProp,
1146 (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) ); 1146 (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) );
1147 } 1147 }
1148 1148
1149 safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() ); 1149 safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() );
1150 1150
1151 if ( e.type() == Event::AllDay ) 1151 if ( e.type() == Event::AllDay )
1152 safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() ); 1152 safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() );
1153 1153
1154 // ### repeat missing 1154 // ### repeat missing
1155 1155
1156 // ### categories missing 1156 // ### categories missing
1157 1157
1158 return vcal; 1158 return vcal;
1159} 1159}
1160 1160
1161 1161
1162static Event parseVObject( VObject *obj ) 1162static Event parseVObject( VObject *obj )
1163{ 1163{
1164 Event e; 1164 Event e;
1165 1165
1166 bool haveAlarm = FALSE; 1166 bool haveAlarm = FALSE;
1167 bool haveStart = FALSE; 1167 bool haveStart = FALSE;
1168 bool haveEnd = FALSE; 1168 bool haveEnd = FALSE;
1169 QDateTime alarmTime; 1169 QDateTime alarmTime;
1170 Event::SoundTypeChoice soundType = Event::Silent; 1170 Event::SoundTypeChoice soundType = Event::Silent;
1171 1171
1172 VObjectIterator it; 1172 VObjectIterator it;
1173 initPropIterator( &it, obj ); 1173 initPropIterator( &it, obj );
1174 while( moreIteration( &it ) ) { 1174 while( moreIteration( &it ) ) {
1175 VObject *o = nextVObject( &it ); 1175 VObject *o = nextVObject( &it );
1176 QCString name = vObjectName( o ); 1176 QCString name = vObjectName( o );
1177 QCString value = vObjectStringZValue( o ); 1177 QCString value = vObjectStringZValue( o );
1178 if ( name == VCDTstartProp ) { 1178 if ( name == VCDTstartProp ) {
1179 e.setStart( TimeConversion::fromISO8601( value ) ); 1179 e.setStart( TimeConversion::fromISO8601( value ) );
1180 haveStart = TRUE; 1180 haveStart = TRUE;
1181 } 1181 }
1182 else if ( name == VCDTendProp ) { 1182 else if ( name == VCDTendProp ) {
1183 e.setEnd( TimeConversion::fromISO8601( value ) ); 1183 e.setEnd( TimeConversion::fromISO8601( value ) );
1184 haveEnd = TRUE; 1184 haveEnd = TRUE;
1185 } 1185 }
1186 else if ( name == "X-Qtopia-NOTES" ) { 1186 else if ( name == "X-Qtopia-NOTES" ) {
1187 e.setNotes( value ); 1187 e.setNotes( value );
1188 } 1188 }
1189 else if ( name == VCDescriptionProp ) { 1189 else if ( name == VCDescriptionProp ) {
1190 e.setDescription( value ); 1190 e.setDescription( value );
1191 } 1191 }
1192 else if ( name == VCLocationProp ) { 1192 else if ( name == VCLocationProp ) {
1193 e.setLocation( value ); 1193 e.setLocation( value );
1194 } 1194 }
1195 else if ( name == VCAudioContentProp ) { 1195 else if ( name == VCAudioContentProp ) {
1196 haveAlarm = TRUE; 1196 haveAlarm = TRUE;
1197 VObjectIterator nit; 1197 VObjectIterator nit;
1198 initPropIterator( &nit, o ); 1198 initPropIterator( &nit, o );
1199 while( moreIteration( &nit ) ) { 1199 while( moreIteration( &nit ) ) {
1200 VObject *o = nextVObject( &nit ); 1200 VObject *o = nextVObject( &nit );
1201 QCString name = vObjectName( o ); 1201 QCString name = vObjectName( o );
1202 QCString value = vObjectStringZValue( o ); 1202 QCString value = vObjectStringZValue( o );
1203 if ( name == VCRunTimeProp ) 1203 if ( name == VCRunTimeProp )
1204 alarmTime = TimeConversion::fromISO8601( value ); 1204 alarmTime = TimeConversion::fromISO8601( value );
1205 else if ( name == VCAudioContentProp ) { 1205 else if ( name == VCAudioContentProp ) {
1206 if ( value == "silent" ) 1206 if ( value == "silent" )
1207 soundType = Event::Silent; 1207 soundType = Event::Silent;
1208 else 1208 else
1209 soundType = Event::Loud; 1209 soundType = Event::Loud;
1210 } 1210 }
1211 } 1211 }
1212 } 1212 }
1213 else if ( name == "X-Qtopia-TIMEZONE") { 1213 else if ( name == "X-Qtopia-TIMEZONE") {
1214 e.setTimeZone( value ); 1214 e.setTimeZone( value );
1215 } 1215 }
1216 else if ( name == "X-Qtopia-AllDay" ) { 1216 else if ( name == "X-Qtopia-AllDay" ) {
1217 e.setType( Event::AllDay ); 1217 e.setType( Event::AllDay );
1218 } 1218 }
1219#if 0 1219#if 0
1220 else { 1220 else {
1221 printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); 1221 printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) );
1222 VObjectIterator nit; 1222 VObjectIterator nit;
1223 initPropIterator( &nit, o ); 1223 initPropIterator( &nit, o );
1224 while( moreIteration( &nit ) ) { 1224 while( moreIteration( &nit ) ) {
1225 VObject *o = nextVObject( &nit ); 1225 VObject *o = nextVObject( &nit );
1226 QCString name = vObjectName( o ); 1226 QCString name = vObjectName( o );
1227 QString value = vObjectStringZValue( o ); 1227 QString value = vObjectStringZValue( o );
1228 printf(" subprop: %s = %s\n", name.data(), value.latin1() ); 1228 printf(" subprop: %s = %s\n", name.data(), value.latin1() );
1229 } 1229 }
1230 } 1230 }
1231#endif 1231#endif
1232 } 1232 }
1233 1233
1234 if ( !haveStart && !haveEnd ) 1234 if ( !haveStart && !haveEnd )
1235 e.setStart( QDateTime::currentDateTime() ); 1235 e.setStart( QDateTime::currentDateTime() );
1236 1236
1237 if ( !haveEnd ) { 1237 if ( !haveEnd ) {
1238 e.setType( Event::AllDay ); 1238 e.setType( Event::AllDay );
1239 e.setEnd( e.start() ); 1239 e.setEnd( e.start() );
1240 } 1240 }
1241 1241
1242 if ( haveAlarm ) { 1242 if ( haveAlarm ) {
1243 int minutes = alarmTime.secsTo( e.start() ) / 60; 1243 int minutes = alarmTime.secsTo( e.start() ) / 60;
1244 e.setAlarm( TRUE, minutes, soundType ); 1244 e.setAlarm( TRUE, minutes, soundType );
1245 } 1245 }
1246 return e; 1246 return e;
1247} 1247}
1248 1248
1249 1249
1250/*! 1250/*!
1251 Writes the list of \a events as a set of VCards to the file \a filename. 1251 Writes the list of \a events as a set of VCards to the file \a filename.
1252*/ 1252*/
1253void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events) 1253void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events)
1254{ 1254{
1255 1255
1256 QFileDirect f( filename.utf8().data() ); 1256 QFileDirect f( filename.utf8().data() );
1257 1257
1258 if ( !f.open( IO_WriteOnly ) ) { 1258 if ( !f.open( IO_WriteOnly ) ) {
1259 1259
1260 qWarning("Unable to open vcard write"); 1260 qWarning("Unable to open vcard write");
1261 1261
1262 return; 1262 return;
1263 1263
1264 } 1264 }
1265 1265
1266 1266
1267 QValueList<Event>::ConstIterator it; 1267 QValueList<Event>::ConstIterator it;
1268 for( it = events.begin(); it != events.end(); ++it ) { 1268 for( it = events.begin(); it != events.end(); ++it ) {
1269 VObject *obj = createVObject( *it ); 1269 VObject *obj = createVObject( *it );
1270 writeVObject( f.directHandle() , obj ); 1270 writeVObject( f.directHandle() , obj );
1271 cleanVObject( obj ); 1271 cleanVObject( obj );
1272 } 1272 }
1273 1273
1274 1274
1275 cleanStrTbl(); 1275 cleanStrTbl();
1276} 1276}
1277 1277
1278/*! 1278/*!
1279 Writes \a event as a VCard to the file \a filename. 1279 Writes \a event as a VCard to the file \a filename.
1280*/ 1280*/
1281void Event::writeVCalendar( const QString &filename, const Event &event) 1281void Event::writeVCalendar( const QString &filename, const Event &event)
1282{ 1282{
1283 1283
1284 QFileDirect f( filename.utf8().data() ); 1284 QFileDirect f( filename.utf8().data() );
1285 1285
1286 if ( !f.open( IO_WriteOnly ) ) { 1286 if ( !f.open( IO_WriteOnly ) ) {
1287 1287
1288 qWarning("Unable to open vcard write"); 1288 qWarning("Unable to open vcard write");
1289 1289
1290 return; 1290 return;
1291 1291
1292 } 1292 }
1293 1293
1294 1294
1295 VObject *obj = createVObject( event ); 1295 VObject *obj = createVObject( event );
1296 writeVObject( f.directHandle() , obj ); 1296 writeVObject( f.directHandle() , obj );
1297 cleanVObject( obj ); 1297 cleanVObject( obj );
1298 1298
1299 cleanStrTbl(); 1299 cleanStrTbl();
1300} 1300}
1301 1301
1302/*! 1302/*!
1303 Returns the set of events read as VCards from the file \a filename. 1303 Returns the set of events read as VCards from the file \a filename.
1304*/ 1304*/
1305QValueList<Event> Event::readVCalendar( const QString &filename ) 1305QValueList<Event> Event::readVCalendar( const QString &filename )
1306{ 1306{
1307 VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() ); 1307 VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() );
1308 1308
1309 QValueList<Event> events; 1309 QValueList<Event> events;
1310 1310
1311 while ( obj ) { 1311 while ( obj ) {
1312 QCString name = vObjectName( obj ); 1312 QCString name = vObjectName( obj );
1313 if ( name == VCCalProp ) { 1313 if ( name == VCCalProp ) {
1314 VObjectIterator nit; 1314 VObjectIterator nit;
1315 initPropIterator( &nit, obj ); 1315 initPropIterator( &nit, obj );
1316 while( moreIteration( &nit ) ) { 1316 while( moreIteration( &nit ) ) {
1317 VObject *o = nextVObject( &nit ); 1317 VObject *o = nextVObject( &nit );
1318 QCString name = vObjectName( o ); 1318 QCString name = vObjectName( o );
1319 if ( name == VCEventProp ) 1319 if ( name == VCEventProp )
1320 events.append( parseVObject( o ) ); 1320 events.append( parseVObject( o ) );
1321 } 1321 }
1322 } else if ( name == VCEventProp ) { 1322 } else if ( name == VCEventProp ) {
1323 // shouldn't happen, but just to be sure 1323 // shouldn't happen, but just to be sure
1324 events.append( parseVObject( obj ) ); 1324 events.append( parseVObject( obj ) );
1325 } 1325 }
1326 VObject *t = obj; 1326 VObject *t = obj;
1327 obj = nextVObjectInList(obj); 1327 obj = nextVObjectInList(obj);
1328 cleanVObject( t ); 1328 cleanVObject( t );
1329 } 1329 }
1330 1330
1331 return events; 1331 return events;
1332} 1332}
1333 1333
1334bool Event::match( const QRegExp &r ) const 1334bool Event::match( const QRegExp &r ) const
1335{ 1335{
1336 bool returnMe; 1336 bool returnMe;