-rw-r--r-- | libkcal/calendarlocal.cpp | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/libkcal/calendarlocal.cpp b/libkcal/calendarlocal.cpp index 45e3128..2a57724 100644 --- a/libkcal/calendarlocal.cpp +++ b/libkcal/calendarlocal.cpp | |||
@@ -129,145 +129,155 @@ bool CalendarLocal::mergeCalendar( Calendar* remote ) | |||
129 | { | 129 | { |
130 | // 1 look for raw inc in local | 130 | // 1 look for raw inc in local |
131 | // if inc not in remote, delete in local | 131 | // if inc not in remote, delete in local |
132 | // 2 look for raw inc in remote | 132 | // 2 look for raw inc in remote |
133 | // if inc in local, replace it | 133 | // if inc in local, replace it |
134 | // if not in local, add it to default calendar | 134 | // if not in local, add it to default calendar |
135 | QPtrList<Incidence> localInc = rawIncidences(); | 135 | QPtrList<Incidence> localInc = rawIncidences(); |
136 | Incidence* inL = localInc.first(); | 136 | Incidence* inL = localInc.first(); |
137 | while ( inL ) { | 137 | while ( inL ) { |
138 | if ( ! inL->isReadOnly () ) | 138 | if ( ! inL->isReadOnly () ) |
139 | if ( !remote->incidenceForUid( inL->uid(), true )) | 139 | if ( !remote->incidenceForUid( inL->uid(), true )) |
140 | deleteIncidence( inL ); | 140 | deleteIncidence( inL ); |
141 | inL = localInc.next(); | 141 | inL = localInc.next(); |
142 | } | 142 | } |
143 | QPtrList<Incidence> er = remote->rawIncidences(); | 143 | QPtrList<Incidence> er = remote->rawIncidences(); |
144 | Incidence* inR = er.first(); | 144 | Incidence* inR = er.first(); |
145 | while ( inR ) { | 145 | while ( inR ) { |
146 | inL = incidenceForUid( inR->uid(),false ); | 146 | inL = incidenceForUid( inR->uid(),false ); |
147 | if ( inL ) { | 147 | if ( inL ) { |
148 | if ( ! inL->isReadOnly () || inL->uid().left(15) == QString("last-syncEvent-") ) { | 148 | if ( ! inL->isReadOnly () || inL->uid().left(15) == QString("last-syncEvent-") ) { |
149 | int calID = inL->calID(); | 149 | int calID = inL->calID(); |
150 | deleteIncidence( inL ); | 150 | deleteIncidence( inL ); |
151 | inL = inR->clone(); | 151 | inL = inR->clone(); |
152 | inL->setCalID( calID ); | 152 | inL->setCalID( calID ); |
153 | addIncidence( inL ); | 153 | addIncidence( inL ); |
154 | } | 154 | } |
155 | } else { | 155 | } else { |
156 | inL = inR->clone(); | 156 | inL = inR->clone(); |
157 | inL->setCalID( 0 );// add to default cal | 157 | inL->setCalID( 0 );// add to default cal |
158 | addIncidence( inL ); | 158 | addIncidence( inL ); |
159 | } | 159 | } |
160 | inR = er.next(); | 160 | inR = er.next(); |
161 | } | 161 | } |
162 | return true; | 162 | return true; |
163 | } | 163 | } |
164 | 164 | ||
165 | 165 | ||
166 | bool CalendarLocal::addCalendarFile( QString name, int id ) | 166 | bool CalendarLocal::addCalendarFile( QString name, int id ) |
167 | { | 167 | { |
168 | CalendarLocal calendar( timeZoneId() ); | 168 | CalendarLocal calendar( timeZoneId() ); |
169 | calendar.setDefaultCalendar( id ); | 169 | calendar.setDefaultCalendar( id ); |
170 | if ( calendar.load( name ) ) { | 170 | if ( calendar.load( name ) ) { |
171 | addCalendar( &calendar ); | 171 | addCalendar( &calendar ); |
172 | return true; | 172 | return true; |
173 | } | 173 | } |
174 | return false; | 174 | return false; |
175 | } | 175 | } |
176 | void CalendarLocal::setSyncEventsEnabled() | 176 | void CalendarLocal::setSyncEventsEnabled() |
177 | { | 177 | { |
178 | Event * ev; | 178 | Event * ev; |
179 | ev = mEventList.first(); | 179 | ev = mEventList.first(); |
180 | while ( ev ) { | 180 | while ( ev ) { |
181 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) | 181 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) |
182 | ev->setCalEnabled( true ); | 182 | ev->setCalEnabled( true ); |
183 | ev = mEventList.next(); | 183 | ev = mEventList.next(); |
184 | } | 184 | } |
185 | } | 185 | } |
186 | void CalendarLocal::setSyncEventsReadOnly() | 186 | void CalendarLocal::setSyncEventsReadOnly() |
187 | { | 187 | { |
188 | Event * ev; | 188 | Event * ev; |
189 | ev = mEventList.first(); | 189 | ev = mEventList.first(); |
190 | while ( ev ) { | 190 | while ( ev ) { |
191 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) { | 191 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) { |
192 | ev->setReadOnly( true ); | 192 | ev->setReadOnly( true ); |
193 | ev->setCalID( 1 ); | ||
194 | } | 193 | } |
195 | ev = mEventList.next(); | 194 | ev = mEventList.next(); |
196 | } | 195 | } |
197 | } | 196 | } |
197 | |||
198 | void CalendarLocal::addCalendar( Calendar* cal ) | 198 | void CalendarLocal::addCalendar( Calendar* cal ) |
199 | { | 199 | { |
200 | cal->setDontDeleteIncidencesOnClose(); | 200 | cal->setDontDeleteIncidencesOnClose(); |
201 | setSyncEventsEnabled(); | ||
201 | { | 202 | { |
202 | QPtrList<Event> EventList = cal->rawEvents(); | 203 | QPtrList<Event> EventList = cal->rawEvents(); |
204 | QPtrList<Event> el; | ||
203 | Event * ev = EventList.first(); | 205 | Event * ev = EventList.first(); |
204 | while ( ev ) { | 206 | while ( ev ) { |
207 | if ( ev->uid().left( 15 ) == QString("last-syncEvent-") ) { | ||
208 | Event * se = event( ev->uid() ); | ||
209 | if ( se ) | ||
210 | el.append( se ); | ||
211 | } | ||
205 | ev->unRegisterObserver( cal ); | 212 | ev->unRegisterObserver( cal ); |
206 | ev->registerObserver( this ); | 213 | ev->registerObserver( this ); |
207 | mEventList.append( ev ); | 214 | mEventList.append( ev ); |
208 | ev = EventList.next(); | 215 | ev = EventList.next(); |
209 | } | 216 | } |
217 | for ( ev = el.first(); ev; ev = el.next() ) { | ||
218 | deleteIncidence ( ev ); | ||
219 | } | ||
210 | } | 220 | } |
211 | { | 221 | { |
212 | 222 | ||
213 | QPtrList<Todo> TodoList = cal->rawTodos(); | 223 | QPtrList<Todo> TodoList = cal->rawTodos(); |
214 | Todo * ev = TodoList.first(); | 224 | Todo * ev = TodoList.first(); |
215 | while ( ev ) { | 225 | while ( ev ) { |
216 | QString rel = ev->relatedToUid(); | 226 | QString rel = ev->relatedToUid(); |
217 | if ( !rel.isEmpty() ){ | 227 | if ( !rel.isEmpty() ){ |
218 | ev->setRelatedTo ( 0 ); | 228 | ev->setRelatedTo ( 0 ); |
219 | ev->setRelatedToUid( rel ); | 229 | ev->setRelatedToUid( rel ); |
220 | } | 230 | } |
221 | ev = TodoList.next(); | 231 | ev = TodoList.next(); |
222 | } | 232 | } |
223 | //TodoList = cal->rawTodos(); | 233 | //TodoList = cal->rawTodos(); |
224 | ev = TodoList.first(); | 234 | ev = TodoList.first(); |
225 | while ( ev ) { | 235 | while ( ev ) { |
226 | ev->unRegisterObserver( cal ); | 236 | ev->unRegisterObserver( cal ); |
227 | ev->registerObserver( this ); | 237 | ev->registerObserver( this ); |
228 | mTodoList.append( ev ); | 238 | mTodoList.append( ev ); |
229 | setupRelations( ev ); | 239 | setupRelations( ev ); |
230 | ev = TodoList.next(); | 240 | ev = TodoList.next(); |
231 | } | 241 | } |
232 | } | 242 | } |
233 | { | 243 | { |
234 | QPtrList<Journal> JournalList = cal->journals(); | 244 | QPtrList<Journal> JournalList = cal->journals(); |
235 | Journal * ev = JournalList.first(); | 245 | Journal * ev = JournalList.first(); |
236 | while ( ev ) { | 246 | while ( ev ) { |
237 | ev->unRegisterObserver( cal ); | 247 | ev->unRegisterObserver( cal ); |
238 | ev->registerObserver( this ); | 248 | ev->registerObserver( this ); |
239 | mJournalList.append( ev ); | 249 | mJournalList.append( ev ); |
240 | ev = JournalList.next(); | 250 | ev = JournalList.next(); |
241 | } | 251 | } |
242 | } | 252 | } |
243 | setModified( true ); | 253 | setModified( true ); |
244 | } | 254 | } |
245 | bool CalendarLocal::load( const QString &fileName ) | 255 | bool CalendarLocal::load( const QString &fileName ) |
246 | { | 256 | { |
247 | FileStorage storage( this, fileName ); | 257 | FileStorage storage( this, fileName ); |
248 | return storage.load(); | 258 | return storage.load(); |
249 | } | 259 | } |
250 | 260 | ||
251 | bool CalendarLocal::save( const QString &fileName, CalFormat *format ) | 261 | bool CalendarLocal::save( const QString &fileName, CalFormat *format ) |
252 | { | 262 | { |
253 | FileStorage storage( this, fileName, format ); | 263 | FileStorage storage( this, fileName, format ); |
254 | return storage.save(); | 264 | return storage.save(); |
255 | } | 265 | } |
256 | 266 | ||
257 | void CalendarLocal::stopAllTodos() | 267 | void CalendarLocal::stopAllTodos() |
258 | { | 268 | { |
259 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | 269 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) |
260 | it->setRunning( false ); | 270 | it->setRunning( false ); |
261 | 271 | ||
262 | } | 272 | } |
263 | void CalendarLocal::close() | 273 | void CalendarLocal::close() |
264 | { | 274 | { |
265 | 275 | ||
266 | Todo * i; | 276 | Todo * i; |
267 | for( i = mTodoList.first(); i; i = mTodoList.next() ) i->setRunning(false); | 277 | for( i = mTodoList.first(); i; i = mTodoList.next() ) i->setRunning(false); |
268 | 278 | ||
269 | mEventList.setAutoDelete( true ); | 279 | mEventList.setAutoDelete( true ); |
270 | mTodoList.setAutoDelete( true ); | 280 | mTodoList.setAutoDelete( true ); |
271 | mJournalList.setAutoDelete( true ); | 281 | mJournalList.setAutoDelete( true ); |
272 | 282 | ||
273 | mEventList.clear(); | 283 | mEventList.clear(); |
@@ -942,115 +952,128 @@ Journal *CalendarLocal::journal( const QDate &date ) | |||
942 | return it; | 952 | return it; |
943 | 953 | ||
944 | return 0; | 954 | return 0; |
945 | } | 955 | } |
946 | 956 | ||
947 | Journal *CalendarLocal::journal( const QString &uid ) | 957 | Journal *CalendarLocal::journal( const QString &uid ) |
948 | { | 958 | { |
949 | Journal * retVal = 0; | 959 | Journal * retVal = 0; |
950 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 960 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
951 | if ( it->calEnabled() && it->uid() == uid ) { | 961 | if ( it->calEnabled() && it->uid() == uid ) { |
952 | if ( retVal ) { | 962 | if ( retVal ) { |
953 | if ( retVal->calID() > it->calID() ) { | 963 | if ( retVal->calID() > it->calID() ) { |
954 | retVal = it; | 964 | retVal = it; |
955 | } | 965 | } |
956 | } else { | 966 | } else { |
957 | retVal = it; | 967 | retVal = it; |
958 | } | 968 | } |
959 | } | 969 | } |
960 | return retVal; | 970 | return retVal; |
961 | } | 971 | } |
962 | 972 | ||
963 | QPtrList<Journal> CalendarLocal::journals() | 973 | QPtrList<Journal> CalendarLocal::journals() |
964 | { | 974 | { |
965 | QPtrList<Journal> el; | 975 | QPtrList<Journal> el; |
966 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 976 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
967 | if ( it->calEnabled() ) el.append( it ); | 977 | if ( it->calEnabled() ) el.append( it ); |
968 | return el; | 978 | return el; |
969 | } | 979 | } |
970 | void CalendarLocal::setCalendarRemove( int id ) | 980 | void CalendarLocal::setCalendarRemove( int id ) |
971 | { | 981 | { |
972 | 982 | ||
973 | { | 983 | { |
974 | QPtrList<Event> EventList = mEventList; | 984 | QPtrList<Event> EventList = mEventList; |
975 | Event * ev = EventList.first(); | 985 | Event * ev = EventList.first(); |
976 | while ( ev ) { | 986 | while ( ev ) { |
977 | if ( ev->calID() == id ) | 987 | if ( ev->calID() == id ) |
978 | deleteEvent( ev ); | 988 | deleteEvent( ev ); |
979 | ev = EventList.next(); | 989 | ev = EventList.next(); |
980 | } | 990 | } |
981 | } | 991 | } |
982 | { | 992 | { |
983 | 993 | ||
984 | QPtrList<Todo> TodoList = mTodoList; | 994 | QPtrList<Todo> TodoList = mTodoList; |
985 | Todo * ev = TodoList.first(); | 995 | Todo * ev = TodoList.first(); |
986 | while ( ev ) { | 996 | while ( ev ) { |
987 | if ( ev->calID() == id ) | 997 | if ( ev->calID() == id ) |
988 | deleteTodo( ev ); | 998 | deleteTodo( ev ); |
989 | ev = TodoList.next(); | 999 | ev = TodoList.next(); |
990 | } | 1000 | } |
991 | } | 1001 | } |
992 | { | 1002 | { |
993 | QPtrList<Journal> JournalList = mJournalList; | 1003 | QPtrList<Journal> JournalList = mJournalList; |
994 | Journal * ev = JournalList.first(); | 1004 | Journal * ev = JournalList.first(); |
995 | while ( ev ) { | 1005 | while ( ev ) { |
996 | if ( ev->calID() == id ) | 1006 | if ( ev->calID() == id ) |
997 | deleteJournal( ev ); | 1007 | deleteJournal( ev ); |
998 | ev = JournalList.next(); | 1008 | ev = JournalList.next(); |
999 | } | 1009 | } |
1000 | } | 1010 | } |
1001 | 1011 | ||
1002 | clearUndo(0); | 1012 | clearUndo(0); |
1003 | 1013 | ||
1004 | } | 1014 | } |
1005 | 1015 | ||
1016 | void CalendarLocal::setAllCalendarEnabled( bool enable ) | ||
1017 | { | ||
1018 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | ||
1019 | it->setCalEnabled( enable ); | ||
1020 | |||
1021 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) | ||
1022 | it->setCalEnabled( enable ); | ||
1023 | |||
1024 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | ||
1025 | it->setCalEnabled( enable ); | ||
1026 | |||
1027 | |||
1028 | } | ||
1006 | void CalendarLocal::setCalendarEnabled( int id, bool enable ) | 1029 | void CalendarLocal::setCalendarEnabled( int id, bool enable ) |
1007 | { | 1030 | { |
1008 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 1031 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
1009 | if ( it->calID() == id ) it->setCalEnabled( enable ); | 1032 | if ( it->calID() == id ) it->setCalEnabled( enable ); |
1010 | 1033 | ||
1011 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) | 1034 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) |
1012 | if ( it->calID() == id ) it->setCalEnabled( enable ); | 1035 | if ( it->calID() == id ) it->setCalEnabled( enable ); |
1013 | 1036 | ||
1014 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | 1037 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) |
1015 | if ( it->calID() == id ) it->setCalEnabled( enable ); | 1038 | if ( it->calID() == id ) it->setCalEnabled( enable ); |
1016 | 1039 | ||
1017 | } | 1040 | } |
1018 | 1041 | ||
1019 | void CalendarLocal::setReadOnly( int id, bool enable ) | 1042 | void CalendarLocal::setReadOnly( int id, bool enable ) |
1020 | { | 1043 | { |
1021 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 1044 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
1022 | if ( it->calID() == id ) it->setReadOnly( enable ); | 1045 | if ( it->calID() == id ) it->setReadOnly( enable ); |
1023 | 1046 | ||
1024 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) | 1047 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) |
1025 | if ( it->calID() == id ) it->setReadOnly( enable ); | 1048 | if ( it->calID() == id ) it->setReadOnly( enable ); |
1026 | 1049 | ||
1027 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | 1050 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) |
1028 | if ( it->calID() == id ) it->setReadOnly( enable ); | 1051 | if ( it->calID() == id ) it->setReadOnly( enable ); |
1029 | 1052 | ||
1030 | } | 1053 | } |
1031 | 1054 | ||
1032 | void CalendarLocal::setAlarmEnabled( int id, bool enable ) | 1055 | void CalendarLocal::setAlarmEnabled( int id, bool enable ) |
1033 | { | 1056 | { |
1034 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 1057 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
1035 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); | 1058 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); |
1036 | 1059 | ||
1037 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) | 1060 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) |
1038 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); | 1061 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); |
1039 | 1062 | ||
1040 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | 1063 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) |
1041 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); | 1064 | if ( it->calID() == id ) it->setAlarmEnabled( enable ); |
1042 | reInitAlarmSettings(); | 1065 | reInitAlarmSettings(); |
1043 | 1066 | ||
1044 | } | 1067 | } |
1045 | void CalendarLocal::setDefaultCalendarEnabledOnly() | 1068 | void CalendarLocal::setDefaultCalendarEnabledOnly() |
1046 | { | 1069 | { |
1047 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) | 1070 | for ( Journal *it = mJournalList.first(); it; it = mJournalList.next() ) |
1048 | it->setCalEnabled( it->calID() == mDefaultCalendar ); | 1071 | it->setCalEnabled( it->calID() == mDefaultCalendar ); |
1049 | 1072 | ||
1050 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) | 1073 | for ( Event *it = mEventList.first(); it; it = mEventList.next() ) |
1051 | it->setCalEnabled( it->calID() == mDefaultCalendar); | 1074 | it->setCalEnabled( it->calID() == mDefaultCalendar); |
1052 | 1075 | ||
1053 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) | 1076 | for ( Todo *it = mTodoList.first(); it; it = mTodoList.next() ) |
1054 | it->setCalEnabled( it->calID() == mDefaultCalendar); | 1077 | it->setCalEnabled( it->calID() == mDefaultCalendar); |
1055 | 1078 | ||
1056 | } | 1079 | } |