summaryrefslogtreecommitdiff
authoreilers <eilers>2004-08-29 12:48:43 (UTC)
committer eilers <eilers>2004-08-29 12:48:43 (UTC)
commit45327ef3c0f093fc227682f79158632afc09e6d1 (patch) (unidiff)
treebdfe4e602abcef87117528d2c9c4166820488d11
parentdd159675e6e3c361bc20eaa6994265e73b6599ef (diff)
downloadopie-45327ef3c0f093fc227682f79158632afc09e6d1.zip
opie-45327ef3c0f093fc227682f79158632afc09e6d1.tar.gz
opie-45327ef3c0f093fc227682f79158632afc09e6d1.tar.bz2
Fixed some quirks..
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiepim/backend/otodoaccesssql.cpp11
1 files changed, 8 insertions, 3 deletions
diff --git a/libopie2/opiepim/backend/otodoaccesssql.cpp b/libopie2/opiepim/backend/otodoaccesssql.cpp
index 6f65c48..12a8bea 100644
--- a/libopie2/opiepim/backend/otodoaccesssql.cpp
+++ b/libopie2/opiepim/backend/otodoaccesssql.cpp
@@ -1,884 +1,889 @@
1/* 1/*
2 This file is part of the Opie Project 2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de) 3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 Copyright (C) Holger Freyther (zecke@handhelds.org) 4 Copyright (C) Holger Freyther (zecke@handhelds.org)
5 =. Copyright (C) The Opie Team <opie-devel@handhelds.org> 5 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
6 .=l. 6 .=l.
7 .>+-= 7 .>+-=
8 _;:, .> :=|. This program is free software; you can 8 _;:, .> :=|. This program is free software; you can
9.> <`_, > . <= redistribute it and/or modify it under 9.> <`_, > . <= redistribute it and/or modify it under
10:`=1 )Y*s>-.-- : the terms of the GNU Library General Public 10:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
11.="- .-=="i, .._ License as published by the Free Software 11.="- .-=="i, .._ License as published by the Free Software
12 - . .-<_> .<> Foundation; either version 2 of the License, 12 - . .-<_> .<> Foundation; either version 2 of the License,
13 ._= =} : or (at your option) any later version. 13 ._= =} : or (at your option) any later version.
14 .%`+i> _;_. 14 .%`+i> _;_.
15 .i_,=:_. -<s. This program is distributed in the hope that 15 .i_,=:_. -<s. This program is distributed in the hope that
16 + . -:. = it will be useful, but WITHOUT ANY WARRANTY; 16 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
17 : .. .:, . . . without even the implied warranty of 17 : .. .:, . . . without even the implied warranty of
18 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A 18 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
19 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU 19 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
20..}^=.= = ; Library General Public License for more 20..}^=.= = ; Library General Public License for more
21++= -. .` .: details. 21++= -. .` .: details.
22 : = ...= . :.=- 22 : = ...= . :.=-
23 -. .:....=;==+<; You should have received a copy of the GNU 23 -. .:....=;==+<; You should have received a copy of the GNU
24 -_. . . )=. = Library General Public License along with 24 -_. . . )=. = Library General Public License along with
25 -- :-=` this library; see the file COPYING.LIB. 25 -- :-=` this library; see the file COPYING.LIB.
26 If not, write to the Free Software Foundation, 26 If not, write to the Free Software Foundation,
27 Inc., 59 Temple Place - Suite 330, 27 Inc., 59 Temple Place - Suite 330,
28 Boston, MA 02111-1307, USA. 28 Boston, MA 02111-1307, USA.
29*/ 29*/
30 30
31/* OPIE */ 31/* OPIE */
32#include <opie2/osqldriver.h> 32#include <opie2/osqldriver.h>
33#include <opie2/osqlresult.h> 33#include <opie2/osqlresult.h>
34#include <opie2/osqlmanager.h> 34#include <opie2/osqlmanager.h>
35#include <opie2/osqlquery.h> 35#include <opie2/osqlquery.h>
36 36
37#include <opie2/otodoaccesssql.h> 37#include <opie2/otodoaccesssql.h>
38#include <opie2/opimstate.h> 38#include <opie2/opimstate.h>
39#include <opie2/opimnotifymanager.h> 39#include <opie2/opimnotifymanager.h>
40#include <opie2/opimrecurrence.h> 40#include <opie2/opimrecurrence.h>
41#include <opie2/odebug.h> 41#include <opie2/odebug.h>
42 42
43#include <qpe/global.h> 43#include <qpe/global.h>
44 44
45/* QT */ 45/* QT */
46#include <qdatetime.h> 46#include <qdatetime.h>
47#include <qmap.h> 47#include <qmap.h>
48#include <qstring.h> 48#include <qstring.h>
49 49
50 50
51using namespace Opie::DB; 51using namespace Opie::DB;
52 52
53using namespace Opie; 53using namespace Opie;
54/* 54/*
55 * first some query 55 * first some query
56 * CREATE query 56 * CREATE query
57 * LOAD query 57 * LOAD query
58 * INSERT 58 * INSERT
59 * REMOVE 59 * REMOVE
60 * CLEAR 60 * CLEAR
61 */ 61 */
62namespace { 62namespace {
63 /** 63 /**
64 * CreateQuery for the Todolist Table 64 * CreateQuery for the Todolist Table
65 */ 65 */
66 class CreateQuery : public OSQLQuery { 66 class CreateQuery : public OSQLQuery {
67 public: 67 public:
68 CreateQuery(); 68 CreateQuery();
69 ~CreateQuery(); 69 ~CreateQuery();
70 QString query()const; 70 QString query()const;
71 }; 71 };
72 72
73 /** 73 /**
74 * LoadQuery 74 * LoadQuery
75 * this one queries for all uids 75 * this one queries for all uids
76 */ 76 */
77 class LoadQuery : public OSQLQuery { 77 class LoadQuery : public OSQLQuery {
78 public: 78 public:
79 LoadQuery(); 79 LoadQuery();
80 ~LoadQuery(); 80 ~LoadQuery();
81 QString query()const; 81 QString query()const;
82 }; 82 };
83 83
84 /** 84 /**
85 * inserts/adds a OPimTodo to the table 85 * inserts/adds a OPimTodo to the table
86 */ 86 */
87 class InsertQuery : public OSQLQuery { 87 class InsertQuery : public OSQLQuery {
88 public: 88 public:
89 InsertQuery(const OPimTodo& ); 89 InsertQuery(const OPimTodo& );
90 ~InsertQuery(); 90 ~InsertQuery();
91 QString query()const; 91 QString query()const;
92 private: 92 private:
93 OPimTodo m_todo; 93 OPimTodo m_todo;
94 }; 94 };
95 95
96 /** 96 /**
97 * removes one from the table 97 * removes one from the table
98 */ 98 */
99 class RemoveQuery : public OSQLQuery { 99 class RemoveQuery : public OSQLQuery {
100 public: 100 public:
101 RemoveQuery(int uid ); 101 RemoveQuery(int uid );
102 ~RemoveQuery(); 102 ~RemoveQuery();
103 QString query()const; 103 QString query()const;
104 private: 104 private:
105 int m_uid; 105 int m_uid;
106 }; 106 };
107 107
108 /** 108 /**
109 * Clears (delete) a Table 109 * Clears (delete) a Table
110 */ 110 */
111 class ClearQuery : public OSQLQuery { 111 class ClearQuery : public OSQLQuery {
112 public: 112 public:
113 ClearQuery(); 113 ClearQuery();
114 ~ClearQuery(); 114 ~ClearQuery();
115 QString query()const; 115 QString query()const;
116 116
117 }; 117 };
118 118
119 /** 119 /**
120 * a find query 120 * a find query
121 */ 121 */
122 class FindQuery : public OSQLQuery { 122 class FindQuery : public OSQLQuery {
123 public: 123 public:
124 FindQuery(int uid); 124 FindQuery(int uid);
125 FindQuery(const QArray<int>& ); 125 FindQuery(const QArray<int>& );
126 ~FindQuery(); 126 ~FindQuery();
127 QString query()const; 127 QString query()const;
128 private: 128 private:
129 QString single()const; 129 QString single()const;
130 QString multi()const; 130 QString multi()const;
131 QArray<int> m_uids; 131 QArray<int> m_uids;
132 int m_uid; 132 int m_uid;
133 }; 133 };
134 134
135 /** 135 /**
136 * overdue query 136 * overdue query
137 */ 137 */
138 class OverDueQuery : public OSQLQuery { 138 class OverDueQuery : public OSQLQuery {
139 public: 139 public:
140 OverDueQuery(); 140 OverDueQuery();
141 ~OverDueQuery(); 141 ~OverDueQuery();
142 QString query()const; 142 QString query()const;
143 }; 143 };
144 class EffQuery : public OSQLQuery { 144 class EffQuery : public OSQLQuery {
145 public: 145 public:
146 EffQuery( const QDate&, const QDate&, bool inc ); 146 EffQuery( const QDate&, const QDate&, bool inc );
147 ~EffQuery(); 147 ~EffQuery();
148 QString query()const; 148 QString query()const;
149 private: 149 private:
150 QString with()const; 150 QString with()const;
151 QString out()const; 151 QString out()const;
152 QDate m_start; 152 QDate m_start;
153 QDate m_end; 153 QDate m_end;
154 bool m_inc :1; 154 bool m_inc :1;
155 }; 155 };
156 156
157 157
158 /** 158 /**
159 * a find query for custom elements 159 * a find query for custom elements
160 */ 160 */
161 class FindCustomQuery : public OSQLQuery { 161 class FindCustomQuery : public OSQLQuery {
162 public: 162 public:
163 FindCustomQuery(int uid); 163 FindCustomQuery(int uid);
164 FindCustomQuery(const QArray<int>& ); 164 FindCustomQuery(const QArray<int>& );
165 ~FindCustomQuery(); 165 ~FindCustomQuery();
166 QString query()const; 166 QString query()const;
167 private: 167 private:
168 QString single()const; 168 QString single()const;
169 QString multi()const; 169 QString multi()const;
170 QArray<int> m_uids; 170 QArray<int> m_uids;
171 int m_uid; 171 int m_uid;
172 }; 172 };
173 173
174 174
175 175
176 CreateQuery::CreateQuery() : OSQLQuery() {} 176 CreateQuery::CreateQuery() : OSQLQuery() {}
177 CreateQuery::~CreateQuery() {} 177 CreateQuery::~CreateQuery() {}
178 QString CreateQuery::query()const { 178 QString CreateQuery::query()const {
179 QString qu; 179 QString qu;
180 qu += "create table todolist( uid PRIMARY KEY, categories, completed, "; 180 qu += "create table todolist( uid PRIMARY KEY, categories, completed, ";
181 qu += "description, summary, priority, DueDate, progress , state, "; 181 qu += "description, summary, priority, DueDate, progress , state, ";
182 // This is the recurrance-stuff .. Exceptions are currently not supported (see OPimRecurrence.cpp) ! (eilers) 182 // This is the recurrance-stuff .. Exceptions are currently not supported (see OPimRecurrence.cpp) ! (eilers)
183 qu += "RType, RWeekdays, RPosition, RFreq, RHasEndDate, EndDate, Created, Exceptions, "; 183 qu += "RType, RWeekdays, RPosition, RFreq, RHasEndDate, EndDate, Created, Exceptions, ";
184 qu += "reminders, alarms, maintainer, startdate, completeddate);"; 184 qu += "reminders, alarms, maintainer, startdate, completeddate);";
185 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR(10), priority INTEGER, value VARCHAR(10), PRIMARY KEY /* identifier */ (uid, id) );"; 185 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR(10), priority INTEGER, value VARCHAR(10), PRIMARY KEY /* identifier */ (uid, id) );";
186 return qu; 186 return qu;
187 } 187 }
188 188
189 LoadQuery::LoadQuery() : OSQLQuery() {} 189 LoadQuery::LoadQuery() : OSQLQuery() {}
190 LoadQuery::~LoadQuery() {} 190 LoadQuery::~LoadQuery() {}
191 QString LoadQuery::query()const { 191 QString LoadQuery::query()const {
192 QString qu; 192 QString qu;
193 // We do not need "distinct" here. The primary key is always unique.. 193 // We do not need "distinct" here. The primary key is always unique..
194 //qu += "select distinct uid from todolist"; 194 //qu += "select distinct uid from todolist";
195 qu += "select uid from todolist"; 195 qu += "select uid from todolist";
196 196
197 return qu; 197 return qu;
198 } 198 }
199 199
200 InsertQuery::InsertQuery( const OPimTodo& todo ) 200 InsertQuery::InsertQuery( const OPimTodo& todo )
201 : OSQLQuery(), m_todo( todo ) { 201 : OSQLQuery(), m_todo( todo ) {
202 } 202 }
203 InsertQuery::~InsertQuery() { 203 InsertQuery::~InsertQuery() {
204 } 204 }
205 /* 205 /*
206 * converts from a OPimTodo to a query 206 * converts from a OPimTodo to a query
207 * we leave out X-Ref + Maintainer 207 * we leave out X-Ref + Maintainer
208 * FIXME: Implement/Finish toMap()/fromMap() into OpimTodo to move the encoding 208 * FIXME: Implement/Finish toMap()/fromMap() into OpimTodo to move the encoding
209 * decoding stuff there.. (eilers) 209 * decoding stuff there.. (eilers)
210 */ 210 */
211 QString InsertQuery::query()const{ 211 QString InsertQuery::query()const{
212 212
213 int year, month, day; 213 int year, month, day;
214 year = month = day = 0; 214 year = month = day = 0;
215 if (m_todo.hasDueDate() ) { 215 if (m_todo.hasDueDate() ) {
216 QDate date = m_todo.dueDate(); 216 QDate date = m_todo.dueDate();
217 year = date.year(); 217 year = date.year();
218 month = date.month(); 218 month = date.month();
219 day = date.day(); 219 day = date.day();
220 } 220 }
221 int sYear = 0, sMonth = 0, sDay = 0; 221 int sYear = 0, sMonth = 0, sDay = 0;
222 if( m_todo.hasStartDate() ){ 222 if( m_todo.hasStartDate() ){
223 QDate sDate = m_todo.startDate(); 223 QDate sDate = m_todo.startDate();
224 sYear = sDate.year(); 224 sYear = sDate.year();
225 sMonth= sDate.month(); 225 sMonth= sDate.month();
226 sDay = sDate.day(); 226 sDay = sDate.day();
227 } 227 }
228 228
229 int eYear = 0, eMonth = 0, eDay = 0; 229 int eYear = 0, eMonth = 0, eDay = 0;
230 if( m_todo.hasCompletedDate() ){ 230 if( m_todo.hasCompletedDate() ){
231 QDate eDate = m_todo.completedDate(); 231 QDate eDate = m_todo.completedDate();
232 eYear = eDate.year(); 232 eYear = eDate.year();
233 eMonth= eDate.month(); 233 eMonth= eDate.month();
234 eDay = eDate.day(); 234 eDay = eDate.day();
235 } 235 }
236 QString qu; 236 QString qu;
237 QMap<int, QString> recMap = m_todo.recurrence().toMap(); 237 QMap<int, QString> recMap = m_todo.recurrence().toMap();
238 qu = "insert into todolist VALUES(" 238 qu = "insert into todolist VALUES("
239 + QString::number( m_todo.uid() ) + "," 239 + QString::number( m_todo.uid() ) + ","
240 + "'" + m_todo.idsToString( m_todo.categories() ) + "'" + "," 240 + "'" + m_todo.idsToString( m_todo.categories() ) + "'" + ","
241 + QString::number( m_todo.isCompleted() ) + "," 241 + QString::number( m_todo.isCompleted() ) + ","
242 + "'" + m_todo.description() + "'" + "," 242 + "'" + m_todo.description() + "'" + ","
243 + "'" + m_todo.summary() + "'" + "," 243 + "'" + m_todo.summary() + "'" + ","
244 + QString::number(m_todo.priority() ) + "," 244 + QString::number(m_todo.priority() ) + ","
245 + "'" + QString::number(year).rightJustify( 4, '0' ) + "-" 245 + "'" + QString::number(year).rightJustify( 4, '0' ) + "-"
246 + QString::number(month).rightJustify( 2, '0' ) 246 + QString::number(month).rightJustify( 2, '0' )
247 + "-" + QString::number( day ).rightJustify( 2, '0' )+ "'" + "," 247 + "-" + QString::number( day ).rightJustify( 2, '0' )+ "'" + ","
248 + QString::number( m_todo.progress() ) + "," 248 + QString::number( m_todo.progress() ) + ","
249 + QString::number( m_todo.state().state() ) + "," 249 + QString::number( m_todo.state().state() ) + ","
250 + "'" + recMap[ OPimRecurrence::RType ] + "'" + "," 250 + "'" + recMap[ OPimRecurrence::RType ] + "'" + ","
251 + "'" + recMap[ OPimRecurrence::RWeekdays ] + "'" + "," 251 + "'" + recMap[ OPimRecurrence::RWeekdays ] + "'" + ","
252 + "'" + recMap[ OPimRecurrence::RPosition ] + "'" + "," 252 + "'" + recMap[ OPimRecurrence::RPosition ] + "'" + ","
253 + "'" + recMap[ OPimRecurrence::RFreq ] + "'" + "," 253 + "'" + recMap[ OPimRecurrence::RFreq ] + "'" + ","
254 + "'" + recMap[ OPimRecurrence::RHasEndDate ] + "'" + "," 254 + "'" + recMap[ OPimRecurrence::RHasEndDate ] + "'" + ","
255 + "'" + recMap[ OPimRecurrence::EndDate ] + "'" + "," 255 + "'" + recMap[ OPimRecurrence::EndDate ] + "'" + ","
256 + "'" + recMap[ OPimRecurrence::Created ] + "'" + "," 256 + "'" + recMap[ OPimRecurrence::Created ] + "'" + ","
257 + "'" + recMap[ OPimRecurrence::Exceptions ] + "'" + ","; 257 + "'" + recMap[ OPimRecurrence::Exceptions ] + "'" + ",";
258 258
259 if ( m_todo.hasNotifiers() ) { 259 if ( m_todo.hasNotifiers() ) {
260 OPimNotifyManager manager = m_todo.notifiers(); 260 OPimNotifyManager manager = m_todo.notifiers();
261 qu += "'" + manager.remindersToString() + "'" + "," 261 qu += "'" + manager.remindersToString() + "'" + ","
262 + "'" + manager.alarmsToString() + "'" + ","; 262 + "'" + manager.alarmsToString() + "'" + ",";
263 } 263 }
264 else{ 264 else{
265 qu += QString( "''" ) + "," 265 qu += QString( "''" ) + ","
266 + "''" + ","; 266 + "''" + ",";
267 } 267 }
268 268
269 qu += QString( "''" ) + QString( "," ) // Maintainers (cur. not supported !) 269 qu += QString( "''" ) + QString( "," ) // Maintainers (cur. not supported !)
270 + "'" + QString::number(sYear).rightJustify( 4, '0' ) + "-" 270 + "'" + QString::number(sYear).rightJustify( 4, '0' ) + "-"
271 + QString::number(sMonth).rightJustify( 2, '0' ) 271 + QString::number(sMonth).rightJustify( 2, '0' )
272 + "-" + QString::number(sDay).rightJustify( 2, '0' )+ "'" + "," 272 + "-" + QString::number(sDay).rightJustify( 2, '0' )+ "'" + ","
273 + "'" + QString::number(eYear).rightJustify( 4, '0' ) + "-" 273 + "'" + QString::number(eYear).rightJustify( 4, '0' ) + "-"
274 + QString::number(eMonth).rightJustify( 2, '0' ) 274 + QString::number(eMonth).rightJustify( 2, '0' )
275 + "-"+QString::number(eDay).rightJustify( 2, '0' ) + "'" 275 + "-"+QString::number(eDay).rightJustify( 2, '0' ) + "'"
276 + "); "; 276 + "); ";
277 277
278 // Save custom Entries: 278 // Save custom Entries:
279 int id = 0; 279 int id = 0;
280 id = 0; 280 id = 0;
281 QMap<QString, QString> customMap = m_todo.toExtraMap(); 281 QMap<QString, QString> customMap = m_todo.toExtraMap();
282 for( QMap<QString, QString>::Iterator it = customMap.begin(); 282 for( QMap<QString, QString>::Iterator it = customMap.begin();
283 it != customMap.end(); ++it ){ 283 it != customMap.end(); ++it ){
284 qu += "insert into custom_data VALUES(" 284 qu += "insert into custom_data VALUES("
285 + QString::number( m_todo.uid() ) 285 + QString::number( m_todo.uid() )
286 + "," 286 + ","
287 + QString::number( id++ ) 287 + QString::number( id++ )
288 + ",'" 288 + ",'"
289 + it.key() 289 + it.key()
290 + "'," 290 + "',"
291 + "0" // Priority for future enhancements 291 + "0" // Priority for future enhancements
292 + ",'" 292 + ",'"
293 + it.data() 293 + it.data()
294 + "');"; 294 + "');";
295 } 295 }
296 296
297 297
298 odebug << "add " << qu << "" << oendl; 298 odebug << "add " << qu << "" << oendl;
299 return qu; 299 return qu;
300 } 300 }
301 301
302 RemoveQuery::RemoveQuery(int uid ) 302 RemoveQuery::RemoveQuery(int uid )
303 : OSQLQuery(), m_uid( uid ) {} 303 : OSQLQuery(), m_uid( uid ) {}
304 RemoveQuery::~RemoveQuery() {} 304 RemoveQuery::~RemoveQuery() {}
305 QString RemoveQuery::query()const { 305 QString RemoveQuery::query()const {
306 QString qu = "DELETE FROM todolist WHERE uid = " + QString::number(m_uid) + " ;"; 306 QString qu = "DELETE FROM todolist WHERE uid = " + QString::number(m_uid) + " ;";
307 qu += "DELETE FROM custom_data WHERE uid = " + QString::number(m_uid); 307 qu += "DELETE FROM custom_data WHERE uid = " + QString::number(m_uid);
308 return qu; 308 return qu;
309 } 309 }
310 310
311 311
312 ClearQuery::ClearQuery() 312 ClearQuery::ClearQuery()
313 : OSQLQuery() {} 313 : OSQLQuery() {}
314 ClearQuery::~ClearQuery() {} 314 ClearQuery::~ClearQuery() {}
315 QString ClearQuery::query()const { 315 QString ClearQuery::query()const {
316 QString qu = "drop table todolist"; 316 QString qu = "drop table todolist";
317 return qu; 317 return qu;
318 } 318 }
319 FindQuery::FindQuery(int uid) 319 FindQuery::FindQuery(int uid)
320 : OSQLQuery(), m_uid(uid ) { 320 : OSQLQuery(), m_uid(uid ) {
321 } 321 }
322 FindQuery::FindQuery(const QArray<int>& ints) 322 FindQuery::FindQuery(const QArray<int>& ints)
323 : OSQLQuery(), m_uids(ints){ 323 : OSQLQuery(), m_uids(ints){
324 } 324 }
325 FindQuery::~FindQuery() { 325 FindQuery::~FindQuery() {
326 } 326 }
327 QString FindQuery::query()const{ 327 QString FindQuery::query()const{
328 if (m_uids.count() == 0 ) 328 if (m_uids.count() == 0 )
329 return single(); 329 return single();
330 else 330 else
331 return multi(); 331 return multi();
332 } 332 }
333 QString FindQuery::single()const{ 333 QString FindQuery::single()const{
334 QString qu = "select * from todolist where uid = " + QString::number(m_uid); 334 QString qu = "select * from todolist where uid = " + QString::number(m_uid);
335 return qu; 335 return qu;
336 } 336 }
337 QString FindQuery::multi()const { 337 QString FindQuery::multi()const {
338 QString qu = "select * from todolist where "; 338 QString qu = "select * from todolist where ";
339 for (uint i = 0; i < m_uids.count(); i++ ) { 339 for (uint i = 0; i < m_uids.count(); i++ ) {
340 qu += " UID = " + QString::number( m_uids[i] ) + " OR"; 340 qu += " UID = " + QString::number( m_uids[i] ) + " OR";
341 } 341 }
342 qu.remove( qu.length()-2, 2 ); 342 qu.remove( qu.length()-2, 2 );
343 return qu; 343 return qu;
344 } 344 }
345 345
346 OverDueQuery::OverDueQuery(): OSQLQuery() {} 346 OverDueQuery::OverDueQuery(): OSQLQuery() {}
347 OverDueQuery::~OverDueQuery() {} 347 OverDueQuery::~OverDueQuery() {}
348 QString OverDueQuery::query()const { 348 QString OverDueQuery::query()const {
349 QDate date = QDate::currentDate(); 349 QDate date = QDate::currentDate();
350 QString str; 350 QString str;
351 str = QString("select uid from todolist where DueDate ='%1-%2-%3'") 351 str = QString("select uid from todolist where DueDate ='%1-%2-%3'")
352 .arg( QString::number( date.year() ).rightJustify( 4, '0' ) ) 352 .arg( QString::number( date.year() ).rightJustify( 4, '0' ) )
353 .arg( QString::number( date.month() ).rightJustify( 2, '0' ) ) 353 .arg( QString::number( date.month() ).rightJustify( 2, '0' ) )
354 .arg( QString::number( date.day() ) .rightJustify( 2, '0' ) ); 354 .arg( QString::number( date.day() ) .rightJustify( 2, '0' ) );
355 355
356 return str; 356 return str;
357 } 357 }
358 358
359 359
360 EffQuery::EffQuery( const QDate& start, const QDate& end, bool inc ) 360 EffQuery::EffQuery( const QDate& start, const QDate& end, bool inc )
361 : OSQLQuery(), m_start( start ), m_end( end ),m_inc(inc) {} 361 : OSQLQuery(), m_start( start ), m_end( end ),m_inc(inc) {}
362 EffQuery::~EffQuery() {} 362 EffQuery::~EffQuery() {}
363 QString EffQuery::query()const { 363 QString EffQuery::query()const {
364 return m_inc ? with() : out(); 364 return m_inc ? with() : out();
365 } 365 }
366 QString EffQuery::with()const { 366 QString EffQuery::with()const {
367 QString str; 367 QString str;
368 str = QString("select uid from todolist where ( DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6' ) OR DueDate = '0-0-0' ") 368 str = QString("select uid from todolist where ( DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6' ) OR DueDate = '0-0-0' ")
369 .arg( QString::number( m_start.year() ).rightJustify( 4, '0' ) ) 369 .arg( QString::number( m_start.year() ).rightJustify( 4, '0' ) )
370 .arg( QString::number( m_start.month() ).rightJustify( 2, '0' ) ) 370 .arg( QString::number( m_start.month() ).rightJustify( 2, '0' ) )
371 .arg( QString::number( m_start.day() ).rightJustify( 2, '0' ) ) 371 .arg( QString::number( m_start.day() ).rightJustify( 2, '0' ) )
372 .arg( QString::number( m_end.year() ).rightJustify( 4, '0' ) ) 372 .arg( QString::number( m_end.year() ).rightJustify( 4, '0' ) )
373 .arg( QString::number( m_end.month() ).rightJustify( 2, '0' ) ) 373 .arg( QString::number( m_end.month() ).rightJustify( 2, '0' ) )
374 .arg( QString::number( m_end.day() ).rightJustify( 2, '0' ) ); 374 .arg( QString::number( m_end.day() ).rightJustify( 2, '0' ) );
375 return str; 375 return str;
376 } 376 }
377 QString EffQuery::out()const { 377 QString EffQuery::out()const {
378 QString str; 378 QString str;
379 str = QString("select uid from todolist where DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6'") 379 str = QString("select uid from todolist where DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6'")
380 .arg( QString::number( m_start.year() ).rightJustify( 4, '0' ) ) 380 .arg( QString::number( m_start.year() ).rightJustify( 4, '0' ) )
381 .arg( QString::number( m_start.month() ).rightJustify( 2, '0' ) ) 381 .arg( QString::number( m_start.month() ).rightJustify( 2, '0' ) )
382 .arg( QString::number( m_start.day() ).rightJustify( 2, '0' ) ) 382 .arg( QString::number( m_start.day() ).rightJustify( 2, '0' ) )
383 .arg( QString::number( m_end.year() ).rightJustify( 4, '0' ) ) 383 .arg( QString::number( m_end.year() ).rightJustify( 4, '0' ) )
384 .arg( QString::number( m_end.month() ).rightJustify( 2, '0' ) ) 384 .arg( QString::number( m_end.month() ).rightJustify( 2, '0' ) )
385 .arg( QString::number( m_end.day() ).rightJustify( 2, '0' ) ); 385 .arg( QString::number( m_end.day() ).rightJustify( 2, '0' ) );
386 386
387 return str; 387 return str;
388 } 388 }
389 389
390 FindCustomQuery::FindCustomQuery(int uid) 390 FindCustomQuery::FindCustomQuery(int uid)
391 : OSQLQuery(), m_uid( uid ) { 391 : OSQLQuery(), m_uid( uid ) {
392 } 392 }
393 FindCustomQuery::FindCustomQuery(const QArray<int>& ints) 393 FindCustomQuery::FindCustomQuery(const QArray<int>& ints)
394 : OSQLQuery(), m_uids( ints ){ 394 : OSQLQuery(), m_uids( ints ){
395 } 395 }
396 FindCustomQuery::~FindCustomQuery() { 396 FindCustomQuery::~FindCustomQuery() {
397 } 397 }
398 QString FindCustomQuery::query()const{ 398 QString FindCustomQuery::query()const{
399 return single(); // Multiple requests not supported ! 399 return single(); // Multiple requests not supported !
400 } 400 }
401 QString FindCustomQuery::single()const{ 401 QString FindCustomQuery::single()const{
402 QString qu = "select uid, type, value from custom_data where uid = "; 402 QString qu = "select uid, type, value from custom_data where uid = ";
403 qu += QString::number(m_uid); 403 qu += QString::number(m_uid);
404 return qu; 404 return qu;
405 } 405 }
406 406
407}; 407};
408 408
409 409
410namespace Opie { 410namespace Opie {
411OPimTodoAccessBackendSQL::OPimTodoAccessBackendSQL( const QString& file ) 411OPimTodoAccessBackendSQL::OPimTodoAccessBackendSQL( const QString& file )
412 : OPimTodoAccessBackend(),/* m_dict(15),*/ m_driver(NULL), m_dirty(true) 412 : OPimTodoAccessBackend(),/* m_dict(15),*/ m_driver(NULL), m_dirty(true)
413{ 413{
414 QString fi = file; 414 QString fi = file;
415 if ( fi.isEmpty() ) 415 if ( fi.isEmpty() )
416 fi = Global::applicationFileName( "todolist", "todolist.db" ); 416 fi = Global::applicationFileName( "todolist", "todolist.db" );
417 OSQLManager man; 417 OSQLManager man;
418 m_driver = man.standard(); 418 m_driver = man.standard();
419 m_driver->setUrl(fi); 419 m_driver->setUrl(fi);
420 // fillDict(); 420 // fillDict();
421} 421}
422 422
423OPimTodoAccessBackendSQL::~OPimTodoAccessBackendSQL(){ 423OPimTodoAccessBackendSQL::~OPimTodoAccessBackendSQL(){
424 if( m_driver ) 424 if( m_driver )
425 delete m_driver; 425 delete m_driver;
426} 426}
427 427
428bool OPimTodoAccessBackendSQL::load(){ 428bool OPimTodoAccessBackendSQL::load(){
429 if (!m_driver->open() ) 429 if (!m_driver->open() )
430 return false; 430 return false;
431 431
432 CreateQuery creat; 432 CreateQuery creat;
433 OSQLResult res = m_driver->query(&creat ); 433 OSQLResult res = m_driver->query(&creat );
434 434
435 m_dirty = true; 435 m_dirty = true;
436 return true; 436 return true;
437} 437}
438bool OPimTodoAccessBackendSQL::reload(){ 438bool OPimTodoAccessBackendSQL::reload(){
439 return load(); 439 return load();
440} 440}
441 441
442bool OPimTodoAccessBackendSQL::save(){ 442bool OPimTodoAccessBackendSQL::save(){
443 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers) 443 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers)
444} 444}
445QArray<int> OPimTodoAccessBackendSQL::allRecords()const { 445QArray<int> OPimTodoAccessBackendSQL::allRecords()const {
446 if (m_dirty ) 446 if (m_dirty )
447 update(); 447 update();
448 448
449 return m_uids; 449 return m_uids;
450} 450}
451QArray<int> OPimTodoAccessBackendSQL::queryByExample( const OPimTodo& , int, const QDateTime& ){ 451QArray<int> OPimTodoAccessBackendSQL::queryByExample( const OPimTodo& , int, const QDateTime& ){
452 QArray<int> ints(0); 452 QArray<int> ints(0);
453 return ints; 453 return ints;
454} 454}
455OPimTodo OPimTodoAccessBackendSQL::find(int uid ) const{ 455OPimTodo OPimTodoAccessBackendSQL::find(int uid ) const{
456 FindQuery query( uid ); 456 FindQuery query( uid );
457 return todo( m_driver->query(&query) ); 457 return todo( m_driver->query(&query) );
458 458
459} 459}
460
461// Remember: uid is already in the list of uids, called ints !
460OPimTodo OPimTodoAccessBackendSQL::find( int uid, const QArray<int>& ints, 462OPimTodo OPimTodoAccessBackendSQL::find( int uid, const QArray<int>& ints,
461 uint cur, Frontend::CacheDirection dir ) const{ 463 uint cur, Frontend::CacheDirection dir ) const{
462 uint CACHE = readAhead(); 464 uint CACHE = readAhead();
463 odebug << "searching for " << uid << "" << oendl; 465 odebug << "searching for " << uid << "" << oendl;
464 QArray<int> search( CACHE ); 466 QArray<int> search( CACHE );
465 uint size =0; 467 uint size =0;
466 OPimTodo to; 468 OPimTodo to;
467 469
468 // we try to cache CACHE items 470 // we try to cache CACHE items
469 switch( dir ) { 471 switch( dir ) {
470 /* forward */ 472 /* forward */
471 case 0: // FIXME: Not a good style to use magic numbers here (eilers) 473 case Frontend::Forward:
472 for (uint i = cur; i < ints.count() && size < CACHE; i++ ) { 474 for (uint i = cur; i < ints.count() && size < CACHE; i++ ) {
473 odebug << "size " << size << " " << ints[i] << "" << oendl; 475 odebug << "size " << size << " " << ints[i] << "" << oendl;
474 search[size] = ints[i]; 476 search[size] = ints[i];
475 size++; 477 size++;
476 } 478 }
477 break; 479 break;
478 /* reverse */ 480 /* reverse */
479 case 1: // FIXME: Not a good style to use magic numbers here (eilers) 481 case Frontend::Reverse:
480 for (uint i = cur; i != 0 && size < CACHE; i-- ) { 482 for (uint i = cur; i != 0 && size < CACHE; i-- ) {
481 search[size] = ints[i]; 483 search[size] = ints[i];
482 size++; 484 size++;
483 } 485 }
484 break; 486 break;
485 } 487 }
488
486 search.resize( size ); 489 search.resize( size );
487 FindQuery query( search ); 490 FindQuery query( search );
488 OSQLResult res = m_driver->query( &query ); 491 OSQLResult res = m_driver->query( &query );
489 if ( res.state() != OSQLResult::Success ) 492 if ( res.state() != OSQLResult::Success )
490 return to; 493 return to;
491 494
492 return todo( res ); 495 todo( res ); //FIXME: Don't like polymorphism here. It makes the code hard to read here..(eilers)
496 return cacheFind( uid );
493} 497}
498
494void OPimTodoAccessBackendSQL::clear() { 499void OPimTodoAccessBackendSQL::clear() {
495 ClearQuery cle; 500 ClearQuery cle;
496 OSQLResult res = m_driver->query( &cle ); 501 OSQLResult res = m_driver->query( &cle );
497 CreateQuery qu; 502 CreateQuery qu;
498 res = m_driver->query(&qu); 503 res = m_driver->query(&qu);
499} 504}
500bool OPimTodoAccessBackendSQL::add( const OPimTodo& t) { 505bool OPimTodoAccessBackendSQL::add( const OPimTodo& t) {
501 InsertQuery ins( t ); 506 InsertQuery ins( t );
502 OSQLResult res = m_driver->query( &ins ); 507 OSQLResult res = m_driver->query( &ins );
503 508
504 if ( res.state() == OSQLResult::Failure ) 509 if ( res.state() == OSQLResult::Failure )
505 return false; 510 return false;
506 int c = m_uids.count(); 511 int c = m_uids.count();
507 m_uids.resize( c+1 ); 512 m_uids.resize( c+1 );
508 m_uids[c] = t.uid(); 513 m_uids[c] = t.uid();
509 514
510 return true; 515 return true;
511} 516}
512bool OPimTodoAccessBackendSQL::remove( int uid ) { 517bool OPimTodoAccessBackendSQL::remove( int uid ) {
513 RemoveQuery rem( uid ); 518 RemoveQuery rem( uid );
514 OSQLResult res = m_driver->query(&rem ); 519 OSQLResult res = m_driver->query(&rem );
515 520
516 if ( res.state() == OSQLResult::Failure ) 521 if ( res.state() == OSQLResult::Failure )
517 return false; 522 return false;
518 523
519 m_dirty = true; 524 m_dirty = true;
520 return true; 525 return true;
521} 526}
522/* 527/*
523 * FIXME better set query 528 * FIXME better set query
524 * but we need the cache for that 529 * but we need the cache for that
525 * now we remove 530 * now we remove
526 */ 531 */
527bool OPimTodoAccessBackendSQL::replace( const OPimTodo& t) { 532bool OPimTodoAccessBackendSQL::replace( const OPimTodo& t) {
528 remove( t.uid() ); 533 remove( t.uid() );
529 bool b= add(t); 534 bool b= add(t);
530 m_dirty = false; // we changed some stuff but the UID stayed the same 535 m_dirty = false; // we changed some stuff but the UID stayed the same
531 return b; 536 return b;
532} 537}
533QArray<int> OPimTodoAccessBackendSQL::overDue() { 538QArray<int> OPimTodoAccessBackendSQL::overDue() {
534 OverDueQuery qu; 539 OverDueQuery qu;
535 return uids( m_driver->query(&qu ) ); 540 return uids( m_driver->query(&qu ) );
536} 541}
537QArray<int> OPimTodoAccessBackendSQL::effectiveToDos( const QDate& s, 542QArray<int> OPimTodoAccessBackendSQL::effectiveToDos( const QDate& s,
538 const QDate& t, 543 const QDate& t,
539 bool u) { 544 bool u) {
540 EffQuery ef(s, t, u ); 545 EffQuery ef(s, t, u );
541 return uids (m_driver->query(&ef) ); 546 return uids (m_driver->query(&ef) );
542} 547}
543/* 548/*
544 * 549 *
545 */ 550 */
546QArray<int> OPimTodoAccessBackendSQL::sorted( bool asc, int sortOrder, 551QArray<int> OPimTodoAccessBackendSQL::sorted( bool asc, int sortOrder,
547 int sortFilter, int cat ) { 552 int sortFilter, int cat ) {
548 odebug << "sorted " << asc << ", " << sortOrder << "" << oendl; 553 odebug << "sorted " << asc << ", " << sortOrder << "" << oendl;
549 QString query; 554 QString query;
550 query = "select uid from todolist WHERE "; 555 query = "select uid from todolist WHERE ";
551 556
552 /* 557 /*
553 * Sort Filter stuff 558 * Sort Filter stuff
554 * not that straight forward 559 * not that straight forward
555 * FIXME: Replace magic numbers 560 * FIXME: Replace magic numbers
556 * 561 *
557 */ 562 */
558 /* Category */ 563 /* Category */
559 if ( sortFilter & 1 ) { 564 if ( sortFilter & 1 ) {
560 QString str; 565 QString str;
561 if (cat != 0 ) str = QString::number( cat ); 566 if (cat != 0 ) str = QString::number( cat );
562 query += " categories like '%" +str+"%' AND"; 567 query += " categories like '%" +str+"%' AND";
563 } 568 }
564 /* Show only overdue */ 569 /* Show only overdue */
565 if ( sortFilter & 2 ) { 570 if ( sortFilter & 2 ) {
566 QDate date = QDate::currentDate(); 571 QDate date = QDate::currentDate();
567 QString due; 572 QString due;
568 QString base; 573 QString base;
569 base = QString("DueDate <= '%1-%2-%3' AND completed = 0") 574 base = QString("DueDate <= '%1-%2-%3' AND completed = 0")
570 .arg( QString::number( date.year() ).rightJustify( 4, '0' ) ) 575 .arg( QString::number( date.year() ).rightJustify( 4, '0' ) )
571 .arg( QString::number( date.month() ).rightJustify( 2, '0' ) ) 576 .arg( QString::number( date.month() ).rightJustify( 2, '0' ) )
572 .arg( QString::number( date.day() ).rightJustify( 2, '0' ) ); 577 .arg( QString::number( date.day() ).rightJustify( 2, '0' ) );
573 query += " " + base + " AND"; 578 query += " " + base + " AND";
574 } 579 }
575 /* not show completed */ 580 /* not show completed */
576 if ( sortFilter & 4 ) { 581 if ( sortFilter & 4 ) {
577 query += " completed = 0 AND"; 582 query += " completed = 0 AND";
578 }else{ 583 }else{
579 query += " ( completed = 1 OR completed = 0) AND"; 584 query += " ( completed = 1 OR completed = 0) AND";
580 } 585 }
581 /* strip the end */ 586 /* strip the end */
582 query = query.remove( query.length()-3, 3 ); 587 query = query.remove( query.length()-3, 3 );
583 588
584 589
585 /* 590 /*
586 * sort order stuff 591 * sort order stuff
587 * quite straight forward 592 * quite straight forward
588 */ 593 */
589 query += "ORDER BY "; 594 query += "ORDER BY ";
590 switch( sortOrder ) { 595 switch( sortOrder ) {
591 /* completed */ 596 /* completed */
592 case 0: 597 case 0:
593 query += "completed"; 598 query += "completed";
594 break; 599 break;
595 case 1: 600 case 1:
596 query += "priority"; 601 query += "priority";
597 break; 602 break;
598 case 2: 603 case 2:
599 query += "summary"; 604 query += "summary";
600 break; 605 break;
601 case 3: 606 case 3:
602 query += "DueDate"; 607 query += "DueDate";
603 break; 608 break;
604 } 609 }
605 610
606 if ( !asc ) { 611 if ( !asc ) {
607 odebug << "not ascending!" << oendl; 612 odebug << "not ascending!" << oendl;
608 query += " DESC"; 613 query += " DESC";
609 } 614 }
610 615
611 odebug << query << oendl; 616 odebug << query << oendl;
612 OSQLRawQuery raw(query ); 617 OSQLRawQuery raw(query );
613 return uids( m_driver->query(&raw) ); 618 return uids( m_driver->query(&raw) );
614} 619}
615bool OPimTodoAccessBackendSQL::date( QDate& da, const QString& str ) const{ 620bool OPimTodoAccessBackendSQL::date( QDate& da, const QString& str ) const{
616 if ( str == "0-0-0" ) 621 if ( str == "0-0-0" )
617 return false; 622 return false;
618 else{ 623 else{
619 int day, year, month; 624 int day, year, month;
620 QStringList list = QStringList::split("-", str ); 625 QStringList list = QStringList::split("-", str );
621 year = list[0].toInt(); 626 year = list[0].toInt();
622 month = list[1].toInt(); 627 month = list[1].toInt();
623 day = list[2].toInt(); 628 day = list[2].toInt();
624 da.setYMD( year, month, day ); 629 da.setYMD( year, month, day );
625 return true; 630 return true;
626 } 631 }
627} 632}
628OPimTodo OPimTodoAccessBackendSQL::todo( const OSQLResult& res ) const{ 633OPimTodo OPimTodoAccessBackendSQL::todo( const OSQLResult& res ) const{
629 if ( res.state() == OSQLResult::Failure ) { 634 if ( res.state() == OSQLResult::Failure ) {
630 OPimTodo to; 635 OPimTodo to;
631 return to; 636 return to;
632 } 637 }
633 638
634 OSQLResultItem::ValueList list = res.results(); 639 OSQLResultItem::ValueList list = res.results();
635 OSQLResultItem::ValueList::Iterator it = list.begin(); 640 OSQLResultItem::ValueList::Iterator it = list.begin();
636 odebug << "todo1" << oendl; 641 odebug << "todo1" << oendl;
637 OPimTodo to = todo( (*it) ); 642 OPimTodo to = todo( (*it) );
638 cache( to ); 643 cache( to );
639 ++it; 644 ++it;
640 645
641 for ( ; it != list.end(); ++it ) { 646 for ( ; it != list.end(); ++it ) {
642 odebug << "caching" << oendl; 647 odebug << "caching" << oendl;
643 cache( todo( (*it) ) ); 648 cache( todo( (*it) ) );
644 } 649 }
645 return to; 650 return to;
646} 651}
647OPimTodo OPimTodoAccessBackendSQL::todo( OSQLResultItem& item )const { 652OPimTodo OPimTodoAccessBackendSQL::todo( OSQLResultItem& item )const {
648 odebug << "todo(ResultItem)" << oendl; 653 odebug << "todo(ResultItem)" << oendl;
649 654
650 // Request information from addressbook table and create the OPimTodo-object. 655 // Request information from addressbook table and create the OPimTodo-object.
651 656
652 bool hasDueDate = false; QDate dueDate = QDate::currentDate(); 657 bool hasDueDate = false; QDate dueDate = QDate::currentDate();
653 hasDueDate = date( dueDate, item.data("DueDate") ); 658 hasDueDate = date( dueDate, item.data("DueDate") );
654 QStringList cats = QStringList::split(";", item.data("categories") ); 659 QStringList cats = QStringList::split(";", item.data("categories") );
655 660
656 odebug << "Item is completed: " << item.data("completed").toInt() << "" << oendl; 661 odebug << "Item is completed: " << item.data("completed").toInt() << "" << oendl;
657 662
658 OPimTodo to( (bool)item.data("completed").toInt(), item.data("priority").toInt(), 663 OPimTodo to( (bool)item.data("completed").toInt(), item.data("priority").toInt(),
659 cats, item.data("summary"), item.data("description"), 664 cats, item.data("summary"), item.data("description"),
660 item.data("progress").toUShort(), hasDueDate, dueDate, 665 item.data("progress").toUShort(), hasDueDate, dueDate,
661 item.data("uid").toInt() ); 666 item.data("uid").toInt() );
662 667
663 bool isOk; 668 bool isOk;
664 int prioInt = QString( item.data("priority") ).toInt( &isOk ); 669 int prioInt = QString( item.data("priority") ).toInt( &isOk );
665 if ( isOk ) 670 if ( isOk )
666 to.setPriority( prioInt ); 671 to.setPriority( prioInt );
667 672
668 bool hasStartDate = false; QDate startDate = QDate::currentDate(); 673 bool hasStartDate = false; QDate startDate = QDate::currentDate();
669 hasStartDate = date( startDate, item.data("startdate") ); 674 hasStartDate = date( startDate, item.data("startdate") );
670 bool hasCompletedDate = false; QDate completedDate = QDate::currentDate(); 675 bool hasCompletedDate = false; QDate completedDate = QDate::currentDate();
671 hasCompletedDate = date( completedDate, item.data("completeddate") ); 676 hasCompletedDate = date( completedDate, item.data("completeddate") );
672 677
673 if ( hasStartDate ) 678 if ( hasStartDate )
674 to.setStartDate( startDate ); 679 to.setStartDate( startDate );
675 if ( hasCompletedDate ) 680 if ( hasCompletedDate )
676 to.setCompletedDate( completedDate ); 681 to.setCompletedDate( completedDate );
677 682
678 OPimNotifyManager& manager = to.notifiers(); 683 OPimNotifyManager& manager = to.notifiers();
679 manager.alarmsFromString( item.data("alarms") ); 684 manager.alarmsFromString( item.data("alarms") );
680 manager.remindersFromString( item.data("reminders") ); 685 manager.remindersFromString( item.data("reminders") );
681 686
682 OPimState pimState; 687 OPimState pimState;
683 pimState.setState( QString( item.data("state") ).toInt() ); 688 pimState.setState( QString( item.data("state") ).toInt() );
684 to.setState( pimState ); 689 to.setState( pimState );
685 690
686 QMap<int, QString> recMap; 691 QMap<int, QString> recMap;
687 recMap.insert( OPimRecurrence::RType , item.data("RType") ); 692 recMap.insert( OPimRecurrence::RType , item.data("RType") );
688 recMap.insert( OPimRecurrence::RWeekdays , item.data("RWeekdays") ); 693 recMap.insert( OPimRecurrence::RWeekdays , item.data("RWeekdays") );
689 recMap.insert( OPimRecurrence::RPosition , item.data("RPosition") ); 694 recMap.insert( OPimRecurrence::RPosition , item.data("RPosition") );
690 recMap.insert( OPimRecurrence::RFreq , item.data("RFreq") ); 695 recMap.insert( OPimRecurrence::RFreq , item.data("RFreq") );
691 recMap.insert( OPimRecurrence::RHasEndDate, item.data("RHasEndDate") ); 696 recMap.insert( OPimRecurrence::RHasEndDate, item.data("RHasEndDate") );
692 recMap.insert( OPimRecurrence::EndDate , item.data("EndDate") ); 697 recMap.insert( OPimRecurrence::EndDate , item.data("EndDate") );
693 recMap.insert( OPimRecurrence::Created , item.data("Created") ); 698 recMap.insert( OPimRecurrence::Created , item.data("Created") );
694 recMap.insert( OPimRecurrence::Exceptions , item.data("Exceptions") ); 699 recMap.insert( OPimRecurrence::Exceptions , item.data("Exceptions") );
695 700
696 OPimRecurrence recur; 701 OPimRecurrence recur;
697 recur.fromMap( recMap ); 702 recur.fromMap( recMap );
698 to.setRecurrence( recur ); 703 to.setRecurrence( recur );
699 704
700 // Finally load the custom-entries for this UID and put it into the created object 705 // Finally load the custom-entries for this UID and put it into the created object
701 to.setExtraMap( requestCustom( to.uid() ) ); 706 to.setExtraMap( requestCustom( to.uid() ) );
702 707
703 return to; 708 return to;
704} 709}
705OPimTodo OPimTodoAccessBackendSQL::todo( int uid )const { 710OPimTodo OPimTodoAccessBackendSQL::todo( int uid )const {
706 FindQuery find( uid ); 711 FindQuery find( uid );
707 return todo( m_driver->query(&find) ); 712 return todo( m_driver->query(&find) );
708} 713}
709/* 714/*
710 * update the dict 715 * update the dict
711 */ 716 */
712void OPimTodoAccessBackendSQL::fillDict() { 717void OPimTodoAccessBackendSQL::fillDict() {
713 718
714#if 0 719#if 0
715 /* initialize dict */ 720 /* initialize dict */
716 /* 721 /*
717 * UPDATE dict if you change anything!!! 722 * UPDATE dict if you change anything!!!
718 * FIXME: Isn't this dict obsolete ? (eilers) 723 * FIXME: Isn't this dict obsolete ? (eilers)
719 */ 724 */
720 m_dict.setAutoDelete( TRUE ); 725 m_dict.setAutoDelete( TRUE );
721 m_dict.insert("Categories" , new int(OPimTodo::Category) ); 726 m_dict.insert("Categories" , new int(OPimTodo::Category) );
722 m_dict.insert("Uid" , new int(OPimTodo::Uid) ); 727 m_dict.insert("Uid" , new int(OPimTodo::Uid) );
723 m_dict.insert("HasDate" , new int(OPimTodo::HasDate) ); 728 m_dict.insert("HasDate" , new int(OPimTodo::HasDate) );
724 m_dict.insert("Completed" , new int(OPimTodo::Completed) ); 729 m_dict.insert("Completed" , new int(OPimTodo::Completed) );
725 m_dict.insert("Description" , new int(OPimTodo::Description) ); 730 m_dict.insert("Description" , new int(OPimTodo::Description) );
726 m_dict.insert("Summary" , new int(OPimTodo::Summary) ); 731 m_dict.insert("Summary" , new int(OPimTodo::Summary) );
727 m_dict.insert("Priority" , new int(OPimTodo::Priority) ); 732 m_dict.insert("Priority" , new int(OPimTodo::Priority) );
728 m_dict.insert("DateDay" , new int(OPimTodo::DateDay) ); 733 m_dict.insert("DateDay" , new int(OPimTodo::DateDay) );
729 m_dict.insert("DateMonth" , new int(OPimTodo::DateMonth) ); 734 m_dict.insert("DateMonth" , new int(OPimTodo::DateMonth) );
730 m_dict.insert("DateYear" , new int(OPimTodo::DateYear) ); 735 m_dict.insert("DateYear" , new int(OPimTodo::DateYear) );
731 m_dict.insert("Progress" , new int(OPimTodo::Progress) ); 736 m_dict.insert("Progress" , new int(OPimTodo::Progress) );
732 m_dict.insert("Completed", new int(OPimTodo::Completed) ); // Why twice ? (eilers) 737 m_dict.insert("Completed", new int(OPimTodo::Completed) ); // Why twice ? (eilers)
733 m_dict.insert("CrossReference", new int(OPimTodo::CrossReference) ); 738 m_dict.insert("CrossReference", new int(OPimTodo::CrossReference) );
734// m_dict.insert("HasAlarmDateTime",new int(OPimTodo::HasAlarmDateTime) ); // old stuff (eilers) 739// m_dict.insert("HasAlarmDateTime",new int(OPimTodo::HasAlarmDateTime) ); // old stuff (eilers)
735// m_dict.insert("AlarmDateTime", new int(OPimTodo::AlarmDateTime) ); // old stuff (eilers) 740// m_dict.insert("AlarmDateTime", new int(OPimTodo::AlarmDateTime) ); // old stuff (eilers)
736 741
737#endif 742#endif
738} 743}
739/* 744/*
740 * need to be const so let's fool the 745 * need to be const so let's fool the
741 * compiler :( 746 * compiler :(
742 */ 747 */
743void OPimTodoAccessBackendSQL::update()const { 748void OPimTodoAccessBackendSQL::update()const {
744 ((OPimTodoAccessBackendSQL*)this)->m_dirty = false; 749 ((OPimTodoAccessBackendSQL*)this)->m_dirty = false;
745 LoadQuery lo; 750 LoadQuery lo;
746 OSQLResult res = m_driver->query(&lo); 751 OSQLResult res = m_driver->query(&lo);
747 if ( res.state() != OSQLResult::Success ) 752 if ( res.state() != OSQLResult::Success )
748 return; 753 return;
749 754
750 ((OPimTodoAccessBackendSQL*)this)->m_uids = uids( res ); 755 ((OPimTodoAccessBackendSQL*)this)->m_uids = uids( res );
751} 756}
752QArray<int> OPimTodoAccessBackendSQL::uids( const OSQLResult& res) const{ 757QArray<int> OPimTodoAccessBackendSQL::uids( const OSQLResult& res) const{
753 758
754 OSQLResultItem::ValueList list = res.results(); 759 OSQLResultItem::ValueList list = res.results();
755 OSQLResultItem::ValueList::Iterator it; 760 OSQLResultItem::ValueList::Iterator it;
756 QArray<int> ints(list.count() ); 761 QArray<int> ints(list.count() );
757 odebug << " count = " << list.count() << "" << oendl; 762 odebug << " count = " << list.count() << "" << oendl;
758 763
759 int i = 0; 764 int i = 0;
760 for (it = list.begin(); it != list.end(); ++it ) { 765 for (it = list.begin(); it != list.end(); ++it ) {
761 ints[i] = (*it).data("uid").toInt(); 766 ints[i] = (*it).data("uid").toInt();
762 i++; 767 i++;
763 } 768 }
764 return ints; 769 return ints;
765} 770}
766 771
767QArray<int> OPimTodoAccessBackendSQL::matchRegexp( const QRegExp &r ) const 772QArray<int> OPimTodoAccessBackendSQL::matchRegexp( const QRegExp &r ) const
768{ 773{
769 774
770#if 0 775#if 0
771 QArray<int> empty; 776 QArray<int> empty;
772 return empty; 777 return empty;
773 778
774#else 779#else
775 QString qu = "SELECT uid FROM todolist WHERE ("; 780 QString qu = "SELECT uid FROM todolist WHERE (";
776 781
777 // Do it make sense to search other fields, too ? 782 // Do it make sense to search other fields, too ?
778 qu += " rlike(\""+ r.pattern() + "\",\"description\") OR"; 783 qu += " rlike(\""+ r.pattern() + "\",\"description\") OR";
779 qu += " rlike(\""+ r.pattern() + "\",\"summary\")"; 784 qu += " rlike(\""+ r.pattern() + "\",\"summary\")";
780 785
781 qu += ")"; 786 qu += ")";
782 787
783 odebug << "query: " << qu << "" << oendl; 788 odebug << "query: " << qu << "" << oendl;
784 789
785 OSQLRawQuery raw( qu ); 790 OSQLRawQuery raw( qu );
786 OSQLResult res = m_driver->query( &raw ); 791 OSQLResult res = m_driver->query( &raw );
787 792
788 return uids( res ); 793 return uids( res );
789 794
790 795
791#endif 796#endif
792 797
793} 798}
794QBitArray OPimTodoAccessBackendSQL::supports()const { 799QBitArray OPimTodoAccessBackendSQL::supports()const {
795 800
796 return sup(); 801 return sup();
797} 802}
798 803
799QBitArray OPimTodoAccessBackendSQL::sup() const{ 804QBitArray OPimTodoAccessBackendSQL::sup() const{
800 805
801 QBitArray ar( OPimTodo::CompletedDate + 1 ); 806 QBitArray ar( OPimTodo::CompletedDate + 1 );
802 ar.fill( true ); 807 ar.fill( true );
803 ar[OPimTodo::CrossReference] = false; 808 ar[OPimTodo::CrossReference] = false;
804 ar[OPimTodo::State ] = false; 809 ar[OPimTodo::State ] = false;
805 ar[OPimTodo::Reminders] = false; 810 ar[OPimTodo::Reminders] = false;
806 ar[OPimTodo::Notifiers] = false; 811 ar[OPimTodo::Notifiers] = false;
807 ar[OPimTodo::Maintainer] = false; 812 ar[OPimTodo::Maintainer] = false;
808 813
809 return ar; 814 return ar;
810} 815}
811 816
812void OPimTodoAccessBackendSQL::removeAllCompleted(){ 817void OPimTodoAccessBackendSQL::removeAllCompleted(){
813 // First we need the uids from all entries which are 818 // First we need the uids from all entries which are
814 // completed. Then, we just have to remove them... 819 // completed. Then, we just have to remove them...
815 820
816 QString qu = "SELECT uid FROM todolist WHERE completed = 1"; 821 QString qu = "SELECT uid FROM todolist WHERE completed = 1";
817 822
818 OSQLRawQuery raw( qu ); 823 OSQLRawQuery raw( qu );
819 OSQLResult res = m_driver->query( &raw ); 824 OSQLResult res = m_driver->query( &raw );
820 825
821 QArray<int> completed_uids = uids( res ); 826 QArray<int> completed_uids = uids( res );
822 827
823 odebug << "Number of completed: " << completed_uids.size() << "" << oendl; 828 odebug << "Number of completed: " << completed_uids.size() << "" << oendl;
824 829
825 if ( completed_uids.size() == 0 ) 830 if ( completed_uids.size() == 0 )
826 return; 831 return;
827 832
828 qu = "DELETE FROM todolist WHERE ("; 833 qu = "DELETE FROM todolist WHERE (";
829 QString query; 834 QString query;
830 835
831 for ( int i = 0; i < completed_uids.size(); i++ ){ 836 for ( int i = 0; i < completed_uids.size(); i++ ){
832 if ( !query.isEmpty() ) 837 if ( !query.isEmpty() )
833 query += " OR "; 838 query += " OR ";
834 query += QString( "uid = %1" ).arg( completed_uids[i] ); 839 query += QString( "uid = %1" ).arg( completed_uids[i] );
835 } 840 }
836 qu += query + " );"; 841 qu += query + " );";
837 842
838 // Put remove of custom entries in this query to speed up.. 843 // Put remove of custom entries in this query to speed up..
839 qu += "DELETE FORM custom_data WHERE ("; 844 qu += "DELETE FORM custom_data WHERE (";
840 query = ""; 845 query = "";
841 846
842 for ( int i = 0; i < completed_uids.size(); i++ ){ 847 for ( int i = 0; i < completed_uids.size(); i++ ){
843 if ( !query.isEmpty() ) 848 if ( !query.isEmpty() )
844 query += " OR "; 849 query += " OR ";
845 query += QString( "uid = %1" ).arg( completed_uids[i] ); 850 query += QString( "uid = %1" ).arg( completed_uids[i] );
846 } 851 }
847 qu += query + " );"; 852 qu += query + " );";
848 853
849 odebug << "query: " << qu << "" << oendl; 854 odebug << "query: " << qu << "" << oendl;
850 855
851 OSQLRawQuery raw2( qu ); 856 OSQLRawQuery raw2( qu );
852 res = m_driver->query( &raw2 ); 857 res = m_driver->query( &raw2 );
853 if ( res.state() == OSQLResult::Failure ) { 858 if ( res.state() == OSQLResult::Failure ) {
854 owarn << "OPimTodoAccessBackendSQL::removeAllCompleted():Failure in query: " << qu << "" << oendl; 859 owarn << "OPimTodoAccessBackendSQL::removeAllCompleted():Failure in query: " << qu << "" << oendl;
855 } 860 }
856} 861}
857 862
858 863
859QMap<QString, QString> OPimTodoAccessBackendSQL::requestCustom( int uid ) const 864QMap<QString, QString> OPimTodoAccessBackendSQL::requestCustom( int uid ) const
860{ 865{
861 QMap<QString, QString> customMap; 866 QMap<QString, QString> customMap;
862 867
863 FindCustomQuery query( uid ); 868 FindCustomQuery query( uid );
864 OSQLResult res_custom = m_driver->query( &query ); 869 OSQLResult res_custom = m_driver->query( &query );
865 870
866 if ( res_custom.state() == OSQLResult::Failure ) { 871 if ( res_custom.state() == OSQLResult::Failure ) {
867 owarn << "OSQLResult::Failure in find query !!" << oendl; 872 owarn << "OSQLResult::Failure in find query !!" << oendl;
868 QMap<QString, QString> empty; 873 QMap<QString, QString> empty;
869 return empty; 874 return empty;
870 } 875 }
871 876
872 OSQLResultItem::ValueList list = res_custom.results(); 877 OSQLResultItem::ValueList list = res_custom.results();
873 OSQLResultItem::ValueList::Iterator it = list.begin(); 878 OSQLResultItem::ValueList::Iterator it = list.begin();
874 for ( ; it != list.end(); ++it ) { 879 for ( ; it != list.end(); ++it ) {
875 customMap.insert( (*it).data( "type" ), (*it).data( "value" ) ); 880 customMap.insert( (*it).data( "type" ), (*it).data( "value" ) );
876 } 881 }
877 882
878 return customMap; 883 return customMap;
879} 884}
880 885
881 886
882 887
883 888
884} 889}