summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiepim/backend/backends.pro31
-rw-r--r--libopie2/opiepim/backend/obackendfactory.h118
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend.h82
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_sql.cpp77
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_sql.h62
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_vcard.cpp125
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_vcard.h77
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_xml.cpp135
-rw-r--r--libopie2/opiepim/backend/ocontactaccessbackend_xml.h118
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend.cpp38
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend.h35
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend_sql.cpp67
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend_sql.h33
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend_xml.cpp41
-rw-r--r--libopie2/opiepim/backend/odatebookaccessbackend_xml.h33
-rw-r--r--libopie2/opiepim/backend/opimaccessbackend.h36
-rw-r--r--libopie2/opiepim/backend/otodoaccessbackend.cpp33
-rw-r--r--libopie2/opiepim/backend/otodoaccessbackend.h35
-rw-r--r--libopie2/opiepim/backend/otodoaccesssql.cpp41
-rw-r--r--libopie2/opiepim/backend/otodoaccesssql.h34
-rw-r--r--libopie2/opiepim/backend/otodoaccessvcal.cpp35
-rw-r--r--libopie2/opiepim/backend/otodoaccessvcal.h34
-rw-r--r--libopie2/opiepim/backend/otodoaccessxml.cpp45
-rw-r--r--libopie2/opiepim/backend/otodoaccessxml.h33
-rw-r--r--libopie2/opiepim/core/core.pro21
-rw-r--r--libopie2/opiepim/core/ocontactaccess.cpp80
-rw-r--r--libopie2/opiepim/core/ocontactaccess.h105
-rw-r--r--libopie2/opiepim/core/oconversion.cpp47
-rw-r--r--libopie2/opiepim/core/oconversion.h50
-rw-r--r--libopie2/opiepim/core/odatebookaccess.cpp35
-rw-r--r--libopie2/opiepim/core/odatebookaccess.h33
-rw-r--r--libopie2/opiepim/core/opimaccesstemplate.h43
-rw-r--r--libopie2/opiepim/core/opimcache.h33
-rw-r--r--libopie2/opiepim/core/opimmaintainer.cpp34
-rw-r--r--libopie2/opiepim/core/opimmaintainer.h31
-rw-r--r--libopie2/opiepim/core/opimnotify.cpp33
-rw-r--r--libopie2/opiepim/core/opimnotify.h32
-rw-r--r--libopie2/opiepim/core/opimnotifymanager.cpp37
-rw-r--r--libopie2/opiepim/core/opimnotifymanager.h33
-rw-r--r--libopie2/opiepim/core/opimrecord.cpp33
-rw-r--r--libopie2/opiepim/core/opimrecord.h33
-rw-r--r--libopie2/opiepim/core/opimresolver.cpp38
-rw-r--r--libopie2/opiepim/core/opimresolver.h33
-rw-r--r--libopie2/opiepim/core/opimstate.cpp31
-rw-r--r--libopie2/opiepim/core/opimstate.h31
-rw-r--r--libopie2/opiepim/core/opimxref.cpp34
-rw-r--r--libopie2/opiepim/core/opimxref.h34
-rw-r--r--libopie2/opiepim/core/opimxrefmanager.cpp33
-rw-r--r--libopie2/opiepim/core/opimxrefmanager.h33
-rw-r--r--libopie2/opiepim/core/opimxrefpartner.cpp34
-rw-r--r--libopie2/opiepim/core/opimxrefpartner.h30
-rw-r--r--libopie2/opiepim/core/orecur.cpp36
-rw-r--r--libopie2/opiepim/core/orecur.h31
-rw-r--r--libopie2/opiepim/core/otemplatebase.h33
-rw-r--r--libopie2/opiepim/core/otimezone.cpp37
-rw-r--r--libopie2/opiepim/core/otimezone.h33
-rw-r--r--libopie2/opiepim/core/otodoaccess.cpp37
-rw-r--r--libopie2/opiepim/core/otodoaccess.h37
-rw-r--r--libopie2/opiepim/ocontact.cpp37
-rw-r--r--libopie2/opiepim/ocontact.h51
-rw-r--r--libopie2/opiepim/ocontactfields.cpp35
-rw-r--r--libopie2/opiepim/ocontactfields.h33
-rw-r--r--libopie2/opiepim/oevent.cpp40
-rw-r--r--libopie2/opiepim/oevent.h36
-rw-r--r--libopie2/opiepim/opiepim.pro10
-rw-r--r--libopie2/opiepim/orecordlist.h36
-rw-r--r--libopie2/opiepim/otodo.cpp44
-rw-r--r--libopie2/opiepim/otodo.h34
-rw-r--r--libopie2/opiepim/ui/opimmainwindow.cpp33
-rw-r--r--libopie2/opiepim/ui/opimmainwindow.h36
-rw-r--r--libopie2/opiepim/ui/ui.pro3
71 files changed, 2288 insertions, 826 deletions
diff --git a/libopie2/opiepim/backend/backends.pro b/libopie2/opiepim/backend/backends.pro
new file mode 100644
index 0000000..4231a00
--- a/dev/null
+++ b/libopie2/opiepim/backend/backends.pro
@@ -0,0 +1,31 @@
1SOURCES += core/backends/ocontactaccessbackend_sql.cpp \
2 core/backends/ocontactaccessbackend_vcard.cpp \
3 core/backends/ocontactaccessbackend_xml.cpp \
4 core/backends/ocontactaccess.cpp \
5 core/backends/odatebookaccessbackend.cpp \
6 core/backends/odatebookaccessbackend_xml.cpp \
7 core/backends/otodoaccessbackend.cpp \
8 core/backends/otodoaccess.cpp \
9 core/backends/otodoaccesssql.cpp \
10 core/backends/otodoaccessvcal.cpp \
11 core/backends/otodoaccessxml.cpp \
12 core/backends/odatebookaccess.cpp \
13 core/backends/odatebookaccessbackend_sql.cpp
14
15HEADERS += core/backends/obackendfactory.h \
16 core/backends/ocontactaccessbackend.h \
17 core/backends/ocontactaccessbackend_sql.h \
18 core/backends/ocontactaccessbackend_vcard.h \
19 core/backends/ocontactaccessbackend_xml.h \
20 core/backends/ocontactaccess.h \
21 core/backends/odatebookaccessbackend.h \
22 core/backends/odatebookaccessbackend_sql.h \
23 core/backends/odatebookaccessbackend_xml.h \
24 core/backends/opimaccessbackend.h \
25 core/backends/opimaccesstemplate.h \
26 core/backends/otodoaccessbackend.h \
27 core/backends/otodoaccess.h \
28 core/backends/otodoaccesssql.h \
29 core/backends/otodoaccessvcal.h \
30 core/backends/otodoaccessxml.h \
31 core/backends/odatebookaccess.h
diff --git a/libopie2/opiepim/backend/obackendfactory.h b/libopie2/opiepim/backend/obackendfactory.h
index 761ab9a..346e2f5 100644
--- a/libopie2/opiepim/backend/obackendfactory.h
+++ b/libopie2/opiepim/backend/obackendfactory.h
@@ -1,194 +1,150 @@
1/* 1/*
2 * Class to manage Backends. 2 This file is part of the Opie Project
3 * 3 Copyright (C) The Main Author <main-author@whereever.org>
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 * 5 .=l.
6 * ===================================================================== 6 .>+-=
7 *This program is free software; you can redistribute it and/or 7 _;:, .> :=|. This program is free software; you can
8 *modify it under the terms of the GNU Library General Public 8.> <`_, > . <= redistribute it and/or modify it under
9 * License as published by the Free Software Foundation; 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10 * either version 2 of the License, or (at your option) any later 10.="- .-=="i, .._ License as published by the Free Software
11 * version. 11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
12 * ===================================================================== 30 * =====================================================================
13 * ToDo: Use plugins 31 * ToDo: Use plugins
14 * ===================================================================== 32 * =====================================================================
15 * Version: $Id$
16 * =====================================================================
17 * History:
18 * $Log$
19 * Revision 1.9 2003/12/22 10:19:26 eilers
20 * Finishing implementation of sql-backend for datebook. But I have to
21 * port the PIM datebook application to use it, before I could debug the
22 * whole stuff.
23 * Thus, PIM-Database backend is finished, but highly experimental. And some
24 * parts are still generic. For instance, the "queryByExample()" methods are
25 * not (or not fully) implemented. Todo: custom-entries not stored.
26 * The big show stopper: matchRegExp() (needed by OpieSearch) needs regular
27 * expression search in the database, which is not supported by sqlite !
28 * Therefore we need either an extended sqlite or a workaround which would
29 * be very slow and memory consuming..
30 *
31 * Revision 1.8 2003/09/22 14:31:16 eilers
32 * Added first experimental incarnation of sql-backend for addressbook.
33 * Some modifications to be able to compile the todo sql-backend.
34 * A lot of changes fill follow...
35 *
36 * Revision 1.7 2003/08/01 12:30:16 eilers
37 * Merging changes from BRANCH_1_0 to HEAD
38 *
39 * Revision 1.6.4.1 2003/06/30 14:34:19 eilers
40 * Patches from Zecke:
41 * Fixing and cleaning up extraMap handling
42 * Adding d_ptr for binary compatibility in the future
43 *
44 * Revision 1.6 2003/04/13 18:07:10 zecke
45 * More API doc
46 * QString -> const QString&
47 * QString = 0l -> QString::null
48 *
49 * Revision 1.5 2003/02/21 23:31:52 zecke
50 * Add XML datebookresource
51 * -clean up todoaccessxml header
52 * -implement some more stuff in the oeven tester
53 * -extend DefaultFactory to not crash and to use datebook
54 *
55 * -reading of OEvents is working nicely.. saving will be added
56 * tomorrow
57 * -fix spelling in ODateBookAcces
58 *
59 * Revision 1.4 2002/10/14 15:55:18 eilers
60 * Redeactivate SQL.. ;)
61 *
62 * Revision 1.3 2002/10/10 17:08:58 zecke
63 * The Cache is finally in place
64 * I tested it with my todolist and it 'works' for 10.000 todos the hits are awesome ;)
65 * The read ahead functionality does not make sense for XMLs backends because most of the stuff is already in memory. While using readahead on SQL makes things a lot faster....
66 * I still have to fully implement read ahead
67 * This change is bic but sc
68 *
69 * Revision 1.2 2002/10/08 09:27:36 eilers
70 * Fixed libopie.pro to include the new pim-API.
71 * The SQL-Stuff is currently deactivated. Otherwise everyone who wants to
72 * compile itself would need to install libsqlite, libopiesql...
73 * Therefore, the backend currently uses XML only..
74 *
75 * Revision 1.1 2002/10/07 17:35:01 eilers
76 * added OBackendFactory for advanced backend access
77 *
78 *
79 * =====================================================================
80 */ 33 */
81#ifndef OPIE_BACKENDFACTORY_H_ 34#ifndef OPIE_BACKENDFACTORY_H_
82#define OPIE_BACKENDFACTORY_H_ 35#define OPIE_BACKENDFACTORY_H_
83 36
84#include <qstring.h> 37#include <qstring.h>
85#include <qasciidict.h> 38#include <qasciidict.h>
86#include <qpe/config.h> 39#include <qpe/config.h>
87 40
88#include "otodoaccessxml.h" 41#include <opie2/otodoaccessxml.h>
89#include "ocontactaccessbackend_xml.h" 42#include <opie2/ocontactaccessbackend_xml.h>
90#include "odatebookaccessbackend_xml.h" 43#include <opie2/odatebookaccessbackend_xml.h>
91 44
92#ifdef __USE_SQL 45#ifdef __USE_SQL
93#include "otodoaccesssql.h" 46#include <opie2/otodoaccesssql.h>
94#include "ocontactaccessbackend_sql.h" 47#include <opie2/ocontactaccessbackend_sql.h>
95#include "odatebookaccessbackend_sql.h" 48#include <opie2/odatebookaccessbackend_sql.h>
96#endif 49#endif
97 50
51namespace Opie {
52
98class OBackendPrivate; 53class OBackendPrivate;
99 54
100/** 55/**
101 * This class is our factory. It will give us the default implementations 56 * This class is our factory. It will give us the default implementations
102 * of at least Todolist, Contacts and Datebook. In the future this class will 57 * of at least Todolist, Contacts and Datebook. In the future this class will
103 * allow users to switch the backend with ( XML->SQLite ) without the need 58 * allow users to switch the backend with ( XML->SQLite ) without the need
104 * to recompile.# 59 * to recompile.#
105 * This class as the whole PIM Api is making use of templates 60 * This class as the whole PIM Api is making use of templates
106 * 61 *
107 * <pre> 62 * <pre>
108 * OTodoAccessBackend* backend = OBackEndFactory<OTodoAccessBackend>::Default("todo", QString::null ); 63 * OTodoAccessBackend* backend = OBackEndFactory<OTodoAccessBackend>::Default("todo", QString::null );
109 * backend->load(); 64 * backend->load();
110 * </pre> 65 * </pre>
111 * 66 *
112 * @author Stefan Eilers 67 * @author Stefan Eilers
113 * @version 0.1 68 * @version 0.1
114 */ 69 */
115template<class T> 70template<class T>
116class OBackendFactory 71class OBackendFactory
117{ 72{
118 public: 73 public:
119 OBackendFactory() {}; 74 OBackendFactory() {};
120 75
121 enum BACKENDS { 76 enum BACKENDS {
122 TODO, 77 TODO,
123 CONTACT, 78 CONTACT,
124 DATE 79 DATE
125 }; 80 };
126 81
127 /** 82 /**
128 * Returns a backend implementation for backendName 83 * Returns a backend implementation for backendName
129 * @param backendName the type of the backend 84 * @param backendName the type of the backend
130 * @param appName will be passed on to the backend 85 * @param appName will be passed on to the backend
131 */ 86 */
132 static T* Default( const QString backendName, const QString& appName ){ 87 static T* Default( const QString backendName, const QString& appName ){
133 88
134 // __asm__("int3"); 89 // __asm__("int3");
135 90
136 Config config( "pimaccess" ); 91 Config config( "pimaccess" );
137 config.setGroup ( backendName ); 92 config.setGroup ( backendName );
138 QString backend = config.readEntry( "usebackend" ); 93 QString backend = config.readEntry( "usebackend" );
139 94
140 qWarning("Selected backend for %s is: %s", backendName.latin1(), backend.latin1() ); 95 qWarning("Selected backend for %s is: %s", backendName.latin1(), backend.latin1() );
141 96
142 QAsciiDict<int> dict ( 3 ); 97 QAsciiDict<int> dict ( 3 );
143 dict.setAutoDelete ( TRUE ); 98 dict.setAutoDelete ( TRUE );
144 99
145 dict.insert( "todo", new int (TODO) ); 100 dict.insert( "todo", new int (TODO) );
146 dict.insert( "contact", new int (CONTACT) ); 101 dict.insert( "contact", new int (CONTACT) );
147 dict.insert( "datebook", new int(DATE) ); 102 dict.insert( "datebook", new int(DATE) );
148 103
149 int *find = dict[ backendName ]; 104 int *find = dict[ backendName ];
150 if (!find ) return 0; 105 if (!find ) return 0;
151 106
152 switch ( *find ){ 107 switch ( *find ){
153 case TODO: 108 case TODO:
154#ifdef __USE_SQL 109#ifdef __USE_SQL
155 if ( backend == "sql" ) 110 if ( backend == "sql" )
156 return (T*) new OTodoAccessBackendSQL(""); 111 return (T*) new OTodoAccessBackendSQL("");
157#else 112#else
158 if ( backend == "sql" ) 113 if ( backend == "sql" )
159 qWarning ("OBackendFactory:: sql Backend for TODO not implemented! Using XML instead!"); 114 qWarning ("OBackendFactory:: sql Backend for TODO not implemented! Using XML instead!");
160#endif 115#endif
161 116
162 return (T*) new OTodoAccessXML( appName ); 117 return (T*) new OTodoAccessXML( appName );
163 case CONTACT: 118 case CONTACT:
164#ifdef __USE_SQL 119#ifdef __USE_SQL
165 if ( backend == "sql" ) 120 if ( backend == "sql" )
166 return (T*) new OContactAccessBackend_SQL(""); 121 return (T*) new OContactAccessBackend_SQL("");
167#else 122#else
168 if ( backend == "sql" ) 123 if ( backend == "sql" )
169 qWarning ("OBackendFactory:: sql Backend for CONTACT not implemented! Using XML instead!"); 124 qWarning ("OBackendFactory:: sql Backend for CONTACT not implemented! Using XML instead!");
170#endif 125#endif
171 126
172 return (T*) new OContactAccessBackend_XML( appName ); 127 return (T*) new OContactAccessBackend_XML( appName );
173 case DATE: 128 case DATE:
174#ifdef __USE_SQL 129#ifdef __USE_SQL
175 if ( backend == "sql" ) 130 if ( backend == "sql" )
176 return (T*) new ODateBookAccessBackend_SQL(""); 131 return (T*) new ODateBookAccessBackend_SQL("");
177#else 132#else
178 if ( backend == "sql" ) 133 if ( backend == "sql" )
179 qWarning("OBackendFactory:: sql Backend for DATEBOOK not implemented! Using XML instead!"); 134 qWarning("OBackendFactory:: sql Backend for DATEBOOK not implemented! Using XML instead!");
180#endif 135#endif
181 136
182 return (T*) new ODateBookAccessBackend_XML( appName ); 137 return (T*) new ODateBookAccessBackend_XML( appName );
183 default: 138 default:
184 return NULL; 139 return NULL;
185 } 140 }
186 141
187 142
188 } 143 }
189 private: 144 private:
190 OBackendPrivate* d; 145 OBackendPrivate* d;
191}; 146};
192 147
148}
193 149
194#endif 150#endif
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend.h b/libopie2/opiepim/backend/ocontactaccessbackend.h
index 0eac6dc..6113cea 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend.h
+++ b/libopie2/opiepim/backend/ocontactaccessbackend.h
@@ -1,128 +1,114 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1/** 29/**
2 * The class responsible for managing a backend. 30 * The class responsible for managing a backend.
3 * The implementation of this abstract class contains 31 * The implementation of this abstract class contains
4 * the complete database handling. 32 * the complete database handling.
5 * 33 *
6 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 34 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
7 * Copyright (c) 2002 by Holger Freyther (zecke@handhelds.org) 35 * Copyright (c) 2002 by Holger Freyther (zecke@handhelds.org)
8 * 36 *
9 * =====================================================================
10 *This program is free software; you can redistribute it and/or
11 *modify it under the terms of the GNU Library General Public
12 * License as published by the Free Software Foundation;
13 * either version 2 of the License, or (at your option) any later
14 * version.
15 * =====================================================================
16 * ToDo: Define enum for query settings
17 * =====================================================================
18 * Version: $Id$
19 * =====================================================================
20 * History:
21 * $Log$
22 * Revision 1.7 2004/02/19 02:05:37 zecke
23 * Add notes for API fixes and BC stuff
24 *
25 * Revision 1.6 2003/08/01 12:30:16 eilers
26 * Merging changes from BRANCH_1_0 to HEAD
27 *
28 * Revision 1.5.4.1 2003/06/30 14:34:19 eilers
29 * Patches from Zecke:
30 * Fixing and cleaning up extraMap handling
31 * Adding d_ptr for binary compatibility in the future
32 *
33 * Revision 1.5 2003/04/13 18:07:10 zecke
34 * More API doc
35 * QString -> const QString&
36 * QString = 0l -> QString::null
37 *
38 * Revision 1.4 2002/11/13 14:14:51 eilers
39 * Added sorted for Contacts..
40 *
41 * Revision 1.3 2002/11/01 15:10:42 eilers
42 * Added regExp-search in database for all fields in a contact.
43 *
44 * Revision 1.2 2002/10/07 17:34:24 eilers
45 * added OBackendFactory for advanced backend access
46 *
47 * Revision 1.1 2002/09/27 17:11:44 eilers
48 * Added API for accessing the Contact-Database ! It is compiling, but
49 * please do not expect that anything is working !
50 * I will debug that stuff in the next time ..
51 * Please read README_COMPILE for compiling !
52 *
53 * =====================================================================
54 *
55 */ 37 */
56 38
57#ifndef _OCONTACTACCESSBACKEND_H_ 39#ifndef _OCONTACTACCESSBACKEND_H_
58#define _OCONTACTACCESSBACKEND_H_ 40#define _OCONTACTACCESSBACKEND_H_
59 41
60#include "ocontact.h" 42#include <opie2/ocontact.h>
61#include "opimaccessbackend.h" 43#include <opie2/opimaccessbackend.h>
62 44
63#include <qregexp.h> 45#include <qregexp.h>
64 46
47namespace Opie {
65/** 48/**
66 * This class represents the interface of all Contact Backends. 49 * This class represents the interface of all Contact Backends.
67 * Derivates of this class will be used to access the contacts. 50 * Derivates of this class will be used to access the contacts.
68 * As implementation currently XML and vCard exist. This class needs to be implemented 51 * As implementation currently XML and vCard exist. This class needs to be implemented
69 * if you want to provide your own storage. 52 * if you want to provide your own storage.
70 * In all queries a list of uids is passed on instead of loading the actual record! 53 * In all queries a list of uids is passed on instead of loading the actual record!
71 * 54 *
72 * @see OContactAccessBackend_VCard 55 * @see OContactAccessBackend_VCard
73 * @see OContactAccessBackend_XML 56 * @see OContactAccessBackend_XML
74 */ 57 */
75class OContactAccessBackend: public OPimAccessBackend<OContact> { 58class OContactAccessBackend: public OPimAccessBackend<OContact> {
76 public: 59 public:
77 /** 60 /**
78 * @todo make non line in regard to BC guide of KDE 61 * @todo make non line in regard to BC guide of KDE
79 */ 62 */
80 OContactAccessBackend() {} 63 OContactAccessBackend() {}
81 /** 64 /**
82 * @todo make non inline in regard to the BC guide of KDE 65 * @todo make non inline in regard to the BC guide of KDE
83 */ 66 */
84 virtual ~OContactAccessBackend() {} 67 virtual ~OContactAccessBackend() {}
85 68
86 69
87 /** 70 /**
88 * Return if database was changed externally. 71 * Return if database was changed externally.
89 * This may just make sense on file based databases like a XML-File. 72 * This may just make sense on file based databases like a XML-File.
90 * It is used to prevent to overwrite the current database content 73 * It is used to prevent to overwrite the current database content
91 * if the file was already changed by something else ! 74 * if the file was already changed by something else !
92 * If this happens, we have to reload before save our data. 75 * If this happens, we have to reload before save our data.
93 * If we use real databases, this should be handled by the database 76 * If we use real databases, this should be handled by the database
94 * management system themselve, therefore this function should always return false in 77 * management system themselve, therefore this function should always return false in
95 * this case. It is not our problem to handle this conflict ... 78 * this case. It is not our problem to handle this conflict ...
96 * @return <i>true</i> if the database was changed and if save without reload will 79 * @return <i>true</i> if the database was changed and if save without reload will
97 * be dangerous. <i>false</i> if the database was not changed or it is save to write 80 * be dangerous. <i>false</i> if the database was not changed or it is save to write
98 * in this situation. 81 * in this situation.
99 */ 82 */
100 virtual bool wasChangedExternally() = 0; 83 virtual bool wasChangedExternally() = 0;
101 84
102 virtual QArray<int> matchRegexp( const QRegExp &r ) const = 0; 85 virtual QArray<int> matchRegexp( const QRegExp &r ) const = 0;
103 86
104 /** 87 /**
105 * Return all possible settings. 88 * Return all possible settings.
106 * @return All settings provided by the current backend 89 * @return All settings provided by the current backend
107 * (i.e.: query_WildCards & query_IgnoreCase) 90 * (i.e.: query_WildCards & query_IgnoreCase)
108 */ 91 */
109 virtual const uint querySettings() = 0; 92 virtual const uint querySettings() = 0;
110 93
111 /** 94 /**
112 * Check whether settings are correct. 95 * Check whether settings are correct.
113 * @return <i>true</i> if the given settings are correct and possible. 96 * @return <i>true</i> if the given settings are correct and possible.
114 */ 97 */
115 virtual bool hasQuerySettings (uint querySettings) const = 0; 98 virtual bool hasQuerySettings (uint querySettings) const = 0;
116 99
117 /** 100 /**
118 * FIXME!!! 101 * FIXME!!!
119 * Returns a sorted list of records either ascendinf or descending for a giving criteria and category 102 * Returns a sorted list of records either ascendinf or descending for a giving criteria and category
120 */ 103 */
121 virtual QArray<int> sorted( bool ascending, int sortOrder, int sortFilter, int cat ) = 0; 104 virtual QArray<int> sorted( bool ascending, int sortOrder, int sortFilter, int cat ) = 0;
122 105
123 106
124private: 107private:
125 class Private; 108 class Private;
126 Private *d; 109 Private *d;
127}; 110};
111
112}
113
128#endif 114#endif
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_sql.cpp b/libopie2/opiepim/backend/ocontactaccessbackend_sql.cpp
index a5be4c8..d0c8052 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_sql.cpp
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_sql.cpp
@@ -1,942 +1,935 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * SQL Backend for the OPIE-Contact Database. 30 * SQL Backend for the OPIE-Contact Database.
3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 *
6 * =====================================================================
7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 * =====================================================================
12 * =====================================================================
13 * Version: $Id$
14 * =====================================================================
15 * History:
16 * $Log$
17 * Revision 1.4 2003/12/22 10:19:26 eilers
18 * Finishing implementation of sql-backend for datebook. But I have to
19 * port the PIM datebook application to use it, before I could debug the
20 * whole stuff.
21 * Thus, PIM-Database backend is finished, but highly experimental. And some
22 * parts are still generic. For instance, the "queryByExample()" methods are
23 * not (or not fully) implemented. Todo: custom-entries not stored.
24 * The big show stopper: matchRegExp() (needed by OpieSearch) needs regular
25 * expression search in the database, which is not supported by sqlite !
26 * Therefore we need either an extended sqlite or a workaround which would
27 * be very slow and memory consuming..
28 *
29 * Revision 1.3 2003/12/08 15:18:10 eilers
30 * Committing unfinished sql implementation before merging to libopie2 starts..
31 *
32 * Revision 1.2 2003/09/29 07:44:26 eilers
33 * Improvement of PIM-SQL Databases, but search queries are still limited.
34 * Addressbook: Changed table layout. Now, we just need 1/3 of disk-space.
35 * Todo: Started to add new attributes. Some type conversions missing.
36 *
37 * Revision 1.1 2003/09/22 14:31:16 eilers
38 * Added first experimental incarnation of sql-backend for addressbook.
39 * Some modifications to be able to compile the todo sql-backend.
40 * A lot of changes fill follow...
41 *
42 */ 31 */
43 32
44#include "ocontactaccessbackend_sql.h" 33#include "ocontactaccessbackend_sql.h"
45 34
46#include <qarray.h> 35#include <qarray.h>
47#include <qdatetime.h> 36#include <qdatetime.h>
48#include <qstringlist.h> 37#include <qstringlist.h>
49 38
50#include <qpe/global.h> 39#include <qpe/global.h>
51#include <qpe/recordfields.h> 40#include <qpe/recordfields.h>
52 41
53#include <opie/ocontactfields.h> 42#include <opie2/ocontactfields.h>
54#include <opie/oconversion.h> 43#include <opie2/oconversion.h>
55#include <opie2/osqldriver.h> 44#include <opie2/osqldriver.h>
56#include <opie2/osqlresult.h> 45#include <opie2/osqlresult.h>
57#include <opie2/osqlmanager.h> 46#include <opie2/osqlmanager.h>
58#include <opie2/osqlquery.h> 47#include <opie2/osqlquery.h>
59 48
60 49
61 50
62 51
63// If defined, we use a horizontal table ( uid, attr1, attr2, attr3, ..., attrn ) instead 52// If defined, we use a horizontal table ( uid, attr1, attr2, attr3, ..., attrn ) instead
64// vertical like "uid, type, value". 53// vertical like "uid, type, value".
65// DON'T DEACTIVATE THIS DEFINE IN PRODUCTIVE ENVIRONMENTS !! 54// DON'T DEACTIVATE THIS DEFINE IN PRODUCTIVE ENVIRONMENTS !!
66#define __STORE_HORIZONTAL_ 55#define __STORE_HORIZONTAL_
67 56
68// Distinct loading is not very fast. If I expect that every person has just 57// Distinct loading is not very fast. If I expect that every person has just
69// one (and always one) 'Last Name', I can request all uid's for existing lastnames, 58// one (and always one) 'Last Name', I can request all uid's for existing lastnames,
70// which is faster.. 59// which is faster..
71// But this may not be true for all entries, like company contacts.. 60// But this may not be true for all entries, like company contacts..
72// The current AddressBook application handles this problem, but other may not.. (eilers) 61// The current AddressBook application handles this problem, but other may not.. (eilers)
73#define __USE_SUPERFAST_LOADQUERY 62#define __USE_SUPERFAST_LOADQUERY
74 63
75 64
76/* 65/*
77 * Implementation of used query types 66 * Implementation of used query types
78 * CREATE query 67 * CREATE query
79 * LOAD query 68 * LOAD query
80 * INSERT 69 * INSERT
81 * REMOVE 70 * REMOVE
82 * CLEAR 71 * CLEAR
83 */ 72 */
84namespace { 73namespace Opie {
85 /** 74 /**
86 * CreateQuery for the Todolist Table 75 * CreateQuery for the Todolist Table
87 */ 76 */
88 class CreateQuery : public OSQLQuery { 77 class CreateQuery : public OSQLQuery {
89 public: 78 public:
90 CreateQuery(); 79 CreateQuery();
91 ~CreateQuery(); 80 ~CreateQuery();
92 QString query()const; 81 QString query()const;
93 }; 82 };
94 83
95 /** 84 /**
96 * Clears (delete) a Table 85 * Clears (delete) a Table
97 */ 86 */
98 class ClearQuery : public OSQLQuery { 87 class ClearQuery : public OSQLQuery {
99 public: 88 public:
100 ClearQuery(); 89 ClearQuery();
101 ~ClearQuery(); 90 ~ClearQuery();
102 QString query()const; 91 QString query()const;
103 92
104 }; 93 };
105 94
106 95
107 /** 96 /**
108 * LoadQuery 97 * LoadQuery
109 * this one queries for all uids 98 * this one queries for all uids
110 */ 99 */
111 class LoadQuery : public OSQLQuery { 100 class LoadQuery : public OSQLQuery {
112 public: 101 public:
113 LoadQuery(); 102 LoadQuery();
114 ~LoadQuery(); 103 ~LoadQuery();
115 QString query()const; 104 QString query()const;
116 }; 105 };
117 106
118 /** 107 /**
119 * inserts/adds a OContact to the table 108 * inserts/adds a OContact to the table
120 */ 109 */
121 class InsertQuery : public OSQLQuery { 110 class InsertQuery : public OSQLQuery {
122 public: 111 public:
123 InsertQuery(const OContact& ); 112 InsertQuery(const OContact& );
124 ~InsertQuery(); 113 ~InsertQuery();
125 QString query()const; 114 QString query()const;
126 private: 115 private:
127 OContact m_contact; 116 OContact m_contact;
128 }; 117 };
129 118
130 119
131 /** 120 /**
132 * removes one from the table 121 * removes one from the table
133 */ 122 */
134 class RemoveQuery : public OSQLQuery { 123 class RemoveQuery : public OSQLQuery {
135 public: 124 public:
136 RemoveQuery(int uid ); 125 RemoveQuery(int uid );
137 ~RemoveQuery(); 126 ~RemoveQuery();
138 QString query()const; 127 QString query()const;
139 private: 128 private:
140 int m_uid; 129 int m_uid;
141 }; 130 };
142 131
143 /** 132 /**
144 * a find query for noncustom elements 133 * a find query for noncustom elements
145 */ 134 */
146 class FindQuery : public OSQLQuery { 135 class FindQuery : public OSQLQuery {
147 public: 136 public:
148 FindQuery(int uid); 137 FindQuery(int uid);
149 FindQuery(const QArray<int>& ); 138 FindQuery(const QArray<int>& );
150 ~FindQuery(); 139 ~FindQuery();
151 QString query()const; 140 QString query()const;
152 private: 141 private:
153 QString single()const; 142 QString single()const;
154 QString multi()const; 143 QString multi()const;
155 QArray<int> m_uids; 144 QArray<int> m_uids;
156 int m_uid; 145 int m_uid;
157 }; 146 };
158 147
159 /** 148 /**
160 * a find query for custom elements 149 * a find query for custom elements
161 */ 150 */
162 class FindCustomQuery : public OSQLQuery { 151 class FindCustomQuery : public OSQLQuery {
163 public: 152 public:
164 FindCustomQuery(int uid); 153 FindCustomQuery(int uid);
165 FindCustomQuery(const QArray<int>& ); 154 FindCustomQuery(const QArray<int>& );
166 ~FindCustomQuery(); 155 ~FindCustomQuery();
167 QString query()const; 156 QString query()const;
168 private: 157 private:
169 QString single()const; 158 QString single()const;
170 QString multi()const; 159 QString multi()const;
171 QArray<int> m_uids; 160 QArray<int> m_uids;
172 int m_uid; 161 int m_uid;
173 }; 162 };
174 163
175 164
176 165
177 // We using three tables to store the information: 166 // We using three tables to store the information:
178 // 1. addressbook : It contains General information about the contact (non custom) 167 // 1. addressbook : It contains General information about the contact (non custom)
179 // 2. custom_data : Not official supported entries 168 // 2. custom_data : Not official supported entries
180 // All tables are connected by the uid of the contact. 169 // All tables are connected by the uid of the contact.
181 // Maybe I should add a table for meta-information ? 170 // Maybe I should add a table for meta-information ?
182 CreateQuery::CreateQuery() : OSQLQuery() {} 171 CreateQuery::CreateQuery() : OSQLQuery() {}
183 CreateQuery::~CreateQuery() {} 172 CreateQuery::~CreateQuery() {}
184 QString CreateQuery::query()const { 173 QString CreateQuery::query()const {
185 QString qu; 174 QString qu;
186#ifdef __STORE_HORIZONTAL_ 175#ifdef __STORE_HORIZONTAL_
187 176
188 qu += "create table addressbook( uid PRIMARY KEY "; 177 qu += "create table addressbook( uid PRIMARY KEY ";
189 178
190 QStringList fieldList = OContactFields::untrfields( false ); 179 QStringList fieldList = OContactFields::untrfields( false );
191 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){ 180 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){
192 qu += QString( ",\"%1\" VARCHAR(10)" ).arg( *it ); 181 qu += QString( ",\"%1\" VARCHAR(10)" ).arg( *it );
193 } 182 }
194 qu += " );"; 183 qu += " );";
195 184
196 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );"; 185 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );";
197 186
198#else 187#else
199 188
200 qu += "create table addressbook( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id));"; 189 qu += "create table addressbook( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id));";
201 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );"; 190 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );";
202 // qu += "create table dates( uid PRIMARY KEY, type, day, month, year, hour, minute, second );"; 191 // qu += "create table dates( uid PRIMARY KEY, type, day, month, year, hour, minute, second );";
203 192
204#endif // __STORE_HORIZONTAL_ 193#endif // __STORE_HORIZONTAL_
205 return qu; 194 return qu;
206 } 195 }
207 196
208 ClearQuery::ClearQuery() 197 ClearQuery::ClearQuery()
209 : OSQLQuery() {} 198 : OSQLQuery() {}
210 ClearQuery::~ClearQuery() {} 199 ClearQuery::~ClearQuery() {}
211 QString ClearQuery::query()const { 200 QString ClearQuery::query()const {
212 QString qu = "drop table addressbook;"; 201 QString qu = "drop table addressbook;";
213 qu += "drop table custom_data;"; 202 qu += "drop table custom_data;";
214 // qu += "drop table dates;"; 203 // qu += "drop table dates;";
215 return qu; 204 return qu;
216 } 205 }
217 206
218 207
219 LoadQuery::LoadQuery() : OSQLQuery() {} 208 LoadQuery::LoadQuery() : OSQLQuery() {}
220 LoadQuery::~LoadQuery() {} 209 LoadQuery::~LoadQuery() {}
221 QString LoadQuery::query()const { 210 QString LoadQuery::query()const {
222 QString qu; 211 QString qu;
223#ifdef __STORE_HORIZONTAL_ 212#ifdef __STORE_HORIZONTAL_
224 qu += "select uid from addressbook"; 213 qu += "select uid from addressbook";
225#else 214#else
226# ifndef __USE_SUPERFAST_LOADQUERY 215# ifndef __USE_SUPERFAST_LOADQUERY
227 qu += "select distinct uid from addressbook"; 216 qu += "select distinct uid from addressbook";
228# else 217# else
229 qu += "select uid from addressbook where type = 'Last Name'"; 218 qu += "select uid from addressbook where type = 'Last Name'";
230# endif // __USE_SUPERFAST_LOADQUERY 219# endif // __USE_SUPERFAST_LOADQUERY
231#endif // __STORE_HORIZONTAL_ 220#endif // __STORE_HORIZONTAL_
232 221
233 return qu; 222 return qu;
234 } 223 }
235 224
236 225
237 InsertQuery::InsertQuery( const OContact& contact ) 226 InsertQuery::InsertQuery( const OContact& contact )
238 : OSQLQuery(), m_contact( contact ) { 227 : OSQLQuery(), m_contact( contact ) {
239 } 228 }
240 229
241 InsertQuery::~InsertQuery() { 230 InsertQuery::~InsertQuery() {
242 } 231 }
243 232
244 /* 233 /*
245 * converts from a OContact to a query 234 * converts from a OContact to a query
246 */ 235 */
247 QString InsertQuery::query()const{ 236 QString InsertQuery::query()const{
248 237
249#ifdef __STORE_HORIZONTAL_ 238#ifdef __STORE_HORIZONTAL_
250 QString qu; 239 QString qu;
251 qu += "insert into addressbook VALUES( " + 240 qu += "insert into addressbook VALUES( " +
252 QString::number( m_contact.uid() ); 241 QString::number( m_contact.uid() );
253 242
254 // Get all information out of the contact-class 243 // Get all information out of the contact-class
255 // Remember: The category is stored in contactMap, too ! 244 // Remember: The category is stored in contactMap, too !
256 QMap<int, QString> contactMap = m_contact.toMap(); 245 QMap<int, QString> contactMap = m_contact.toMap();
257 246
258 QStringList fieldList = OContactFields::untrfields( false ); 247 QStringList fieldList = OContactFields::untrfields( false );
259 QMap<QString, int> translate = OContactFields::untrFieldsToId(); 248 QMap<QString, int> translate = OContactFields::untrFieldsToId();
260 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){ 249 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){
261 // Convert Column-String to Id and get value for this id.. 250 // Convert Column-String to Id and get value for this id..
262 // Hmmm.. Maybe not very cute solution.. 251 // Hmmm.. Maybe not very cute solution..
263 int id = translate[*it]; 252 int id = translate[*it];
264 switch ( id ){ 253 switch ( id ){
265 case Qtopia::Birthday:{ 254 case Qtopia::Birthday:{
266 // These entries should stored in a special format 255 // These entries should stored in a special format
267 // year-month-day 256 // year-month-day
268 QDate day = m_contact.birthday(); 257 QDate day = m_contact.birthday();
269 if ( day.isValid() ){ 258 if ( day.isValid() ){
270 qu += QString(",\"%1-%2-%3\"") 259 qu += QString(",\"%1-%2-%3\"")
271 .arg( day.year() ) 260 .arg( day.year() )
272 .arg( day.month() ) 261 .arg( day.month() )
273 .arg( day.day() ); 262 .arg( day.day() );
274 } else { 263 } else {
275 qu += ",\"\""; 264 qu += ",\"\"";
276 } 265 }
277 } 266 }
278 break; 267 break;
279 case Qtopia::Anniversary:{ 268 case Qtopia::Anniversary:{
280 // These entries should stored in a special format 269 // These entries should stored in a special format
281 // year-month-day 270 // year-month-day
282 QDate day = m_contact.anniversary(); 271 QDate day = m_contact.anniversary();
283 if ( day.isValid() ){ 272 if ( day.isValid() ){
284 qu += QString(",\"%1-%2-%3\"") 273 qu += QString(",\"%1-%2-%3\"")
285 .arg( day.year() ) 274 .arg( day.year() )
286 .arg( day.month() ) 275 .arg( day.month() )
287 .arg( day.day() ); 276 .arg( day.day() );
288 } else { 277 } else {
289 qu += ",\"\""; 278 qu += ",\"\"";
290 } 279 }
291 } 280 }
292 break; 281 break;
293 282
294 default: 283 default:
295 qu += QString( ",\"%1\"" ).arg( contactMap[id] ); 284 qu += QString( ",\"%1\"" ).arg( contactMap[id] );
296 } 285 }
297 } 286 }
298 qu += " );"; 287 qu += " );";
299 288
300 289
301#else 290#else
302 // Get all information out of the contact-class 291 // Get all information out of the contact-class
303 // Remember: The category is stored in contactMap, too ! 292 // Remember: The category is stored in contactMap, too !
304 QMap<int, QString> contactMap = m_contact.toMap(); 293 QMap<int, QString> contactMap = m_contact.toMap();
305 294
306 QMap<QString, QString> addressbook_db; 295 QMap<QString, QString> addressbook_db;
307 296
308 // Get the translation from the ID to the String 297 // Get the translation from the ID to the String
309 QMap<int, QString> transMap = OContactFields::idToUntrFields(); 298 QMap<int, QString> transMap = OContactFields::idToUntrFields();
310 299
311 for( QMap<int, QString>::Iterator it = contactMap.begin(); 300 for( QMap<int, QString>::Iterator it = contactMap.begin();
312 it != contactMap.end(); ++it ){ 301 it != contactMap.end(); ++it ){
313 switch ( it.key() ){ 302 switch ( it.key() ){
314 case Qtopia::Birthday:{ 303 case Qtopia::Birthday:{
315 // These entries should stored in a special format 304 // These entries should stored in a special format
316 // year-month-day 305 // year-month-day
317 QDate day = m_contact.birthday(); 306 QDate day = m_contact.birthday();
318 addressbook_db.insert( transMap[it.key()], 307 addressbook_db.insert( transMap[it.key()],
319 QString("%1-%2-%3") 308 QString("%1-%2-%3")
320 .arg( day.year() ) 309 .arg( day.year() )
321 .arg( day.month() ) 310 .arg( day.month() )
322 .arg( day.day() ) ); 311 .arg( day.day() ) );
323 } 312 }
324 break; 313 break;
325 case Qtopia::Anniversary:{ 314 case Qtopia::Anniversary:{
326 // These entries should stored in a special format 315 // These entries should stored in a special format
327 // year-month-day 316 // year-month-day
328 QDate day = m_contact.anniversary(); 317 QDate day = m_contact.anniversary();
329 addressbook_db.insert( transMap[it.key()], 318 addressbook_db.insert( transMap[it.key()],
330 QString("%1-%2-%3") 319 QString("%1-%2-%3")
331 .arg( day.year() ) 320 .arg( day.year() )
332 .arg( day.month() ) 321 .arg( day.month() )
333 .arg( day.day() ) ); 322 .arg( day.day() ) );
334 } 323 }
335 break; 324 break;
336 case Qtopia::AddressUid: // Ignore UID 325 case Qtopia::AddressUid: // Ignore UID
337 break; 326 break;
338 default: // Translate id to String 327 default: // Translate id to String
339 addressbook_db.insert( transMap[it.key()], it.data() ); 328 addressbook_db.insert( transMap[it.key()], it.data() );
340 break; 329 break;
341 } 330 }
342 331
343 } 332 }
344 333
345 // Now convert this whole stuff into a SQL String, beginning with 334 // Now convert this whole stuff into a SQL String, beginning with
346 // the addressbook table.. 335 // the addressbook table..
347 QString qu; 336 QString qu;
348 // qu += "begin transaction;"; 337 // qu += "begin transaction;";
349 int id = 0; 338 int id = 0;
350 for( QMap<QString, QString>::Iterator it = addressbook_db.begin(); 339 for( QMap<QString, QString>::Iterator it = addressbook_db.begin();
351 it != addressbook_db.end(); ++it ){ 340 it != addressbook_db.end(); ++it ){
352 qu += "insert into addressbook VALUES(" 341 qu += "insert into addressbook VALUES("
353 + QString::number( m_contact.uid() ) 342 + QString::number( m_contact.uid() )
354 + "," 343 + ","
355 + QString::number( id++ ) 344 + QString::number( id++ )
356 + ",'" 345 + ",'"
357 + it.key() //.latin1() 346 + it.key() //.latin1()
358 + "'," 347 + "',"
359 + "0" // Priority for future enhancements 348 + "0" // Priority for future enhancements
360 + ",'" 349 + ",'"
361 + it.data() //.latin1() 350 + it.data() //.latin1()
362 + "');"; 351 + "');";
363 } 352 }
364 353
365 #endif //__STORE_HORIZONTAL_ 354 #endif //__STORE_HORIZONTAL_
366 // Now add custom data.. 355 // Now add custom data..
367#ifdef __STORE_HORIZONTAL_ 356#ifdef __STORE_HORIZONTAL_
368 int id = 0; 357 int id = 0;
369#endif 358#endif
370 id = 0; 359 id = 0;
371 QMap<QString, QString> customMap = m_contact.toExtraMap(); 360 QMap<QString, QString> customMap = m_contact.toExtraMap();
372 for( QMap<QString, QString>::Iterator it = customMap.begin(); 361 for( QMap<QString, QString>::Iterator it = customMap.begin();
373 it != customMap.end(); ++it ){ 362 it != customMap.end(); ++it ){
374 qu += "insert into custom_data VALUES(" 363 qu += "insert into custom_data VALUES("
375 + QString::number( m_contact.uid() ) 364 + QString::number( m_contact.uid() )
376 + "," 365 + ","
377 + QString::number( id++ ) 366 + QString::number( id++ )
378 + ",'" 367 + ",'"
379 + it.key() //.latin1() 368 + it.key() //.latin1()
380 + "'," 369 + "',"
381 + "0" // Priority for future enhancements 370 + "0" // Priority for future enhancements
382 + ",'" 371 + ",'"
383 + it.data() //.latin1() 372 + it.data() //.latin1()
384 + "');"; 373 + "');";
385 } 374 }
386 // qu += "commit;"; 375 // qu += "commit;";
387 qWarning("add %s", qu.latin1() ); 376 qWarning("add %s", qu.latin1() );
388 return qu; 377 return qu;
389 } 378 }
390 379
391 380
392 RemoveQuery::RemoveQuery(int uid ) 381 RemoveQuery::RemoveQuery(int uid )
393 : OSQLQuery(), m_uid( uid ) {} 382 : OSQLQuery(), m_uid( uid ) {}
394 RemoveQuery::~RemoveQuery() {} 383 RemoveQuery::~RemoveQuery() {}
395 QString RemoveQuery::query()const { 384 QString RemoveQuery::query()const {
396 QString qu = "DELETE from addressbook where uid = " 385 QString qu = "DELETE from addressbook where uid = "
397 + QString::number(m_uid) + ";"; 386 + QString::number(m_uid) + ";";
398 qu += "DELETE from custom_data where uid = " 387 qu += "DELETE from custom_data where uid = "
399 + QString::number(m_uid) + ";"; 388 + QString::number(m_uid) + ";";
400 return qu; 389 return qu;
401 } 390 }
402 391
403 392
404 393
405 394
406 FindQuery::FindQuery(int uid) 395 FindQuery::FindQuery(int uid)
407 : OSQLQuery(), m_uid( uid ) { 396 : OSQLQuery(), m_uid( uid ) {
408 } 397 }
409 FindQuery::FindQuery(const QArray<int>& ints) 398 FindQuery::FindQuery(const QArray<int>& ints)
410 : OSQLQuery(), m_uids( ints ){ 399 : OSQLQuery(), m_uids( ints ){
411 } 400 }
412 FindQuery::~FindQuery() { 401 FindQuery::~FindQuery() {
413 } 402 }
414 QString FindQuery::query()const{ 403 QString FindQuery::query()const{
415 // if ( m_uids.count() == 0 ) 404 // if ( m_uids.count() == 0 )
416 return single(); 405 return single();
417 } 406 }
418 /* 407 /*
419 else 408 else
420 return multi(); 409 return multi();
421 } 410 }
422 QString FindQuery::multi()const { 411 QString FindQuery::multi()const {
423 QString qu = "select uid, type, value from addressbook where"; 412 QString qu = "select uid, type, value from addressbook where";
424 for (uint i = 0; i < m_uids.count(); i++ ) { 413 for (uint i = 0; i < m_uids.count(); i++ ) {
425 qu += " UID = " + QString::number( m_uids[i] ) + " OR"; 414 qu += " UID = " + QString::number( m_uids[i] ) + " OR";
426 } 415 }
427 qu.remove( qu.length()-2, 2 ); // Hmmmm.. 416 qu.remove( qu.length()-2, 2 ); // Hmmmm..
428 return qu; 417 return qu;
429 } 418 }
430 */ 419 */
431#ifdef __STORE_HORIZONTAL_ 420#ifdef __STORE_HORIZONTAL_
432 QString FindQuery::single()const{ 421 QString FindQuery::single()const{
433 QString qu = "select *"; 422 QString qu = "select *";
434 qu += " from addressbook where uid = " + QString::number(m_uid); 423 qu += " from addressbook where uid = " + QString::number(m_uid);
435 424
436 // qWarning("find query: %s", qu.latin1() ); 425 // qWarning("find query: %s", qu.latin1() );
437 return qu; 426 return qu;
438 } 427 }
439#else 428#else
440 QString FindQuery::single()const{ 429 QString FindQuery::single()const{
441 QString qu = "select uid, type, value from addressbook where uid = "; 430 QString qu = "select uid, type, value from addressbook where uid = ";
442 qu += QString::number(m_uid); 431 qu += QString::number(m_uid);
443 return qu; 432 return qu;
444 } 433 }
445#endif 434#endif
446 435
447 436
448 FindCustomQuery::FindCustomQuery(int uid) 437 FindCustomQuery::FindCustomQuery(int uid)
449 : OSQLQuery(), m_uid( uid ) { 438 : OSQLQuery(), m_uid( uid ) {
450 } 439 }
451 FindCustomQuery::FindCustomQuery(const QArray<int>& ints) 440 FindCustomQuery::FindCustomQuery(const QArray<int>& ints)
452 : OSQLQuery(), m_uids( ints ){ 441 : OSQLQuery(), m_uids( ints ){
453 } 442 }
454 FindCustomQuery::~FindCustomQuery() { 443 FindCustomQuery::~FindCustomQuery() {
455 } 444 }
456 QString FindCustomQuery::query()const{ 445 QString FindCustomQuery::query()const{
457 // if ( m_uids.count() == 0 ) 446 // if ( m_uids.count() == 0 )
458 return single(); 447 return single();
459 } 448 }
460 QString FindCustomQuery::single()const{ 449 QString FindCustomQuery::single()const{
461 QString qu = "select uid, type, value from custom_data where uid = "; 450 QString qu = "select uid, type, value from custom_data where uid = ";
462 qu += QString::number(m_uid); 451 qu += QString::number(m_uid);
463 return qu; 452 return qu;
464 } 453 }
465 454
466}; 455};
467 456
468 457
469/* --------------------------------------------------------------------------- */ 458/* --------------------------------------------------------------------------- */
470 459
460namespace Opie {
461
471OContactAccessBackend_SQL::OContactAccessBackend_SQL ( const QString& /* appname */, 462OContactAccessBackend_SQL::OContactAccessBackend_SQL ( const QString& /* appname */,
472 const QString& filename ): 463 const QString& filename ):
473 OContactAccessBackend(), m_changed(false), m_driver( NULL ) 464 OContactAccessBackend(), m_changed(false), m_driver( NULL )
474{ 465{
475 qWarning("C'tor OContactAccessBackend_SQL starts"); 466 qWarning("C'tor OContactAccessBackend_SQL starts");
476 QTime t; 467 QTime t;
477 t.start(); 468 t.start();
478 469
479 /* Expecting to access the default filename if nothing else is set */ 470 /* Expecting to access the default filename if nothing else is set */
480 if ( filename.isEmpty() ){ 471 if ( filename.isEmpty() ){
481 m_fileName = Global::applicationFileName( "addressbook","addressbook.db" ); 472 m_fileName = Global::applicationFileName( "addressbook","addressbook.db" );
482 } else 473 } else
483 m_fileName = filename; 474 m_fileName = filename;
484 475
485 // Get the standart sql-driver from the OSQLManager.. 476 // Get the standart sql-driver from the OSQLManager..
486 OSQLManager man; 477 OSQLManager man;
487 m_driver = man.standard(); 478 m_driver = man.standard();
488 m_driver->setUrl( m_fileName ); 479 m_driver->setUrl( m_fileName );
489 480
490 load(); 481 load();
491 482
492 qWarning("C'tor OContactAccessBackend_SQL ends: %d ms", t.elapsed() ); 483 qWarning("C'tor OContactAccessBackend_SQL ends: %d ms", t.elapsed() );
493} 484}
494 485
495OContactAccessBackend_SQL::~OContactAccessBackend_SQL () 486OContactAccessBackend_SQL::~OContactAccessBackend_SQL ()
496{ 487{
497 if( m_driver ) 488 if( m_driver )
498 delete m_driver; 489 delete m_driver;
499} 490}
500 491
501bool OContactAccessBackend_SQL::load () 492bool OContactAccessBackend_SQL::load ()
502{ 493{
503 if (!m_driver->open() ) 494 if (!m_driver->open() )
504 return false; 495 return false;
505 496
506 // Don't expect that the database exists. 497 // Don't expect that the database exists.
507 // It is save here to create the table, even if it 498 // It is save here to create the table, even if it
508 // do exist. ( Is that correct for all databases ?? ) 499 // do exist. ( Is that correct for all databases ?? )
509 CreateQuery creat; 500 CreateQuery creat;
510 OSQLResult res = m_driver->query( &creat ); 501 OSQLResult res = m_driver->query( &creat );
511 502
512 update(); 503 update();
513 504
514 return true; 505 return true;
515 506
516} 507}
517 508
518bool OContactAccessBackend_SQL::reload() 509bool OContactAccessBackend_SQL::reload()
519{ 510{
520 return load(); 511 return load();
521} 512}
522 513
523bool OContactAccessBackend_SQL::save() 514bool OContactAccessBackend_SQL::save()
524{ 515{
525 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers) 516 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers)
526} 517}
527 518
528 519
529void OContactAccessBackend_SQL::clear () 520void OContactAccessBackend_SQL::clear ()
530{ 521{
531 ClearQuery cle; 522 ClearQuery cle;
532 OSQLResult res = m_driver->query( &cle ); 523 OSQLResult res = m_driver->query( &cle );
533 524
534 reload(); 525 reload();
535} 526}
536 527
537bool OContactAccessBackend_SQL::wasChangedExternally() 528bool OContactAccessBackend_SQL::wasChangedExternally()
538{ 529{
539 return false; 530 return false;
540} 531}
541 532
542QArray<int> OContactAccessBackend_SQL::allRecords() const 533QArray<int> OContactAccessBackend_SQL::allRecords() const
543{ 534{
544 535
545 // FIXME: Think about cute handling of changed tables.. 536 // FIXME: Think about cute handling of changed tables..
546 // Thus, we don't have to call update here... 537 // Thus, we don't have to call update here...
547 if ( m_changed ) 538 if ( m_changed )
548 ((OContactAccessBackend_SQL*)this)->update(); 539 ((OContactAccessBackend_SQL*)this)->update();
549 540
550 return m_uids; 541 return m_uids;
551} 542}
552 543
553bool OContactAccessBackend_SQL::add ( const OContact &newcontact ) 544bool OContactAccessBackend_SQL::add ( const OContact &newcontact )
554{ 545{
555 InsertQuery ins( newcontact ); 546 InsertQuery ins( newcontact );
556 OSQLResult res = m_driver->query( &ins ); 547 OSQLResult res = m_driver->query( &ins );
557 548
558 if ( res.state() == OSQLResult::Failure ) 549 if ( res.state() == OSQLResult::Failure )
559 return false; 550 return false;
560 551
561 int c = m_uids.count(); 552 int c = m_uids.count();
562 m_uids.resize( c+1 ); 553 m_uids.resize( c+1 );
563 m_uids[c] = newcontact.uid(); 554 m_uids[c] = newcontact.uid();
564 555
565 return true; 556 return true;
566} 557}
567 558
568 559
569bool OContactAccessBackend_SQL::remove ( int uid ) 560bool OContactAccessBackend_SQL::remove ( int uid )
570{ 561{
571 RemoveQuery rem( uid ); 562 RemoveQuery rem( uid );
572 OSQLResult res = m_driver->query(&rem ); 563 OSQLResult res = m_driver->query(&rem );
573 564
574 if ( res.state() == OSQLResult::Failure ) 565 if ( res.state() == OSQLResult::Failure )
575 return false; 566 return false;
576 567
577 m_changed = true; 568 m_changed = true;
578 569
579 return true; 570 return true;
580} 571}
581 572
582bool OContactAccessBackend_SQL::replace ( const OContact &contact ) 573bool OContactAccessBackend_SQL::replace ( const OContact &contact )
583{ 574{
584 if ( !remove( contact.uid() ) ) 575 if ( !remove( contact.uid() ) )
585 return false; 576 return false;
586 577
587 return add( contact ); 578 return add( contact );
588} 579}
589 580
590 581
591OContact OContactAccessBackend_SQL::find ( int uid ) const 582OContact OContactAccessBackend_SQL::find ( int uid ) const
592{ 583{
593 qWarning("OContactAccessBackend_SQL::find()"); 584 qWarning("OContactAccessBackend_SQL::find()");
594 QTime t; 585 QTime t;
595 t.start(); 586 t.start();
596 587
597 OContact retContact( requestNonCustom( uid ) ); 588 OContact retContact( requestNonCustom( uid ) );
598 retContact.setExtraMap( requestCustom( uid ) ); 589 retContact.setExtraMap( requestCustom( uid ) );
599 590
600 qWarning("OContactAccessBackend_SQL::find() needed: %d ms", t.elapsed() ); 591 qWarning("OContactAccessBackend_SQL::find() needed: %d ms", t.elapsed() );
601 return retContact; 592 return retContact;
602} 593}
603 594
604 595
605 596
606QArray<int> OContactAccessBackend_SQL::queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() ) 597QArray<int> OContactAccessBackend_SQL::queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() )
607{ 598{
608 QString qu = "SELECT uid FROM addressbook WHERE"; 599 QString qu = "SELECT uid FROM addressbook WHERE";
609 600
610 QMap<int, QString> queryFields = query.toMap(); 601 QMap<int, QString> queryFields = query.toMap();
611 QStringList fieldList = OContactFields::untrfields( false ); 602 QStringList fieldList = OContactFields::untrfields( false );
612 QMap<QString, int> translate = OContactFields::untrFieldsToId(); 603 QMap<QString, int> translate = OContactFields::untrFieldsToId();
613 604
614 // Convert every filled field to a SQL-Query 605 // Convert every filled field to a SQL-Query
615 bool isAnyFieldSelected = false; 606 bool isAnyFieldSelected = false;
616 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){ 607 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){
617 int id = translate[*it]; 608 int id = translate[*it];
618 QString queryStr = queryFields[id]; 609 QString queryStr = queryFields[id];
619 if ( !queryStr.isEmpty() ){ 610 if ( !queryStr.isEmpty() ){
620 isAnyFieldSelected = true; 611 isAnyFieldSelected = true;
621 switch( id ){ 612 switch( id ){
622 default: 613 default:
623 // Switching between case sensitive and insensitive... 614 // Switching between case sensitive and insensitive...
624 // LIKE is not case sensitive, GLOB is case sensitive 615 // LIKE is not case sensitive, GLOB is case sensitive
625 // Do exist a better solution to switch this ? 616 // Do exist a better solution to switch this ?
626 if ( settings & OContactAccess::IgnoreCase ) 617 if ( settings & OContactAccess::IgnoreCase )
627 qu += "(\"" + *it + "\"" + " LIKE " + "'" 618 qu += "(\"" + *it + "\"" + " LIKE " + "'"
628 + queryStr.replace(QRegExp("\\*"),"%") + "'" + ") AND "; 619 + queryStr.replace(QRegExp("\\*"),"%") + "'" + ") AND ";
629 else 620 else
630 qu += "(\"" + *it + "\"" + " GLOB " + "'" 621 qu += "(\"" + *it + "\"" + " GLOB " + "'"
631 + queryStr + "'" + ") AND "; 622 + queryStr + "'" + ") AND ";
632 623
633 } 624 }
634 } 625 }
635 } 626 }
636 // Skip trailing "AND" 627 // Skip trailing "AND"
637 if ( isAnyFieldSelected ) 628 if ( isAnyFieldSelected )
638 qu = qu.left( qu.length() - 4 ); 629 qu = qu.left( qu.length() - 4 );
639 630
640 qWarning( "queryByExample query: %s", qu.latin1() ); 631 qWarning( "queryByExample query: %s", qu.latin1() );
641 632
642 // Execute query and return the received uid's 633 // Execute query and return the received uid's
643 OSQLRawQuery raw( qu ); 634 OSQLRawQuery raw( qu );
644 OSQLResult res = m_driver->query( &raw ); 635 OSQLResult res = m_driver->query( &raw );
645 if ( res.state() != OSQLResult::Success ){ 636 if ( res.state() != OSQLResult::Success ){
646 QArray<int> empty; 637 QArray<int> empty;
647 return empty; 638 return empty;
648 } 639 }
649 640
650 QArray<int> list = extractUids( res ); 641 QArray<int> list = extractUids( res );
651 642
652 return list; 643 return list;
653} 644}
654 645
655QArray<int> OContactAccessBackend_SQL::matchRegexp( const QRegExp &r ) const 646QArray<int> OContactAccessBackend_SQL::matchRegexp( const QRegExp &r ) const
656{ 647{
657 QArray<int> nix(0); 648 QArray<int> nix(0);
658 return nix; 649 return nix;
659} 650}
660 651
661const uint OContactAccessBackend_SQL::querySettings() 652const uint OContactAccessBackend_SQL::querySettings()
662{ 653{
663 return OContactAccess::IgnoreCase 654 return OContactAccess::IgnoreCase
664 || OContactAccess::WildCards; 655 || OContactAccess::WildCards;
665} 656}
666 657
667bool OContactAccessBackend_SQL::hasQuerySettings (uint querySettings) const 658bool OContactAccessBackend_SQL::hasQuerySettings (uint querySettings) const
668{ 659{
669 /* OContactAccess::IgnoreCase, DateDiff, DateYear, DateMonth, DateDay 660 /* OContactAccess::IgnoreCase, DateDiff, DateYear, DateMonth, DateDay
670 * may be added with any of the other settings. IgnoreCase should never used alone. 661 * may be added with any of the other settings. IgnoreCase should never used alone.
671 * Wildcards, RegExp, ExactMatch should never used at the same time... 662 * Wildcards, RegExp, ExactMatch should never used at the same time...
672 */ 663 */
673 664
674 // Step 1: Check whether the given settings are supported by this backend 665 // Step 1: Check whether the given settings are supported by this backend
675 if ( ( querySettings & ( 666 if ( ( querySettings & (
676 OContactAccess::IgnoreCase 667 OContactAccess::IgnoreCase
677 | OContactAccess::WildCards 668 | OContactAccess::WildCards
678 // | OContactAccess::DateDiff 669 // | OContactAccess::DateDiff
679 // | OContactAccess::DateYear 670 // | OContactAccess::DateYear
680 // | OContactAccess::DateMonth 671 // | OContactAccess::DateMonth
681 // | OContactAccess::DateDay 672 // | OContactAccess::DateDay
682 // | OContactAccess::RegExp 673 // | OContactAccess::RegExp
683 // | OContactAccess::ExactMatch 674 // | OContactAccess::ExactMatch
684 ) ) != querySettings ) 675 ) ) != querySettings )
685 return false; 676 return false;
686 677
687 // Step 2: Check whether the given combinations are ok.. 678 // Step 2: Check whether the given combinations are ok..
688 679
689 // IngoreCase alone is invalid 680 // IngoreCase alone is invalid
690 if ( querySettings == OContactAccess::IgnoreCase ) 681 if ( querySettings == OContactAccess::IgnoreCase )
691 return false; 682 return false;
692 683
693 // WildCards, RegExp and ExactMatch should never used at the same time 684 // WildCards, RegExp and ExactMatch should never used at the same time
694 switch ( querySettings & ~( OContactAccess::IgnoreCase 685 switch ( querySettings & ~( OContactAccess::IgnoreCase
695 | OContactAccess::DateDiff 686 | OContactAccess::DateDiff
696 | OContactAccess::DateYear 687 | OContactAccess::DateYear
697 | OContactAccess::DateMonth 688 | OContactAccess::DateMonth
698 | OContactAccess::DateDay 689 | OContactAccess::DateDay
699 ) 690 )
700 ){ 691 ){
701 case OContactAccess::RegExp: 692 case OContactAccess::RegExp:
702 return ( true ); 693 return ( true );
703 case OContactAccess::WildCards: 694 case OContactAccess::WildCards:
704 return ( true ); 695 return ( true );
705 case OContactAccess::ExactMatch: 696 case OContactAccess::ExactMatch:
706 return ( true ); 697 return ( true );
707 case 0: // one of the upper removed bits were set.. 698 case 0: // one of the upper removed bits were set..
708 return ( true ); 699 return ( true );
709 default: 700 default:
710 return ( false ); 701 return ( false );
711 } 702 }
712 703
713} 704}
714 705
715QArray<int> OContactAccessBackend_SQL::sorted( bool asc, int , int , int ) 706QArray<int> OContactAccessBackend_SQL::sorted( bool asc, int , int , int )
716{ 707{
717 QTime t; 708 QTime t;
718 t.start(); 709 t.start();
719 710
720#ifdef __STORE_HORIZONTAL_ 711#ifdef __STORE_HORIZONTAL_
721 QString query = "SELECT uid FROM addressbook "; 712 QString query = "SELECT uid FROM addressbook ";
722 query += "ORDER BY \"Last Name\" "; 713 query += "ORDER BY \"Last Name\" ";
723#else 714#else
724 QString query = "SELECT uid FROM addressbook WHERE type = 'Last Name' "; 715 QString query = "SELECT uid FROM addressbook WHERE type = 'Last Name' ";
725 query += "ORDER BY upper( value )"; 716 query += "ORDER BY upper( value )";
726#endif 717#endif
727 718
728 if ( !asc ) 719 if ( !asc )
729 query += "DESC"; 720 query += "DESC";
730 721
731 // qWarning("sorted query is: %s", query.latin1() ); 722 // qWarning("sorted query is: %s", query.latin1() );
732 723
733 OSQLRawQuery raw( query ); 724 OSQLRawQuery raw( query );
734 OSQLResult res = m_driver->query( &raw ); 725 OSQLResult res = m_driver->query( &raw );
735 if ( res.state() != OSQLResult::Success ){ 726 if ( res.state() != OSQLResult::Success ){
736 QArray<int> empty; 727 QArray<int> empty;
737 return empty; 728 return empty;
738 } 729 }
739 730
740 QArray<int> list = extractUids( res ); 731 QArray<int> list = extractUids( res );
741 732
742 qWarning("sorted needed %d ms!", t.elapsed() ); 733 qWarning("sorted needed %d ms!", t.elapsed() );
743 return list; 734 return list;
744} 735}
745 736
746 737
747void OContactAccessBackend_SQL::update() 738void OContactAccessBackend_SQL::update()
748{ 739{
749 qWarning("Update starts"); 740 qWarning("Update starts");
750 QTime t; 741 QTime t;
751 t.start(); 742 t.start();
752 743
753 // Now load the database set and extract the uid's 744 // Now load the database set and extract the uid's
754 // which will be held locally 745 // which will be held locally
755 746
756 LoadQuery lo; 747 LoadQuery lo;
757 OSQLResult res = m_driver->query(&lo); 748 OSQLResult res = m_driver->query(&lo);
758 if ( res.state() != OSQLResult::Success ) 749 if ( res.state() != OSQLResult::Success )
759 return; 750 return;
760 751
761 m_uids = extractUids( res ); 752 m_uids = extractUids( res );
762 753
763 m_changed = false; 754 m_changed = false;
764 755
765 qWarning("Update ends %d ms", t.elapsed() ); 756 qWarning("Update ends %d ms", t.elapsed() );
766} 757}
767 758
768QArray<int> OContactAccessBackend_SQL::extractUids( OSQLResult& res ) const 759QArray<int> OContactAccessBackend_SQL::extractUids( OSQLResult& res ) const
769{ 760{
770 qWarning("extractUids"); 761 qWarning("extractUids");
771 QTime t; 762 QTime t;
772 t.start(); 763 t.start();
773 OSQLResultItem::ValueList list = res.results(); 764 OSQLResultItem::ValueList list = res.results();
774 OSQLResultItem::ValueList::Iterator it; 765 OSQLResultItem::ValueList::Iterator it;
775 QArray<int> ints(list.count() ); 766 QArray<int> ints(list.count() );
776 qWarning(" count = %d", list.count() ); 767 qWarning(" count = %d", list.count() );
777 768
778 int i = 0; 769 int i = 0;
779 for (it = list.begin(); it != list.end(); ++it ) { 770 for (it = list.begin(); it != list.end(); ++it ) {
780 ints[i] = (*it).data("uid").toInt(); 771 ints[i] = (*it).data("uid").toInt();
781 i++; 772 i++;
782 } 773 }
783 qWarning("extractUids ready: count2 = %d needs %d ms", i, t.elapsed() ); 774 qWarning("extractUids ready: count2 = %d needs %d ms", i, t.elapsed() );
784 775
785 return ints; 776 return ints;
786 777
787} 778}
788 779
789#ifdef __STORE_HORIZONTAL_ 780#ifdef __STORE_HORIZONTAL_
790QMap<int, QString> OContactAccessBackend_SQL::requestNonCustom( int uid ) const 781QMap<int, QString> OContactAccessBackend_SQL::requestNonCustom( int uid ) const
791{ 782{
792 QTime t; 783 QTime t;
793 t.start(); 784 t.start();
794 785
795 QMap<int, QString> nonCustomMap; 786 QMap<int, QString> nonCustomMap;
796 787
797 int t2needed = 0; 788 int t2needed = 0;
798 int t3needed = 0; 789 int t3needed = 0;
799 QTime t2; 790 QTime t2;
800 t2.start(); 791 t2.start();
801 FindQuery query( uid ); 792 FindQuery query( uid );
802 OSQLResult res_noncustom = m_driver->query( &query ); 793 OSQLResult res_noncustom = m_driver->query( &query );
803 t2needed = t2.elapsed(); 794 t2needed = t2.elapsed();
804 795
805 OSQLResultItem resItem = res_noncustom.first(); 796 OSQLResultItem resItem = res_noncustom.first();
806 797
807 QTime t3; 798 QTime t3;
808 t3.start(); 799 t3.start();
809 // Now loop through all columns 800 // Now loop through all columns
810 QStringList fieldList = OContactFields::untrfields( false ); 801 QStringList fieldList = OContactFields::untrfields( false );
811 QMap<QString, int> translate = OContactFields::untrFieldsToId(); 802 QMap<QString, int> translate = OContactFields::untrFieldsToId();
812 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){ 803 for ( QStringList::Iterator it = ++fieldList.begin(); it != fieldList.end(); ++it ){
813 // Get data for the selected column and store it with the 804 // Get data for the selected column and store it with the
814 // corresponding id into the map.. 805 // corresponding id into the map..
815 806
816 int id = translate[*it]; 807 int id = translate[*it];
817 QString value = resItem.data( (*it) ); 808 QString value = resItem.data( (*it) );
818 809
819 // qWarning("Reading %s... found: %s", (*it).latin1(), value.latin1() ); 810 // qWarning("Reading %s... found: %s", (*it).latin1(), value.latin1() );
820 811
821 switch( id ){ 812 switch( id ){
822 case Qtopia::Birthday: 813 case Qtopia::Birthday:
823 case Qtopia::Anniversary:{ 814 case Qtopia::Anniversary:{
824 // Birthday and Anniversary are encoded special ( yyyy-mm-dd ) 815 // Birthday and Anniversary are encoded special ( yyyy-mm-dd )
825 QStringList list = QStringList::split( '-', value ); 816 QStringList list = QStringList::split( '-', value );
826 QStringList::Iterator lit = list.begin(); 817 QStringList::Iterator lit = list.begin();
827 int year = (*lit).toInt(); 818 int year = (*lit).toInt();
828 int month = (*(++lit)).toInt(); 819 int month = (*(++lit)).toInt();
829 int day = (*(++lit)).toInt(); 820 int day = (*(++lit)).toInt();
830 if ( ( day != 0 ) && ( month != 0 ) && ( year != 0 ) ){ 821 if ( ( day != 0 ) && ( month != 0 ) && ( year != 0 ) ){
831 QDate date( year, month, day ); 822 QDate date( year, month, day );
832 nonCustomMap.insert( id, OConversion::dateToString( date ) ); 823 nonCustomMap.insert( id, OConversion::dateToString( date ) );
833 } 824 }
834 } 825 }
835 break; 826 break;
836 case Qtopia::AddressCategory: 827 case Qtopia::AddressCategory:
837 qWarning("Category is: %s", value.latin1() ); 828 qWarning("Category is: %s", value.latin1() );
838 default: 829 default:
839 nonCustomMap.insert( id, value ); 830 nonCustomMap.insert( id, value );
840 } 831 }
841 } 832 }
842 833
843 // First insert uid 834 // First insert uid
844 nonCustomMap.insert( Qtopia::AddressUid, resItem.data( "uid" ) ); 835 nonCustomMap.insert( Qtopia::AddressUid, resItem.data( "uid" ) );
845 t3needed = t3.elapsed(); 836 t3needed = t3.elapsed();
846 837
847 // qWarning("Adding UID: %s", resItem.data( "uid" ).latin1() ); 838 // qWarning("Adding UID: %s", resItem.data( "uid" ).latin1() );
848 qWarning("RequestNonCustom needed: insg.:%d ms, query: %d ms, mapping: %d ms", 839 qWarning("RequestNonCustom needed: insg.:%d ms, query: %d ms, mapping: %d ms",
849 t.elapsed(), t2needed, t3needed ); 840 t.elapsed(), t2needed, t3needed );
850 841
851 return nonCustomMap; 842 return nonCustomMap;
852} 843}
853#else 844#else
854 845
855QMap<int, QString> OContactAccessBackend_SQL::requestNonCustom( int uid ) const 846QMap<int, QString> OContactAccessBackend_SQL::requestNonCustom( int uid ) const
856{ 847{
857 QTime t; 848 QTime t;
858 t.start(); 849 t.start();
859 850
860 QMap<int, QString> nonCustomMap; 851 QMap<int, QString> nonCustomMap;
861 852
862 int t2needed = 0; 853 int t2needed = 0;
863 QTime t2; 854 QTime t2;
864 t2.start(); 855 t2.start();
865 FindQuery query( uid ); 856 FindQuery query( uid );
866 OSQLResult res_noncustom = m_driver->query( &query ); 857 OSQLResult res_noncustom = m_driver->query( &query );
867 t2needed = t2.elapsed(); 858 t2needed = t2.elapsed();
868 859
869 if ( res_noncustom.state() == OSQLResult::Failure ) { 860 if ( res_noncustom.state() == OSQLResult::Failure ) {
870 qWarning("OSQLResult::Failure in find query !!"); 861 qWarning("OSQLResult::Failure in find query !!");
871 QMap<int, QString> empty; 862 QMap<int, QString> empty;
872 return empty; 863 return empty;
873 } 864 }
874 865
875 int t3needed = 0; 866 int t3needed = 0;
876 QTime t3; 867 QTime t3;
877 t3.start(); 868 t3.start();
878 QMap<QString, int> translateMap = OContactFields::untrFieldsToId(); 869 QMap<QString, int> translateMap = OContactFields::untrFieldsToId();
879 870
880 OSQLResultItem::ValueList list = res_noncustom.results(); 871 OSQLResultItem::ValueList list = res_noncustom.results();
881 OSQLResultItem::ValueList::Iterator it = list.begin(); 872 OSQLResultItem::ValueList::Iterator it = list.begin();
882 for ( ; it != list.end(); ++it ) { 873 for ( ; it != list.end(); ++it ) {
883 if ( (*it).data("type") != "" ){ 874 if ( (*it).data("type") != "" ){
884 int typeId = translateMap[(*it).data( "type" )]; 875 int typeId = translateMap[(*it).data( "type" )];
885 switch( typeId ){ 876 switch( typeId ){
886 case Qtopia::Birthday: 877 case Qtopia::Birthday:
887 case Qtopia::Anniversary:{ 878 case Qtopia::Anniversary:{
888 // Birthday and Anniversary are encoded special ( yyyy-mm-dd ) 879 // Birthday and Anniversary are encoded special ( yyyy-mm-dd )
889 QStringList list = QStringList::split( '-', (*it).data( "value" ) ); 880 QStringList list = QStringList::split( '-', (*it).data( "value" ) );
890 QStringList::Iterator lit = list.begin(); 881 QStringList::Iterator lit = list.begin();
891 int year = (*lit).toInt(); 882 int year = (*lit).toInt();
892 qWarning("1. %s", (*lit).latin1()); 883 qWarning("1. %s", (*lit).latin1());
893 int month = (*(++lit)).toInt(); 884 int month = (*(++lit)).toInt();
894 qWarning("2. %s", (*lit).latin1()); 885 qWarning("2. %s", (*lit).latin1());
895 int day = (*(++lit)).toInt(); 886 int day = (*(++lit)).toInt();
896 qWarning("3. %s", (*lit).latin1()); 887 qWarning("3. %s", (*lit).latin1());
897 qWarning( "RequestNonCustom->Converting:%s to Year: %d, Month: %d, Day: %d ", (*it).data( "value" ).latin1(), year, month, day ); 888 qWarning( "RequestNonCustom->Converting:%s to Year: %d, Month: %d, Day: %d ", (*it).data( "value" ).latin1(), year, month, day );
898 QDate date( year, month, day ); 889 QDate date( year, month, day );
899 nonCustomMap.insert( typeId, OConversion::dateToString( date ) ); 890 nonCustomMap.insert( typeId, OConversion::dateToString( date ) );
900 } 891 }
901 break; 892 break;
902 default: 893 default:
903 nonCustomMap.insert( typeId, 894 nonCustomMap.insert( typeId,
904 (*it).data( "value" ) ); 895 (*it).data( "value" ) );
905 } 896 }
906 } 897 }
907 } 898 }
908 // Add UID to Map.. 899 // Add UID to Map..
909 nonCustomMap.insert( Qtopia::AddressUid, QString::number( uid ) ); 900 nonCustomMap.insert( Qtopia::AddressUid, QString::number( uid ) );
910 t3needed = t3.elapsed(); 901 t3needed = t3.elapsed();
911 902
912 qWarning("RequestNonCustom needed: insg.:%d ms, query: %d ms, mapping: %d ms", t.elapsed(), t2needed, t3needed ); 903 qWarning("RequestNonCustom needed: insg.:%d ms, query: %d ms, mapping: %d ms", t.elapsed(), t2needed, t3needed );
913 return nonCustomMap; 904 return nonCustomMap;
914} 905}
915 906
916#endif // __STORE_HORIZONTAL_ 907#endif // __STORE_HORIZONTAL_
917 908
918QMap<QString, QString> OContactAccessBackend_SQL::requestCustom( int uid ) const 909QMap<QString, QString> OContactAccessBackend_SQL::requestCustom( int uid ) const
919{ 910{
920 QTime t; 911 QTime t;
921 t.start(); 912 t.start();
922 913
923 QMap<QString, QString> customMap; 914 QMap<QString, QString> customMap;
924 915
925 FindCustomQuery query( uid ); 916 FindCustomQuery query( uid );
926 OSQLResult res_custom = m_driver->query( &query ); 917 OSQLResult res_custom = m_driver->query( &query );
927 918
928 if ( res_custom.state() == OSQLResult::Failure ) { 919 if ( res_custom.state() == OSQLResult::Failure ) {
929 qWarning("OSQLResult::Failure in find query !!"); 920 qWarning("OSQLResult::Failure in find query !!");
930 QMap<QString, QString> empty; 921 QMap<QString, QString> empty;
931 return empty; 922 return empty;
932 } 923 }
933 924
934 OSQLResultItem::ValueList list = res_custom.results(); 925 OSQLResultItem::ValueList list = res_custom.results();
935 OSQLResultItem::ValueList::Iterator it = list.begin(); 926 OSQLResultItem::ValueList::Iterator it = list.begin();
936 for ( ; it != list.end(); ++it ) { 927 for ( ; it != list.end(); ++it ) {
937 customMap.insert( (*it).data( "type" ), (*it).data( "value" ) ); 928 customMap.insert( (*it).data( "type" ), (*it).data( "value" ) );
938 } 929 }
939 930
940 qWarning("RequestCustom needed: %d ms", t.elapsed() ); 931 qWarning("RequestCustom needed: %d ms", t.elapsed() );
941 return customMap; 932 return customMap;
942} 933}
934
935}
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_sql.h b/libopie2/opiepim/backend/ocontactaccessbackend_sql.h
index b8f1d8d..55b95fd 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_sql.h
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_sql.h
@@ -1,101 +1,109 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * SQL Backend for the OPIE-Contact Database. 30 * SQL Backend for the OPIE-Contact Database.
3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 *
6 * =====================================================================
7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 * =====================================================================
12 *
13 *
14 * =====================================================================
15 * Version: $Id$
16 * =====================================================================
17 * History:
18 * $Log$
19 * Revision 1.2 2003/12/08 15:18:11 eilers
20 * Committing unfinished sql implementation before merging to libopie2 starts..
21 *
22 * Revision 1.1 2003/09/22 14:31:16 eilers
23 * Added first experimental incarnation of sql-backend for addressbook.
24 * Some modifications to be able to compile the todo sql-backend.
25 * A lot of changes fill follow...
26 *
27 *
28 */ 31 */
29 32
30#ifndef _OContactAccessBackend_SQL_ 33#ifndef _OContactAccessBackend_SQL_
31#define _OContactAccessBackend_SQL_ 34#define _OContactAccessBackend_SQL_
32 35
33#include "ocontactaccessbackend.h" 36#include <opie2/ocontactaccessbackend.h>
34#include "ocontactaccess.h" 37#include <opie2/ocontactaccess.h>
35 38
36#include <qlist.h> 39#include <qlist.h>
37#include <qdict.h> 40#include <qdict.h>
38 41
42/* aren't in namespace Opie yet - alwin */
39class OSQLDriver; 43class OSQLDriver;
40class OSQLResult; 44class OSQLResult;
41class OSQLResultItem; 45class OSQLResultItem;
42 46
47namespace Opie {
48
43/* the default xml implementation */ 49/* the default xml implementation */
44/** 50/**
45 * This class is the SQL implementation of a Contact backend 51 * This class is the SQL implementation of a Contact backend
46 * it does implement everything available for OContact. 52 * it does implement everything available for OContact.
47 * @see OPimAccessBackend for more information of available methods 53 * @see OPimAccessBackend for more information of available methods
48 */ 54 */
49class OContactAccessBackend_SQL : public OContactAccessBackend { 55class OContactAccessBackend_SQL : public OContactAccessBackend {
50 public: 56 public:
51 OContactAccessBackend_SQL ( const QString& appname, const QString& filename = QString::null ); 57 OContactAccessBackend_SQL ( const QString& appname, const QString& filename = QString::null );
52 58
53 ~OContactAccessBackend_SQL (); 59 ~OContactAccessBackend_SQL ();
54 60
55 bool save(); 61 bool save();
56 62
57 bool load (); 63 bool load ();
58 64
59 void clear (); 65 void clear ();
60 66
61 bool wasChangedExternally(); 67 bool wasChangedExternally();
62 68
63 QArray<int> allRecords() const; 69 QArray<int> allRecords() const;
64 70
65 OContact find ( int uid ) const; 71 OContact find ( int uid ) const;
66 // FIXME: Add lookahead-cache support ! 72 // FIXME: Add lookahead-cache support !
67 //OContact find(int uid, const QArray<int>&, uint cur, Frontend::CacheDirection )const; 73 //OContact find(int uid, const QArray<int>&, uint cur, Frontend::CacheDirection )const;
68 74
69 QArray<int> queryByExample ( const OContact &query, int settings, 75 QArray<int> queryByExample ( const OContact &query, int settings,
70 const QDateTime& d ); 76 const QDateTime& d );
71 77
72 QArray<int> matchRegexp( const QRegExp &r ) const; 78 QArray<int> matchRegexp( const QRegExp &r ) const;
73 79
74 const uint querySettings(); 80 const uint querySettings();
75 81
76 bool hasQuerySettings (uint querySettings) const; 82 bool hasQuerySettings (uint querySettings) const;
77 83
78 // Currently only asc implemented.. 84 // Currently only asc implemented..
79 QArray<int> sorted( bool asc, int , int , int ); 85 QArray<int> sorted( bool asc, int , int , int );
80 bool add ( const OContact &newcontact ); 86 bool add ( const OContact &newcontact );
81 87
82 bool replace ( const OContact &contact ); 88 bool replace ( const OContact &contact );
83 89
84 bool remove ( int uid ); 90 bool remove ( int uid );
85 bool reload(); 91 bool reload();
86 92
87 private: 93 private:
88 QArray<int> extractUids( OSQLResult& res ) const; 94 QArray<int> extractUids( OSQLResult& res ) const;
89 QMap<int, QString> requestNonCustom( int uid ) const; 95 QMap<int, QString> requestNonCustom( int uid ) const;
90 QMap<QString, QString> requestCustom( int uid ) const; 96 QMap<QString, QString> requestCustom( int uid ) const;
91 void update(); 97 void update();
92 98
93 protected: 99 protected:
94 bool m_changed; 100 bool m_changed;
95 QString m_fileName; 101 QString m_fileName;
96 QArray<int> m_uids; 102 QArray<int> m_uids;
97 103
98 OSQLDriver* m_driver; 104 OSQLDriver* m_driver;
99}; 105};
100 106
107}
108
101#endif 109#endif
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_vcard.cpp b/libopie2/opiepim/backend/ocontactaccessbackend_vcard.cpp
index b60c5be..f85cf38 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_vcard.cpp
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_vcard.cpp
@@ -1,646 +1,591 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * VCard Backend for the OPIE-Contact Database. 30 * VCard Backend for the OPIE-Contact Database.
3 *
4 * Copyright (C) 2000 Trolltech AS. All rights reserved.
5 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
6 *
7 * =====================================================================
8 *This program is free software; you can redistribute it and/or
9 *modify it under the terms of the GNU Library General Public
10 * License as published by the Free Software Foundation; either
11 * version 2 of the License, or (at your option) any later version.
12 * =====================================================================
13 * ToDo:
14 *
15 * =====================================================================
16 * Version: $Id$
17 * =====================================================================
18 * History:
19 * $Log$
20 * Revision 1.11 2003/08/01 12:30:16 eilers
21 * Merging changes from BRANCH_1_0 to HEAD
22 *
23 * Revision 1.10.4.3 2003/07/23 08:54:37 eilers
24 * Default email was added to the list of all emails, which already contains
25 * the default email..
26 * This closes bug #1045
27 *
28 * Revision 1.10.4.2 2003/07/23 08:44:45 eilers
29 * Importing of Notes in vcard files wasn't implemented.
30 * Closes bug #1044
31 *
32 * Revision 1.10.4.1 2003/06/02 13:37:49 eilers
33 * Fixing memory leak
34 *
35 * Revision 1.10 2003/04/13 18:07:10 zecke
36 * More API doc
37 * QString -> const QString&
38 * QString = 0l -> QString::null
39 *
40 * Revision 1.9 2003/03/21 10:33:09 eilers
41 * Merged speed optimized xml backend for contacts to main.
42 * Added QDateTime to querybyexample. For instance, it is now possible to get
43 * all Birthdays/Anniversaries between two dates. This should be used
44 * to show all birthdays in the datebook..
45 * This change is sourcecode backward compatible but you have to upgrade
46 * the binaries for today-addressbook.
47 *
48 * Revision 1.8 2003/02/21 16:52:49 zecke
49 * -Remove old Todo classes they're deprecated and today I already using the
50 * new API
51 * -Guard against self assignment in OTodo
52 * -Add test apps for OPIM
53 * -Opiefied Event classes
54 * -Added TimeZone handling and pinning of TimeZones to OEvent
55 * -Adjust ORecur and the widget to better timezone behaviour
56 *
57 * Revision 1.7 2003/02/16 22:25:46 zecke
58 * 0000276 Fix for that bug.. or better temp workaround
59 * A Preferred Number is HOME|VOICE
60 * A CellPhone is HOME|VOICE|CELL the type & HOME|VOICE test
61 * triggers both
62 * and the cell phone number overrides the other entries..
63 *
64 * as a temp I check that it's not equal to HOME|VOICE|CELL before setting the
65 * number
66 *
67 * The right and final fix would be to reorder the if statement to make it
68 * if else based and the less common thing put to the bottom
69 *
70 * OTodoAccessVcal fix the date for beaming
71 *
72 * Revision 1.6 2003/01/13 15:49:31 eilers
73 * Fixing crash when businesscard.vcf is missing..
74 *
75 * Revision 1.5 2002/12/07 13:26:22 eilers
76 * Fixing bug in storing anniversary..
77 *
78 * Revision 1.4 2002/11/13 14:14:51 eilers
79 * Added sorted for Contacts..
80 *
81 * Revision 1.3 2002/11/11 16:41:09 kergoth
82 * no default arguments in implementation
83 *
84 * Revision 1.2 2002/11/10 15:41:53 eilers
85 * Bugfixes..
86 *
87 * Revision 1.1 2002/11/09 14:34:52 eilers
88 * Added VCard Backend.
89 *
90 */ 31 */
91#include "ocontactaccessbackend_vcard.h" 32#include <opie2/ocontactaccessbackend_vcard.h>
92#include "../../library/backend/vobject_p.h" 33#include "../../../../library/backend/vobject_p.h"
93#include "../../library/backend/qfiledirect_p.h" 34#include "../../../../library/backend/qfiledirect_p.h"
94 35
95#include <qpe/timeconversion.h> 36#include <qpe/timeconversion.h>
96 37
97#include <qfile.h> 38#include <qfile.h>
98 39
40namespace Opie {
41
99OContactAccessBackend_VCard::OContactAccessBackend_VCard ( const QString& , const QString& filename ): 42OContactAccessBackend_VCard::OContactAccessBackend_VCard ( const QString& , const QString& filename ):
100 m_dirty( false ), 43 m_dirty( false ),
101 m_file( filename ) 44 m_file( filename )
102{ 45{
103 load(); 46 load();
104} 47}
105 48
106 49
107bool OContactAccessBackend_VCard::load () 50bool OContactAccessBackend_VCard::load ()
108{ 51{
109 m_map.clear(); 52 m_map.clear();
110 m_dirty = false; 53 m_dirty = false;
111 54
112 VObject* obj = 0l; 55 VObject* obj = 0l;
113 56
114 if ( QFile::exists(m_file) ){ 57 if ( QFile::exists(m_file) ){
115 obj = Parse_MIME_FromFileName( QFile::encodeName(m_file).data() ); 58 obj = Parse_MIME_FromFileName( QFile::encodeName(m_file).data() );
116 if ( !obj ) 59 if ( !obj )
117 return false; 60 return false;
118 }else{ 61 }else{
119 qWarning("File \"%s\" not found !", m_file.latin1() ); 62 qWarning("File \"%s\" not found !", m_file.latin1() );
120 return false; 63 return false;
121 } 64 }
122 65
123 while ( obj ) { 66 while ( obj ) {
124 OContact con = parseVObject( obj ); 67 OContact con = parseVObject( obj );
125 /* 68 /*
126 * if uid is 0 assign a new one 69 * if uid is 0 assign a new one
127 * this at least happens on 70 * this at least happens on
128 * Nokia6210 71 * Nokia6210
129 */ 72 */
130 if ( con.uid() == 0 ){ 73 if ( con.uid() == 0 ){
131 con.setUid( 1 ); 74 con.setUid( 1 );
132 qWarning("assigned new uid %d",con.uid() ); 75 qWarning("assigned new uid %d",con.uid() );
133 } 76 }
134 77
135 m_map.insert( con.uid(), con ); 78 m_map.insert( con.uid(), con );
136 79
137 VObject *t = obj; 80 VObject *t = obj;
138 obj = nextVObjectInList(obj); 81 obj = nextVObjectInList(obj);
139 cleanVObject( t ); 82 cleanVObject( t );
140 } 83 }
141 84
142 return true; 85 return true;
143 86
144} 87}
145bool OContactAccessBackend_VCard::reload() 88bool OContactAccessBackend_VCard::reload()
146{ 89{
147 return load(); 90 return load();
148} 91}
149bool OContactAccessBackend_VCard::save() 92bool OContactAccessBackend_VCard::save()
150{ 93{
151 if (!m_dirty ) 94 if (!m_dirty )
152 return true; 95 return true;
153 96
154 QFileDirect file( m_file ); 97 QFileDirect file( m_file );
155 if (!file.open(IO_WriteOnly ) ) 98 if (!file.open(IO_WriteOnly ) )
156 return false; 99 return false;
157 100
158 VObject *obj; 101 VObject *obj;
159 obj = newVObject( VCCalProp ); 102 obj = newVObject( VCCalProp );
160 addPropValue( obj, VCVersionProp, "1.0" ); 103 addPropValue( obj, VCVersionProp, "1.0" );
161 104
162 VObject *vo; 105 VObject *vo;
163 for(QMap<int, OContact>::ConstIterator it=m_map.begin(); it !=m_map.end(); ++it ){ 106 for(QMap<int, OContact>::ConstIterator it=m_map.begin(); it !=m_map.end(); ++it ){
164 vo = createVObject( *it ); 107 vo = createVObject( *it );
165 writeVObject( file.directHandle() , vo ); 108 writeVObject( file.directHandle() , vo );
166 cleanVObject( vo ); 109 cleanVObject( vo );
167 } 110 }
168 cleanStrTbl(); 111 cleanStrTbl();
169 deleteVObject( obj ); 112 deleteVObject( obj );
170 113
171 m_dirty = false; 114 m_dirty = false;
172 return true; 115 return true;
173 116
174 117
175} 118}
176void OContactAccessBackend_VCard::clear () 119void OContactAccessBackend_VCard::clear ()
177{ 120{
178 m_map.clear(); 121 m_map.clear();
179 m_dirty = true; // ??? sure ? (se) 122 m_dirty = true; // ??? sure ? (se)
180} 123}
181 124
182bool OContactAccessBackend_VCard::add ( const OContact& newcontact ) 125bool OContactAccessBackend_VCard::add ( const OContact& newcontact )
183{ 126{
184 m_map.insert( newcontact.uid(), newcontact ); 127 m_map.insert( newcontact.uid(), newcontact );
185 m_dirty = true; 128 m_dirty = true;
186 return true; 129 return true;
187} 130}
188 131
189bool OContactAccessBackend_VCard::remove ( int uid ) 132bool OContactAccessBackend_VCard::remove ( int uid )
190{ 133{
191 m_map.remove( uid ); 134 m_map.remove( uid );
192 m_dirty = true; 135 m_dirty = true;
193 return true; 136 return true;
194} 137}
195 138
196bool OContactAccessBackend_VCard::replace ( const OContact &contact ) 139bool OContactAccessBackend_VCard::replace ( const OContact &contact )
197{ 140{
198 m_map.replace( contact.uid(), contact ); 141 m_map.replace( contact.uid(), contact );
199 m_dirty = true; 142 m_dirty = true;
200 return true; 143 return true;
201} 144}
202 145
203OContact OContactAccessBackend_VCard::find ( int uid ) const 146OContact OContactAccessBackend_VCard::find ( int uid ) const
204{ 147{
205 return m_map[uid]; 148 return m_map[uid];
206} 149}
207 150
208QArray<int> OContactAccessBackend_VCard::allRecords() const 151QArray<int> OContactAccessBackend_VCard::allRecords() const
209{ 152{
210 QArray<int> ar( m_map.count() ); 153 QArray<int> ar( m_map.count() );
211 QMap<int, OContact>::ConstIterator it; 154 QMap<int, OContact>::ConstIterator it;
212 int i = 0; 155 int i = 0;
213 for ( it = m_map.begin(); it != m_map.end(); ++it ) { 156 for ( it = m_map.begin(); it != m_map.end(); ++it ) {
214 ar[i] = it.key(); 157 ar[i] = it.key();
215 i++; 158 i++;
216 } 159 }
217 return ar; 160 return ar;
218} 161}
219 162
220// Not implemented 163// Not implemented
221QArray<int> OContactAccessBackend_VCard::queryByExample ( const OContact&, int, const QDateTime& ) 164QArray<int> OContactAccessBackend_VCard::queryByExample ( const OContact&, int, const QDateTime& )
222{ 165{
223 QArray<int> ar(0); 166 QArray<int> ar(0);
224 return ar; 167 return ar;
225} 168}
226 169
227// Not implemented 170// Not implemented
228QArray<int> OContactAccessBackend_VCard::matchRegexp( const QRegExp& ) const 171QArray<int> OContactAccessBackend_VCard::matchRegexp( const QRegExp& ) const
229{ 172{
230 QArray<int> ar(0); 173 QArray<int> ar(0);
231 return ar; 174 return ar;
232} 175}
233 176
234const uint OContactAccessBackend_VCard::querySettings() 177const uint OContactAccessBackend_VCard::querySettings()
235{ 178{
236 return 0; // No search possible 179 return 0; // No search possible
237} 180}
238 181
239bool OContactAccessBackend_VCard::hasQuerySettings (uint ) const 182bool OContactAccessBackend_VCard::hasQuerySettings (uint ) const
240{ 183{
241 return false; // No search possible, therefore all settings invalid ;) 184 return false; // No search possible, therefore all settings invalid ;)
242} 185}
243 186
244bool OContactAccessBackend_VCard::wasChangedExternally() 187bool OContactAccessBackend_VCard::wasChangedExternally()
245{ 188{
246 return false; // Don't expect concurrent access 189 return false; // Don't expect concurrent access
247} 190}
248 191
249// Not implemented 192// Not implemented
250QArray<int> OContactAccessBackend_VCard::sorted( bool , int, int, int ) 193QArray<int> OContactAccessBackend_VCard::sorted( bool , int, int, int )
251{ 194{
252 QArray<int> ar(0); 195 QArray<int> ar(0);
253 return ar; 196 return ar;
254} 197}
255 198
256// *** Private stuff *** 199// *** Private stuff ***
257 200
258 201
259OContact OContactAccessBackend_VCard::parseVObject( VObject *obj ) 202OContact OContactAccessBackend_VCard::parseVObject( VObject *obj )
260{ 203{
261 OContact c; 204 OContact c;
262 205
263 VObjectIterator it; 206 VObjectIterator it;
264 initPropIterator( &it, obj ); 207 initPropIterator( &it, obj );
265 while( moreIteration( &it ) ) { 208 while( moreIteration( &it ) ) {
266 VObject *o = nextVObject( &it ); 209 VObject *o = nextVObject( &it );
267 QCString name = vObjectName( o ); 210 QCString name = vObjectName( o );
268 QCString value = vObjectStringZValue( o ); 211 QCString value = vObjectStringZValue( o );
269 if ( name == VCNameProp ) { 212 if ( name == VCNameProp ) {
270 VObjectIterator nit; 213 VObjectIterator nit;
271 initPropIterator( &nit, o ); 214 initPropIterator( &nit, o );
272 while( moreIteration( &nit ) ) { 215 while( moreIteration( &nit ) ) {
273 VObject *o = nextVObject( &nit ); 216 VObject *o = nextVObject( &nit );
274 QCString name = vObjectTypeInfo( o ); 217 QCString name = vObjectTypeInfo( o );
275 QString value = vObjectStringZValue( o ); 218 QString value = vObjectStringZValue( o );
276 if ( name == VCNamePrefixesProp ) 219 if ( name == VCNamePrefixesProp )
277 c.setTitle( value ); 220 c.setTitle( value );
278 else if ( name == VCNameSuffixesProp ) 221 else if ( name == VCNameSuffixesProp )
279 c.setSuffix( value ); 222 c.setSuffix( value );
280 else if ( name == VCFamilyNameProp ) 223 else if ( name == VCFamilyNameProp )
281 c.setLastName( value ); 224 c.setLastName( value );
282 else if ( name == VCGivenNameProp ) 225 else if ( name == VCGivenNameProp )
283 c.setFirstName( value ); 226 c.setFirstName( value );
284 else if ( name == VCAdditionalNamesProp ) 227 else if ( name == VCAdditionalNamesProp )
285 c.setMiddleName( value ); 228 c.setMiddleName( value );
286 } 229 }
287 } 230 }
288 else if ( name == VCAdrProp ) { 231 else if ( name == VCAdrProp ) {
289 bool work = TRUE; // default address is work address 232 bool work = TRUE; // default address is work address
290 QString street; 233 QString street;
291 QString city; 234 QString city;
292 QString region; 235 QString region;
293 QString postal; 236 QString postal;
294 QString country; 237 QString country;
295 238
296 VObjectIterator nit; 239 VObjectIterator nit;
297 initPropIterator( &nit, o ); 240 initPropIterator( &nit, o );
298 while( moreIteration( &nit ) ) { 241 while( moreIteration( &nit ) ) {
299 VObject *o = nextVObject( &nit ); 242 VObject *o = nextVObject( &nit );
300 QCString name = vObjectName( o ); 243 QCString name = vObjectName( o );
301 QString value = vObjectStringZValue( o ); 244 QString value = vObjectStringZValue( o );
302 if ( name == VCHomeProp ) 245 if ( name == VCHomeProp )
303 work = FALSE; 246 work = FALSE;
304 else if ( name == VCWorkProp ) 247 else if ( name == VCWorkProp )
305 work = TRUE; 248 work = TRUE;
306 else if ( name == VCStreetAddressProp ) 249 else if ( name == VCStreetAddressProp )
307 street = value; 250 street = value;
308 else if ( name == VCCityProp ) 251 else if ( name == VCCityProp )
309 city = value; 252 city = value;
310 else if ( name == VCRegionProp ) 253 else if ( name == VCRegionProp )
311 region = value; 254 region = value;
312 else if ( name == VCPostalCodeProp ) 255 else if ( name == VCPostalCodeProp )
313 postal = value; 256 postal = value;
314 else if ( name == VCCountryNameProp ) 257 else if ( name == VCCountryNameProp )
315 country = value; 258 country = value;
316 } 259 }
317 if ( work ) { 260 if ( work ) {
318 c.setBusinessStreet( street ); 261 c.setBusinessStreet( street );
319 c.setBusinessCity( city ); 262 c.setBusinessCity( city );
320 c.setBusinessCountry( country ); 263 c.setBusinessCountry( country );
321 c.setBusinessZip( postal ); 264 c.setBusinessZip( postal );
322 c.setBusinessState( region ); 265 c.setBusinessState( region );
323 } else { 266 } else {
324 c.setHomeStreet( street ); 267 c.setHomeStreet( street );
325 c.setHomeCity( city ); 268 c.setHomeCity( city );
326 c.setHomeCountry( country ); 269 c.setHomeCountry( country );
327 c.setHomeZip( postal ); 270 c.setHomeZip( postal );
328 c.setHomeState( region ); 271 c.setHomeState( region );
329 } 272 }
330 } 273 }
331 else if ( name == VCTelephoneProp ) { 274 else if ( name == VCTelephoneProp ) {
332 enum { 275 enum {
333 HOME = 0x01, 276 HOME = 0x01,
334 WORK = 0x02, 277 WORK = 0x02,
335 VOICE = 0x04, 278 VOICE = 0x04,
336 CELL = 0x08, 279 CELL = 0x08,
337 FAX = 0x10, 280 FAX = 0x10,
338 PAGER = 0x20, 281 PAGER = 0x20,
339 UNKNOWN = 0x80 282 UNKNOWN = 0x80
340 }; 283 };
341 int type = 0; 284 int type = 0;
342 285
343 VObjectIterator nit; 286 VObjectIterator nit;
344 initPropIterator( &nit, o ); 287 initPropIterator( &nit, o );
345 while( moreIteration( &nit ) ) { 288 while( moreIteration( &nit ) ) {
346 VObject *o = nextVObject( &nit ); 289 VObject *o = nextVObject( &nit );
347 QCString name = vObjectTypeInfo( o ); 290 QCString name = vObjectTypeInfo( o );
348 if ( name == VCHomeProp ) 291 if ( name == VCHomeProp )
349 type |= HOME; 292 type |= HOME;
350 else if ( name == VCWorkProp ) 293 else if ( name == VCWorkProp )
351 type |= WORK; 294 type |= WORK;
352 else if ( name == VCVoiceProp ) 295 else if ( name == VCVoiceProp )
353 type |= VOICE; 296 type |= VOICE;
354 else if ( name == VCCellularProp ) 297 else if ( name == VCCellularProp )
355 type |= CELL; 298 type |= CELL;
356 else if ( name == VCFaxProp ) 299 else if ( name == VCFaxProp )
357 type |= FAX; 300 type |= FAX;
358 else if ( name == VCPagerProp ) 301 else if ( name == VCPagerProp )
359 type |= PAGER; 302 type |= PAGER;
360 else if ( name == VCPreferredProp ) 303 else if ( name == VCPreferredProp )
361 ; 304 ;
362 else 305 else
363 type |= UNKNOWN; 306 type |= UNKNOWN;
364 } 307 }
365 if ( (type & UNKNOWN) != UNKNOWN ) { 308 if ( (type & UNKNOWN) != UNKNOWN ) {
366 if ( ( type & (HOME|WORK) ) == 0 ) // default 309 if ( ( type & (HOME|WORK) ) == 0 ) // default
367 type |= HOME; 310 type |= HOME;
368 if ( ( type & (VOICE|CELL|FAX|PAGER) ) == 0 ) // default 311 if ( ( type & (VOICE|CELL|FAX|PAGER) ) == 0 ) // default
369 type |= VOICE; 312 type |= VOICE;
370 313
371 qWarning("value %s %d", value.data(), type ); 314 qWarning("value %s %d", value.data(), type );
372 if ( (type & (VOICE|HOME) ) == (VOICE|HOME) && (type & (CELL|HOME) ) != (CELL|HOME) ) 315 if ( (type & (VOICE|HOME) ) == (VOICE|HOME) && (type & (CELL|HOME) ) != (CELL|HOME) )
373 c.setHomePhone( value ); 316 c.setHomePhone( value );
374 if ( ( type & (FAX|HOME) ) == (FAX|HOME) ) 317 if ( ( type & (FAX|HOME) ) == (FAX|HOME) )
375 c.setHomeFax( value ); 318 c.setHomeFax( value );
376 if ( ( type & (CELL|HOME) ) == (CELL|HOME) ) 319 if ( ( type & (CELL|HOME) ) == (CELL|HOME) )
377 c.setHomeMobile( value ); 320 c.setHomeMobile( value );
378 if ( ( type & (VOICE|WORK) ) == (VOICE|WORK) && (type & (CELL|WORK) ) != (CELL|WORK) ) 321 if ( ( type & (VOICE|WORK) ) == (VOICE|WORK) && (type & (CELL|WORK) ) != (CELL|WORK) )
379 c.setBusinessPhone( value ); 322 c.setBusinessPhone( value );
380 if ( ( type & (FAX|WORK) ) == (FAX|WORK) ) 323 if ( ( type & (FAX|WORK) ) == (FAX|WORK) )
381 c.setBusinessFax( value ); 324 c.setBusinessFax( value );
382 if ( ( type & (CELL|WORK) ) == (CELL|WORK) ) 325 if ( ( type & (CELL|WORK) ) == (CELL|WORK) )
383 c.setBusinessMobile( value ); 326 c.setBusinessMobile( value );
384 if ( ( type & (PAGER|WORK) ) == (PAGER|WORK) ) 327 if ( ( type & (PAGER|WORK) ) == (PAGER|WORK) )
385 c.setBusinessPager( value ); 328 c.setBusinessPager( value );
386 } 329 }
387 } 330 }
388 else if ( name == VCEmailAddressProp ) { 331 else if ( name == VCEmailAddressProp ) {
389 QString email = vObjectStringZValue( o ); 332 QString email = vObjectStringZValue( o );
390 bool valid = TRUE; 333 bool valid = TRUE;
391 VObjectIterator nit; 334 VObjectIterator nit;
392 initPropIterator( &nit, o ); 335 initPropIterator( &nit, o );
393 while( moreIteration( &nit ) ) { 336 while( moreIteration( &nit ) ) {
394 VObject *o = nextVObject( &nit ); 337 VObject *o = nextVObject( &nit );
395 QCString name = vObjectTypeInfo( o ); 338 QCString name = vObjectTypeInfo( o );
396 if ( name != VCInternetProp && name != VCHomeProp && 339 if ( name != VCInternetProp && name != VCHomeProp &&
397 name != VCWorkProp && 340 name != VCWorkProp &&
398 name != VCPreferredProp ) 341 name != VCPreferredProp )
399 // ### preffered should map to default email 342 // ### preffered should map to default email
400 valid = FALSE; 343 valid = FALSE;
401 } 344 }
402 if ( valid ) { 345 if ( valid ) {
403 c.insertEmail( email ); 346 c.insertEmail( email );
404 } 347 }
405 } 348 }
406 else if ( name == VCURLProp ) { 349 else if ( name == VCURLProp ) {
407 VObjectIterator nit; 350 VObjectIterator nit;
408 initPropIterator( &nit, o ); 351 initPropIterator( &nit, o );
409 while( moreIteration( &nit ) ) { 352 while( moreIteration( &nit ) ) {
410 VObject *o = nextVObject( &nit ); 353 VObject *o = nextVObject( &nit );
411 QCString name = vObjectTypeInfo( o ); 354 QCString name = vObjectTypeInfo( o );
412 if ( name == VCHomeProp ) 355 if ( name == VCHomeProp )
413 c.setHomeWebpage( value ); 356 c.setHomeWebpage( value );
414 else if ( name == VCWorkProp ) 357 else if ( name == VCWorkProp )
415 c.setBusinessWebpage( value ); 358 c.setBusinessWebpage( value );
416 } 359 }
417 } 360 }
418 else if ( name == VCOrgProp ) { 361 else if ( name == VCOrgProp ) {
419 VObjectIterator nit; 362 VObjectIterator nit;
420 initPropIterator( &nit, o ); 363 initPropIterator( &nit, o );
421 while( moreIteration( &nit ) ) { 364 while( moreIteration( &nit ) ) {
422 VObject *o = nextVObject( &nit ); 365 VObject *o = nextVObject( &nit );
423 QCString name = vObjectName( o ); 366 QCString name = vObjectName( o );
424 QString value = vObjectStringZValue( o ); 367 QString value = vObjectStringZValue( o );
425 if ( name == VCOrgNameProp ) 368 if ( name == VCOrgNameProp )
426 c.setCompany( value ); 369 c.setCompany( value );
427 else if ( name == VCOrgUnitProp ) 370 else if ( name == VCOrgUnitProp )
428 c.setDepartment( value ); 371 c.setDepartment( value );
429 else if ( name == VCOrgUnit2Prop ) 372 else if ( name == VCOrgUnit2Prop )
430 c.setOffice( value ); 373 c.setOffice( value );
431 } 374 }
432 } 375 }
433 else if ( name == VCTitleProp ) { 376 else if ( name == VCTitleProp ) {
434 c.setJobTitle( value ); 377 c.setJobTitle( value );
435 } 378 }
436 else if ( name == "X-Qtopia-Profession" ) { 379 else if ( name == "X-Qtopia-Profession" ) {
437 c.setProfession( value ); 380 c.setProfession( value );
438 } 381 }
439 else if ( name == "X-Qtopia-Manager" ) { 382 else if ( name == "X-Qtopia-Manager" ) {
440 c.setManager( value ); 383 c.setManager( value );
441 } 384 }
442 else if ( name == "X-Qtopia-Assistant" ) { 385 else if ( name == "X-Qtopia-Assistant" ) {
443 c.setAssistant( value ); 386 c.setAssistant( value );
444 } 387 }
445 else if ( name == "X-Qtopia-Spouse" ) { 388 else if ( name == "X-Qtopia-Spouse" ) {
446 c.setSpouse( value ); 389 c.setSpouse( value );
447 } 390 }
448 else if ( name == "X-Qtopia-Gender" ) { 391 else if ( name == "X-Qtopia-Gender" ) {
449 c.setGender( value ); 392 c.setGender( value );
450 } 393 }
451 else if ( name == "X-Qtopia-Anniversary" ) { 394 else if ( name == "X-Qtopia-Anniversary" ) {
452 c.setAnniversary( convVCardDateToDate( value ) ); 395 c.setAnniversary( convVCardDateToDate( value ) );
453 } 396 }
454 else if ( name == "X-Qtopia-Nickname" ) { 397 else if ( name == "X-Qtopia-Nickname" ) {
455 c.setNickname( value ); 398 c.setNickname( value );
456 } 399 }
457 else if ( name == "X-Qtopia-Children" ) { 400 else if ( name == "X-Qtopia-Children" ) {
458 c.setChildren( value ); 401 c.setChildren( value );
459 } 402 }
460 else if ( name == VCBirthDateProp ) { 403 else if ( name == VCBirthDateProp ) {
461 // Reading Birthdate regarding RFC 2425 (5.8.4) 404 // Reading Birthdate regarding RFC 2425 (5.8.4)
462 c.setBirthday( convVCardDateToDate( value ) ); 405 c.setBirthday( convVCardDateToDate( value ) );
463 406
464 } 407 }
465 else if ( name == VCCommentProp ) { 408 else if ( name == VCCommentProp ) {
466 c.setNotes( value ); 409 c.setNotes( value );
467 } 410 }
468#if 0 411#if 0
469 else { 412 else {
470 printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); 413 printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) );
471 VObjectIterator nit; 414 VObjectIterator nit;
472 initPropIterator( &nit, o ); 415 initPropIterator( &nit, o );
473 while( moreIteration( &nit ) ) { 416 while( moreIteration( &nit ) ) {
474 VObject *o = nextVObject( &nit ); 417 VObject *o = nextVObject( &nit );
475 QCString name = vObjectName( o ); 418 QCString name = vObjectName( o );
476 QString value = vObjectStringZValue( o ); 419 QString value = vObjectStringZValue( o );
477 printf(" subprop: %s = %s\n", name.data(), value.latin1() ); 420 printf(" subprop: %s = %s\n", name.data(), value.latin1() );
478 } 421 }
479 } 422 }
480#endif 423#endif
481 } 424 }
482 c.setFileAs(); 425 c.setFileAs();
483 return c; 426 return c;
484} 427}
485 428
486 429
487VObject* OContactAccessBackend_VCard::createVObject( const OContact &c ) 430VObject* OContactAccessBackend_VCard::createVObject( const OContact &c )
488{ 431{
489 VObject *vcard = newVObject( VCCardProp ); 432 VObject *vcard = newVObject( VCCardProp );
490 safeAddPropValue( vcard, VCVersionProp, "2.1" ); 433 safeAddPropValue( vcard, VCVersionProp, "2.1" );
491 safeAddPropValue( vcard, VCLastRevisedProp, TimeConversion::toISO8601( QDateTime::currentDateTime() ) ); 434 safeAddPropValue( vcard, VCLastRevisedProp, TimeConversion::toISO8601( QDateTime::currentDateTime() ) );
492 safeAddPropValue( vcard, VCUniqueStringProp, QString::number(c.uid()) ); 435 safeAddPropValue( vcard, VCUniqueStringProp, QString::number(c.uid()) );
493 436
494 // full name 437 // full name
495 safeAddPropValue( vcard, VCFullNameProp, c.fullName() ); 438 safeAddPropValue( vcard, VCFullNameProp, c.fullName() );
496 439
497 // name properties 440 // name properties
498 VObject *name = safeAddProp( vcard, VCNameProp ); 441 VObject *name = safeAddProp( vcard, VCNameProp );
499 safeAddPropValue( name, VCFamilyNameProp, c.lastName() ); 442 safeAddPropValue( name, VCFamilyNameProp, c.lastName() );
500 safeAddPropValue( name, VCGivenNameProp, c.firstName() ); 443 safeAddPropValue( name, VCGivenNameProp, c.firstName() );
501 safeAddPropValue( name, VCAdditionalNamesProp, c.middleName() ); 444 safeAddPropValue( name, VCAdditionalNamesProp, c.middleName() );
502 safeAddPropValue( name, VCNamePrefixesProp, c.title() ); 445 safeAddPropValue( name, VCNamePrefixesProp, c.title() );
503 safeAddPropValue( name, VCNameSuffixesProp, c.suffix() ); 446 safeAddPropValue( name, VCNameSuffixesProp, c.suffix() );
504 447
505 // home properties 448 // home properties
506 VObject *home_adr= safeAddProp( vcard, VCAdrProp ); 449 VObject *home_adr= safeAddProp( vcard, VCAdrProp );
507 safeAddProp( home_adr, VCHomeProp ); 450 safeAddProp( home_adr, VCHomeProp );
508 safeAddPropValue( home_adr, VCStreetAddressProp, c.homeStreet() ); 451 safeAddPropValue( home_adr, VCStreetAddressProp, c.homeStreet() );
509 safeAddPropValue( home_adr, VCCityProp, c.homeCity() ); 452 safeAddPropValue( home_adr, VCCityProp, c.homeCity() );
510 safeAddPropValue( home_adr, VCRegionProp, c.homeState() ); 453 safeAddPropValue( home_adr, VCRegionProp, c.homeState() );
511 safeAddPropValue( home_adr, VCPostalCodeProp, c.homeZip() ); 454 safeAddPropValue( home_adr, VCPostalCodeProp, c.homeZip() );
512 safeAddPropValue( home_adr, VCCountryNameProp, c.homeCountry() ); 455 safeAddPropValue( home_adr, VCCountryNameProp, c.homeCountry() );
513 456
514 VObject *home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homePhone() ); 457 VObject *home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homePhone() );
515 safeAddProp( home_phone, VCHomeProp ); 458 safeAddProp( home_phone, VCHomeProp );
516 home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homeMobile() ); 459 home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homeMobile() );
517 safeAddProp( home_phone, VCHomeProp ); 460 safeAddProp( home_phone, VCHomeProp );
518 safeAddProp( home_phone, VCCellularProp ); 461 safeAddProp( home_phone, VCCellularProp );
519 home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homeFax() ); 462 home_phone = safeAddPropValue( vcard, VCTelephoneProp, c.homeFax() );
520 safeAddProp( home_phone, VCHomeProp ); 463 safeAddProp( home_phone, VCHomeProp );
521 safeAddProp( home_phone, VCFaxProp ); 464 safeAddProp( home_phone, VCFaxProp );
522 465
523 VObject *url = safeAddPropValue( vcard, VCURLProp, c.homeWebpage() ); 466 VObject *url = safeAddPropValue( vcard, VCURLProp, c.homeWebpage() );
524 safeAddProp( url, VCHomeProp ); 467 safeAddProp( url, VCHomeProp );
525 468
526 // work properties 469 // work properties
527 VObject *work_adr= safeAddProp( vcard, VCAdrProp ); 470 VObject *work_adr= safeAddProp( vcard, VCAdrProp );
528 safeAddProp( work_adr, VCWorkProp ); 471 safeAddProp( work_adr, VCWorkProp );
529 safeAddPropValue( work_adr, VCStreetAddressProp, c.businessStreet() ); 472 safeAddPropValue( work_adr, VCStreetAddressProp, c.businessStreet() );
530 safeAddPropValue( work_adr, VCCityProp, c.businessCity() ); 473 safeAddPropValue( work_adr, VCCityProp, c.businessCity() );
531 safeAddPropValue( work_adr, VCRegionProp, c.businessState() ); 474 safeAddPropValue( work_adr, VCRegionProp, c.businessState() );
532 safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() ); 475 safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() );
533 safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() ); 476 safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() );
534 477
535 VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() ); 478 VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() );
536 safeAddProp( work_phone, VCWorkProp ); 479 safeAddProp( work_phone, VCWorkProp );
537 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() ); 480 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() );
538 safeAddProp( work_phone, VCWorkProp ); 481 safeAddProp( work_phone, VCWorkProp );
539 safeAddProp( work_phone, VCCellularProp ); 482 safeAddProp( work_phone, VCCellularProp );
540 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() ); 483 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() );
541 safeAddProp( work_phone, VCWorkProp ); 484 safeAddProp( work_phone, VCWorkProp );
542 safeAddProp( work_phone, VCFaxProp ); 485 safeAddProp( work_phone, VCFaxProp );
543 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() ); 486 work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() );
544 safeAddProp( work_phone, VCWorkProp ); 487 safeAddProp( work_phone, VCWorkProp );
545 safeAddProp( work_phone, VCPagerProp ); 488 safeAddProp( work_phone, VCPagerProp );
546 489
547 url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() ); 490 url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() );
548 safeAddProp( url, VCWorkProp ); 491 safeAddProp( url, VCWorkProp );
549 492
550 VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() ); 493 VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() );
551 safeAddProp( title, VCWorkProp ); 494 safeAddProp( title, VCWorkProp );
552 495
553 496
554 QStringList emails = c.emailList(); 497 QStringList emails = c.emailList();
555 // emails.prepend( c.defaultEmail() ); Fix for bugreport #1045 498 // emails.prepend( c.defaultEmail() ); Fix for bugreport #1045
556 for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { 499 for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) {
557 VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it ); 500 VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it );
558 safeAddProp( email, VCInternetProp ); 501 safeAddProp( email, VCInternetProp );
559 } 502 }
560 503
561 safeAddPropValue( vcard, VCNoteProp, c.notes() ); 504 safeAddPropValue( vcard, VCNoteProp, c.notes() );
562 505
563 // Exporting Birthday regarding RFC 2425 (5.8.4) 506 // Exporting Birthday regarding RFC 2425 (5.8.4)
564 if ( c.birthday().isValid() ){ 507 if ( c.birthday().isValid() ){
565 qWarning("Exporting birthday as: %s", convDateToVCardDate( c.birthday() ).latin1() ); 508 qWarning("Exporting birthday as: %s", convDateToVCardDate( c.birthday() ).latin1() );
566 safeAddPropValue( vcard, VCBirthDateProp, convDateToVCardDate( c.birthday() ) ); 509 safeAddPropValue( vcard, VCBirthDateProp, convDateToVCardDate( c.birthday() ) );
567 } 510 }
568 511
569 if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { 512 if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) {
570 VObject *org = safeAddProp( vcard, VCOrgProp ); 513 VObject *org = safeAddProp( vcard, VCOrgProp );
571 safeAddPropValue( org, VCOrgNameProp, c.company() ); 514 safeAddPropValue( org, VCOrgNameProp, c.company() );
572 safeAddPropValue( org, VCOrgUnitProp, c.department() ); 515 safeAddPropValue( org, VCOrgUnitProp, c.department() );
573 safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); 516 safeAddPropValue( org, VCOrgUnit2Prop, c.office() );
574 } 517 }
575 518
576 // some values we have to export as custom fields 519 // some values we have to export as custom fields
577 safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); 520 safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() );
578 safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); 521 safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() );
579 safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); 522 safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() );
580 523
581 safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); 524 safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() );
582 safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); 525 safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() );
583 if ( c.anniversary().isValid() ){ 526 if ( c.anniversary().isValid() ){
584 qWarning("Exporting anniversary as: %s", convDateToVCardDate( c.anniversary() ).latin1() ); 527 qWarning("Exporting anniversary as: %s", convDateToVCardDate( c.anniversary() ).latin1() );
585 safeAddPropValue( vcard, "X-Qtopia-Anniversary", convDateToVCardDate( c.anniversary() ) ); 528 safeAddPropValue( vcard, "X-Qtopia-Anniversary", convDateToVCardDate( c.anniversary() ) );
586 } 529 }
587 safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); 530 safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() );
588 safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); 531 safeAddPropValue( vcard, "X-Qtopia-Children", c.children() );
589 532
590 return vcard; 533 return vcard;
591} 534}
592 535
593QString OContactAccessBackend_VCard::convDateToVCardDate( const QDate& d ) const 536QString OContactAccessBackend_VCard::convDateToVCardDate( const QDate& d ) const
594{ 537{
595 QString str_rfc2425 = QString("%1-%2-%3") 538 QString str_rfc2425 = QString("%1-%2-%3")
596 .arg( d.year() ) 539 .arg( d.year() )
597 .arg( d.month(), 2 ) 540 .arg( d.month(), 2 )
598 .arg( d.day(), 2 ); 541 .arg( d.day(), 2 );
599 // Now replace spaces with "0"... 542 // Now replace spaces with "0"...
600 int pos = 0; 543 int pos = 0;
601 while ( ( pos = str_rfc2425.find (' ') ) > 0 ) 544 while ( ( pos = str_rfc2425.find (' ') ) > 0 )
602 str_rfc2425.replace( pos, 1, "0" ); 545 str_rfc2425.replace( pos, 1, "0" );
603 546
604 return str_rfc2425; 547 return str_rfc2425;
605} 548}
606 549
607QDate OContactAccessBackend_VCard::convVCardDateToDate( const QString& datestr ) 550QDate OContactAccessBackend_VCard::convVCardDateToDate( const QString& datestr )
608{ 551{
609 int monthPos = datestr.find('-'); 552 int monthPos = datestr.find('-');
610 int dayPos = datestr.find('-', monthPos+1 ); 553 int dayPos = datestr.find('-', monthPos+1 );
611 int sep_ignore = 1; 554 int sep_ignore = 1;
612 if ( monthPos == -1 || dayPos == -1 ) { 555 if ( monthPos == -1 || dayPos == -1 ) {
613 qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); 556 qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos );
614 // Ok.. No "-" found, therefore we will try to read other format ( YYYYMMDD ) 557 // Ok.. No "-" found, therefore we will try to read other format ( YYYYMMDD )
615 if ( datestr.length() == 8 ){ 558 if ( datestr.length() == 8 ){
616 monthPos = 4; 559 monthPos = 4;
617 dayPos = 6; 560 dayPos = 6;
618 sep_ignore = 0; 561 sep_ignore = 0;
619 qDebug("Try with follwing positions str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); 562 qDebug("Try with follwing positions str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos );
620 } else { 563 } else {
621 return QDate(); 564 return QDate();
622 } 565 }
623 } 566 }
624 int y = datestr.left( monthPos ).toInt(); 567 int y = datestr.left( monthPos ).toInt();
625 int m = datestr.mid( monthPos + sep_ignore, dayPos - monthPos - sep_ignore ).toInt(); 568 int m = datestr.mid( monthPos + sep_ignore, dayPos - monthPos - sep_ignore ).toInt();
626 int d = datestr.mid( dayPos + sep_ignore ).toInt(); 569 int d = datestr.mid( dayPos + sep_ignore ).toInt();
627 qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos); 570 qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos);
628 QDate date ( y,m,d ); 571 QDate date ( y,m,d );
629 return date; 572 return date;
630} 573}
631 574
632VObject* OContactAccessBackend_VCard::safeAddPropValue( VObject *o, const char *prop, const QString &value ) 575VObject* OContactAccessBackend_VCard::safeAddPropValue( VObject *o, const char *prop, const QString &value )
633{ 576{
634 VObject *ret = 0; 577 VObject *ret = 0;
635 if ( o && !value.isEmpty() ) 578 if ( o && !value.isEmpty() )
636 ret = addPropValue( o, prop, value.latin1() ); 579 ret = addPropValue( o, prop, value.latin1() );
637 return ret; 580 return ret;
638} 581}
639 582
640VObject* OContactAccessBackend_VCard::safeAddProp( VObject *o, const char *prop) 583VObject* OContactAccessBackend_VCard::safeAddProp( VObject *o, const char *prop)
641{ 584{
642 VObject *ret = 0; 585 VObject *ret = 0;
643 if ( o ) 586 if ( o )
644 ret = addProp( o, prop ); 587 ret = addProp( o, prop );
645 return ret; 588 return ret;
646} 589}
590
591}
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_vcard.h b/libopie2/opiepim/backend/ocontactaccessbackend_vcard.h
index 712d769..11be027 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_vcard.h
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_vcard.h
@@ -1,96 +1,85 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * VCard Backend for the OPIE-Contact Database. 30 * VCard Backend for the OPIE-Contact Database.
3 *
4 * Copyright (C) 2000 Trolltech AS. All rights reserved.
5 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
6 *
7 * =====================================================================
8 *This program is free software; you can redistribute it and/or
9 *modify it under the terms of the GNU Library General Public
10 * License as published by the Free Software Foundation; either
11 * version 2 of the License, or (at your option) any later version.
12 * =====================================================================
13 * ToDo:
14 *
15 * =====================================================================
16 * Version: $Id$
17 * =====================================================================
18 * History:
19 * $Log$
20 * Revision 1.6 2003/04/13 18:07:10 zecke
21 * More API doc
22 * QString -> const QString&
23 * QString = 0l -> QString::null
24 *
25 * Revision 1.5 2003/03/21 10:33:09 eilers
26 * Merged speed optimized xml backend for contacts to main.
27 * Added QDateTime to querybyexample. For instance, it is now possible to get
28 * all Birthdays/Anniversaries between two dates. This should be used
29 * to show all birthdays in the datebook..
30 * This change is sourcecode backward compatible but you have to upgrade
31 * the binaries for today-addressbook.
32 *
33 * Revision 1.4 2002/12/07 13:26:22 eilers
34 * Fixing bug in storing anniversary..
35 *
36 * Revision 1.3 2002/11/13 14:14:51 eilers
37 * Added sorted for Contacts..
38 *
39 * Revision 1.2 2002/11/10 15:41:53 eilers
40 * Bugfixes..
41 *
42 * Revision 1.1 2002/11/09 14:34:52 eilers
43 * Added VCard Backend.
44 *
45 */ 31 */
46#ifndef __OCONTACTACCESSBACKEND_VCARD_H_ 32#ifndef __OCONTACTACCESSBACKEND_VCARD_H_
47#define __OCONTACTACCESSBACKEND_VCARD_H_ 33#define __OCONTACTACCESSBACKEND_VCARD_H_
48 34
49#include <opie/ocontact.h> 35#include <opie2/ocontact.h>
50 36
51#include "ocontactaccessbackend.h" 37#include <opie2/ocontactaccessbackend.h>
52 38
53class VObject; 39class VObject;
54 40
41namespace Opie {
55/** 42/**
56 * This is the vCard 2.1 implementation of the Contact Storage 43 * This is the vCard 2.1 implementation of the Contact Storage
57 * @see OContactAccessBackend_XML 44 * @see OContactAccessBackend_XML
58 * @see OPimAccessBackend 45 * @see OPimAccessBackend
59 */ 46 */
60class OContactAccessBackend_VCard : public OContactAccessBackend { 47class OContactAccessBackend_VCard : public OContactAccessBackend {
61 public: 48 public:
62 OContactAccessBackend_VCard ( const QString& appname, const QString& filename = QString::null ); 49 OContactAccessBackend_VCard ( const QString& appname, const QString& filename = QString::null );
63 50
64 bool load (); 51 bool load ();
65 bool reload(); 52 bool reload();
66 bool save(); 53 bool save();
67 void clear (); 54 void clear ();
68 55
69 bool add ( const OContact& newcontact ); 56 bool add ( const OContact& newcontact );
70 bool remove ( int uid ); 57 bool remove ( int uid );
71 bool replace ( const OContact& contact ); 58 bool replace ( const OContact& contact );
72 59
73 OContact find ( int uid ) const; 60 OContact find ( int uid ) const;
74 QArray<int> allRecords() const; 61 QArray<int> allRecords() const;
75 QArray<int> queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() ); 62 QArray<int> queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() );
76 QArray<int> matchRegexp( const QRegExp &r ) const; 63 QArray<int> matchRegexp( const QRegExp &r ) const;
77 64
78 const uint querySettings(); 65 const uint querySettings();
79 bool hasQuerySettings (uint querySettings) const; 66 bool hasQuerySettings (uint querySettings) const;
80 QArray<int> sorted( bool ascending, int sortOrder, int sortFilter, int cat ); 67 QArray<int> sorted( bool ascending, int sortOrder, int sortFilter, int cat );
81 bool wasChangedExternally(); 68 bool wasChangedExternally();
82 69
83private: 70private:
84 OContact parseVObject( VObject* obj ); 71 OContact parseVObject( VObject* obj );
85 VObject* createVObject( const OContact& c ); 72 VObject* createVObject( const OContact& c );
86 QString convDateToVCardDate( const QDate& c ) const; 73 QString convDateToVCardDate( const QDate& c ) const;
87 QDate convVCardDateToDate( const QString& datestr ); 74 QDate convVCardDateToDate( const QString& datestr );
88 VObject *safeAddPropValue( VObject *o, const char* prop, const QString& value ); 75 VObject *safeAddPropValue( VObject *o, const char* prop, const QString& value );
89 VObject *safeAddProp( VObject* o, const char* prop); 76 VObject *safeAddProp( VObject* o, const char* prop);
90 77
91 bool m_dirty : 1; 78 bool m_dirty : 1;
92 QString m_file; 79 QString m_file;
93 QMap<int, OContact> m_map; 80 QMap<int, OContact> m_map;
94}; 81};
95 82
83}
84
96#endif 85#endif
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_xml.cpp b/libopie2/opiepim/backend/ocontactaccessbackend_xml.cpp
index aae7fca..4c3da0c 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_xml.cpp
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_xml.cpp
@@ -1,820 +1,751 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * XML Backend for the OPIE-Contact Database. 30 * XML Backend for the OPIE-Contact Database.
3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 *
6 * =====================================================================
7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 * =====================================================================
12 *
13 * =====================================================================
14 * Version: $Id$
15 * =====================================================================
16 * History:
17 * $Log$
18 * Revision 1.9 2003/09/22 14:31:16 eilers
19 * Added first experimental incarnation of sql-backend for addressbook.
20 * Some modifications to be able to compile the todo sql-backend.
21 * A lot of changes fill follow...
22 *
23 * Revision 1.8 2003/08/30 15:28:26 eilers
24 * Removed some unimportant debug output which causes slow down..
25 *
26 * Revision 1.7 2003/08/01 12:30:16 eilers
27 * Merging changes from BRANCH_1_0 to HEAD
28 *
29 * Revision 1.6 2003/07/07 16:19:47 eilers
30 * Fixing serious bug in hasQuerySettings()
31 *
32 * Revision 1.5 2003/04/13 18:07:10 zecke
33 * More API doc
34 * QString -> const QString&
35 * QString = 0l -> QString::null
36 *
37 * Revision 1.4 2003/03/21 14:32:54 mickeyl
38 * g++ compliance fix: default arguments belong into the declaration, but not the definition
39 *
40 * Revision 1.3 2003/03/21 12:26:28 eilers
41 * Fixing small bug: If we search a birthday from today to today, it returned
42 * every contact ..
43 *
44 * Revision 1.2 2003/03/21 10:33:09 eilers
45 * Merged speed optimized xml backend for contacts to main.
46 * Added QDateTime to querybyexample. For instance, it is now possible to get
47 * all Birthdays/Anniversaries between two dates. This should be used
48 * to show all birthdays in the datebook..
49 * This change is sourcecode backward compatible but you have to upgrade
50 * the binaries for today-addressbook.
51 *
52 * Revision 1.1.2.2 2003/02/11 12:17:28 eilers
53 * Speed optimization. Removed the sequential search loops.
54 *
55 * Revision 1.1.2.1 2003/02/10 15:31:38 eilers
56 * Writing offsets to debug output..
57 *
58 * Revision 1.1 2003/02/09 15:05:01 eilers
59 * Nothing happened.. Just some cleanup before I will start..
60 *
61 * Revision 1.12 2003/01/03 16:58:03 eilers
62 * Reenable debug output
63 *
64 * Revision 1.11 2003/01/03 12:31:28 eilers
65 * Bugfix for calculating data diffs..
66 *
67 * Revision 1.10 2003/01/02 14:27:12 eilers
68 * Improved query by example: Search by date is possible.. First step
69 * for a today plugin for birthdays..
70 *
71 * Revision 1.9 2002/12/08 12:48:57 eilers
72 * Moved journal-enum from ocontact into i the xml-backend..
73 *
74 * Revision 1.8 2002/11/14 17:04:24 eilers
75 * Sorting will now work if fullname is identical on some entries
76 *
77 * Revision 1.7 2002/11/13 15:02:46 eilers
78 * Small Bug in sorted fixed
79 *
80 * Revision 1.6 2002/11/13 14:14:51 eilers
81 * Added sorted for Contacts..
82 *
83 * Revision 1.5 2002/11/01 15:10:42 eilers
84 * Added regExp-search in database for all fields in a contact.
85 *
86 * Revision 1.4 2002/10/16 10:52:40 eilers
87 * Added some docu to the interface and now using the cache infrastucture by zecke.. :)
88 *
89 * Revision 1.3 2002/10/14 16:21:54 eilers
90 * Some minor interface updates
91 *
92 * Revision 1.2 2002/10/07 17:34:24 eilers
93 * added OBackendFactory for advanced backend access
94 *
95 * Revision 1.1 2002/09/27 17:11:44 eilers
96 * Added API for accessing the Contact-Database ! It is compiling, but
97 * please do not expect that anything is working !
98 * I will debug that stuff in the next time ..
99 * Please read README_COMPILE for compiling !
100 *
101 *
102 */ 31 */
103 32
104#include "ocontactaccessbackend_xml.h" 33#include <opie2/ocontactaccessbackend_xml.h>
105 34
106#include <qasciidict.h> 35#include <qasciidict.h>
107#include <qdatetime.h> 36#include <qdatetime.h>
108#include <qfile.h> 37#include <qfile.h>
109#include <qfileinfo.h> 38#include <qfileinfo.h>
110#include <qregexp.h> 39#include <qregexp.h>
111#include <qarray.h> 40#include <qarray.h>
112#include <qmap.h> 41#include <qmap.h>
113#include <qdatetime.h> 42#include <qdatetime.h>
114 43
115#include <qpe/global.h> 44#include <qpe/global.h>
116 45
117#include <opie/xmltree.h> 46#include <opie/xmltree.h>
118#include "ocontactaccessbackend.h" 47#include <opie2/ocontactaccessbackend.h>
119#include "ocontactaccess.h" 48#include <opie2/ocontactaccess.h>
120 49
121#include <stdlib.h> 50#include <stdlib.h>
122#include <errno.h> 51#include <errno.h>
123 52
124using namespace Opie; 53using namespace Opie;
125 54
126 55
56namespace Opie {
127OContactAccessBackend_XML::OContactAccessBackend_XML ( const QString& appname, const QString& filename ): 57OContactAccessBackend_XML::OContactAccessBackend_XML ( const QString& appname, const QString& filename ):
128 m_changed( false ) 58 m_changed( false )
129{ 59{
130 // Just m_contactlist should call delete if an entry 60 // Just m_contactlist should call delete if an entry
131 // is removed. 61 // is removed.
132 m_contactList.setAutoDelete( true ); 62 m_contactList.setAutoDelete( true );
133 m_uidToContact.setAutoDelete( false ); 63 m_uidToContact.setAutoDelete( false );
134 64
135 m_appName = appname; 65 m_appName = appname;
136 66
137 /* Set journalfile name ... */ 67 /* Set journalfile name ... */
138 m_journalName = getenv("HOME"); 68 m_journalName = getenv("HOME");
139 m_journalName +="/.abjournal" + appname; 69 m_journalName +="/.abjournal" + appname;
140 70
141 /* Expecting to access the default filename if nothing else is set */ 71 /* Expecting to access the default filename if nothing else is set */
142 if ( filename.isEmpty() ){ 72 if ( filename.isEmpty() ){
143 m_fileName = Global::applicationFileName( "addressbook","addressbook.xml" ); 73 m_fileName = Global::applicationFileName( "addressbook","addressbook.xml" );
144 } else 74 } else
145 m_fileName = filename; 75 m_fileName = filename;
146 76
147 /* Load Database now */ 77 /* Load Database now */
148 load (); 78 load ();
149} 79}
150 80
151bool OContactAccessBackend_XML::save() 81bool OContactAccessBackend_XML::save()
152{ 82{
153 83
154 if ( !m_changed ) 84 if ( !m_changed )
155 return true; 85 return true;
156 86
157 QString strNewFile = m_fileName + ".new"; 87 QString strNewFile = m_fileName + ".new";
158 QFile f( strNewFile ); 88 QFile f( strNewFile );
159 if ( !f.open( IO_WriteOnly|IO_Raw ) ) 89 if ( !f.open( IO_WriteOnly|IO_Raw ) )
160 return false; 90 return false;
161 91
162 int total_written; 92 int total_written;
163 int idx_offset = 0; 93 int idx_offset = 0;
164 QString out; 94 QString out;
165 95
166 // Write Header 96 // Write Header
167 out = "<?xml version=\"1.0\" encoding=\"UTF-8\"?><!DOCTYPE Addressbook ><AddressBook>\n" 97 out = "<?xml version=\"1.0\" encoding=\"UTF-8\"?><!DOCTYPE Addressbook ><AddressBook>\n"
168 " <Groups>\n" 98 " <Groups>\n"
169 " </Groups>\n" 99 " </Groups>\n"
170 " <Contacts>\n"; 100 " <Contacts>\n";
171 QCString cstr = out.utf8(); 101 QCString cstr = out.utf8();
172 f.writeBlock( cstr.data(), cstr.length() ); 102 f.writeBlock( cstr.data(), cstr.length() );
173 idx_offset += cstr.length(); 103 idx_offset += cstr.length();
174 out = ""; 104 out = "";
175 105
176 // Write all contacts 106 // Write all contacts
177 QListIterator<OContact> it( m_contactList ); 107 QListIterator<OContact> it( m_contactList );
178 for ( ; it.current(); ++it ) { 108 for ( ; it.current(); ++it ) {
179 // qWarning(" Uid %d at Offset: %x", (*it)->uid(), idx_offset ); 109 // qWarning(" Uid %d at Offset: %x", (*it)->uid(), idx_offset );
180 out += "<Contact "; 110 out += "<Contact ";
181 (*it)->save( out ); 111 (*it)->save( out );
182 out += "/>\n"; 112 out += "/>\n";
183 cstr = out.utf8(); 113 cstr = out.utf8();
184 total_written = f.writeBlock( cstr.data(), cstr.length() ); 114 total_written = f.writeBlock( cstr.data(), cstr.length() );
185 idx_offset += cstr.length(); 115 idx_offset += cstr.length();
186 if ( total_written != int(cstr.length()) ) { 116 if ( total_written != int(cstr.length()) ) {
187 f.close(); 117 f.close();
188 QFile::remove( strNewFile ); 118 QFile::remove( strNewFile );
189 return false; 119 return false;
190 } 120 }
191 out = ""; 121 out = "";
192 } 122 }
193 out += " </Contacts>\n</AddressBook>\n"; 123 out += " </Contacts>\n</AddressBook>\n";
194 124
195 // Write Footer 125 // Write Footer
196 cstr = out.utf8(); 126 cstr = out.utf8();
197 total_written = f.writeBlock( cstr.data(), cstr.length() ); 127 total_written = f.writeBlock( cstr.data(), cstr.length() );
198 if ( total_written != int( cstr.length() ) ) { 128 if ( total_written != int( cstr.length() ) ) {
199 f.close(); 129 f.close();
200 QFile::remove( strNewFile ); 130 QFile::remove( strNewFile );
201 return false; 131 return false;
202 } 132 }
203 f.close(); 133 f.close();
204 134
205 // move the file over, I'm just going to use the system call 135 // move the file over, I'm just going to use the system call
206 // because, I don't feel like using QDir. 136 // because, I don't feel like using QDir.
207 if ( ::rename( strNewFile.latin1(), m_fileName.latin1() ) < 0 ) { 137 if ( ::rename( strNewFile.latin1(), m_fileName.latin1() ) < 0 ) {
208 qWarning( "problem renaming file %s to %s, errno: %d", 138 qWarning( "problem renaming file %s to %s, errno: %d",
209 strNewFile.latin1(), m_journalName.latin1(), errno ); 139 strNewFile.latin1(), m_journalName.latin1(), errno );
210 // remove the tmp file... 140 // remove the tmp file...
211 QFile::remove( strNewFile ); 141 QFile::remove( strNewFile );
212 } 142 }
213 143
214 /* The journalfile should be removed now... */ 144 /* The journalfile should be removed now... */
215 removeJournal(); 145 removeJournal();
216 146
217 m_changed = false; 147 m_changed = false;
218 return true; 148 return true;
219} 149}
220 150
221bool OContactAccessBackend_XML::load () 151bool OContactAccessBackend_XML::load ()
222{ 152{
223 m_contactList.clear(); 153 m_contactList.clear();
224 m_uidToContact.clear(); 154 m_uidToContact.clear();
225 155
226 /* Load XML-File and journal if it exists */ 156 /* Load XML-File and journal if it exists */
227 if ( !load ( m_fileName, false ) ) 157 if ( !load ( m_fileName, false ) )
228 return false; 158 return false;
229 /* The returncode of the journalfile is ignored due to the 159 /* The returncode of the journalfile is ignored due to the
230 * fact that it does not exist when this class is instantiated ! 160 * fact that it does not exist when this class is instantiated !
231 * But there may such a file exist, if the application crashed. 161 * But there may such a file exist, if the application crashed.
232 * Therefore we try to load it to get the changes before the # 162 * Therefore we try to load it to get the changes before the #
233 * crash happened... 163 * crash happened...
234 */ 164 */
235 load (m_journalName, true); 165 load (m_journalName, true);
236 166
237 return true; 167 return true;
238} 168}
239 169
240void OContactAccessBackend_XML::clear () 170void OContactAccessBackend_XML::clear ()
241{ 171{
242 m_contactList.clear(); 172 m_contactList.clear();
243 m_uidToContact.clear(); 173 m_uidToContact.clear();
244 174
245 m_changed = false; 175 m_changed = false;
246} 176}
247 177
248bool OContactAccessBackend_XML::wasChangedExternally() 178bool OContactAccessBackend_XML::wasChangedExternally()
249{ 179{
250 QFileInfo fi( m_fileName ); 180 QFileInfo fi( m_fileName );
251 181
252 QDateTime lastmod = fi.lastModified (); 182 QDateTime lastmod = fi.lastModified ();
253 183
254 return (lastmod != m_readtime); 184 return (lastmod != m_readtime);
255} 185}
256 186
257QArray<int> OContactAccessBackend_XML::allRecords() const 187QArray<int> OContactAccessBackend_XML::allRecords() const
258{ 188{
259 QArray<int> uid_list( m_contactList.count() ); 189 QArray<int> uid_list( m_contactList.count() );
260 190
261 uint counter = 0; 191 uint counter = 0;
262 QListIterator<OContact> it( m_contactList ); 192 QListIterator<OContact> it( m_contactList );
263 for( ; it.current(); ++it ){ 193 for( ; it.current(); ++it ){
264 uid_list[counter++] = (*it)->uid(); 194 uid_list[counter++] = (*it)->uid();
265 } 195 }
266 196
267 return ( uid_list ); 197 return ( uid_list );
268} 198}
269 199
270OContact OContactAccessBackend_XML::find ( int uid ) const 200OContact OContactAccessBackend_XML::find ( int uid ) const
271{ 201{
272 OContact foundContact; //Create empty contact 202 OContact foundContact; //Create empty contact
273 203
274 OContact* found = m_uidToContact.find( QString().setNum( uid ) ); 204 OContact* found = m_uidToContact.find( QString().setNum( uid ) );
275 205
276 if ( found ){ 206 if ( found ){
277 foundContact = *found; 207 foundContact = *found;
278 } 208 }
279 209
280 return ( foundContact ); 210 return ( foundContact );
281} 211}
282 212
283QArray<int> OContactAccessBackend_XML::queryByExample ( const OContact &query, int settings, 213QArray<int> OContactAccessBackend_XML::queryByExample ( const OContact &query, int settings,
284 const QDateTime& d ) 214 const QDateTime& d )
285{ 215{
286 216
287 QArray<int> m_currentQuery( m_contactList.count() ); 217 QArray<int> m_currentQuery( m_contactList.count() );
288 QListIterator<OContact> it( m_contactList ); 218 QListIterator<OContact> it( m_contactList );
289 uint arraycounter = 0; 219 uint arraycounter = 0;
290 220
291 for( ; it.current(); ++it ){ 221 for( ; it.current(); ++it ){
292 /* Search all fields and compare them with query object. Store them into list 222 /* Search all fields and compare them with query object. Store them into list
293 * if all fields matches. 223 * if all fields matches.
294 */ 224 */
295 QDate* queryDate = 0l; 225 QDate* queryDate = 0l;
296 QDate* checkDate = 0l; 226 QDate* checkDate = 0l;
297 bool allcorrect = true; 227 bool allcorrect = true;
298 for ( int i = 0; i < Qtopia::Groups; i++ ) { 228 for ( int i = 0; i < Qtopia::Groups; i++ ) {
299 // Birthday and anniversary are special nonstring fields and should 229 // Birthday and anniversary are special nonstring fields and should
300 // be handled specially 230 // be handled specially
301 switch ( i ){ 231 switch ( i ){
302 case Qtopia::Birthday: 232 case Qtopia::Birthday:
303 queryDate = new QDate( query.birthday() ); 233 queryDate = new QDate( query.birthday() );
304 checkDate = new QDate( (*it)->birthday() ); 234 checkDate = new QDate( (*it)->birthday() );
305 case Qtopia::Anniversary: 235 case Qtopia::Anniversary:
306 if ( queryDate == 0l ){ 236 if ( queryDate == 0l ){
307 queryDate = new QDate( query.anniversary() ); 237 queryDate = new QDate( query.anniversary() );
308 checkDate = new QDate( (*it)->anniversary() ); 238 checkDate = new QDate( (*it)->anniversary() );
309 } 239 }
310 240
311 if ( queryDate->isValid() ){ 241 if ( queryDate->isValid() ){
312 if( checkDate->isValid() ){ 242 if( checkDate->isValid() ){
313 if ( settings & OContactAccess::DateYear ){ 243 if ( settings & OContactAccess::DateYear ){
314 if ( queryDate->year() != checkDate->year() ) 244 if ( queryDate->year() != checkDate->year() )
315 allcorrect = false; 245 allcorrect = false;
316 } 246 }
317 if ( settings & OContactAccess::DateMonth ){ 247 if ( settings & OContactAccess::DateMonth ){
318 if ( queryDate->month() != checkDate->month() ) 248 if ( queryDate->month() != checkDate->month() )
319 allcorrect = false; 249 allcorrect = false;
320 } 250 }
321 if ( settings & OContactAccess::DateDay ){ 251 if ( settings & OContactAccess::DateDay ){
322 if ( queryDate->day() != checkDate->day() ) 252 if ( queryDate->day() != checkDate->day() )
323 allcorrect = false; 253 allcorrect = false;
324 } 254 }
325 if ( settings & OContactAccess::DateDiff ) { 255 if ( settings & OContactAccess::DateDiff ) {
326 QDate current; 256 QDate current;
327 // If we get an additional date, we 257 // If we get an additional date, we
328 // will take this date instead of 258 // will take this date instead of
329 // the current one.. 259 // the current one..
330 if ( !d.date().isValid() ) 260 if ( !d.date().isValid() )
331 current = QDate::currentDate(); 261 current = QDate::currentDate();
332 else 262 else
333 current = d.date(); 263 current = d.date();
334 264
335 // We have to equalize the year, otherwise 265 // We have to equalize the year, otherwise
336 // the search will fail.. 266 // the search will fail..
337 checkDate->setYMD( current.year(), 267 checkDate->setYMD( current.year(),
338 checkDate->month(), 268 checkDate->month(),
339 checkDate->day() ); 269 checkDate->day() );
340 if ( *checkDate < current ) 270 if ( *checkDate < current )
341 checkDate->setYMD( current.year()+1, 271 checkDate->setYMD( current.year()+1,
342 checkDate->month(), 272 checkDate->month(),
343 checkDate->day() ); 273 checkDate->day() );
344 274
345 // Check whether the birthday/anniversary date is between 275 // Check whether the birthday/anniversary date is between
346 // the current/given date and the maximum date 276 // the current/given date and the maximum date
347 // ( maximum time range ) ! 277 // ( maximum time range ) !
348 qWarning("Checking if %s is between %s and %s ! ", 278 qWarning("Checking if %s is between %s and %s ! ",
349 checkDate->toString().latin1(), 279 checkDate->toString().latin1(),
350 current.toString().latin1(), 280 current.toString().latin1(),
351 queryDate->toString().latin1() ); 281 queryDate->toString().latin1() );
352 if ( current.daysTo( *queryDate ) >= 0 ){ 282 if ( current.daysTo( *queryDate ) >= 0 ){
353 if ( !( ( *checkDate >= current ) && 283 if ( !( ( *checkDate >= current ) &&
354 ( *checkDate <= *queryDate ) ) ){ 284 ( *checkDate <= *queryDate ) ) ){
355 allcorrect = false; 285 allcorrect = false;
356 qWarning (" Nope!.."); 286 qWarning (" Nope!..");
357 } 287 }
358 } 288 }
359 } 289 }
360 } else{ 290 } else{
361 // checkDate is invalid. Therefore this entry is always rejected 291 // checkDate is invalid. Therefore this entry is always rejected
362 allcorrect = false; 292 allcorrect = false;
363 } 293 }
364 } 294 }
365 295
366 delete queryDate; 296 delete queryDate;
367 queryDate = 0l; 297 queryDate = 0l;
368 delete checkDate; 298 delete checkDate;
369 checkDate = 0l; 299 checkDate = 0l;
370 break; 300 break;
371 default: 301 default:
372 /* Just compare fields which are not empty in the query object */ 302 /* Just compare fields which are not empty in the query object */
373 if ( !query.field(i).isEmpty() ){ 303 if ( !query.field(i).isEmpty() ){
374 switch ( settings & ~( OContactAccess::IgnoreCase 304 switch ( settings & ~( OContactAccess::IgnoreCase
375 | OContactAccess::DateDiff 305 | OContactAccess::DateDiff
376 | OContactAccess::DateYear 306 | OContactAccess::DateYear
377 | OContactAccess::DateMonth 307 | OContactAccess::DateMonth
378 | OContactAccess::DateDay 308 | OContactAccess::DateDay
379 | OContactAccess::MatchOne 309 | OContactAccess::MatchOne
380 ) ){ 310 ) ){
381 311
382 case OContactAccess::RegExp:{ 312 case OContactAccess::RegExp:{
383 QRegExp expr ( query.field(i), 313 QRegExp expr ( query.field(i),
384 !(settings & OContactAccess::IgnoreCase), 314 !(settings & OContactAccess::IgnoreCase),
385 false ); 315 false );
386 if ( expr.find ( (*it)->field(i), 0 ) == -1 ) 316 if ( expr.find ( (*it)->field(i), 0 ) == -1 )
387 allcorrect = false; 317 allcorrect = false;
388 } 318 }
389 break; 319 break;
390 case OContactAccess::WildCards:{ 320 case OContactAccess::WildCards:{
391 QRegExp expr ( query.field(i), 321 QRegExp expr ( query.field(i),
392 !(settings & OContactAccess::IgnoreCase), 322 !(settings & OContactAccess::IgnoreCase),
393 true ); 323 true );
394 if ( expr.find ( (*it)->field(i), 0 ) == -1 ) 324 if ( expr.find ( (*it)->field(i), 0 ) == -1 )
395 allcorrect = false; 325 allcorrect = false;
396 } 326 }
397 break; 327 break;
398 case OContactAccess::ExactMatch:{ 328 case OContactAccess::ExactMatch:{
399 if (settings & OContactAccess::IgnoreCase){ 329 if (settings & OContactAccess::IgnoreCase){
400 if ( query.field(i).upper() != 330 if ( query.field(i).upper() !=
401 (*it)->field(i).upper() ) 331 (*it)->field(i).upper() )
402 allcorrect = false; 332 allcorrect = false;
403 }else{ 333 }else{
404 if ( query.field(i) != (*it)->field(i) ) 334 if ( query.field(i) != (*it)->field(i) )
405 allcorrect = false; 335 allcorrect = false;
406 } 336 }
407 } 337 }
408 break; 338 break;
409 } 339 }
410 } 340 }
411 } 341 }
412 } 342 }
413 if ( allcorrect ){ 343 if ( allcorrect ){
414 m_currentQuery[arraycounter++] = (*it)->uid(); 344 m_currentQuery[arraycounter++] = (*it)->uid();
415 } 345 }
416 } 346 }
417 347
418 // Shrink to fit.. 348 // Shrink to fit..
419 m_currentQuery.resize(arraycounter); 349 m_currentQuery.resize(arraycounter);
420 350
421 return m_currentQuery; 351 return m_currentQuery;
422} 352}
423 353
424QArray<int> OContactAccessBackend_XML::matchRegexp( const QRegExp &r ) const 354QArray<int> OContactAccessBackend_XML::matchRegexp( const QRegExp &r ) const
425{ 355{
426 QArray<int> m_currentQuery( m_contactList.count() ); 356 QArray<int> m_currentQuery( m_contactList.count() );
427 QListIterator<OContact> it( m_contactList ); 357 QListIterator<OContact> it( m_contactList );
428 uint arraycounter = 0; 358 uint arraycounter = 0;
429 359
430 for( ; it.current(); ++it ){ 360 for( ; it.current(); ++it ){
431 if ( (*it)->match( r ) ){ 361 if ( (*it)->match( r ) ){
432 m_currentQuery[arraycounter++] = (*it)->uid(); 362 m_currentQuery[arraycounter++] = (*it)->uid();
433 } 363 }
434 364
435 } 365 }
436 // Shrink to fit.. 366 // Shrink to fit..
437 m_currentQuery.resize(arraycounter); 367 m_currentQuery.resize(arraycounter);
438 368
439 return m_currentQuery; 369 return m_currentQuery;
440} 370}
441 371
442const uint OContactAccessBackend_XML::querySettings() 372const uint OContactAccessBackend_XML::querySettings()
443{ 373{
444 return ( OContactAccess::WildCards 374 return ( OContactAccess::WildCards
445 | OContactAccess::IgnoreCase 375 | OContactAccess::IgnoreCase
446 | OContactAccess::RegExp 376 | OContactAccess::RegExp
447 | OContactAccess::ExactMatch 377 | OContactAccess::ExactMatch
448 | OContactAccess::DateDiff 378 | OContactAccess::DateDiff
449 | OContactAccess::DateYear 379 | OContactAccess::DateYear
450 | OContactAccess::DateMonth 380 | OContactAccess::DateMonth
451 | OContactAccess::DateDay 381 | OContactAccess::DateDay
452 ); 382 );
453} 383}
454 384
455bool OContactAccessBackend_XML::hasQuerySettings (uint querySettings) const 385bool OContactAccessBackend_XML::hasQuerySettings (uint querySettings) const
456{ 386{
457 /* OContactAccess::IgnoreCase, DateDiff, DateYear, DateMonth, DateDay 387 /* OContactAccess::IgnoreCase, DateDiff, DateYear, DateMonth, DateDay
458 * may be added with any of the other settings. IgnoreCase should never used alone. 388 * may be added with any of the other settings. IgnoreCase should never used alone.
459 * Wildcards, RegExp, ExactMatch should never used at the same time... 389 * Wildcards, RegExp, ExactMatch should never used at the same time...
460 */ 390 */
461 391
462 // Step 1: Check whether the given settings are supported by this backend 392 // Step 1: Check whether the given settings are supported by this backend
463 if ( ( querySettings & ( 393 if ( ( querySettings & (
464 OContactAccess::IgnoreCase 394 OContactAccess::IgnoreCase
465 | OContactAccess::WildCards 395 | OContactAccess::WildCards
466 | OContactAccess::DateDiff 396 | OContactAccess::DateDiff
467 | OContactAccess::DateYear 397 | OContactAccess::DateYear
468 | OContactAccess::DateMonth 398 | OContactAccess::DateMonth
469 | OContactAccess::DateDay 399 | OContactAccess::DateDay
470 | OContactAccess::RegExp 400 | OContactAccess::RegExp
471 | OContactAccess::ExactMatch 401 | OContactAccess::ExactMatch
472 ) ) != querySettings ) 402 ) ) != querySettings )
473 return false; 403 return false;
474 404
475 // Step 2: Check whether the given combinations are ok.. 405 // Step 2: Check whether the given combinations are ok..
476 406
477 // IngoreCase alone is invalid 407 // IngoreCase alone is invalid
478 if ( querySettings == OContactAccess::IgnoreCase ) 408 if ( querySettings == OContactAccess::IgnoreCase )
479 return false; 409 return false;
480 410
481 // WildCards, RegExp and ExactMatch should never used at the same time 411 // WildCards, RegExp and ExactMatch should never used at the same time
482 switch ( querySettings & ~( OContactAccess::IgnoreCase 412 switch ( querySettings & ~( OContactAccess::IgnoreCase
483 | OContactAccess::DateDiff 413 | OContactAccess::DateDiff
484 | OContactAccess::DateYear 414 | OContactAccess::DateYear
485 | OContactAccess::DateMonth 415 | OContactAccess::DateMonth
486 | OContactAccess::DateDay 416 | OContactAccess::DateDay
487 ) 417 )
488 ){ 418 ){
489 case OContactAccess::RegExp: 419 case OContactAccess::RegExp:
490 return ( true ); 420 return ( true );
491 case OContactAccess::WildCards: 421 case OContactAccess::WildCards:
492 return ( true ); 422 return ( true );
493 case OContactAccess::ExactMatch: 423 case OContactAccess::ExactMatch:
494 return ( true ); 424 return ( true );
495 case 0: // one of the upper removed bits were set.. 425 case 0: // one of the upper removed bits were set..
496 return ( true ); 426 return ( true );
497 default: 427 default:
498 return ( false ); 428 return ( false );
499 } 429 }
500} 430}
501 431
502// Currently only asc implemented.. 432// Currently only asc implemented..
503QArray<int> OContactAccessBackend_XML::sorted( bool asc, int , int , int ) 433QArray<int> OContactAccessBackend_XML::sorted( bool asc, int , int , int )
504{ 434{
505 QMap<QString, int> nameToUid; 435 QMap<QString, int> nameToUid;
506 QStringList names; 436 QStringList names;
507 QArray<int> m_currentQuery( m_contactList.count() ); 437 QArray<int> m_currentQuery( m_contactList.count() );
508 438
509 // First fill map and StringList with all Names 439 // First fill map and StringList with all Names
510 // Afterwards sort namelist and use map to fill array to return.. 440 // Afterwards sort namelist and use map to fill array to return..
511 QListIterator<OContact> it( m_contactList ); 441 QListIterator<OContact> it( m_contactList );
512 for( ; it.current(); ++it ){ 442 for( ; it.current(); ++it ){
513 names.append( (*it)->fileAs() + QString::number( (*it)->uid() ) ); 443 names.append( (*it)->fileAs() + QString::number( (*it)->uid() ) );
514 nameToUid.insert( (*it)->fileAs() + QString::number( (*it)->uid() ), (*it)->uid() ); 444 nameToUid.insert( (*it)->fileAs() + QString::number( (*it)->uid() ), (*it)->uid() );
515 } 445 }
516 names.sort(); 446 names.sort();
517 447
518 int i = 0; 448 int i = 0;
519 if ( asc ){ 449 if ( asc ){
520 for ( QStringList::Iterator it = names.begin(); it != names.end(); ++it ) 450 for ( QStringList::Iterator it = names.begin(); it != names.end(); ++it )
521 m_currentQuery[i++] = nameToUid[ (*it) ]; 451 m_currentQuery[i++] = nameToUid[ (*it) ];
522 }else{ 452 }else{
523 for ( QStringList::Iterator it = names.end(); it != names.begin(); --it ) 453 for ( QStringList::Iterator it = names.end(); it != names.begin(); --it )
524 m_currentQuery[i++] = nameToUid[ (*it) ]; 454 m_currentQuery[i++] = nameToUid[ (*it) ];
525 } 455 }
526 456
527 return m_currentQuery; 457 return m_currentQuery;
528 458
529} 459}
530 460
531bool OContactAccessBackend_XML::add ( const OContact &newcontact ) 461bool OContactAccessBackend_XML::add ( const OContact &newcontact )
532{ 462{
533 //qWarning("odefaultbackend: ACTION::ADD"); 463 //qWarning("odefaultbackend: ACTION::ADD");
534 updateJournal (newcontact, ACTION_ADD); 464 updateJournal (newcontact, ACTION_ADD);
535 addContact_p( newcontact ); 465 addContact_p( newcontact );
536 466
537 m_changed = true; 467 m_changed = true;
538 468
539 return true; 469 return true;
540} 470}
541 471
542bool OContactAccessBackend_XML::replace ( const OContact &contact ) 472bool OContactAccessBackend_XML::replace ( const OContact &contact )
543{ 473{
544 m_changed = true; 474 m_changed = true;
545 475
546 OContact* found = m_uidToContact.find ( QString().setNum( contact.uid() ) ); 476 OContact* found = m_uidToContact.find ( QString().setNum( contact.uid() ) );
547 477
548 if ( found ) { 478 if ( found ) {
549 OContact* newCont = new OContact( contact ); 479 OContact* newCont = new OContact( contact );
550 480
551 updateJournal ( *newCont, ACTION_REPLACE); 481 updateJournal ( *newCont, ACTION_REPLACE);
552 m_contactList.removeRef ( found ); 482 m_contactList.removeRef ( found );
553 m_contactList.append ( newCont ); 483 m_contactList.append ( newCont );
554 m_uidToContact.remove( QString().setNum( contact.uid() ) ); 484 m_uidToContact.remove( QString().setNum( contact.uid() ) );
555 m_uidToContact.insert( QString().setNum( newCont->uid() ), newCont ); 485 m_uidToContact.insert( QString().setNum( newCont->uid() ), newCont );
556 486
557 qWarning("Nur zur Sicherheit: %d == %d ?",contact.uid(), newCont->uid()); 487 qWarning("Nur zur Sicherheit: %d == %d ?",contact.uid(), newCont->uid());
558 488
559 return true; 489 return true;
560 } else 490 } else
561 return false; 491 return false;
562} 492}
563 493
564bool OContactAccessBackend_XML::remove ( int uid ) 494bool OContactAccessBackend_XML::remove ( int uid )
565{ 495{
566 m_changed = true; 496 m_changed = true;
567 497
568 OContact* found = m_uidToContact.find ( QString().setNum( uid ) ); 498 OContact* found = m_uidToContact.find ( QString().setNum( uid ) );
569 499
570 if ( found ) { 500 if ( found ) {
571 updateJournal ( *found, ACTION_REMOVE); 501 updateJournal ( *found, ACTION_REMOVE);
572 m_contactList.removeRef ( found ); 502 m_contactList.removeRef ( found );
573 m_uidToContact.remove( QString().setNum( uid ) ); 503 m_uidToContact.remove( QString().setNum( uid ) );
574 504
575 return true; 505 return true;
576 } else 506 } else
577 return false; 507 return false;
578} 508}
579 509
580bool OContactAccessBackend_XML::reload(){ 510bool OContactAccessBackend_XML::reload(){
581 /* Reload is the same as load in this implementation */ 511 /* Reload is the same as load in this implementation */
582 return ( load() ); 512 return ( load() );
583} 513}
584 514
585void OContactAccessBackend_XML::addContact_p( const OContact &newcontact ) 515void OContactAccessBackend_XML::addContact_p( const OContact &newcontact )
586{ 516{
587 OContact* contRef = new OContact( newcontact ); 517 OContact* contRef = new OContact( newcontact );
588 518
589 m_contactList.append ( contRef ); 519 m_contactList.append ( contRef );
590 m_uidToContact.insert( QString().setNum( newcontact.uid() ), contRef ); 520 m_uidToContact.insert( QString().setNum( newcontact.uid() ), contRef );
591} 521}
592 522
593/* This function loads the xml-database and the journalfile */ 523/* This function loads the xml-database and the journalfile */
594bool OContactAccessBackend_XML::load( const QString filename, bool isJournal ) 524bool OContactAccessBackend_XML::load( const QString filename, bool isJournal )
595{ 525{
596 526
597 /* We use the time of the last read to check if the file was 527 /* We use the time of the last read to check if the file was
598 * changed externally. 528 * changed externally.
599 */ 529 */
600 if ( !isJournal ){ 530 if ( !isJournal ){
601 QFileInfo fi( filename ); 531 QFileInfo fi( filename );
602 m_readtime = fi.lastModified (); 532 m_readtime = fi.lastModified ();
603 } 533 }
604 534
605 const int JOURNALACTION = Qtopia::Notes + 1; 535 const int JOURNALACTION = Qtopia::Notes + 1;
606 const int JOURNALROW = JOURNALACTION + 1; 536 const int JOURNALROW = JOURNALACTION + 1;
607 537
608 bool foundAction = false; 538 bool foundAction = false;
609 journal_action action = ACTION_ADD; 539 journal_action action = ACTION_ADD;
610 int journalKey = 0; 540 int journalKey = 0;
611 QMap<int, QString> contactMap; 541 QMap<int, QString> contactMap;
612 QMap<QString, QString> customMap; 542 QMap<QString, QString> customMap;
613 QMap<QString, QString>::Iterator customIt; 543 QMap<QString, QString>::Iterator customIt;
614 QAsciiDict<int> dict( 47 ); 544 QAsciiDict<int> dict( 47 );
615 545
616 dict.setAutoDelete( TRUE ); 546 dict.setAutoDelete( TRUE );
617 dict.insert( "Uid", new int(Qtopia::AddressUid) ); 547 dict.insert( "Uid", new int(Qtopia::AddressUid) );
618 dict.insert( "Title", new int(Qtopia::Title) ); 548 dict.insert( "Title", new int(Qtopia::Title) );
619 dict.insert( "FirstName", new int(Qtopia::FirstName) ); 549 dict.insert( "FirstName", new int(Qtopia::FirstName) );
620 dict.insert( "MiddleName", new int(Qtopia::MiddleName) ); 550 dict.insert( "MiddleName", new int(Qtopia::MiddleName) );
621 dict.insert( "LastName", new int(Qtopia::LastName) ); 551 dict.insert( "LastName", new int(Qtopia::LastName) );
622 dict.insert( "Suffix", new int(Qtopia::Suffix) ); 552 dict.insert( "Suffix", new int(Qtopia::Suffix) );
623 dict.insert( "FileAs", new int(Qtopia::FileAs) ); 553 dict.insert( "FileAs", new int(Qtopia::FileAs) );
624 dict.insert( "Categories", new int(Qtopia::AddressCategory) ); 554 dict.insert( "Categories", new int(Qtopia::AddressCategory) );
625 dict.insert( "DefaultEmail", new int(Qtopia::DefaultEmail) ); 555 dict.insert( "DefaultEmail", new int(Qtopia::DefaultEmail) );
626 dict.insert( "Emails", new int(Qtopia::Emails) ); 556 dict.insert( "Emails", new int(Qtopia::Emails) );
627 dict.insert( "HomeStreet", new int(Qtopia::HomeStreet) ); 557 dict.insert( "HomeStreet", new int(Qtopia::HomeStreet) );
628 dict.insert( "HomeCity", new int(Qtopia::HomeCity) ); 558 dict.insert( "HomeCity", new int(Qtopia::HomeCity) );
629 dict.insert( "HomeState", new int(Qtopia::HomeState) ); 559 dict.insert( "HomeState", new int(Qtopia::HomeState) );
630 dict.insert( "HomeZip", new int(Qtopia::HomeZip) ); 560 dict.insert( "HomeZip", new int(Qtopia::HomeZip) );
631 dict.insert( "HomeCountry", new int(Qtopia::HomeCountry) ); 561 dict.insert( "HomeCountry", new int(Qtopia::HomeCountry) );
632 dict.insert( "HomePhone", new int(Qtopia::HomePhone) ); 562 dict.insert( "HomePhone", new int(Qtopia::HomePhone) );
633 dict.insert( "HomeFax", new int(Qtopia::HomeFax) ); 563 dict.insert( "HomeFax", new int(Qtopia::HomeFax) );
634 dict.insert( "HomeMobile", new int(Qtopia::HomeMobile) ); 564 dict.insert( "HomeMobile", new int(Qtopia::HomeMobile) );
635 dict.insert( "HomeWebPage", new int(Qtopia::HomeWebPage) ); 565 dict.insert( "HomeWebPage", new int(Qtopia::HomeWebPage) );
636 dict.insert( "Company", new int(Qtopia::Company) ); 566 dict.insert( "Company", new int(Qtopia::Company) );
637 dict.insert( "BusinessStreet", new int(Qtopia::BusinessStreet) ); 567 dict.insert( "BusinessStreet", new int(Qtopia::BusinessStreet) );
638 dict.insert( "BusinessCity", new int(Qtopia::BusinessCity) ); 568 dict.insert( "BusinessCity", new int(Qtopia::BusinessCity) );
639 dict.insert( "BusinessState", new int(Qtopia::BusinessState) ); 569 dict.insert( "BusinessState", new int(Qtopia::BusinessState) );
640 dict.insert( "BusinessZip", new int(Qtopia::BusinessZip) ); 570 dict.insert( "BusinessZip", new int(Qtopia::BusinessZip) );
641 dict.insert( "BusinessCountry", new int(Qtopia::BusinessCountry) ); 571 dict.insert( "BusinessCountry", new int(Qtopia::BusinessCountry) );
642 dict.insert( "BusinessWebPage", new int(Qtopia::BusinessWebPage) ); 572 dict.insert( "BusinessWebPage", new int(Qtopia::BusinessWebPage) );
643 dict.insert( "JobTitle", new int(Qtopia::JobTitle) ); 573 dict.insert( "JobTitle", new int(Qtopia::JobTitle) );
644 dict.insert( "Department", new int(Qtopia::Department) ); 574 dict.insert( "Department", new int(Qtopia::Department) );
645 dict.insert( "Office", new int(Qtopia::Office) ); 575 dict.insert( "Office", new int(Qtopia::Office) );
646 dict.insert( "BusinessPhone", new int(Qtopia::BusinessPhone) ); 576 dict.insert( "BusinessPhone", new int(Qtopia::BusinessPhone) );
647 dict.insert( "BusinessFax", new int(Qtopia::BusinessFax) ); 577 dict.insert( "BusinessFax", new int(Qtopia::BusinessFax) );
648 dict.insert( "BusinessMobile", new int(Qtopia::BusinessMobile) ); 578 dict.insert( "BusinessMobile", new int(Qtopia::BusinessMobile) );
649 dict.insert( "BusinessPager", new int(Qtopia::BusinessPager) ); 579 dict.insert( "BusinessPager", new int(Qtopia::BusinessPager) );
650 dict.insert( "Profession", new int(Qtopia::Profession) ); 580 dict.insert( "Profession", new int(Qtopia::Profession) );
651 dict.insert( "Assistant", new int(Qtopia::Assistant) ); 581 dict.insert( "Assistant", new int(Qtopia::Assistant) );
652 dict.insert( "Manager", new int(Qtopia::Manager) ); 582 dict.insert( "Manager", new int(Qtopia::Manager) );
653 dict.insert( "Spouse", new int(Qtopia::Spouse) ); 583 dict.insert( "Spouse", new int(Qtopia::Spouse) );
654 dict.insert( "Children", new int(Qtopia::Children) ); 584 dict.insert( "Children", new int(Qtopia::Children) );
655 dict.insert( "Gender", new int(Qtopia::Gender) ); 585 dict.insert( "Gender", new int(Qtopia::Gender) );
656 dict.insert( "Birthday", new int(Qtopia::Birthday) ); 586 dict.insert( "Birthday", new int(Qtopia::Birthday) );
657 dict.insert( "Anniversary", new int(Qtopia::Anniversary) ); 587 dict.insert( "Anniversary", new int(Qtopia::Anniversary) );
658 dict.insert( "Nickname", new int(Qtopia::Nickname) ); 588 dict.insert( "Nickname", new int(Qtopia::Nickname) );
659 dict.insert( "Notes", new int(Qtopia::Notes) ); 589 dict.insert( "Notes", new int(Qtopia::Notes) );
660 dict.insert( "action", new int(JOURNALACTION) ); 590 dict.insert( "action", new int(JOURNALACTION) );
661 dict.insert( "actionrow", new int(JOURNALROW) ); 591 dict.insert( "actionrow", new int(JOURNALROW) );
662 592
663 //qWarning( "OContactDefaultBackEnd::loading %s", filename.latin1() ); 593 //qWarning( "OContactDefaultBackEnd::loading %s", filename.latin1() );
664 594
665 XMLElement *root = XMLElement::load( filename ); 595 XMLElement *root = XMLElement::load( filename );
666 if(root != 0l ){ // start parsing 596 if(root != 0l ){ // start parsing
667 /* Parse all XML-Elements and put the data into the 597 /* Parse all XML-Elements and put the data into the
668 * Contact-Class 598 * Contact-Class
669 */ 599 */
670 XMLElement *element = root->firstChild(); 600 XMLElement *element = root->firstChild();
671 //qWarning("OContactAccess::load tagName(): %s", root->tagName().latin1() ); 601 //qWarning("OContactAccess::load tagName(): %s", root->tagName().latin1() );
672 element = element->firstChild(); 602 element = element->firstChild();
673 603
674 /* Search Tag "Contacts" which is the parent of all Contacts */ 604 /* Search Tag "Contacts" which is the parent of all Contacts */
675 while( element && !isJournal ){ 605 while( element && !isJournal ){
676 if( element->tagName() != QString::fromLatin1("Contacts") ){ 606 if( element->tagName() != QString::fromLatin1("Contacts") ){
677 //qWarning ("OContactDefBack::Searching for Tag \"Contacts\"! Found: %s", 607 //qWarning ("OContactDefBack::Searching for Tag \"Contacts\"! Found: %s",
678 // element->tagName().latin1()); 608 // element->tagName().latin1());
679 element = element->nextChild(); 609 element = element->nextChild();
680 } else { 610 } else {
681 element = element->firstChild(); 611 element = element->firstChild();
682 break; 612 break;
683 } 613 }
684 } 614 }
685 /* Parse all Contacts and ignore unknown tags */ 615 /* Parse all Contacts and ignore unknown tags */
686 while( element ){ 616 while( element ){
687 if( element->tagName() != QString::fromLatin1("Contact") ){ 617 if( element->tagName() != QString::fromLatin1("Contact") ){
688 //qWarning ("OContactDefBack::Searching for Tag \"Contact\"! Found: %s", 618 //qWarning ("OContactDefBack::Searching for Tag \"Contact\"! Found: %s",
689 // element->tagName().latin1()); 619 // element->tagName().latin1());
690 element = element->nextChild(); 620 element = element->nextChild();
691 continue; 621 continue;
692 } 622 }
693 /* Found alement with tagname "contact", now parse and store all 623 /* Found alement with tagname "contact", now parse and store all
694 * attributes contained 624 * attributes contained
695 */ 625 */
696 //qWarning("OContactDefBack::load element tagName() : %s", 626 //qWarning("OContactDefBack::load element tagName() : %s",
697 // element->tagName().latin1() ); 627 // element->tagName().latin1() );
698 QString dummy; 628 QString dummy;
699 foundAction = false; 629 foundAction = false;
700 630
701 XMLElement::AttributeMap aMap = element->attributes(); 631 XMLElement::AttributeMap aMap = element->attributes();
702 XMLElement::AttributeMap::Iterator it; 632 XMLElement::AttributeMap::Iterator it;
703 contactMap.clear(); 633 contactMap.clear();
704 customMap.clear(); 634 customMap.clear();
705 for( it = aMap.begin(); it != aMap.end(); ++it ){ 635 for( it = aMap.begin(); it != aMap.end(); ++it ){
706 // qWarning ("Read Attribute: %s=%s", it.key().latin1(),it.data().latin1()); 636 // qWarning ("Read Attribute: %s=%s", it.key().latin1(),it.data().latin1());
707 637
708 int *find = dict[ it.key() ]; 638 int *find = dict[ it.key() ];
709 /* Unknown attributes will be stored as "Custom" elements */ 639 /* Unknown attributes will be stored as "Custom" elements */
710 if ( !find ) { 640 if ( !find ) {
711 // qWarning("Attribute %s not known.", it.key().latin1()); 641 // qWarning("Attribute %s not known.", it.key().latin1());
712 //contact.setCustomField(it.key(), it.data()); 642 //contact.setCustomField(it.key(), it.data());
713 customMap.insert( it.key(), it.data() ); 643 customMap.insert( it.key(), it.data() );
714 continue; 644 continue;
715 } 645 }
716 646
717 /* Check if special conversion is needed and add attribute 647 /* Check if special conversion is needed and add attribute
718 * into Contact class 648 * into Contact class
719 */ 649 */
720 switch( *find ) { 650 switch( *find ) {
721 /* 651 /*
722 case Qtopia::AddressUid: 652 case Qtopia::AddressUid:
723 contact.setUid( it.data().toInt() ); 653 contact.setUid( it.data().toInt() );
724 break; 654 break;
725 case Qtopia::AddressCategory: 655 case Qtopia::AddressCategory:
726 contact.setCategories( Qtopia::Record::idsFromString( it.data( ))); 656 contact.setCategories( Qtopia::Record::idsFromString( it.data( )));
727 break; 657 break;
728 */ 658 */
729 case JOURNALACTION: 659 case JOURNALACTION:
730 action = journal_action(it.data().toInt()); 660 action = journal_action(it.data().toInt());
731 foundAction = true; 661 foundAction = true;
732 qWarning ("ODefBack(journal)::ACTION found: %d", action); 662 qWarning ("ODefBack(journal)::ACTION found: %d", action);
733 break; 663 break;
734 case JOURNALROW: 664 case JOURNALROW:
735 journalKey = it.data().toInt(); 665 journalKey = it.data().toInt();
736 break; 666 break;
737 default: // no conversion needed add them to the map 667 default: // no conversion needed add them to the map
738 contactMap.insert( *find, it.data() ); 668 contactMap.insert( *find, it.data() );
739 break; 669 break;
740 } 670 }
741 } 671 }
742 /* now generate the Contact contact */ 672 /* now generate the Contact contact */
743 OContact contact( contactMap ); 673 OContact contact( contactMap );
744 674
745 for (customIt = customMap.begin(); customIt != customMap.end(); ++customIt ) { 675 for (customIt = customMap.begin(); customIt != customMap.end(); ++customIt ) {
746 contact.setCustomField( customIt.key(), customIt.data() ); 676 contact.setCustomField( customIt.key(), customIt.data() );
747 } 677 }
748 678
749 if (foundAction){ 679 if (foundAction){
750 foundAction = false; 680 foundAction = false;
751 switch ( action ) { 681 switch ( action ) {
752 case ACTION_ADD: 682 case ACTION_ADD:
753 addContact_p (contact); 683 addContact_p (contact);
754 break; 684 break;
755 case ACTION_REMOVE: 685 case ACTION_REMOVE:
756 if ( !remove (contact.uid()) ) 686 if ( !remove (contact.uid()) )
757 qWarning ("ODefBack(journal)::Unable to remove uid: %d", 687 qWarning ("ODefBack(journal)::Unable to remove uid: %d",
758 contact.uid() ); 688 contact.uid() );
759 break; 689 break;
760 case ACTION_REPLACE: 690 case ACTION_REPLACE:
761 if ( !replace ( contact ) ) 691 if ( !replace ( contact ) )
762 qWarning ("ODefBack(journal)::Unable to replace uid: %d", 692 qWarning ("ODefBack(journal)::Unable to replace uid: %d",
763 contact.uid() ); 693 contact.uid() );
764 break; 694 break;
765 default: 695 default:
766 qWarning ("Unknown action: ignored !"); 696 qWarning ("Unknown action: ignored !");
767 break; 697 break;
768 } 698 }
769 }else{ 699 }else{
770 /* Add contact to list */ 700 /* Add contact to list */
771 addContact_p (contact); 701 addContact_p (contact);
772 } 702 }
773 703
774 /* Move to next element */ 704 /* Move to next element */
775 element = element->nextChild(); 705 element = element->nextChild();
776 } 706 }
777 }else { 707 }else {
778 qWarning("ODefBack::could not load"); 708 qWarning("ODefBack::could not load");
779 } 709 }
780 delete root; 710 delete root;
781 qWarning("returning from loading" ); 711 qWarning("returning from loading" );
782 return true; 712 return true;
783} 713}
784 714
785 715
786void OContactAccessBackend_XML::updateJournal( const OContact& cnt, 716void OContactAccessBackend_XML::updateJournal( const OContact& cnt,
787 journal_action action ) 717 journal_action action )
788{ 718{
789 QFile f( m_journalName ); 719 QFile f( m_journalName );
790 bool created = !f.exists(); 720 bool created = !f.exists();
791 if ( !f.open(IO_WriteOnly|IO_Append) ) 721 if ( !f.open(IO_WriteOnly|IO_Append) )
792 return; 722 return;
793 723
794 QString buf; 724 QString buf;
795 QCString str; 725 QCString str;
796 726
797 // if the file was created, we have to set the Tag "<CONTACTS>" to 727 // if the file was created, we have to set the Tag "<CONTACTS>" to
798 // get a XML-File which is readable by our parser. 728 // get a XML-File which is readable by our parser.
799 // This is just a cheat, but better than rewrite the parser. 729 // This is just a cheat, but better than rewrite the parser.
800 if ( created ){ 730 if ( created ){
801 buf = "<Contacts>"; 731 buf = "<Contacts>";
802 QCString cstr = buf.utf8(); 732 QCString cstr = buf.utf8();
803 f.writeBlock( cstr.data(), cstr.length() ); 733 f.writeBlock( cstr.data(), cstr.length() );
804 } 734 }
805 735
806 buf = "<Contact "; 736 buf = "<Contact ";
807 cnt.save( buf ); 737 cnt.save( buf );
808 buf += " action=\"" + QString::number( (int)action ) + "\" "; 738 buf += " action=\"" + QString::number( (int)action ) + "\" ";
809 buf += "/>\n"; 739 buf += "/>\n";
810 QCString cstr = buf.utf8(); 740 QCString cstr = buf.utf8();
811 f.writeBlock( cstr.data(), cstr.length() ); 741 f.writeBlock( cstr.data(), cstr.length() );
812} 742}
813 743
814void OContactAccessBackend_XML::removeJournal() 744void OContactAccessBackend_XML::removeJournal()
815{ 745{
816 QFile f ( m_journalName ); 746 QFile f ( m_journalName );
817 if ( f.exists() ) 747 if ( f.exists() )
818 f.remove(); 748 f.remove();
819} 749}
820 750
751}
diff --git a/libopie2/opiepim/backend/ocontactaccessbackend_xml.h b/libopie2/opiepim/backend/ocontactaccessbackend_xml.h
index a0cae4d..f439c4c 100644
--- a/libopie2/opiepim/backend/ocontactaccessbackend_xml.h
+++ b/libopie2/opiepim/backend/ocontactaccessbackend_xml.h
@@ -1,160 +1,108 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * XML Backend for the OPIE-Contact Database. 30 * XML Backend for the OPIE-Contact Database.
3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 *
6 * =====================================================================
7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 * =====================================================================
12 * ToDo: XML-Backend: Automatic reload if something was changed...
13 * File Locking to protect against concurrent access
14 *
15 *
16 * =====================================================================
17 * Version: $Id$
18 * =====================================================================
19 * History:
20 * $Log$
21 * Revision 1.15 2003/09/22 14:31:16 eilers
22 * Added first experimental incarnation of sql-backend for addressbook.
23 * Some modifications to be able to compile the todo sql-backend.
24 * A lot of changes fill follow...
25 *
26 * Revision 1.14 2003/04/13 18:07:10 zecke
27 * More API doc
28 * QString -> const QString&
29 * QString = 0l -> QString::null
30 *
31 * Revision 1.13 2003/03/21 10:33:09 eilers
32 * Merged speed optimized xml backend for contacts to main.
33 * Added QDateTime to querybyexample. For instance, it is now possible to get
34 * all Birthdays/Anniversaries between two dates. This should be used
35 * to show all birthdays in the datebook..
36 * This change is sourcecode backward compatible but you have to upgrade
37 * the binaries for today-addressbook.
38 *
39 * Revision 1.12.2.2 2003/02/11 12:17:28 eilers
40 * Speed optimization. Removed the sequential search loops.
41 *
42 * Revision 1.12.2.1 2003/02/09 15:05:01 eilers
43 * Nothing happened.. Just some cleanup before I will start..
44 *
45 * Revision 1.12 2003/01/03 16:58:03 eilers
46 * Reenable debug output
47 *
48 * Revision 1.11 2003/01/03 12:31:28 eilers
49 * Bugfix for calculating data diffs..
50 *
51 * Revision 1.10 2003/01/02 14:27:12 eilers
52 * Improved query by example: Search by date is possible.. First step
53 * for a today plugin for birthdays..
54 *
55 * Revision 1.9 2002/12/08 12:48:57 eilers
56 * Moved journal-enum from ocontact into i the xml-backend..
57 *
58 * Revision 1.8 2002/11/14 17:04:24 eilers
59 * Sorting will now work if fullname is identical on some entries
60 *
61 * Revision 1.7 2002/11/13 15:02:46 eilers
62 * Small Bug in sorted fixed
63 *
64 * Revision 1.6 2002/11/13 14:14:51 eilers
65 * Added sorted for Contacts..
66 *
67 * Revision 1.5 2002/11/01 15:10:42 eilers
68 * Added regExp-search in database for all fields in a contact.
69 *
70 * Revision 1.4 2002/10/16 10:52:40 eilers
71 * Added some docu to the interface and now using the cache infrastucture by zecke.. :)
72 *
73 * Revision 1.3 2002/10/14 16:21:54 eilers
74 * Some minor interface updates
75 *
76 * Revision 1.2 2002/10/07 17:34:24 eilers
77 * added OBackendFactory for advanced backend access
78 *
79 * Revision 1.1 2002/09/27 17:11:44 eilers
80 * Added API for accessing the Contact-Database ! It is compiling, but
81 * please do not expect that anything is working !
82 * I will debug that stuff in the next time ..
83 * Please read README_COMPILE for compiling !
84 *
85 *
86 */ 31 */
87 32
88#ifndef _OContactAccessBackend_XML_ 33#ifndef _OContactAccessBackend_XML_
89#define _OContactAccessBackend_XML_ 34#define _OContactAccessBackend_XML_
90 35
91#include "ocontactaccessbackend.h" 36#include <opie2/ocontactaccessbackend.h>
92#include "ocontactaccess.h" 37#include <opie2/ocontactaccess.h>
93 38
94#include <qlist.h> 39#include <qlist.h>
95#include <qdict.h> 40#include <qdict.h>
96 41
42namespace Opie {
97/* the default xml implementation */ 43/* the default xml implementation */
98/** 44/**
99 * This class is the XML implementation of a Contact backend 45 * This class is the XML implementation of a Contact backend
100 * it does implement everything available for OContact. 46 * it does implement everything available for OContact.
101 * @see OPimAccessBackend for more information of available methods 47 * @see OPimAccessBackend for more information of available methods
102 */ 48 */
103class OContactAccessBackend_XML : public OContactAccessBackend { 49class OContactAccessBackend_XML : public OContactAccessBackend {
104 public: 50 public:
105 OContactAccessBackend_XML ( const QString& appname, const QString& filename = QString::null ); 51 OContactAccessBackend_XML ( const QString& appname, const QString& filename = QString::null );
106 52
107 bool save(); 53 bool save();
108 54
109 bool load (); 55 bool load ();
110 56
111 void clear (); 57 void clear ();
112 58
113 bool wasChangedExternally(); 59 bool wasChangedExternally();
114 60
115 QArray<int> allRecords() const; 61 QArray<int> allRecords() const;
116 62
117 OContact find ( int uid ) const; 63 OContact find ( int uid ) const;
118 64
119 QArray<int> queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() ); 65 QArray<int> queryByExample ( const OContact &query, int settings, const QDateTime& d = QDateTime() );
120 66
121 QArray<int> matchRegexp( const QRegExp &r ) const; 67 QArray<int> matchRegexp( const QRegExp &r ) const;
122 68
123 const uint querySettings(); 69 const uint querySettings();
124 70
125 bool hasQuerySettings (uint querySettings) const; 71 bool hasQuerySettings (uint querySettings) const;
126 72
127 // Currently only asc implemented.. 73 // Currently only asc implemented..
128 QArray<int> sorted( bool asc, int , int , int ); 74 QArray<int> sorted( bool asc, int , int , int );
129 bool add ( const OContact &newcontact ); 75 bool add ( const OContact &newcontact );
130 76
131 bool replace ( const OContact &contact ); 77 bool replace ( const OContact &contact );
132 78
133 bool remove ( int uid ); 79 bool remove ( int uid );
134 bool reload(); 80 bool reload();
135 81
136 private: 82 private:
137 83
138 enum journal_action { ACTION_ADD, ACTION_REMOVE, ACTION_REPLACE }; 84 enum journal_action { ACTION_ADD, ACTION_REMOVE, ACTION_REPLACE };
139 85
140 void addContact_p( const OContact &newcontact ); 86 void addContact_p( const OContact &newcontact );
141 87
142 /* This function loads the xml-database and the journalfile */ 88 /* This function loads the xml-database and the journalfile */
143 bool load( const QString filename, bool isJournal ); 89 bool load( const QString filename, bool isJournal );
144 90
145 91
146 void updateJournal( const OContact& cnt, journal_action action ); 92 void updateJournal( const OContact& cnt, journal_action action );
147 void removeJournal(); 93 void removeJournal();
148 94
149 protected: 95 protected:
150 bool m_changed; 96 bool m_changed;
151 QString m_journalName; 97 QString m_journalName;
152 QString m_fileName; 98 QString m_fileName;
153 QString m_appName; 99 QString m_appName;
154 QList<OContact> m_contactList; 100 QList<OContact> m_contactList;
155 QDateTime m_readtime; 101 QDateTime m_readtime;
156 102
157 QDict<OContact> m_uidToContact; 103 QDict<OContact> m_uidToContact;
158}; 104};
159 105
106}
107
160#endif 108#endif
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend.cpp b/libopie2/opiepim/backend/odatebookaccessbackend.cpp
index f0c5d65..9bf4bf0 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend.cpp
+++ b/libopie2/opiepim/backend/odatebookaccessbackend.cpp
@@ -1,182 +1,216 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qtl.h> 29#include <qtl.h>
2 30
3#include "orecur.h" 31#include <opie2/orecur.h>
4 32
5#include "odatebookaccessbackend.h" 33#include <opie2/odatebookaccessbackend.h>
34
35using namespace Opie;
6 36
7namespace { 37namespace {
8/* a small helper to get all NonRepeating events for a range of time */ 38/* a small helper to get all NonRepeating events for a range of time */
9 void events( OEffectiveEvent::ValueList& tmpList, const OEvent::ValueList& events, 39 void events( OEffectiveEvent::ValueList& tmpList, const OEvent::ValueList& events,
10 const QDate& from, const QDate& to ) { 40 const QDate& from, const QDate& to ) {
11 QDateTime dtStart, dtEnd; 41 QDateTime dtStart, dtEnd;
12 42
13 for ( OEvent::ValueList::ConstIterator it = events.begin(); it != events.end(); ++it ) { 43 for ( OEvent::ValueList::ConstIterator it = events.begin(); it != events.end(); ++it ) {
14 dtStart = (*it).startDateTime(); 44 dtStart = (*it).startDateTime();
15 dtEnd = (*it).endDateTime(); 45 dtEnd = (*it).endDateTime();
16 46
17 /* 47 /*
18 * If in range 48 * If in range
19 */ 49 */
20 if (dtStart.date() >= from && dtEnd.date() <= to ) { 50 if (dtStart.date() >= from && dtEnd.date() <= to ) {
21 OEffectiveEvent eff; 51 OEffectiveEvent eff;
22 eff.setEvent( (*it) ); 52 eff.setEvent( (*it) );
23 eff.setDate( dtStart.date() ); 53 eff.setDate( dtStart.date() );
24 eff.setStartTime( dtStart.time() ); 54 eff.setStartTime( dtStart.time() );
25 55
26 /* if not on the same day */ 56 /* if not on the same day */
27 if ( dtStart.date() != dtEnd.date() ) 57 if ( dtStart.date() != dtEnd.date() )
28 eff.setEndTime( QTime(23, 59, 0 ) ); 58 eff.setEndTime( QTime(23, 59, 0 ) );
29 else 59 else
30 eff.setEndTime( dtEnd.time() ); 60 eff.setEndTime( dtEnd.time() );
31 61
32 tmpList.append( eff ); 62 tmpList.append( eff );
33 } 63 }
34 64
35 /* we must also check for end date information... */ 65 /* we must also check for end date information... */
36 if ( dtEnd.date() != dtStart.date() && dtEnd.date() >= from ) { 66 if ( dtEnd.date() != dtStart.date() && dtEnd.date() >= from ) {
37 QDateTime dt = dtStart.addDays( 1 ); 67 QDateTime dt = dtStart.addDays( 1 );
38 dt.setTime( QTime(0, 0, 0 ) ); 68 dt.setTime( QTime(0, 0, 0 ) );
39 QDateTime dtStop; 69 QDateTime dtStop;
40 if ( dtEnd > to ) 70 if ( dtEnd > to )
41 dtStop = to; 71 dtStop = to;
42 else 72 else
43 dtStop = dtEnd; 73 dtStop = dtEnd;
44 74
45 while ( dt <= dtStop ) { 75 while ( dt <= dtStop ) {
46 OEffectiveEvent eff; 76 OEffectiveEvent eff;
47 eff.setEvent( (*it) ); 77 eff.setEvent( (*it) );
48 eff.setDate( dt.date() ); 78 eff.setDate( dt.date() );
49 79
50 if ( dt >= from ) { 80 if ( dt >= from ) {
51 eff.setStartTime( QTime(0, 0, 0 ) ); 81 eff.setStartTime( QTime(0, 0, 0 ) );
52 if ( dt.date() == dtEnd.date() ) 82 if ( dt.date() == dtEnd.date() )
53 eff.setEndTime( dtEnd.time() ); 83 eff.setEndTime( dtEnd.time() );
54 else 84 else
55 eff.setEndTime( QTime(23, 59, 0 ) ); 85 eff.setEndTime( QTime(23, 59, 0 ) );
56 tmpList.append( eff ); 86 tmpList.append( eff );
57 } 87 }
58 dt = dt.addDays( 1 ); 88 dt = dt.addDays( 1 );
59 } 89 }
60 } 90 }
61 } 91 }
62 } 92 }
63 93
64 void repeat( OEffectiveEvent::ValueList& tmpList, const OEvent::ValueList& list, 94 void repeat( OEffectiveEvent::ValueList& tmpList, const OEvent::ValueList& list,
65 const QDate& from, const QDate& to ) { 95 const QDate& from, const QDate& to ) {
66 QDate repeat; 96 QDate repeat;
67 for ( OEvent::ValueList::ConstIterator it = list.begin(); it != list.end(); ++it ) { 97 for ( OEvent::ValueList::ConstIterator it = list.begin(); it != list.end(); ++it ) {
68 int dur = (*it).startDateTime().date().daysTo( (*it).endDateTime().date() ); 98 int dur = (*it).startDateTime().date().daysTo( (*it).endDateTime().date() );
69 QDate itDate = from.addDays(-dur ); 99 QDate itDate = from.addDays(-dur );
70 ORecur rec = (*it).recurrence(); 100 ORecur rec = (*it).recurrence();
71 if ( !rec.hasEndDate() || rec.endDate() > to ) { 101 if ( !rec.hasEndDate() || rec.endDate() > to ) {
72 rec.setEndDate( to ); 102 rec.setEndDate( to );
73 rec.setHasEndDate( true ); 103 rec.setHasEndDate( true );
74 } 104 }
75 while (rec.nextOcurrence(itDate, repeat ) ) { 105 while (rec.nextOcurrence(itDate, repeat ) ) {
76 if (repeat > to ) break; 106 if (repeat > to ) break;
77 OEffectiveEvent eff; 107 OEffectiveEvent eff;
78 eff.setDate( repeat ); 108 eff.setDate( repeat );
79 if ( (*it).isAllDay() ) { 109 if ( (*it).isAllDay() ) {
80 eff.setStartTime( QTime(0, 0, 0 ) ); 110 eff.setStartTime( QTime(0, 0, 0 ) );
81 eff.setEndTime( QTime(23, 59, 59 ) ); 111 eff.setEndTime( QTime(23, 59, 59 ) );
82 }else { 112 }else {
83 /* we only occur by days, not hours/minutes/seconds. Hence 113 /* we only occur by days, not hours/minutes/seconds. Hence
84 * the actual end and start times will be the same for 114 * the actual end and start times will be the same for
85 * every repeated event. For multi day events this is 115 * every repeated event. For multi day events this is
86 * fixed up later if on wronge day span 116 * fixed up later if on wronge day span
87 */ 117 */
88 eff.setStartTime( (*it).startDateTime().time() ); 118 eff.setStartTime( (*it).startDateTime().time() );
89 eff.setEndTime( (*it).endDateTime().time() ); 119 eff.setEndTime( (*it).endDateTime().time() );
90 } 120 }
91 if ( dur != 0 ) { 121 if ( dur != 0 ) {
92 // multi-day repeating events 122 // multi-day repeating events
93 QDate sub_it = QMAX( repeat, from ); 123 QDate sub_it = QMAX( repeat, from );
94 QDate startDate = repeat; 124 QDate startDate = repeat;
95 QDate endDate = startDate.addDays( dur ); 125 QDate endDate = startDate.addDays( dur );
96 126
97 while ( sub_it <= endDate && sub_it <= to ) { 127 while ( sub_it <= endDate && sub_it <= to ) {
98 OEffectiveEvent tmpEff = eff; 128 OEffectiveEvent tmpEff = eff;
99 tmpEff.setEvent( (*it) ); 129 tmpEff.setEvent( (*it) );
100 if ( sub_it != startDate ) 130 if ( sub_it != startDate )
101 tmpEff.setStartTime( QTime(0, 0, 0 ) ); 131 tmpEff.setStartTime( QTime(0, 0, 0 ) );
102 if ( sub_it != endDate ) 132 if ( sub_it != endDate )
103 tmpEff.setEndTime( QTime( 23, 59, 59 ) ); 133 tmpEff.setEndTime( QTime( 23, 59, 59 ) );
104 134
105 tmpEff.setDate( sub_it ); 135 tmpEff.setDate( sub_it );
106 tmpEff.setEffectiveDates( startDate, endDate ); 136 tmpEff.setEffectiveDates( startDate, endDate );
107 tmpList.append( tmpEff ); 137 tmpList.append( tmpEff );
108 138
109 sub_it = sub_it.addDays( 1 ); 139 sub_it = sub_it.addDays( 1 );
110 } 140 }
111 itDate = endDate; 141 itDate = endDate;
112 }else { 142 }else {
113 eff.setEvent( (*it) ); 143 eff.setEvent( (*it) );
114 tmpList.append( eff ); 144 tmpList.append( eff );
115 itDate = repeat.addDays( 1 ); 145 itDate = repeat.addDays( 1 );
116 } 146 }
117 } 147 }
118 } 148 }
119 } 149 }
120} 150}
121 151
152namespace Opie {
153
122ODateBookAccessBackend::ODateBookAccessBackend() 154ODateBookAccessBackend::ODateBookAccessBackend()
123 : OPimAccessBackend<OEvent>() 155 : OPimAccessBackend<OEvent>()
124{ 156{
125 157
126} 158}
127ODateBookAccessBackend::~ODateBookAccessBackend() { 159ODateBookAccessBackend::~ODateBookAccessBackend() {
128 160
129} 161}
130OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveEvents( const QDate& from, 162OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveEvents( const QDate& from,
131 const QDate& to ) { 163 const QDate& to ) {
132 OEffectiveEvent::ValueList tmpList; 164 OEffectiveEvent::ValueList tmpList;
133 OEvent::ValueList list = directNonRepeats(); 165 OEvent::ValueList list = directNonRepeats();
134 166
135 events( tmpList, list, from, to ); 167 events( tmpList, list, from, to );
136 repeat( tmpList, directRawRepeats(),from,to ); 168 repeat( tmpList, directRawRepeats(),from,to );
137 169
138 list = directRawRepeats(); // Useless, isn't it ? (eilers) 170 list = directRawRepeats(); // Useless, isn't it ? (eilers)
139 171
140 qHeapSort( tmpList ); 172 qHeapSort( tmpList );
141 return tmpList; 173 return tmpList;
142} 174}
143OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveEvents( const QDateTime& dt ) { 175OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveEvents( const QDateTime& dt ) {
144 OEffectiveEvent::ValueList day = effectiveEvents( dt.date(), dt.date() ); 176 OEffectiveEvent::ValueList day = effectiveEvents( dt.date(), dt.date() );
145 OEffectiveEvent::ValueList::Iterator it; 177 OEffectiveEvent::ValueList::Iterator it;
146 178
147 OEffectiveEvent::ValueList tmpList; 179 OEffectiveEvent::ValueList tmpList;
148 QDateTime dtTmp; 180 QDateTime dtTmp;
149 for ( it = day.begin(); it != day.end(); ++it ) { 181 for ( it = day.begin(); it != day.end(); ++it ) {
150 dtTmp = QDateTime( (*it).date(), (*it).startTime() ); 182 dtTmp = QDateTime( (*it).date(), (*it).startTime() );
151 if ( QABS(dt.secsTo(dtTmp) ) < 60 ) 183 if ( QABS(dt.secsTo(dtTmp) ) < 60 )
152 tmpList.append( (*it) ); 184 tmpList.append( (*it) );
153 } 185 }
154 186
155 return tmpList; 187 return tmpList;
156} 188}
157 189
158OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveNonRepeatingEvents( const QDate& from, 190OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveNonRepeatingEvents( const QDate& from,
159 const QDate& to ) { 191 const QDate& to ) {
160 OEffectiveEvent::ValueList tmpList; 192 OEffectiveEvent::ValueList tmpList;
161 OEvent::ValueList list = directNonRepeats(); 193 OEvent::ValueList list = directNonRepeats();
162 194
163 events( tmpList, list, from, to ); 195 events( tmpList, list, from, to );
164 196
165 qHeapSort( tmpList ); 197 qHeapSort( tmpList );
166 return tmpList; 198 return tmpList;
167} 199}
168 200
169OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveNonRepeatingEvents( const QDateTime& dt ) { 201OEffectiveEvent::ValueList ODateBookAccessBackend::effectiveNonRepeatingEvents( const QDateTime& dt ) {
170 OEffectiveEvent::ValueList day = effectiveNonRepeatingEvents( dt.date(), dt.date() ); 202 OEffectiveEvent::ValueList day = effectiveNonRepeatingEvents( dt.date(), dt.date() );
171 OEffectiveEvent::ValueList::Iterator it; 203 OEffectiveEvent::ValueList::Iterator it;
172 204
173 OEffectiveEvent::ValueList tmpList; 205 OEffectiveEvent::ValueList tmpList;
174 QDateTime dtTmp; 206 QDateTime dtTmp;
175 for ( it = day.begin(); it != day.end(); ++it ) { 207 for ( it = day.begin(); it != day.end(); ++it ) {
176 dtTmp = QDateTime( (*it).date(), (*it).startTime() ); 208 dtTmp = QDateTime( (*it).date(), (*it).startTime() );
177 if ( QABS(dt.secsTo(dtTmp) ) < 60 ) 209 if ( QABS(dt.secsTo(dtTmp) ) < 60 )
178 tmpList.append( (*it) ); 210 tmpList.append( (*it) );
179 } 211 }
180 212
181 return tmpList; 213 return tmpList;
182} 214}
215
216}
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend.h b/libopie2/opiepim/backend/odatebookaccessbackend.h
index 3472ab3..6853670 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend.h
+++ b/libopie2/opiepim/backend/odatebookaccessbackend.h
@@ -1,90 +1,121 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_H 29#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_H
2#define OPIE_DATE_BOOK_ACCESS_BACKEND_H 30#define OPIE_DATE_BOOK_ACCESS_BACKEND_H
3 31
4#include <qarray.h> 32#include <qarray.h>
5 33
6#include "opimaccessbackend.h" 34#include <opie2/opimaccessbackend.h>
7#include "oevent.h" 35#include <opie2/oevent.h>
8 36
37namespace Opie {
9/** 38/**
10 * This class is the interface to the storage of Events. 39 * This class is the interface to the storage of Events.
11 * @see OPimAccessBackend 40 * @see OPimAccessBackend
12 * 41 *
13 */ 42 */
14class ODateBookAccessBackend : public OPimAccessBackend<OEvent> { 43class ODateBookAccessBackend : public OPimAccessBackend<OEvent> {
15public: 44public:
16 typedef int UID; 45 typedef int UID;
17 46
18 /** 47 /**
19 * c'tor without parameter 48 * c'tor without parameter
20 */ 49 */
21 ODateBookAccessBackend(); 50 ODateBookAccessBackend();
22 ~ODateBookAccessBackend(); 51 ~ODateBookAccessBackend();
23 52
24 /** 53 /**
25 * This method should return a list of UIDs containing 54 * This method should return a list of UIDs containing
26 * all events. No filter should be applied 55 * all events. No filter should be applied
27 * @return list of events 56 * @return list of events
28 */ 57 */
29 virtual QArray<UID> rawEvents()const = 0; 58 virtual QArray<UID> rawEvents()const = 0;
30 59
31 /** 60 /**
32 * This method should return a list of UIDs containing 61 * This method should return a list of UIDs containing
33 * all repeating events. No filter should be applied 62 * all repeating events. No filter should be applied
34 * @return list of repeating events 63 * @return list of repeating events
35 */ 64 */
36 virtual QArray<UID> rawRepeats()const = 0; 65 virtual QArray<UID> rawRepeats()const = 0;
37 66
38 /** 67 /**
39 * This mthod should return a list of UIDs containing all non 68 * This mthod should return a list of UIDs containing all non
40 * repeating events. No filter should be applied 69 * repeating events. No filter should be applied
41 * @return list of nonrepeating events 70 * @return list of nonrepeating events
42 */ 71 */
43 virtual QArray<UID> nonRepeats() const = 0; 72 virtual QArray<UID> nonRepeats() const = 0;
44 73
45 /** 74 /**
46 * If you do not want to implement the effectiveEvents methods below 75 * If you do not want to implement the effectiveEvents methods below
47 * you need to supply it with directNonRepeats. 76 * you need to supply it with directNonRepeats.
48 * This method can return empty lists if effectiveEvents is implememted 77 * This method can return empty lists if effectiveEvents is implememted
49 */ 78 */
50 virtual OEvent::ValueList directNonRepeats() = 0; 79 virtual OEvent::ValueList directNonRepeats() = 0;
51 80
52 /** 81 /**
53 * Same as above but return raw repeats! 82 * Same as above but return raw repeats!
54 */ 83 */
55 virtual OEvent::ValueList directRawRepeats() = 0; 84 virtual OEvent::ValueList directRawRepeats() = 0;
56 85
57 /* is implemented by default but you can reimplement it*/ 86 /* is implemented by default but you can reimplement it*/
58 /** 87 /**
59 * Effective Events are special event occuring during a time frame. This method does calcualte 88 * Effective Events are special event occuring during a time frame. This method does calcualte
60 * EffectiveEvents bases on the directNonRepeats and directRawRepeats. You may implement this method 89 * EffectiveEvents bases on the directNonRepeats and directRawRepeats. You may implement this method
61 * yourself 90 * yourself
62 */ 91 */
63 virtual OEffectiveEvent::ValueList effectiveEvents( const QDate& from, const QDate& to ); 92 virtual OEffectiveEvent::ValueList effectiveEvents( const QDate& from, const QDate& to );
64 93
65 /** 94 /**
66 * this is an overloaded member function 95 * this is an overloaded member function
67 * @see effectiveEvents( const QDate& from, const QDate& to ) 96 * @see effectiveEvents( const QDate& from, const QDate& to )
68 */ 97 */
69 virtual OEffectiveEvent::ValueList effectiveEvents( const QDateTime& start ); 98 virtual OEffectiveEvent::ValueList effectiveEvents( const QDateTime& start );
70 99
71 /** 100 /**
72 * Effective Events are special event occuring during a time frame. This method does calcualte 101 * Effective Events are special event occuring during a time frame. This method does calcualte
73 * EffectiveEvents bases on the directNonRepeats and directRawRepeats. You may implement this method 102 * EffectiveEvents bases on the directNonRepeats and directRawRepeats. You may implement this method
74 * yourself 103 * yourself
75 */ 104 */
76 virtual OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDate& from, const QDate& to ); 105 virtual OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDate& from, const QDate& to );
77 106
78 /** 107 /**
79 * this is an overloaded member function 108 * this is an overloaded member function
80 * @see effectiveNonRepeatingEvents( const QDate& from, const QDate& to ) 109 * @see effectiveNonRepeatingEvents( const QDate& from, const QDate& to )
81 */ 110 */
82 virtual OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDateTime& start ); 111 virtual OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDateTime& start );
83 112
84private: 113private:
85 class Private; 114 class Private;
86 Private *d; 115 Private *d;
87 116
88}; 117};
89 118
119}
120
90#endif 121#endif
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend_sql.cpp b/libopie2/opiepim/backend/odatebookaccessbackend_sql.cpp
index 756f405..e79696c 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend_sql.cpp
+++ b/libopie2/opiepim/backend/odatebookaccessbackend_sql.cpp
@@ -1,367 +1,366 @@
1/* 1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
2 * SQL Backend for the OPIE-Calender Database. 30 * SQL Backend for the OPIE-Calender Database.
3 * 31 *
4 * Copyright (c) 2003 by Stefan Eilers (Eilers.Stefan@epost.de)
5 *
6 * =====================================================================
7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 * =====================================================================
12 * =====================================================================
13 * Version: $Id$
14 * =====================================================================
15 * History:
16 * $Log$
17 * Revision 1.3 2003/12/22 11:41:39 eilers
18 * Fixing stupid bug, found by sourcode review..
19 *
20 * Revision 1.2 2003/12/22 10:19:26 eilers
21 * Finishing implementation of sql-backend for datebook. But I have to
22 * port the PIM datebook application to use it, before I could debug the
23 * whole stuff.
24 * Thus, PIM-Database backend is finished, but highly experimental. And some
25 * parts are still generic. For instance, the "queryByExample()" methods are
26 * not (or not fully) implemented. Todo: custom-entries not stored.
27 * The big show stopper: matchRegExp() (needed by OpieSearch) needs regular
28 * expression search in the database, which is not supported by sqlite !
29 * Therefore we need either an extended sqlite or a workaround which would
30 * be very slow and memory consuming..
31 *
32 * Revision 1.1 2003/12/08 15:18:12 eilers
33 * Committing unfinished sql implementation before merging to libopie2 starts..
34 *
35 *
36 */ 32 */
37 33
38#include <stdio.h> 34#include <stdio.h>
39#include <stdlib.h> 35#include <stdlib.h>
40 36
41#include <qarray.h> 37#include <qarray.h>
42#include <qstringlist.h> 38#include <qstringlist.h>
43 39
44#include <qpe/global.h> 40#include <qpe/global.h>
45 41
46#include <opie2/osqldriver.h> 42#include <opie2/osqldriver.h>
47#include <opie2/osqlmanager.h> 43#include <opie2/osqlmanager.h>
48#include <opie2/osqlquery.h> 44#include <opie2/osqlquery.h>
49 45
50#include "orecur.h" 46#include <opie2/orecur.h>
51#include "odatebookaccessbackend_sql.h" 47#include <opie2/odatebookaccessbackend_sql.h>
52 48
49namespace Opie {
53 50
54 51
55ODateBookAccessBackend_SQL::ODateBookAccessBackend_SQL( const QString& , 52ODateBookAccessBackend_SQL::ODateBookAccessBackend_SQL( const QString& ,
56 const QString& fileName ) 53 const QString& fileName )
57 : ODateBookAccessBackend(), m_driver( NULL ) 54 : ODateBookAccessBackend(), m_driver( NULL )
58{ 55{
59 m_fileName = fileName.isEmpty() ? Global::applicationFileName( "datebook", "datebook.db" ) : fileName; 56 m_fileName = fileName.isEmpty() ? Global::applicationFileName( "datebook", "datebook.db" ) : fileName;
60 57
61 // Get the standart sql-driver from the OSQLManager.. 58 // Get the standart sql-driver from the OSQLManager..
62 OSQLManager man; 59 OSQLManager man;
63 m_driver = man.standard(); 60 m_driver = man.standard();
64 m_driver->setUrl( m_fileName ); 61 m_driver->setUrl( m_fileName );
65 62
66 initFields(); 63 initFields();
67 64
68 load(); 65 load();
69} 66}
70 67
71ODateBookAccessBackend_SQL::~ODateBookAccessBackend_SQL() { 68ODateBookAccessBackend_SQL::~ODateBookAccessBackend_SQL() {
72 if( m_driver ) 69 if( m_driver )
73 delete m_driver; 70 delete m_driver;
74} 71}
75 72
76void ODateBookAccessBackend_SQL::initFields() 73void ODateBookAccessBackend_SQL::initFields()
77{ 74{
78 75
79 // This map contains the translation of the fieldtype id's to 76 // This map contains the translation of the fieldtype id's to
80 // the names of the table columns 77 // the names of the table columns
81 m_fieldMap.insert( OEvent::FUid, "uid" ); 78 m_fieldMap.insert( OEvent::FUid, "uid" );
82 m_fieldMap.insert( OEvent::FCategories, "Categories" ); 79 m_fieldMap.insert( OEvent::FCategories, "Categories" );
83 m_fieldMap.insert( OEvent::FDescription, "Description" ); 80 m_fieldMap.insert( OEvent::FDescription, "Description" );
84 m_fieldMap.insert( OEvent::FLocation, "Location" ); 81 m_fieldMap.insert( OEvent::FLocation, "Location" );
85 m_fieldMap.insert( OEvent::FType, "Type" ); 82 m_fieldMap.insert( OEvent::FType, "Type" );
86 m_fieldMap.insert( OEvent::FAlarm, "Alarm" ); 83 m_fieldMap.insert( OEvent::FAlarm, "Alarm" );
87 m_fieldMap.insert( OEvent::FSound, "Sound" ); 84 m_fieldMap.insert( OEvent::FSound, "Sound" );
88 m_fieldMap.insert( OEvent::FRType, "RType" ); 85 m_fieldMap.insert( OEvent::FRType, "RType" );
89 m_fieldMap.insert( OEvent::FRWeekdays, "RWeekdays" ); 86 m_fieldMap.insert( OEvent::FRWeekdays, "RWeekdays" );
90 m_fieldMap.insert( OEvent::FRPosition, "RPosition" ); 87 m_fieldMap.insert( OEvent::FRPosition, "RPosition" );
91 m_fieldMap.insert( OEvent::FRFreq, "RFreq" ); 88 m_fieldMap.insert( OEvent::FRFreq, "RFreq" );
92 m_fieldMap.insert( OEvent::FRHasEndDate, "RHasEndDate" ); 89 m_fieldMap.insert( OEvent::FRHasEndDate, "RHasEndDate" );
93 m_fieldMap.insert( OEvent::FREndDate, "REndDate" ); 90 m_fieldMap.insert( OEvent::FREndDate, "REndDate" );
94 m_fieldMap.insert( OEvent::FRCreated, "RCreated" ); 91 m_fieldMap.insert( OEvent::FRCreated, "RCreated" );
95 m_fieldMap.insert( OEvent::FRExceptions, "RExceptions" ); 92 m_fieldMap.insert( OEvent::FRExceptions, "RExceptions" );
96 m_fieldMap.insert( OEvent::FStart, "Start" ); 93 m_fieldMap.insert( OEvent::FStart, "Start" );
97 m_fieldMap.insert( OEvent::FEnd, "End" ); 94 m_fieldMap.insert( OEvent::FEnd, "End" );
98 m_fieldMap.insert( OEvent::FNote, "Note" ); 95 m_fieldMap.insert( OEvent::FNote, "Note" );
99 m_fieldMap.insert( OEvent::FTimeZone, "TimeZone" ); 96 m_fieldMap.insert( OEvent::FTimeZone, "TimeZone" );
100 m_fieldMap.insert( OEvent::FRecParent, "RecParent" ); 97 m_fieldMap.insert( OEvent::FRecParent, "RecParent" );
101 m_fieldMap.insert( OEvent::FRecChildren, "Recchildren" ); 98 m_fieldMap.insert( OEvent::FRecChildren, "Recchildren" );
102 99
103 // Create a map that maps the column name to the id 100 // Create a map that maps the column name to the id
104 QMapConstIterator<int, QString> it; 101 QMapConstIterator<int, QString> it;
105 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){ 102 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){
106 m_reverseFieldMap.insert( it.data(), it.key() ); 103 m_reverseFieldMap.insert( it.data(), it.key() );
107 } 104 }
108 105
109} 106}
110 107
111bool ODateBookAccessBackend_SQL::load() 108bool ODateBookAccessBackend_SQL::load()
112{ 109{
113 if (!m_driver->open() ) 110 if (!m_driver->open() )
114 return false; 111 return false;
115 112
116 // Don't expect that the database exists. 113 // Don't expect that the database exists.
117 // It is save here to create the table, even if it 114 // It is save here to create the table, even if it
118 // do exist. ( Is that correct for all databases ?? ) 115 // do exist. ( Is that correct for all databases ?? )
119 QStringqu = "create table datebook( uid INTEGER PRIMARY KEY "; 116 QStringqu = "create table datebook( uid INTEGER PRIMARY KEY ";
120 117
121 QMap<int, QString>::Iterator it; 118 QMap<int, QString>::Iterator it;
122 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){ 119 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){
123 qu += QString( ",%1 VARCHAR(10)" ).arg( it.data() ); 120 qu += QString( ",%1 VARCHAR(10)" ).arg( it.data() );
124 } 121 }
125 qu += " );"; 122 qu += " );";
126 123
127 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );"; 124 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR, priority INTEGER, value VARCHAR, PRIMARY KEY /* identifier */ (uid, id) );";
128 125
129 qWarning( "command: %s", qu.latin1() ); 126 qWarning( "command: %s", qu.latin1() );
130 127
131 OSQLRawQuery raw( qu ); 128 OSQLRawQuery raw( qu );
132 OSQLResult res = m_driver->query( &raw ); 129 OSQLResult res = m_driver->query( &raw );
133 if ( res.state() != OSQLResult::Success ) 130 if ( res.state() != OSQLResult::Success )
134 return false; 131 return false;
135 132
136 update(); 133 update();
137 134
138 return true; 135 return true;
139} 136}
140 137
141void ODateBookAccessBackend_SQL::update() 138void ODateBookAccessBackend_SQL::update()
142{ 139{
143 140
144 QString qu = "select uid from datebook"; 141 QString qu = "select uid from datebook";
145 OSQLRawQuery raw( qu ); 142 OSQLRawQuery raw( qu );
146 OSQLResult res = m_driver->query( &raw ); 143 OSQLResult res = m_driver->query( &raw );
147 if ( res.state() != OSQLResult::Success ){ 144 if ( res.state() != OSQLResult::Success ){
148 // m_uids.clear(); 145 // m_uids.clear();
149 return; 146 return;
150 } 147 }
151 148
152 m_uids = extractUids( res ); 149 m_uids = extractUids( res );
153 150
154} 151}
155 152
156bool ODateBookAccessBackend_SQL::reload() 153bool ODateBookAccessBackend_SQL::reload()
157{ 154{
158 return load(); 155 return load();
159} 156}
160 157
161bool ODateBookAccessBackend_SQL::save() 158bool ODateBookAccessBackend_SQL::save()
162{ 159{
163 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers) 160 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers)
164} 161}
165 162
166QArray<int> ODateBookAccessBackend_SQL::allRecords()const 163QArray<int> ODateBookAccessBackend_SQL::allRecords()const
167{ 164{
168 return m_uids; 165 return m_uids;
169} 166}
170 167
171QArray<int> ODateBookAccessBackend_SQL::queryByExample(const OEvent&, int, const QDateTime& ) { 168QArray<int> ODateBookAccessBackend_SQL::queryByExample(const OEvent&, int, const QDateTime& ) {
172 return QArray<int>(); 169 return QArray<int>();
173} 170}
174 171
175void ODateBookAccessBackend_SQL::clear() 172void ODateBookAccessBackend_SQL::clear()
176{ 173{
177 QString qu = "drop table datebook;"; 174 QString qu = "drop table datebook;";
178 qu += "drop table custom_data;"; 175 qu += "drop table custom_data;";
179 176
180 OSQLRawQuery raw( qu ); 177 OSQLRawQuery raw( qu );
181 OSQLResult res = m_driver->query( &raw ); 178 OSQLResult res = m_driver->query( &raw );
182 179
183 reload(); 180 reload();
184} 181}
185 182
186 183
187OEvent ODateBookAccessBackend_SQL::find( int uid ) const{ 184OEvent ODateBookAccessBackend_SQL::find( int uid ) const{
188 QString qu = "select *"; 185 QString qu = "select *";
189 qu += "from datebook where uid = " + QString::number(uid); 186 qu += "from datebook where uid = " + QString::number(uid);
190 187
191 OSQLRawQuery raw( qu ); 188 OSQLRawQuery raw( qu );
192 OSQLResult res = m_driver->query( &raw ); 189 OSQLResult res = m_driver->query( &raw );
193 190
194 OSQLResultItem resItem = res.first(); 191 OSQLResultItem resItem = res.first();
195 192
196 // Create Map for date event and insert UID 193 // Create Map for date event and insert UID
197 QMap<int,QString> dateEventMap; 194 QMap<int,QString> dateEventMap;
198 dateEventMap.insert( OEvent::FUid, QString::number( uid ) ); 195 dateEventMap.insert( OEvent::FUid, QString::number( uid ) );
199 196
200 // Now insert the data out of the columns into the map. 197 // Now insert the data out of the columns into the map.
201 QMapConstIterator<int, QString> it; 198 QMapConstIterator<int, QString> it;
202 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){ 199 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){
203 dateEventMap.insert( m_reverseFieldMap[*it], resItem.data( *it ) ); 200 dateEventMap.insert( m_reverseFieldMap[*it], resItem.data( *it ) );
204 } 201 }
205 202
206 // Last step: Put map into date event and return it 203 // Last step: Put map into date event and return it
207 OEvent retDate( dateEventMap ); 204 OEvent retDate( dateEventMap );
208 205
209 return retDate; 206 return retDate;
210} 207}
211 208
212// FIXME: Speed up update of uid's.. 209// FIXME: Speed up update of uid's..
213bool ODateBookAccessBackend_SQL::add( const OEvent& ev ) 210bool ODateBookAccessBackend_SQL::add( const OEvent& ev )
214{ 211{
215 QMap<int,QString> eventMap = ev.toMap(); 212 QMap<int,QString> eventMap = ev.toMap();
216 213
217 QString qu = "insert into datebook VALUES( " + QString::number( ev.uid() ); 214 QString qu = "insert into datebook VALUES( " + QString::number( ev.uid() );
218 QMap<int, QString>::Iterator it; 215 QMap<int, QString>::Iterator it;
219 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){ 216 for ( it = ++m_fieldMap.begin(); it != m_fieldMap.end(); ++it ){
220 if ( !eventMap[it.key()].isEmpty() ) 217 if ( !eventMap[it.key()].isEmpty() )
221 qu += QString( ",\"%1\"" ).arg( eventMap[it.key()] ); 218 qu += QString( ",\"%1\"" ).arg( eventMap[it.key()] );
222 else 219 else
223 qu += QString( ",\"\"" ); 220 qu += QString( ",\"\"" );
224 } 221 }
225 qu += " );"; 222 qu += " );";
226 223
227 // Add custom entries 224 // Add custom entries
228 int id = 0; 225 int id = 0;
229 QMap<QString, QString> customMap = ev.toExtraMap(); 226 QMap<QString, QString> customMap = ev.toExtraMap();
230 for( QMap<QString, QString>::Iterator it = customMap.begin(); 227 for( QMap<QString, QString>::Iterator it = customMap.begin();
231 it != customMap.end(); ++it ){ 228 it != customMap.end(); ++it ){
232 qu += "insert into custom_data VALUES(" 229 qu += "insert into custom_data VALUES("
233 + QString::number( ev.uid() ) 230 + QString::number( ev.uid() )
234 + "," 231 + ","
235 + QString::number( id++ ) 232 + QString::number( id++ )
236 + ",'" 233 + ",'"
237 + it.key() //.latin1() 234 + it.key() //.latin1()
238 + "'," 235 + "',"
239 + "0" // Priority for future enhancements 236 + "0" // Priority for future enhancements
240 + ",'" 237 + ",'"
241 + it.data() //.latin1() 238 + it.data() //.latin1()
242 + "');"; 239 + "');";
243 } 240 }
244 qWarning("add %s", qu.latin1() ); 241 qWarning("add %s", qu.latin1() );
245 242
246 OSQLRawQuery raw( qu ); 243 OSQLRawQuery raw( qu );
247 OSQLResult res = m_driver->query( &raw ); 244 OSQLResult res = m_driver->query( &raw );
248 if ( res.state() != OSQLResult::Success ){ 245 if ( res.state() != OSQLResult::Success ){
249 return false; 246 return false;
250 } 247 }
251 248
252 // Update list of uid's 249 // Update list of uid's
253 update(); 250 update();
254 251
255 return true; 252 return true;
256} 253}
257 254
258// FIXME: Speed up update of uid's.. 255// FIXME: Speed up update of uid's..
259bool ODateBookAccessBackend_SQL::remove( int uid ) 256bool ODateBookAccessBackend_SQL::remove( int uid )
260{ 257{
261 QString qu = "DELETE from datebook where uid = " 258 QString qu = "DELETE from datebook where uid = "
262 + QString::number( uid ) + ";"; 259 + QString::number( uid ) + ";";
263 qu += "DELETE from custom_data where uid = " 260 qu += "DELETE from custom_data where uid = "
264 + QString::number( uid ) + ";"; 261 + QString::number( uid ) + ";";
265 262
266 OSQLRawQuery raw( qu ); 263 OSQLRawQuery raw( qu );
267 OSQLResult res = m_driver->query( &raw ); 264 OSQLResult res = m_driver->query( &raw );
268 if ( res.state() != OSQLResult::Success ){ 265 if ( res.state() != OSQLResult::Success ){
269 return false; 266 return false;
270 } 267 }
271 268
272 // Update list of uid's 269 // Update list of uid's
273 update(); 270 update();
274 271
275 return true; 272 return true;
276} 273}
277 274
278bool ODateBookAccessBackend_SQL::replace( const OEvent& ev ) 275bool ODateBookAccessBackend_SQL::replace( const OEvent& ev )
279{ 276{
280 remove( ev.uid() ); 277 remove( ev.uid() );
281 return add( ev ); 278 return add( ev );
282} 279}
283 280
284QArray<int> ODateBookAccessBackend_SQL::rawEvents()const 281QArray<int> ODateBookAccessBackend_SQL::rawEvents()const
285{ 282{
286 return allRecords(); 283 return allRecords();
287} 284}
288 285
289QArray<int> ODateBookAccessBackend_SQL::rawRepeats()const 286QArray<int> ODateBookAccessBackend_SQL::rawRepeats()const
290{ 287{
291 QString qu = "select uid from datebook where RType!=\"\" AND RType!=\"NoRepeat\""; 288 QString qu = "select uid from datebook where RType!=\"\" AND RType!=\"NoRepeat\"";
292 OSQLRawQuery raw( qu ); 289 OSQLRawQuery raw( qu );
293 OSQLResult res = m_driver->query( &raw ); 290 OSQLResult res = m_driver->query( &raw );
294 if ( res.state() != OSQLResult::Success ){ 291 if ( res.state() != OSQLResult::Success ){
295 QArray<int> nix; 292 QArray<int> nix;
296 return nix; 293 return nix;
297 } 294 }
298 295
299 return extractUids( res ); 296 return extractUids( res );
300} 297}
301 298
302QArray<int> ODateBookAccessBackend_SQL::nonRepeats()const 299QArray<int> ODateBookAccessBackend_SQL::nonRepeats()const
303{ 300{
304 QString qu = "select uid from datebook where RType=\"\" or RType=\"NoRepeat\""; 301 QString qu = "select uid from datebook where RType=\"\" or RType=\"NoRepeat\"";
305 OSQLRawQuery raw( qu ); 302 OSQLRawQuery raw( qu );
306 OSQLResult res = m_driver->query( &raw ); 303 OSQLResult res = m_driver->query( &raw );
307 if ( res.state() != OSQLResult::Success ){ 304 if ( res.state() != OSQLResult::Success ){
308 QArray<int> nix; 305 QArray<int> nix;
309 return nix; 306 return nix;
310 } 307 }
311 308
312 return extractUids( res ); 309 return extractUids( res );
313} 310}
314 311
315OEvent::ValueList ODateBookAccessBackend_SQL::directNonRepeats() 312OEvent::ValueList ODateBookAccessBackend_SQL::directNonRepeats()
316{ 313{
317 QArray<int> nonRepUids = nonRepeats(); 314 QArray<int> nonRepUids = nonRepeats();
318 OEvent::ValueList list; 315 OEvent::ValueList list;
319 316
320 for (uint i = 0; i < nonRepUids.count(); ++i ){ 317 for (uint i = 0; i < nonRepUids.count(); ++i ){
321 list.append( find( nonRepUids[i] ) ); 318 list.append( find( nonRepUids[i] ) );
322 } 319 }
323 320
324 return list; 321 return list;
325 322
326} 323}
327OEvent::ValueList ODateBookAccessBackend_SQL::directRawRepeats() 324OEvent::ValueList ODateBookAccessBackend_SQL::directRawRepeats()
328{ 325{
329 QArray<int> rawRepUids = rawRepeats(); 326 QArray<int> rawRepUids = rawRepeats();
330 OEvent::ValueList list; 327 OEvent::ValueList list;
331 328
332 for (uint i = 0; i < rawRepUids.count(); ++i ){ 329 for (uint i = 0; i < rawRepUids.count(); ++i ){
333 list.append( find( rawRepUids[i] ) ); 330 list.append( find( rawRepUids[i] ) );
334 } 331 }
335 332
336 return list; 333 return list;
337} 334}
338 335
339 336
340QArray<int> ODateBookAccessBackend_SQL::matchRegexp( const QRegExp &r ) const 337QArray<int> ODateBookAccessBackend_SQL::matchRegexp( const QRegExp &r ) const
341{ 338{
342 QArray<int> null; 339 QArray<int> null;
343 return null; 340 return null;
344} 341}
345 342
346/* ===== Private Functions ========================================== */ 343/* ===== Private Functions ========================================== */
347 344
348QArray<int> ODateBookAccessBackend_SQL::extractUids( OSQLResult& res ) const 345QArray<int> ODateBookAccessBackend_SQL::extractUids( OSQLResult& res ) const
349{ 346{
350 qWarning("extractUids"); 347 qWarning("extractUids");
351 QTime t; 348 QTime t;
352 t.start(); 349 t.start();
353 OSQLResultItem::ValueList list = res.results(); 350 OSQLResultItem::ValueList list = res.results();
354 OSQLResultItem::ValueList::Iterator it; 351 OSQLResultItem::ValueList::Iterator it;
355 QArray<int> ints(list.count() ); 352 QArray<int> ints(list.count() );
356 qWarning(" count = %d", list.count() ); 353 qWarning(" count = %d", list.count() );
357 354
358 int i = 0; 355 int i = 0;
359 for (it = list.begin(); it != list.end(); ++it ) { 356 for (it = list.begin(); it != list.end(); ++it ) {
360 ints[i] = (*it).data("uid").toInt(); 357 ints[i] = (*it).data("uid").toInt();
361 i++; 358 i++;
362 } 359 }
363 qWarning("extractUids ready: count2 = %d needs %d ms", i, t.elapsed() ); 360 qWarning("extractUids ready: count2 = %d needs %d ms", i, t.elapsed() );
364 361
365 return ints; 362 return ints;
366 363
367} 364}
365
366}
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend_sql.h b/libopie2/opiepim/backend/odatebookaccessbackend_sql.h
index f39e154..89939ef 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend_sql.h
+++ b/libopie2/opiepim/backend/odatebookaccessbackend_sql.h
@@ -1,62 +1,93 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_SQL__H 29#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_SQL__H
2#define OPIE_DATE_BOOK_ACCESS_BACKEND_SQL__H 30#define OPIE_DATE_BOOK_ACCESS_BACKEND_SQL__H
3 31
4#include <qmap.h> 32#include <qmap.h>
5#include <opie2/osqlresult.h> 33#include <opie2/osqlresult.h>
6 34
7#include "odatebookaccessbackend.h" 35#include <opie2/odatebookaccessbackend.h>
8 36
9class OSQLDriver; 37class OSQLDriver;
10 38
39namespace Opie {
11/** 40/**
12 * This is the default SQL implementation for DateBoook SQL storage 41 * This is the default SQL implementation for DateBoook SQL storage
13 * It fully implements the interface 42 * It fully implements the interface
14 * @see ODateBookAccessBackend 43 * @see ODateBookAccessBackend
15 * @see OPimAccessBackend 44 * @see OPimAccessBackend
16 */ 45 */
17class ODateBookAccessBackend_SQL : public ODateBookAccessBackend { 46class ODateBookAccessBackend_SQL : public ODateBookAccessBackend {
18public: 47public:
19 ODateBookAccessBackend_SQL( const QString& appName, 48 ODateBookAccessBackend_SQL( const QString& appName,
20 const QString& fileName = QString::null); 49 const QString& fileName = QString::null);
21 ~ODateBookAccessBackend_SQL(); 50 ~ODateBookAccessBackend_SQL();
22 51
23 bool load(); 52 bool load();
24 bool reload(); 53 bool reload();
25 bool save(); 54 bool save();
26 55
27 QArray<int> allRecords()const; 56 QArray<int> allRecords()const;
28 QArray<int> matchRegexp(const QRegExp &r) const; 57 QArray<int> matchRegexp(const QRegExp &r) const;
29 QArray<int> queryByExample( const OEvent&, int, const QDateTime& d = QDateTime() ); 58 QArray<int> queryByExample( const OEvent&, int, const QDateTime& d = QDateTime() );
30 OEvent find( int uid )const; 59 OEvent find( int uid )const;
31 void clear(); 60 void clear();
32 bool add( const OEvent& ev ); 61 bool add( const OEvent& ev );
33 bool remove( int uid ); 62 bool remove( int uid );
34 bool replace( const OEvent& ev ); 63 bool replace( const OEvent& ev );
35 64
36 QArray<UID> rawEvents()const; 65 QArray<UID> rawEvents()const;
37 QArray<UID> rawRepeats()const; 66 QArray<UID> rawRepeats()const;
38 QArray<UID> nonRepeats()const; 67 QArray<UID> nonRepeats()const;
39 68
40 OEvent::ValueList directNonRepeats(); 69 OEvent::ValueList directNonRepeats();
41 OEvent::ValueList directRawRepeats(); 70 OEvent::ValueList directRawRepeats();
42 71
43private: 72private:
44 bool loadFile(); 73 bool loadFile();
45 QString m_fileName; 74 QString m_fileName;
46 QArray<int> m_uids; 75 QArray<int> m_uids;
47 76
48 QMap<int, QString> m_fieldMap; 77 QMap<int, QString> m_fieldMap;
49 QMap<QString, int> m_reverseFieldMap; 78 QMap<QString, int> m_reverseFieldMap;
50 79
51 OSQLDriver* m_driver; 80 OSQLDriver* m_driver;
52 81
53 class Private; 82 class Private;
54 Private *d; 83 Private *d;
55 84
56 void initFields(); 85 void initFields();
57 void update(); 86 void update();
58 QArray<int> extractUids( OSQLResult& res ) const; 87 QArray<int> extractUids( OSQLResult& res ) const;
59 88
60}; 89};
61 90
91}
92
62#endif 93#endif
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend_xml.cpp b/libopie2/opiepim/backend/odatebookaccessbackend_xml.cpp
index 929d004..0ebda98 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend_xml.cpp
+++ b/libopie2/opiepim/backend/odatebookaccessbackend_xml.cpp
@@ -1,612 +1,645 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <errno.h> 29#include <errno.h>
2#include <fcntl.h> 30#include <fcntl.h>
3 31
4#include <stdio.h> 32#include <stdio.h>
5#include <stdlib.h> 33#include <stdlib.h>
6 34
7#include <sys/types.h> 35#include <sys/types.h>
8#include <sys/mman.h> 36#include <sys/mman.h>
9#include <sys/stat.h> 37#include <sys/stat.h>
10 38
11#include <unistd.h> 39#include <unistd.h>
12 40
13#include <qasciidict.h> 41#include <qasciidict.h>
14#include <qfile.h> 42#include <qfile.h>
15 43
16#include <qtopia/global.h> 44#include <qtopia/global.h>
17#include <qtopia/stringutil.h> 45#include <qtopia/stringutil.h>
18#include <qtopia/timeconversion.h> 46#include <qtopia/timeconversion.h>
19 47
20#include "opimnotifymanager.h" 48#include <opie2/opimnotifymanager.h>
21#include "orecur.h" 49#include <opie2/orecur.h>
22#include "otimezone.h" 50#include <opie2/otimezone.h>
23#include "odatebookaccessbackend_xml.h" 51#include <opie2/odatebookaccessbackend_xml.h>
52
53using namespace Opie;
24 54
25namespace { 55namespace {
26 // FROM TT again 56 // FROM TT again
27char *strstrlen(const char *haystack, int hLen, const char* needle, int nLen) 57char *strstrlen(const char *haystack, int hLen, const char* needle, int nLen)
28{ 58{
29 char needleChar; 59 char needleChar;
30 char haystackChar; 60 char haystackChar;
31 if (!needle || !haystack || !hLen || !nLen) 61 if (!needle || !haystack || !hLen || !nLen)
32 return 0; 62 return 0;
33 63
34 const char* hsearch = haystack; 64 const char* hsearch = haystack;
35 65
36 if ((needleChar = *needle++) != 0) { 66 if ((needleChar = *needle++) != 0) {
37 nLen--; //(to make up for needle++) 67 nLen--; //(to make up for needle++)
38 do { 68 do {
39 do { 69 do {
40 if ((haystackChar = *hsearch++) == 0) 70 if ((haystackChar = *hsearch++) == 0)
41 return (0); 71 return (0);
42 if (hsearch >= haystack + hLen) 72 if (hsearch >= haystack + hLen)
43 return (0); 73 return (0);
44 } while (haystackChar != needleChar); 74 } while (haystackChar != needleChar);
45 } while (strncmp(hsearch, needle, QMIN(hLen - (hsearch - haystack), nLen)) != 0); 75 } while (strncmp(hsearch, needle, QMIN(hLen - (hsearch - haystack), nLen)) != 0);
46 hsearch--; 76 hsearch--;
47 } 77 }
48 return ((char *)hsearch); 78 return ((char *)hsearch);
49} 79}
50} 80}
51 81
52namespace { 82namespace {
53 time_t start, end, created, rp_end; 83 time_t start, end, created, rp_end;
54 ORecur* rec; 84 ORecur* rec;
55 ORecur* recur() { 85 ORecur* recur() {
56 if (!rec) 86 if (!rec)
57 rec = new ORecur; 87 rec = new ORecur;
58 88
59 return rec; 89 return rec;
60 } 90 }
61 int alarmTime; 91 int alarmTime;
62 int snd; 92 int snd;
63 enum Attribute{ 93 enum Attribute{
64 FDescription = 0, 94 FDescription = 0,
65 FLocation, 95 FLocation,
66 FCategories, 96 FCategories,
67 FUid, 97 FUid,
68 FType, 98 FType,
69 FAlarm, 99 FAlarm,
70 FSound, 100 FSound,
71 FRType, 101 FRType,
72 FRWeekdays, 102 FRWeekdays,
73 FRPosition, 103 FRPosition,
74 FRFreq, 104 FRFreq,
75 FRHasEndDate, 105 FRHasEndDate,
76 FREndDate, 106 FREndDate,
77 FRStart, 107 FRStart,
78 FREnd, 108 FREnd,
79 FNote, 109 FNote,
80 FCreated, // Should't this be called FRCreated ? 110 FCreated, // Should't this be called FRCreated ?
81 FTimeZone, 111 FTimeZone,
82 FRecParent, 112 FRecParent,
83 FRecChildren, 113 FRecChildren,
84 FExceptions 114 FExceptions
85 }; 115 };
86 116
87 // FIXME: Use OEvent::toMap() here !! (eilers) 117 // FIXME: Use OEvent::toMap() here !! (eilers)
88 inline void save( const OEvent& ev, QString& buf ) { 118 inline void save( const OEvent& ev, QString& buf ) {
89 qWarning("Saving %d %s", ev.uid(), ev.description().latin1() ); 119 qWarning("Saving %d %s", ev.uid(), ev.description().latin1() );
90 buf += " description=\"" + Qtopia::escapeString(ev.description() ) + "\""; 120 buf += " description=\"" + Qtopia::escapeString(ev.description() ) + "\"";
91 if (!ev.location().isEmpty() ) 121 if (!ev.location().isEmpty() )
92 buf += " location=\"" + Qtopia::escapeString(ev.location() ) + "\""; 122 buf += " location=\"" + Qtopia::escapeString(ev.location() ) + "\"";
93 123
94 buf += " categories=\""+ Qtopia::escapeString( Qtopia::Record::idsToString( ev.categories() ) ) + "\""; 124 buf += " categories=\""+ Qtopia::escapeString( Qtopia::Record::idsToString( ev.categories() ) ) + "\"";
95 buf += " uid=\"" + QString::number( ev.uid() ) + "\""; 125 buf += " uid=\"" + QString::number( ev.uid() ) + "\"";
96 126
97 if (ev.isAllDay() ) 127 if (ev.isAllDay() )
98 buf += " type=\"AllDay\""; // is that all ?? (eilers) 128 buf += " type=\"AllDay\""; // is that all ?? (eilers)
99 129
100 if (ev.hasNotifiers() ) { 130 if (ev.hasNotifiers() ) {
101 OPimAlarm alarm = ev.notifiers().alarms()[0]; // take only the first 131 OPimAlarm alarm = ev.notifiers().alarms()[0]; // take only the first
102 int minutes = alarm.dateTime().secsTo( ev.startDateTime() ) / 60; 132 int minutes = alarm.dateTime().secsTo( ev.startDateTime() ) / 60;
103 buf += " alarm=\"" + QString::number(minutes) + "\" sound=\""; 133 buf += " alarm=\"" + QString::number(minutes) + "\" sound=\"";
104 if ( alarm.sound() == OPimAlarm::Loud ) 134 if ( alarm.sound() == OPimAlarm::Loud )
105 buf += "loud"; 135 buf += "loud";
106 else 136 else
107 buf += "silent"; 137 buf += "silent";
108 buf += "\""; 138 buf += "\"";
109 } 139 }
110 if ( ev.hasRecurrence() ) { 140 if ( ev.hasRecurrence() ) {
111 buf += ev.recurrence().toString(); 141 buf += ev.recurrence().toString();
112 } 142 }
113 143
114 /* 144 /*
115 * fscking timezones :) well, we'll first convert 145 * fscking timezones :) well, we'll first convert
116 * the QDateTime to a QDateTime in UTC time 146 * the QDateTime to a QDateTime in UTC time
117 * and then we'll create a nice time_t 147 * and then we'll create a nice time_t
118 */ 148 */
119 OTimeZone zone( ev.timeZone().isEmpty() ? OTimeZone::current() : ev.timeZone() ); 149 OTimeZone zone( ev.timeZone().isEmpty() ? OTimeZone::current() : ev.timeZone() );
120 buf += " start=\"" + QString::number( zone.fromUTCDateTime( zone.toDateTime( ev.startDateTime(), OTimeZone::utc() ) ) ) + "\""; 150 buf += " start=\"" + QString::number( zone.fromUTCDateTime( zone.toDateTime( ev.startDateTime(), OTimeZone::utc() ) ) ) + "\"";
121 buf += " end=\"" + QString::number( zone.fromUTCDateTime( zone.toDateTime( ev.endDateTime() , OTimeZone::utc() ) ) ) + "\""; 151 buf += " end=\"" + QString::number( zone.fromUTCDateTime( zone.toDateTime( ev.endDateTime() , OTimeZone::utc() ) ) ) + "\"";
122 if (!ev.note().isEmpty() ) { 152 if (!ev.note().isEmpty() ) {
123 buf += " note=\"" + Qtopia::escapeString( ev.note() ) + "\""; 153 buf += " note=\"" + Qtopia::escapeString( ev.note() ) + "\"";
124 } 154 }
125 155
126 buf += " timezone=\""; 156 buf += " timezone=\"";
127 if ( ev.timeZone().isEmpty() ) 157 if ( ev.timeZone().isEmpty() )
128 buf += "None"; 158 buf += "None";
129 else 159 else
130 buf += ev.timeZone(); 160 buf += ev.timeZone();
131 buf += "\""; 161 buf += "\"";
132 162
133 if (ev.parent() != 0 ) { 163 if (ev.parent() != 0 ) {
134 buf += " recparent=\""+QString::number(ev.parent() )+"\""; 164 buf += " recparent=\""+QString::number(ev.parent() )+"\"";
135 } 165 }
136 166
137 if (ev.children().count() != 0 ) { 167 if (ev.children().count() != 0 ) {
138 QArray<int> children = ev.children(); 168 QArray<int> children = ev.children();
139 buf += " recchildren=\""; 169 buf += " recchildren=\"";
140 for ( uint i = 0; i < children.count(); i++ ) { 170 for ( uint i = 0; i < children.count(); i++ ) {
141 if ( i != 0 ) buf += " "; 171 if ( i != 0 ) buf += " ";
142 buf += QString::number( children[i] ); 172 buf += QString::number( children[i] );
143 } 173 }
144 buf+= "\""; 174 buf+= "\"";
145 } 175 }
146 176
147 // skip custom writing 177 // skip custom writing
148 } 178 }
149 179
150 inline bool forAll( const QMap<int, OEvent>& list, QFile& file ) { 180 inline bool forAll( const QMap<int, OEvent>& list, QFile& file ) {
151 QMap<int, OEvent>::ConstIterator it; 181 QMap<int, OEvent>::ConstIterator it;
152 QString buf; 182 QString buf;
153 QCString str; 183 QCString str;
154 int total_written; 184 int total_written;
155 for ( it = list.begin(); it != list.end(); ++it ) { 185 for ( it = list.begin(); it != list.end(); ++it ) {
156 buf = "<event"; 186 buf = "<event";
157 save( it.data(), buf ); 187 save( it.data(), buf );
158 buf += " />\n"; 188 buf += " />\n";
159 str = buf.utf8(); 189 str = buf.utf8();
160 190
161 total_written = file.writeBlock(str.data(), str.length() ); 191 total_written = file.writeBlock(str.data(), str.length() );
162 if ( total_written != int(str.length() ) ) 192 if ( total_written != int(str.length() ) )
163 return false; 193 return false;
164 } 194 }
165 return true; 195 return true;
166 } 196 }
167} 197}
168 198
199namespace Opie {
169ODateBookAccessBackend_XML::ODateBookAccessBackend_XML( const QString& , 200ODateBookAccessBackend_XML::ODateBookAccessBackend_XML( const QString& ,
170 const QString& fileName ) 201 const QString& fileName )
171 : ODateBookAccessBackend() { 202 : ODateBookAccessBackend() {
172 m_name = fileName.isEmpty() ? Global::applicationFileName( "datebook", "datebook.xml" ) : fileName; 203 m_name = fileName.isEmpty() ? Global::applicationFileName( "datebook", "datebook.xml" ) : fileName;
173 m_changed = false; 204 m_changed = false;
174} 205}
175ODateBookAccessBackend_XML::~ODateBookAccessBackend_XML() { 206ODateBookAccessBackend_XML::~ODateBookAccessBackend_XML() {
176} 207}
177bool ODateBookAccessBackend_XML::load() { 208bool ODateBookAccessBackend_XML::load() {
178 return loadFile(); 209 return loadFile();
179} 210}
180bool ODateBookAccessBackend_XML::reload() { 211bool ODateBookAccessBackend_XML::reload() {
181 clear(); 212 clear();
182 return load(); 213 return load();
183} 214}
184bool ODateBookAccessBackend_XML::save() { 215bool ODateBookAccessBackend_XML::save() {
185 if (!m_changed) return true; 216 if (!m_changed) return true;
186 217
187 int total_written; 218 int total_written;
188 QString strFileNew = m_name + ".new"; 219 QString strFileNew = m_name + ".new";
189 220
190 QFile f( strFileNew ); 221 QFile f( strFileNew );
191 if (!f.open( IO_WriteOnly | IO_Raw ) ) return false; 222 if (!f.open( IO_WriteOnly | IO_Raw ) ) return false;
192 223
193 QString buf( "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" ); 224 QString buf( "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" );
194 buf += "<!DOCTYPE DATEBOOK><DATEBOOK>\n"; 225 buf += "<!DOCTYPE DATEBOOK><DATEBOOK>\n";
195 buf += "<events>\n"; 226 buf += "<events>\n";
196 QCString str = buf.utf8(); 227 QCString str = buf.utf8();
197 total_written = f.writeBlock( str.data(), str.length() ); 228 total_written = f.writeBlock( str.data(), str.length() );
198 if ( total_written != int(str.length() ) ) { 229 if ( total_written != int(str.length() ) ) {
199 f.close(); 230 f.close();
200 QFile::remove( strFileNew ); 231 QFile::remove( strFileNew );
201 return false; 232 return false;
202 } 233 }
203 234
204 if (!forAll( m_raw, f ) ) { 235 if (!forAll( m_raw, f ) ) {
205 f.close(); 236 f.close();
206 QFile::remove( strFileNew ); 237 QFile::remove( strFileNew );
207 return false; 238 return false;
208 } 239 }
209 if (!forAll( m_rep, f ) ) { 240 if (!forAll( m_rep, f ) ) {
210 f.close(); 241 f.close();
211 QFile::remove( strFileNew ); 242 QFile::remove( strFileNew );
212 return false; 243 return false;
213 } 244 }
214 245
215 buf = "</events>\n</DATEBOOK>\n"; 246 buf = "</events>\n</DATEBOOK>\n";
216 str = buf.utf8(); 247 str = buf.utf8();
217 total_written = f.writeBlock( str.data(), str.length() ); 248 total_written = f.writeBlock( str.data(), str.length() );
218 if ( total_written != int(str.length() ) ) { 249 if ( total_written != int(str.length() ) ) {
219 f.close(); 250 f.close();
220 QFile::remove( strFileNew ); 251 QFile::remove( strFileNew );
221 return false; 252 return false;
222 } 253 }
223 f.close(); 254 f.close();
224 255
225 if ( ::rename( strFileNew, m_name ) < 0 ) { 256 if ( ::rename( strFileNew, m_name ) < 0 ) {
226 QFile::remove( strFileNew ); 257 QFile::remove( strFileNew );
227 return false; 258 return false;
228 } 259 }
229 260
230 m_changed = false; 261 m_changed = false;
231 return true; 262 return true;
232} 263}
233QArray<int> ODateBookAccessBackend_XML::allRecords()const { 264QArray<int> ODateBookAccessBackend_XML::allRecords()const {
234 QArray<int> ints( m_raw.count()+ m_rep.count() ); 265 QArray<int> ints( m_raw.count()+ m_rep.count() );
235 uint i = 0; 266 uint i = 0;
236 QMap<int, OEvent>::ConstIterator it; 267 QMap<int, OEvent>::ConstIterator it;
237 268
238 for ( it = m_raw.begin(); it != m_raw.end(); ++it ) { 269 for ( it = m_raw.begin(); it != m_raw.end(); ++it ) {
239 ints[i] = it.key(); 270 ints[i] = it.key();
240 i++; 271 i++;
241 } 272 }
242 for ( it = m_rep.begin(); it != m_rep.end(); ++it ) { 273 for ( it = m_rep.begin(); it != m_rep.end(); ++it ) {
243 ints[i] = it.key(); 274 ints[i] = it.key();
244 i++; 275 i++;
245 } 276 }
246 277
247 return ints; 278 return ints;
248} 279}
249QArray<int> ODateBookAccessBackend_XML::queryByExample(const OEvent&, int, const QDateTime& ) { 280QArray<int> ODateBookAccessBackend_XML::queryByExample(const OEvent&, int, const QDateTime& ) {
250 return QArray<int>(); 281 return QArray<int>();
251} 282}
252void ODateBookAccessBackend_XML::clear() { 283void ODateBookAccessBackend_XML::clear() {
253 m_changed = true; 284 m_changed = true;
254 m_raw.clear(); 285 m_raw.clear();
255 m_rep.clear(); 286 m_rep.clear();
256} 287}
257OEvent ODateBookAccessBackend_XML::find( int uid ) const{ 288OEvent ODateBookAccessBackend_XML::find( int uid ) const{
258 if ( m_raw.contains( uid ) ) 289 if ( m_raw.contains( uid ) )
259 return m_raw[uid]; 290 return m_raw[uid];
260 else 291 else
261 return m_rep[uid]; 292 return m_rep[uid];
262} 293}
263bool ODateBookAccessBackend_XML::add( const OEvent& ev ) { 294bool ODateBookAccessBackend_XML::add( const OEvent& ev ) {
264 m_changed = true; 295 m_changed = true;
265 if (ev.hasRecurrence() ) 296 if (ev.hasRecurrence() )
266 m_rep.insert( ev.uid(), ev ); 297 m_rep.insert( ev.uid(), ev );
267 else 298 else
268 m_raw.insert( ev.uid(), ev ); 299 m_raw.insert( ev.uid(), ev );
269 300
270 return true; 301 return true;
271} 302}
272bool ODateBookAccessBackend_XML::remove( int uid ) { 303bool ODateBookAccessBackend_XML::remove( int uid ) {
273 m_changed = true; 304 m_changed = true;
274 m_rep.remove( uid ); 305 m_rep.remove( uid );
275 m_rep.remove( uid ); 306 m_rep.remove( uid );
276 307
277 return true; 308 return true;
278} 309}
279bool ODateBookAccessBackend_XML::replace( const OEvent& ev ) { 310bool ODateBookAccessBackend_XML::replace( const OEvent& ev ) {
280 replace( ev.uid() ); // ??? Shouldn't this be "remove( ev.uid() ) ??? (eilers) 311 replace( ev.uid() ); // ??? Shouldn't this be "remove( ev.uid() ) ??? (eilers)
281 return add( ev ); 312 return add( ev );
282} 313}
283QArray<int> ODateBookAccessBackend_XML::rawEvents()const { 314QArray<int> ODateBookAccessBackend_XML::rawEvents()const {
284 return allRecords(); 315 return allRecords();
285} 316}
286QArray<int> ODateBookAccessBackend_XML::rawRepeats()const { 317QArray<int> ODateBookAccessBackend_XML::rawRepeats()const {
287 QArray<int> ints( m_rep.count() ); 318 QArray<int> ints( m_rep.count() );
288 uint i = 0; 319 uint i = 0;
289 QMap<int, OEvent>::ConstIterator it; 320 QMap<int, OEvent>::ConstIterator it;
290 321
291 for ( it = m_rep.begin(); it != m_rep.end(); ++it ) { 322 for ( it = m_rep.begin(); it != m_rep.end(); ++it ) {
292 ints[i] = it.key(); 323 ints[i] = it.key();
293 i++; 324 i++;
294 } 325 }
295 326
296 return ints; 327 return ints;
297} 328}
298QArray<int> ODateBookAccessBackend_XML::nonRepeats()const { 329QArray<int> ODateBookAccessBackend_XML::nonRepeats()const {
299 QArray<int> ints( m_raw.count() ); 330 QArray<int> ints( m_raw.count() );
300 uint i = 0; 331 uint i = 0;
301 QMap<int, OEvent>::ConstIterator it; 332 QMap<int, OEvent>::ConstIterator it;
302 333
303 for ( it = m_raw.begin(); it != m_raw.end(); ++it ) { 334 for ( it = m_raw.begin(); it != m_raw.end(); ++it ) {
304 ints[i] = it.key(); 335 ints[i] = it.key();
305 i++; 336 i++;
306 } 337 }
307 338
308 return ints; 339 return ints;
309} 340}
310OEvent::ValueList ODateBookAccessBackend_XML::directNonRepeats() { 341OEvent::ValueList ODateBookAccessBackend_XML::directNonRepeats() {
311 OEvent::ValueList list; 342 OEvent::ValueList list;
312 QMap<int, OEvent>::ConstIterator it; 343 QMap<int, OEvent>::ConstIterator it;
313 for (it = m_raw.begin(); it != m_raw.end(); ++it ) 344 for (it = m_raw.begin(); it != m_raw.end(); ++it )
314 list.append( it.data() ); 345 list.append( it.data() );
315 346
316 return list; 347 return list;
317} 348}
318OEvent::ValueList ODateBookAccessBackend_XML::directRawRepeats() { 349OEvent::ValueList ODateBookAccessBackend_XML::directRawRepeats() {
319 OEvent::ValueList list; 350 OEvent::ValueList list;
320 QMap<int, OEvent>::ConstIterator it; 351 QMap<int, OEvent>::ConstIterator it;
321 for (it = m_rep.begin(); it != m_rep.end(); ++it ) 352 for (it = m_rep.begin(); it != m_rep.end(); ++it )
322 list.append( it.data() ); 353 list.append( it.data() );
323 354
324 return list; 355 return list;
325} 356}
326 357
327// FIXME: Use OEvent::fromMap() (eilers) 358// FIXME: Use OEvent::fromMap() (eilers)
328bool ODateBookAccessBackend_XML::loadFile() { 359bool ODateBookAccessBackend_XML::loadFile() {
329 m_changed = false; 360 m_changed = false;
330 361
331 int fd = ::open( QFile::encodeName(m_name).data(), O_RDONLY ); 362 int fd = ::open( QFile::encodeName(m_name).data(), O_RDONLY );
332 if ( fd < 0 ) return false; 363 if ( fd < 0 ) return false;
333 364
334 struct stat attribute; 365 struct stat attribute;
335 if ( ::fstat(fd, &attribute ) == -1 ) { 366 if ( ::fstat(fd, &attribute ) == -1 ) {
336 ::close( fd ); 367 ::close( fd );
337 return false; 368 return false;
338 } 369 }
339 void* map_addr = ::mmap(NULL, attribute.st_size, PROT_READ, MAP_SHARED, fd, 0 ); 370 void* map_addr = ::mmap(NULL, attribute.st_size, PROT_READ, MAP_SHARED, fd, 0 );
340 if ( map_addr == ( (caddr_t)-1) ) { 371 if ( map_addr == ( (caddr_t)-1) ) {
341 ::close( fd ); 372 ::close( fd );
342 return false; 373 return false;
343 } 374 }
344 375
345 ::madvise( map_addr, attribute.st_size, MADV_SEQUENTIAL ); 376 ::madvise( map_addr, attribute.st_size, MADV_SEQUENTIAL );
346 ::close( fd ); 377 ::close( fd );
347 378
348 QAsciiDict<int> dict(FExceptions+1); 379 QAsciiDict<int> dict(FExceptions+1);
349 dict.setAutoDelete( true ); 380 dict.setAutoDelete( true );
350 dict.insert( "description", new int(FDescription) ); 381 dict.insert( "description", new int(FDescription) );
351 dict.insert( "location", new int(FLocation) ); 382 dict.insert( "location", new int(FLocation) );
352 dict.insert( "categories", new int(FCategories) ); 383 dict.insert( "categories", new int(FCategories) );
353 dict.insert( "uid", new int(FUid) ); 384 dict.insert( "uid", new int(FUid) );
354 dict.insert( "type", new int(FType) ); 385 dict.insert( "type", new int(FType) );
355 dict.insert( "alarm", new int(FAlarm) ); 386 dict.insert( "alarm", new int(FAlarm) );
356 dict.insert( "sound", new int(FSound) ); 387 dict.insert( "sound", new int(FSound) );
357 dict.insert( "rtype", new int(FRType) ); 388 dict.insert( "rtype", new int(FRType) );
358 dict.insert( "rweekdays", new int(FRWeekdays) ); 389 dict.insert( "rweekdays", new int(FRWeekdays) );
359 dict.insert( "rposition", new int(FRPosition) ); 390 dict.insert( "rposition", new int(FRPosition) );
360 dict.insert( "rfreq", new int(FRFreq) ); 391 dict.insert( "rfreq", new int(FRFreq) );
361 dict.insert( "rhasenddate", new int(FRHasEndDate) ); 392 dict.insert( "rhasenddate", new int(FRHasEndDate) );
362 dict.insert( "enddt", new int(FREndDate) ); 393 dict.insert( "enddt", new int(FREndDate) );
363 dict.insert( "start", new int(FRStart) ); 394 dict.insert( "start", new int(FRStart) );
364 dict.insert( "end", new int(FREnd) ); 395 dict.insert( "end", new int(FREnd) );
365 dict.insert( "note", new int(FNote) ); 396 dict.insert( "note", new int(FNote) );
366 dict.insert( "created", new int(FCreated) ); // Shouldn't this be FRCreated ?? 397 dict.insert( "created", new int(FCreated) ); // Shouldn't this be FRCreated ??
367 dict.insert( "recparent", new int(FRecParent) ); 398 dict.insert( "recparent", new int(FRecParent) );
368 dict.insert( "recchildren", new int(FRecChildren) ); 399 dict.insert( "recchildren", new int(FRecChildren) );
369 dict.insert( "exceptions", new int(FExceptions) ); 400 dict.insert( "exceptions", new int(FExceptions) );
370 dict.insert( "timezone", new int(FTimeZone) ); 401 dict.insert( "timezone", new int(FTimeZone) );
371 402
372 char* dt = (char*)map_addr; 403 char* dt = (char*)map_addr;
373 int len = attribute.st_size; 404 int len = attribute.st_size;
374 int i = 0; 405 int i = 0;
375 char* point; 406 char* point;
376 const char* collectionString = "<event "; 407 const char* collectionString = "<event ";
377 int strLen = ::strlen(collectionString); 408 int strLen = ::strlen(collectionString);
378 int *find; 409 int *find;
379 while ( ( point = ::strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0 ) { 410 while ( ( point = ::strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0 ) {
380 i = point -dt; 411 i = point -dt;
381 i+= strLen; 412 i+= strLen;
382 413
383 alarmTime = -1; 414 alarmTime = -1;
384 snd = 0; // silent 415 snd = 0; // silent
385 416
386 OEvent ev; 417 OEvent ev;
387 rec = 0; 418 rec = 0;
388 419
389 while ( TRUE ) { 420 while ( TRUE ) {
390 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') ) 421 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') )
391 ++i; 422 ++i;
392 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') ) 423 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') )
393 break; 424 break;
394 425
395 426
396 // we have another attribute, read it. 427 // we have another attribute, read it.
397 int j = i; 428 int j = i;
398 while ( j < len && dt[j] != '=' ) 429 while ( j < len && dt[j] != '=' )
399 ++j; 430 ++j;
400 QCString attr( dt+i, j-i+1); 431 QCString attr( dt+i, j-i+1);
401 432
402 i = ++j; // skip = 433 i = ++j; // skip =
403 434
404 // find the start of quotes 435 // find the start of quotes
405 while ( i < len && dt[i] != '"' ) 436 while ( i < len && dt[i] != '"' )
406 ++i; 437 ++i;
407 j = ++i; 438 j = ++i;
408 439
409 bool haveUtf = FALSE; 440 bool haveUtf = FALSE;
410 bool haveEnt = FALSE; 441 bool haveEnt = FALSE;
411 while ( j < len && dt[j] != '"' ) { 442 while ( j < len && dt[j] != '"' ) {
412 if ( ((unsigned char)dt[j]) > 0x7f ) 443 if ( ((unsigned char)dt[j]) > 0x7f )
413 haveUtf = TRUE; 444 haveUtf = TRUE;
414 if ( dt[j] == '&' ) 445 if ( dt[j] == '&' )
415 haveEnt = TRUE; 446 haveEnt = TRUE;
416 ++j; 447 ++j;
417 } 448 }
418 if ( i == j ) { 449 if ( i == j ) {
419 // empty value 450 // empty value
420 i = j + 1; 451 i = j + 1;
421 continue; 452 continue;
422 } 453 }
423 454
424 QCString value( dt+i, j-i+1 ); 455 QCString value( dt+i, j-i+1 );
425 i = j + 1; 456 i = j + 1;
426 457
427 QString str = (haveUtf ? QString::fromUtf8( value ) 458 QString str = (haveUtf ? QString::fromUtf8( value )
428 : QString::fromLatin1( value ) ); 459 : QString::fromLatin1( value ) );
429 if ( haveEnt ) 460 if ( haveEnt )
430 str = Qtopia::plainString( str ); 461 str = Qtopia::plainString( str );
431 462
432 /* 463 /*
433 * add key + value 464 * add key + value
434 */ 465 */
435 find = dict[attr.data()]; 466 find = dict[attr.data()];
436 if (!find) 467 if (!find)
437 ev.setCustomField( attr, str ); 468 ev.setCustomField( attr, str );
438 else { 469 else {
439 setField( ev, *find, str ); 470 setField( ev, *find, str );
440 } 471 }
441 } 472 }
442 /* time to finalize */ 473 /* time to finalize */
443 finalizeRecord( ev ); 474 finalizeRecord( ev );
444 delete rec; 475 delete rec;
445 } 476 }
446 ::munmap(map_addr, attribute.st_size ); 477 ::munmap(map_addr, attribute.st_size );
447 m_changed = false; // changed during add 478 m_changed = false; // changed during add
448 479
449 return true; 480 return true;
450} 481}
451 482
452// FIXME: Use OEvent::fromMap() which makes this obsolete.. (eilers) 483// FIXME: Use OEvent::fromMap() which makes this obsolete.. (eilers)
453void ODateBookAccessBackend_XML::finalizeRecord( OEvent& ev ) { 484void ODateBookAccessBackend_XML::finalizeRecord( OEvent& ev ) {
454 /* AllDay is alway in UTC */ 485 /* AllDay is alway in UTC */
455 if ( ev.isAllDay() ) { 486 if ( ev.isAllDay() ) {
456 OTimeZone utc = OTimeZone::utc(); 487 OTimeZone utc = OTimeZone::utc();
457 ev.setStartDateTime( utc.fromUTCDateTime( start ) ); 488 ev.setStartDateTime( utc.fromUTCDateTime( start ) );
458 ev.setEndDateTime ( utc.fromUTCDateTime( end ) ); 489 ev.setEndDateTime ( utc.fromUTCDateTime( end ) );
459 ev.setTimeZone( "UTC"); // make sure it is really utc 490 ev.setTimeZone( "UTC"); // make sure it is really utc
460 }else { 491 }else {
461 /* to current date time */ 492 /* to current date time */
462 // qWarning(" Start is %d", start ); 493 // qWarning(" Start is %d", start );
463 OTimeZone zone( ev.timeZone().isEmpty() ? OTimeZone::current() : ev.timeZone() ); 494 OTimeZone zone( ev.timeZone().isEmpty() ? OTimeZone::current() : ev.timeZone() );
464 QDateTime date = zone.toDateTime( start ); 495 QDateTime date = zone.toDateTime( start );
465 qWarning(" Start is %s", date.toString().latin1() ); 496 qWarning(" Start is %s", date.toString().latin1() );
466 ev.setStartDateTime( zone.toDateTime( date, OTimeZone::current() ) ); 497 ev.setStartDateTime( zone.toDateTime( date, OTimeZone::current() ) );
467 498
468 date = zone.toDateTime( end ); 499 date = zone.toDateTime( end );
469 ev.setEndDateTime ( zone.toDateTime( date, OTimeZone::current() ) ); 500 ev.setEndDateTime ( zone.toDateTime( date, OTimeZone::current() ) );
470 } 501 }
471 if ( rec && rec->doesRecur() ) { 502 if ( rec && rec->doesRecur() ) {
472 OTimeZone utc = OTimeZone::utc(); 503 OTimeZone utc = OTimeZone::utc();
473 ORecur recu( *rec ); // call copy c'tor; 504 ORecur recu( *rec ); // call copy c'tor;
474 recu.setEndDate ( utc.fromUTCDateTime( rp_end ).date() ); 505 recu.setEndDate ( utc.fromUTCDateTime( rp_end ).date() );
475 recu.setCreatedDateTime( utc.fromUTCDateTime( created ) ); 506 recu.setCreatedDateTime( utc.fromUTCDateTime( created ) );
476 recu.setStart( ev.startDateTime().date() ); 507 recu.setStart( ev.startDateTime().date() );
477 ev.setRecurrence( recu ); 508 ev.setRecurrence( recu );
478 } 509 }
479 510
480 if (alarmTime != -1 ) { 511 if (alarmTime != -1 ) {
481 QDateTime dt = ev.startDateTime().addSecs( -1*alarmTime*60 ); 512 QDateTime dt = ev.startDateTime().addSecs( -1*alarmTime*60 );
482 OPimAlarm al( snd , dt ); 513 OPimAlarm al( snd , dt );
483 ev.notifiers().add( al ); 514 ev.notifiers().add( al );
484 } 515 }
485 if ( m_raw.contains( ev.uid() ) || m_rep.contains( ev.uid() ) ) { 516 if ( m_raw.contains( ev.uid() ) || m_rep.contains( ev.uid() ) ) {
486 qWarning("already contains assign uid"); 517 qWarning("already contains assign uid");
487 ev.setUid( 1 ); 518 ev.setUid( 1 );
488 } 519 }
489 qWarning("addind %d %s", ev.uid(), ev.description().latin1() ); 520 qWarning("addind %d %s", ev.uid(), ev.description().latin1() );
490 if ( ev.hasRecurrence() ) 521 if ( ev.hasRecurrence() )
491 m_rep.insert( ev.uid(), ev ); 522 m_rep.insert( ev.uid(), ev );
492 else 523 else
493 m_raw.insert( ev.uid(), ev ); 524 m_raw.insert( ev.uid(), ev );
494 525
495} 526}
496void ODateBookAccessBackend_XML::setField( OEvent& e, int id, const QString& value) { 527void ODateBookAccessBackend_XML::setField( OEvent& e, int id, const QString& value) {
497// qWarning(" setting %s", value.latin1() ); 528// qWarning(" setting %s", value.latin1() );
498 switch( id ) { 529 switch( id ) {
499 case FDescription: 530 case FDescription:
500 e.setDescription( value ); 531 e.setDescription( value );
501 break; 532 break;
502 case FLocation: 533 case FLocation:
503 e.setLocation( value ); 534 e.setLocation( value );
504 break; 535 break;
505 case FCategories: 536 case FCategories:
506 e.setCategories( e.idsFromString( value ) ); 537 e.setCategories( e.idsFromString( value ) );
507 break; 538 break;
508 case FUid: 539 case FUid:
509 e.setUid( value.toInt() ); 540 e.setUid( value.toInt() );
510 break; 541 break;
511 case FType: 542 case FType:
512 if ( value == "AllDay" ) { 543 if ( value == "AllDay" ) {
513 e.setAllDay( true ); 544 e.setAllDay( true );
514 e.setTimeZone( "UTC" ); 545 e.setTimeZone( "UTC" );
515 } 546 }
516 break; 547 break;
517 case FAlarm: 548 case FAlarm:
518 alarmTime = value.toInt(); 549 alarmTime = value.toInt();
519 break; 550 break;
520 case FSound: 551 case FSound:
521 snd = value == "loud" ? OPimAlarm::Loud : OPimAlarm::Silent; 552 snd = value == "loud" ? OPimAlarm::Loud : OPimAlarm::Silent;
522 break; 553 break;
523 // recurrence stuff 554 // recurrence stuff
524 case FRType: 555 case FRType:
525 if ( value == "Daily" ) 556 if ( value == "Daily" )
526 recur()->setType( ORecur::Daily ); 557 recur()->setType( ORecur::Daily );
527 else if ( value == "Weekly" ) 558 else if ( value == "Weekly" )
528 recur()->setType( ORecur::Weekly); 559 recur()->setType( ORecur::Weekly);
529 else if ( value == "MonthlyDay" ) 560 else if ( value == "MonthlyDay" )
530 recur()->setType( ORecur::MonthlyDay ); 561 recur()->setType( ORecur::MonthlyDay );
531 else if ( value == "MonthlyDate" ) 562 else if ( value == "MonthlyDate" )
532 recur()->setType( ORecur::MonthlyDate ); 563 recur()->setType( ORecur::MonthlyDate );
533 else if ( value == "Yearly" ) 564 else if ( value == "Yearly" )
534 recur()->setType( ORecur::Yearly ); 565 recur()->setType( ORecur::Yearly );
535 else 566 else
536 recur()->setType( ORecur::NoRepeat ); 567 recur()->setType( ORecur::NoRepeat );
537 break; 568 break;
538 case FRWeekdays: 569 case FRWeekdays:
539 recur()->setDays( value.toInt() ); 570 recur()->setDays( value.toInt() );
540 break; 571 break;
541 case FRPosition: 572 case FRPosition:
542 recur()->setPosition( value.toInt() ); 573 recur()->setPosition( value.toInt() );
543 break; 574 break;
544 case FRFreq: 575 case FRFreq:
545 recur()->setFrequency( value.toInt() ); 576 recur()->setFrequency( value.toInt() );
546 break; 577 break;
547 case FRHasEndDate: 578 case FRHasEndDate:
548 recur()->setHasEndDate( value.toInt() ); 579 recur()->setHasEndDate( value.toInt() );
549 break; 580 break;
550 case FREndDate: { 581 case FREndDate: {
551 rp_end = (time_t) value.toLong(); 582 rp_end = (time_t) value.toLong();
552 break; 583 break;
553 } 584 }
554 case FRStart: { 585 case FRStart: {
555 start = (time_t) value.toLong(); 586 start = (time_t) value.toLong();
556 break; 587 break;
557 } 588 }
558 case FREnd: { 589 case FREnd: {
559 end = ( (time_t) value.toLong() ); 590 end = ( (time_t) value.toLong() );
560 break; 591 break;
561 } 592 }
562 case FNote: 593 case FNote:
563 e.setNote( value ); 594 e.setNote( value );
564 break; 595 break;
565 case FCreated: 596 case FCreated:
566 created = value.toInt(); 597 created = value.toInt();
567 break; 598 break;
568 case FRecParent: 599 case FRecParent:
569 e.setParent( value.toInt() ); 600 e.setParent( value.toInt() );
570 break; 601 break;
571 case FRecChildren:{ 602 case FRecChildren:{
572 QStringList list = QStringList::split(' ', value ); 603 QStringList list = QStringList::split(' ', value );
573 for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { 604 for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) {
574 e.addChild( (*it).toInt() ); 605 e.addChild( (*it).toInt() );
575 } 606 }
576 } 607 }
577 break; 608 break;
578 case FExceptions:{ 609 case FExceptions:{
579 QStringList list = QStringList::split(' ', value ); 610 QStringList list = QStringList::split(' ', value );
580 for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { 611 for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) {
581 QDate date( (*it).left(4).toInt(), (*it).mid(4, 2).toInt(), (*it).right(2).toInt() ); 612 QDate date( (*it).left(4).toInt(), (*it).mid(4, 2).toInt(), (*it).right(2).toInt() );
582 qWarning("adding exception %s", date.toString().latin1() ); 613 qWarning("adding exception %s", date.toString().latin1() );
583 recur()->exceptions().append( date ); 614 recur()->exceptions().append( date );
584 } 615 }
585 } 616 }
586 break; 617 break;
587 case FTimeZone: 618 case FTimeZone:
588 if ( value != "None" ) 619 if ( value != "None" )
589 e.setTimeZone( value ); 620 e.setTimeZone( value );
590 break; 621 break;
591 default: 622 default:
592 break; 623 break;
593 } 624 }
594} 625}
595QArray<int> ODateBookAccessBackend_XML::matchRegexp( const QRegExp &r ) const 626QArray<int> ODateBookAccessBackend_XML::matchRegexp( const QRegExp &r ) const
596{ 627{
597 QArray<int> m_currentQuery( m_raw.count()+ m_rep.count() ); 628 QArray<int> m_currentQuery( m_raw.count()+ m_rep.count() );
598 uint arraycounter = 0; 629 uint arraycounter = 0;
599 QMap<int, OEvent>::ConstIterator it; 630 QMap<int, OEvent>::ConstIterator it;
600 631
601 for ( it = m_raw.begin(); it != m_raw.end(); ++it ) 632 for ( it = m_raw.begin(); it != m_raw.end(); ++it )
602 if ( it.data().match( r ) ) 633 if ( it.data().match( r ) )
603 m_currentQuery[arraycounter++] = it.data().uid(); 634 m_currentQuery[arraycounter++] = it.data().uid();
604 for ( it = m_rep.begin(); it != m_rep.end(); ++it ) 635 for ( it = m_rep.begin(); it != m_rep.end(); ++it )
605 if ( it.data().match( r ) ) 636 if ( it.data().match( r ) )
606 m_currentQuery[arraycounter++] = it.data().uid(); 637 m_currentQuery[arraycounter++] = it.data().uid();
607 638
608 // Shrink to fit.. 639 // Shrink to fit..
609 m_currentQuery.resize(arraycounter); 640 m_currentQuery.resize(arraycounter);
610 641
611 return m_currentQuery; 642 return m_currentQuery;
612} 643}
644
645}
diff --git a/libopie2/opiepim/backend/odatebookaccessbackend_xml.h b/libopie2/opiepim/backend/odatebookaccessbackend_xml.h
index a5cc0fc..29f5f4f 100644
--- a/libopie2/opiepim/backend/odatebookaccessbackend_xml.h
+++ b/libopie2/opiepim/backend/odatebookaccessbackend_xml.h
@@ -1,55 +1,86 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_XML__H 29#ifndef OPIE_DATE_BOOK_ACCESS_BACKEND_XML__H
2#define OPIE_DATE_BOOK_ACCESS_BACKEND_XML__H 30#define OPIE_DATE_BOOK_ACCESS_BACKEND_XML__H
3 31
4#include <qmap.h> 32#include <qmap.h>
5 33
6#include "odatebookaccessbackend.h" 34#include <opie2/odatebookaccessbackend.h>
7 35
36namespace Opie {
8/** 37/**
9 * This is the default XML implementation for DateBoook XML storage 38 * This is the default XML implementation for DateBoook XML storage
10 * It fully implements the interface 39 * It fully implements the interface
11 * @see ODateBookAccessBackend 40 * @see ODateBookAccessBackend
12 * @see OPimAccessBackend 41 * @see OPimAccessBackend
13 */ 42 */
14class ODateBookAccessBackend_XML : public ODateBookAccessBackend { 43class ODateBookAccessBackend_XML : public ODateBookAccessBackend {
15public: 44public:
16 ODateBookAccessBackend_XML( const QString& appName, 45 ODateBookAccessBackend_XML( const QString& appName,
17 const QString& fileName = QString::null); 46 const QString& fileName = QString::null);
18 ~ODateBookAccessBackend_XML(); 47 ~ODateBookAccessBackend_XML();
19 48
20 bool load(); 49 bool load();
21 bool reload(); 50 bool reload();
22 bool save(); 51 bool save();
23 52
24 QArray<int> allRecords()const; 53 QArray<int> allRecords()const;
25 QArray<int> matchRegexp(const QRegExp &r) const; 54 QArray<int> matchRegexp(const QRegExp &r) const;
26 QArray<int> queryByExample( const OEvent&, int, const QDateTime& d = QDateTime() ); 55 QArray<int> queryByExample( const OEvent&, int, const QDateTime& d = QDateTime() );
27 OEvent find( int uid )const; 56 OEvent find( int uid )const;
28 void clear(); 57 void clear();
29 bool add( const OEvent& ev ); 58 bool add( const OEvent& ev );
30 bool remove( int uid ); 59 bool remove( int uid );
31 bool replace( const OEvent& ev ); 60 bool replace( const OEvent& ev );
32 61
33 QArray<UID> rawEvents()const; 62 QArray<UID> rawEvents()const;
34 QArray<UID> rawRepeats()const; 63 QArray<UID> rawRepeats()const;
35 QArray<UID> nonRepeats()const; 64 QArray<UID> nonRepeats()const;
36 65
37 OEvent::ValueList directNonRepeats(); 66 OEvent::ValueList directNonRepeats();
38 OEvent::ValueList directRawRepeats(); 67 OEvent::ValueList directRawRepeats();
39 68
40private: 69private:
41 bool m_changed :1 ; 70 bool m_changed :1 ;
42 bool loadFile(); 71 bool loadFile();
43 inline void finalizeRecord( OEvent& ev ); 72 inline void finalizeRecord( OEvent& ev );
44 inline void setField( OEvent&, int field, const QString& val ); 73 inline void setField( OEvent&, int field, const QString& val );
45 QString m_name; 74 QString m_name;
46 QMap<int, OEvent> m_raw; 75 QMap<int, OEvent> m_raw;
47 QMap<int, OEvent> m_rep; 76 QMap<int, OEvent> m_rep;
48 77
49 struct Data; 78 struct Data;
50 Data* data; 79 Data* data;
51 class Private; 80 class Private;
52 Private *d; 81 Private *d;
53}; 82};
54 83
84}
85
55#endif 86#endif
diff --git a/libopie2/opiepim/backend/opimaccessbackend.h b/libopie2/opiepim/backend/opimaccessbackend.h
index fd264fc..505358e 100644
--- a/libopie2/opiepim/backend/opimaccessbackend.h
+++ b/libopie2/opiepim/backend/opimaccessbackend.h
@@ -1,160 +1,192 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_ACCESS_BACKEND 29#ifndef OPIE_PIM_ACCESS_BACKEND
2#define OPIE_PIM_ACCESS_BACKEND 30#define OPIE_PIM_ACCESS_BACKEND
3 31
4#include <qarray.h> 32#include <qarray.h>
5#include <qdatetime.h> 33#include <qdatetime.h>
6 34
7#include <opie/otemplatebase.h> 35#include <opie2/otemplatebase.h>
8#include <opie/opimrecord.h> 36#include <opie2/opimrecord.h>
9 37
10 38
39namespace Opie {
11class OPimAccessBackendPrivate; 40class OPimAccessBackendPrivate;
12/** 41/**
13 * OPimAccessBackend is the base class 42 * OPimAccessBackend is the base class
14 * for all private backends 43 * for all private backends
15 * it operates on OPimRecord as the base class 44 * it operates on OPimRecord as the base class
16 * and it's responsible for fast manipulating 45 * and it's responsible for fast manipulating
17 * the resource the implementation takes care 46 * the resource the implementation takes care
18 * of 47 * of
19 */ 48 */
20template <class T = OPimRecord> 49template <class T = OPimRecord>
21class OPimAccessBackend { 50class OPimAccessBackend {
22public: 51public:
23 typedef OTemplateBase<T> Frontend; 52 typedef OTemplateBase<T> Frontend;
24 53
25 /** The access hint from the frontend */ 54 /** The access hint from the frontend */
26 OPimAccessBackend(int access = 0); 55 OPimAccessBackend(int access = 0);
27 virtual ~OPimAccessBackend(); 56 virtual ~OPimAccessBackend();
28 57
29 /** 58 /**
30 * load the resource 59 * load the resource
31 */ 60 */
32 virtual bool load() = 0; 61 virtual bool load() = 0;
33 62
34 /** 63 /**
35 * reload the resource 64 * reload the resource
36 */ 65 */
37 virtual bool reload() = 0; 66 virtual bool reload() = 0;
38 67
39 /** 68 /**
40 * save the resource and 69 * save the resource and
41 * all it's changes 70 * all it's changes
42 */ 71 */
43 virtual bool save() = 0; 72 virtual bool save() = 0;
44 73
45 /** 74 /**
46 * return an array of 75 * return an array of
47 * all available uids 76 * all available uids
48 */ 77 */
49 virtual QArray<int> allRecords()const = 0; 78 virtual QArray<int> allRecords()const = 0;
50 79
51 /** 80 /**
52 * return a List of records 81 * return a List of records
53 * that match the regex 82 * that match the regex
54 */ 83 */
55 virtual QArray<int> matchRegexp(const QRegExp &r) const = 0; 84 virtual QArray<int> matchRegexp(const QRegExp &r) const = 0;
56 85
57 /** 86 /**
58 * queryByExample for T with the given Settings 87 * queryByExample for T with the given Settings
59 * 88 *
60 */ 89 */
61 virtual QArray<int> queryByExample( const T& t, int settings, const QDateTime& d = QDateTime() ) = 0; 90 virtual QArray<int> queryByExample( const T& t, int settings, const QDateTime& d = QDateTime() ) = 0;
62 91
63 /** 92 /**
64 * find the OPimRecord with uid @param uid 93 * find the OPimRecord with uid @param uid
65 * returns T and T.isEmpty() if nothing was found 94 * returns T and T.isEmpty() if nothing was found
66 */ 95 */
67 virtual T find(int uid )const = 0; 96 virtual T find(int uid )const = 0;
68 97
69 virtual T find(int uid, const QArray<int>& items, 98 virtual T find(int uid, const QArray<int>& items,
70 uint current, typename Frontend::CacheDirection )const ; 99 uint current, typename Frontend::CacheDirection )const ;
71 /** 100 /**
72 * clear the back end 101 * clear the back end
73 */ 102 */
74 virtual void clear() = 0; 103 virtual void clear() = 0;
75 104
76 /** 105 /**
77 * add T 106 * add T
78 */ 107 */
79 virtual bool add( const T& t ) = 0; 108 virtual bool add( const T& t ) = 0;
80 109
81 /** 110 /**
82 * remove 111 * remove
83 */ 112 */
84 virtual bool remove( int uid ) = 0; 113 virtual bool remove( int uid ) = 0;
85 114
86 /** 115 /**
87 * replace a record with T.uid() 116 * replace a record with T.uid()
88 */ 117 */
89 virtual bool replace( const T& t ) = 0; 118 virtual bool replace( const T& t ) = 0;
90 119
91 /* 120 /*
92 * setTheFrontEnd!!! 121 * setTheFrontEnd!!!
93 */ 122 */
94 void setFrontend( Frontend* front ); 123 void setFrontend( Frontend* front );
95 124
96 /** 125 /**
97 * set the read ahead count 126 * set the read ahead count
98 */ 127 */
99 void setReadAhead( uint count ); 128 void setReadAhead( uint count );
100protected: 129protected:
101 int access()const; 130 int access()const;
102 void cache( const T& t )const; 131 void cache( const T& t )const;
103 132
104 /** 133 /**
105 * use a prime number here! 134 * use a prime number here!
106 */ 135 */
107 void setSaneCacheSize( int ); 136 void setSaneCacheSize( int );
108 137
109 uint readAhead()const; 138 uint readAhead()const;
110 139
111private: 140private:
112 OPimAccessBackendPrivate *d; 141 OPimAccessBackendPrivate *d;
113 Frontend* m_front; 142 Frontend* m_front;
114 uint m_read; 143 uint m_read;
115 int m_acc; 144 int m_acc;
116 145
117}; 146};
118 147
119template <class T> 148template <class T>
120OPimAccessBackend<T>::OPimAccessBackend(int acc) 149OPimAccessBackend<T>::OPimAccessBackend(int acc)
121 : m_acc( acc ) 150 : m_acc( acc )
122{ 151{
123 m_front = 0l; 152 m_front = 0l;
124} 153}
125template <class T> 154template <class T>
126OPimAccessBackend<T>::~OPimAccessBackend() { 155OPimAccessBackend<T>::~OPimAccessBackend() {
127 156
128} 157}
129template <class T> 158template <class T>
130void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { 159void OPimAccessBackend<T>::setFrontend( Frontend* fr ) {
131 m_front = fr; 160 m_front = fr;
132} 161}
133template <class T> 162template <class T>
134void OPimAccessBackend<T>::cache( const T& t )const { 163void OPimAccessBackend<T>::cache( const T& t )const {
135 if (m_front ) 164 if (m_front )
136 m_front->cache( t ); 165 m_front->cache( t );
137} 166}
138template <class T> 167template <class T>
139void OPimAccessBackend<T>::setSaneCacheSize( int size) { 168void OPimAccessBackend<T>::setSaneCacheSize( int size) {
140 if (m_front ) 169 if (m_front )
141 m_front->setSaneCacheSize( size ); 170 m_front->setSaneCacheSize( size );
142} 171}
143template <class T> 172template <class T>
144T OPimAccessBackend<T>::find( int uid, const QArray<int>&, 173T OPimAccessBackend<T>::find( int uid, const QArray<int>&,
145 uint, typename Frontend::CacheDirection )const { 174 uint, typename Frontend::CacheDirection )const {
146 return find( uid ); 175 return find( uid );
147} 176}
148template <class T> 177template <class T>
149void OPimAccessBackend<T>::setReadAhead( uint count ) { 178void OPimAccessBackend<T>::setReadAhead( uint count ) {
150 m_read = count; 179 m_read = count;
151} 180}
152template <class T> 181template <class T>
153uint OPimAccessBackend<T>::readAhead()const { 182uint OPimAccessBackend<T>::readAhead()const {
154 return m_read; 183 return m_read;
155} 184}
156template <class T> 185template <class T>
157int OPimAccessBackend<T>::access()const { 186int OPimAccessBackend<T>::access()const {
158 return m_acc; 187 return m_acc;
159} 188}
189
190}
191
160#endif 192#endif
diff --git a/libopie2/opiepim/backend/otodoaccessbackend.cpp b/libopie2/opiepim/backend/otodoaccessbackend.cpp
index baaeecc..d27f5ef 100644
--- a/libopie2/opiepim/backend/otodoaccessbackend.cpp
+++ b/libopie2/opiepim/backend/otodoaccessbackend.cpp
@@ -1,10 +1,41 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1 29
2#include "otodoaccessbackend.h" 30#include <opie2/otodoaccessbackend.h>
3 31
32namespace Opie {
4OTodoAccessBackend::OTodoAccessBackend() 33OTodoAccessBackend::OTodoAccessBackend()
5 : OPimAccessBackend<OTodo>() 34 : OPimAccessBackend<OTodo>()
6{ 35{
7} 36}
8OTodoAccessBackend::~OTodoAccessBackend() { 37OTodoAccessBackend::~OTodoAccessBackend() {
9 38
10} 39}
40
41}
diff --git a/libopie2/opiepim/backend/otodoaccessbackend.h b/libopie2/opiepim/backend/otodoaccessbackend.h
index 6be95bc..54b52cc 100644
--- a/libopie2/opiepim/backend/otodoaccessbackend.h
+++ b/libopie2/opiepim/backend/otodoaccessbackend.h
@@ -1,28 +1,59 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_TODO_ACCESS_BACKEND_H 29#ifndef OPIE_TODO_ACCESS_BACKEND_H
2#define OPIE_TODO_ACCESS_BACKEND_H 30#define OPIE_TODO_ACCESS_BACKEND_H
3 31
4#include <qbitarray.h> 32#include <qbitarray.h>
5 33
6#include "otodo.h" 34#include <opie2/otodo.h>
7#include "opimaccessbackend.h" 35#include <opie2/opimaccessbackend.h>
8 36
37namespace Opie {
9class OTodoAccessBackend : public OPimAccessBackend<OTodo> { 38class OTodoAccessBackend : public OPimAccessBackend<OTodo> {
10public: 39public:
11 OTodoAccessBackend(); 40 OTodoAccessBackend();
12 ~OTodoAccessBackend(); 41 ~OTodoAccessBackend();
13 virtual QArray<int> effectiveToDos( const QDate& start, 42 virtual QArray<int> effectiveToDos( const QDate& start,
14 const QDate& end, 43 const QDate& end,
15 bool includeNoDates ) = 0; 44 bool includeNoDates ) = 0;
16 virtual QArray<int> overDue() = 0; 45 virtual QArray<int> overDue() = 0;
17 virtual QArray<int> sorted( bool asc, int sortOrder, int sortFilter, 46 virtual QArray<int> sorted( bool asc, int sortOrder, int sortFilter,
18 int cat ) = 0; 47 int cat ) = 0;
19 virtual void removeAllCompleted() = 0; 48 virtual void removeAllCompleted() = 0;
20 virtual QBitArray supports()const = 0; 49 virtual QBitArray supports()const = 0;
21 50
22private: 51private:
23 class Private; 52 class Private;
24 Private *d; 53 Private *d;
25 54
26}; 55};
27 56
57}
58
28#endif 59#endif
diff --git a/libopie2/opiepim/backend/otodoaccesssql.cpp b/libopie2/opiepim/backend/otodoaccesssql.cpp
index 3764c7e..944f82a 100644
--- a/libopie2/opiepim/backend/otodoaccesssql.cpp
+++ b/libopie2/opiepim/backend/otodoaccesssql.cpp
@@ -1,693 +1,726 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1 29
2#include <qdatetime.h> 30#include <qdatetime.h>
3 31
4#include <qpe/global.h> 32#include <qpe/global.h>
5 33
6#include <opie2/osqldriver.h> 34#include <opie2/osqldriver.h>
7#include <opie2/osqlresult.h> 35#include <opie2/osqlresult.h>
8#include <opie2/osqlmanager.h> 36#include <opie2/osqlmanager.h>
9#include <opie2/osqlquery.h> 37#include <opie2/osqlquery.h>
10 38
11#include "otodoaccesssql.h" 39#include <opie2/otodoaccesssql.h>
12#include "opimstate.h" 40#include <opie2/opimstate.h>
13#include "opimnotifymanager.h" 41#include <opie2/opimnotifymanager.h>
14#include "orecur.h" 42#include <opie2/orecur.h>
15 43
44using namespace Opie;
16/* 45/*
17 * first some query 46 * first some query
18 * CREATE query 47 * CREATE query
19 * LOAD query 48 * LOAD query
20 * INSERT 49 * INSERT
21 * REMOVE 50 * REMOVE
22 * CLEAR 51 * CLEAR
23 */ 52 */
24namespace { 53namespace {
25 /** 54 /**
26 * CreateQuery for the Todolist Table 55 * CreateQuery for the Todolist Table
27 */ 56 */
28 class CreateQuery : public OSQLQuery { 57 class CreateQuery : public OSQLQuery {
29 public: 58 public:
30 CreateQuery(); 59 CreateQuery();
31 ~CreateQuery(); 60 ~CreateQuery();
32 QString query()const; 61 QString query()const;
33 }; 62 };
34 63
35 /** 64 /**
36 * LoadQuery 65 * LoadQuery
37 * this one queries for all uids 66 * this one queries for all uids
38 */ 67 */
39 class LoadQuery : public OSQLQuery { 68 class LoadQuery : public OSQLQuery {
40 public: 69 public:
41 LoadQuery(); 70 LoadQuery();
42 ~LoadQuery(); 71 ~LoadQuery();
43 QString query()const; 72 QString query()const;
44 }; 73 };
45 74
46 /** 75 /**
47 * inserts/adds a OTodo to the table 76 * inserts/adds a OTodo to the table
48 */ 77 */
49 class InsertQuery : public OSQLQuery { 78 class InsertQuery : public OSQLQuery {
50 public: 79 public:
51 InsertQuery(const OTodo& ); 80 InsertQuery(const OTodo& );
52 ~InsertQuery(); 81 ~InsertQuery();
53 QString query()const; 82 QString query()const;
54 private: 83 private:
55 OTodo m_todo; 84 OTodo m_todo;
56 }; 85 };
57 86
58 /** 87 /**
59 * removes one from the table 88 * removes one from the table
60 */ 89 */
61 class RemoveQuery : public OSQLQuery { 90 class RemoveQuery : public OSQLQuery {
62 public: 91 public:
63 RemoveQuery(int uid ); 92 RemoveQuery(int uid );
64 ~RemoveQuery(); 93 ~RemoveQuery();
65 QString query()const; 94 QString query()const;
66 private: 95 private:
67 int m_uid; 96 int m_uid;
68 }; 97 };
69 98
70 /** 99 /**
71 * Clears (delete) a Table 100 * Clears (delete) a Table
72 */ 101 */
73 class ClearQuery : public OSQLQuery { 102 class ClearQuery : public OSQLQuery {
74 public: 103 public:
75 ClearQuery(); 104 ClearQuery();
76 ~ClearQuery(); 105 ~ClearQuery();
77 QString query()const; 106 QString query()const;
78 107
79 }; 108 };
80 109
81 /** 110 /**
82 * a find query 111 * a find query
83 */ 112 */
84 class FindQuery : public OSQLQuery { 113 class FindQuery : public OSQLQuery {
85 public: 114 public:
86 FindQuery(int uid); 115 FindQuery(int uid);
87 FindQuery(const QArray<int>& ); 116 FindQuery(const QArray<int>& );
88 ~FindQuery(); 117 ~FindQuery();
89 QString query()const; 118 QString query()const;
90 private: 119 private:
91 QString single()const; 120 QString single()const;
92 QString multi()const; 121 QString multi()const;
93 QArray<int> m_uids; 122 QArray<int> m_uids;
94 int m_uid; 123 int m_uid;
95 }; 124 };
96 125
97 /** 126 /**
98 * overdue query 127 * overdue query
99 */ 128 */
100 class OverDueQuery : public OSQLQuery { 129 class OverDueQuery : public OSQLQuery {
101 public: 130 public:
102 OverDueQuery(); 131 OverDueQuery();
103 ~OverDueQuery(); 132 ~OverDueQuery();
104 QString query()const; 133 QString query()const;
105 }; 134 };
106 class EffQuery : public OSQLQuery { 135 class EffQuery : public OSQLQuery {
107 public: 136 public:
108 EffQuery( const QDate&, const QDate&, bool inc ); 137 EffQuery( const QDate&, const QDate&, bool inc );
109 ~EffQuery(); 138 ~EffQuery();
110 QString query()const; 139 QString query()const;
111 private: 140 private:
112 QString with()const; 141 QString with()const;
113 QString out()const; 142 QString out()const;
114 QDate m_start; 143 QDate m_start;
115 QDate m_end; 144 QDate m_end;
116 bool m_inc :1; 145 bool m_inc :1;
117 }; 146 };
118 147
119 148
120 CreateQuery::CreateQuery() : OSQLQuery() {} 149 CreateQuery::CreateQuery() : OSQLQuery() {}
121 CreateQuery::~CreateQuery() {} 150 CreateQuery::~CreateQuery() {}
122 QString CreateQuery::query()const { 151 QString CreateQuery::query()const {
123 QString qu; 152 QString qu;
124 qu += "create table todolist( uid PRIMARY KEY, categories, completed, "; 153 qu += "create table todolist( uid PRIMARY KEY, categories, completed, ";
125 qu += "description, summary, priority, DueDate, progress , state, "; 154 qu += "description, summary, priority, DueDate, progress , state, ";
126 // This is the recurrance-stuff .. Exceptions are currently not supported (see ORecur.cpp) ! (eilers) 155 // This is the recurrance-stuff .. Exceptions are currently not supported (see ORecur.cpp) ! (eilers)
127 qu += "RType, RWeekdays, RPosition, RFreq, RHasEndDate, EndDate, Created, Exceptions, "; 156 qu += "RType, RWeekdays, RPosition, RFreq, RHasEndDate, EndDate, Created, Exceptions, ";
128 qu += "reminders, alarms, maintainer, startdate, completeddate);"; 157 qu += "reminders, alarms, maintainer, startdate, completeddate);";
129 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR(10), value VARCHAR(10), PRIMARY KEY /* identifier */ (uid, id) );"; 158 qu += "create table custom_data( uid INTEGER, id INTEGER, type VARCHAR(10), value VARCHAR(10), PRIMARY KEY /* identifier */ (uid, id) );";
130 return qu; 159 return qu;
131 } 160 }
132 161
133 LoadQuery::LoadQuery() : OSQLQuery() {} 162 LoadQuery::LoadQuery() : OSQLQuery() {}
134 LoadQuery::~LoadQuery() {} 163 LoadQuery::~LoadQuery() {}
135 QString LoadQuery::query()const { 164 QString LoadQuery::query()const {
136 QString qu; 165 QString qu;
137 // We do not need "distinct" here. The primary key is always unique.. 166 // We do not need "distinct" here. The primary key is always unique..
138 //qu += "select distinct uid from todolist"; 167 //qu += "select distinct uid from todolist";
139 qu += "select uid from todolist"; 168 qu += "select uid from todolist";
140 169
141 return qu; 170 return qu;
142 } 171 }
143 172
144 InsertQuery::InsertQuery( const OTodo& todo ) 173 InsertQuery::InsertQuery( const OTodo& todo )
145 : OSQLQuery(), m_todo( todo ) { 174 : OSQLQuery(), m_todo( todo ) {
146 } 175 }
147 InsertQuery::~InsertQuery() { 176 InsertQuery::~InsertQuery() {
148 } 177 }
149 /* 178 /*
150 * converts from a OTodo to a query 179 * converts from a OTodo to a query
151 * we leave out X-Ref + Alarms 180 * we leave out X-Ref + Alarms
152 */ 181 */
153 QString InsertQuery::query()const{ 182 QString InsertQuery::query()const{
154 183
155 int year, month, day; 184 int year, month, day;
156 year = month = day = 0; 185 year = month = day = 0;
157 if (m_todo.hasDueDate() ) { 186 if (m_todo.hasDueDate() ) {
158 QDate date = m_todo.dueDate(); 187 QDate date = m_todo.dueDate();
159 year = date.year(); 188 year = date.year();
160 month = date.month(); 189 month = date.month();
161 day = date.day(); 190 day = date.day();
162 } 191 }
163 int sYear = 0, sMonth = 0, sDay = 0; 192 int sYear = 0, sMonth = 0, sDay = 0;
164 if( m_todo.hasStartDate() ){ 193 if( m_todo.hasStartDate() ){
165 QDate sDate = m_todo.startDate(); 194 QDate sDate = m_todo.startDate();
166 sYear = sDate.year(); 195 sYear = sDate.year();
167 sMonth= sDate.month(); 196 sMonth= sDate.month();
168 sDay = sDate.day(); 197 sDay = sDate.day();
169 } 198 }
170 199
171 int eYear = 0, eMonth = 0, eDay = 0; 200 int eYear = 0, eMonth = 0, eDay = 0;
172 if( m_todo.hasCompletedDate() ){ 201 if( m_todo.hasCompletedDate() ){
173 QDate eDate = m_todo.completedDate(); 202 QDate eDate = m_todo.completedDate();
174 eYear = eDate.year(); 203 eYear = eDate.year();
175 eMonth= eDate.month(); 204 eMonth= eDate.month();
176 eDay = eDate.day(); 205 eDay = eDate.day();
177 } 206 }
178 QString qu; 207 QString qu;
179 QMap<int, QString> recMap = m_todo.recurrence().toMap(); 208 QMap<int, QString> recMap = m_todo.recurrence().toMap();
180 qu = "insert into todolist VALUES(" 209 qu = "insert into todolist VALUES("
181 + QString::number( m_todo.uid() ) + "," 210 + QString::number( m_todo.uid() ) + ","
182 + "'" + m_todo.idsToString( m_todo.categories() ) + "'" + "," 211 + "'" + m_todo.idsToString( m_todo.categories() ) + "'" + ","
183 + QString::number( m_todo.isCompleted() ) + "," 212 + QString::number( m_todo.isCompleted() ) + ","
184 + "'" + m_todo.description() + "'" + "," 213 + "'" + m_todo.description() + "'" + ","
185 + "'" + m_todo.summary() + "'" + "," 214 + "'" + m_todo.summary() + "'" + ","
186 + QString::number(m_todo.priority() ) + "," 215 + QString::number(m_todo.priority() ) + ","
187 + "'" + QString::number(year) + "-" 216 + "'" + QString::number(year) + "-"
188 + QString::number(month) 217 + QString::number(month)
189 + "-" + QString::number( day ) + "'" + "," 218 + "-" + QString::number( day ) + "'" + ","
190 + QString::number( m_todo.progress() ) + "," 219 + QString::number( m_todo.progress() ) + ","
191 + QString::number( m_todo.state().state() ) + "," 220 + QString::number( m_todo.state().state() ) + ","
192 + "'" + recMap[ ORecur::RType ] + "'" + "," 221 + "'" + recMap[ ORecur::RType ] + "'" + ","
193 + "'" + recMap[ ORecur::RWeekdays ] + "'" + "," 222 + "'" + recMap[ ORecur::RWeekdays ] + "'" + ","
194 + "'" + recMap[ ORecur::RPosition ] + "'" + "," 223 + "'" + recMap[ ORecur::RPosition ] + "'" + ","
195 + "'" + recMap[ ORecur::RFreq ] + "'" + "," 224 + "'" + recMap[ ORecur::RFreq ] + "'" + ","
196 + "'" + recMap[ ORecur::RHasEndDate ] + "'" + "," 225 + "'" + recMap[ ORecur::RHasEndDate ] + "'" + ","
197 + "'" + recMap[ ORecur::EndDate ] + "'" + "," 226 + "'" + recMap[ ORecur::EndDate ] + "'" + ","
198 + "'" + recMap[ ORecur::Created ] + "'" + "," 227 + "'" + recMap[ ORecur::Created ] + "'" + ","
199 + "'" + recMap[ ORecur::Exceptions ] + "'" + ","; 228 + "'" + recMap[ ORecur::Exceptions ] + "'" + ",";
200 229
201 if ( m_todo.hasNotifiers() ) { 230 if ( m_todo.hasNotifiers() ) {
202 OPimNotifyManager manager = m_todo.notifiers(); 231 OPimNotifyManager manager = m_todo.notifiers();
203 qu += "'" + manager.remindersToString() + "'" + "," 232 qu += "'" + manager.remindersToString() + "'" + ","
204 + "'" + manager.alarmsToString() + "'" + ","; 233 + "'" + manager.alarmsToString() + "'" + ",";
205 } 234 }
206 else{ 235 else{
207 qu += QString( "''" ) + "," 236 qu += QString( "''" ) + ","
208 + "''" + ","; 237 + "''" + ",";
209 } 238 }
210 239
211 qu += QString( "''" ) + QString( "," ) // Maintainers (cur. not supported !) 240 qu += QString( "''" ) + QString( "," ) // Maintainers (cur. not supported !)
212 + "'" + QString::number(sYear) + "-" 241 + "'" + QString::number(sYear) + "-"
213 + QString::number(sMonth) 242 + QString::number(sMonth)
214 + "-" + QString::number(sDay) + "'" + "," 243 + "-" + QString::number(sDay) + "'" + ","
215 + "'" + QString::number(eYear) + "-" 244 + "'" + QString::number(eYear) + "-"
216 + QString::number(eMonth) 245 + QString::number(eMonth)
217 + "-"+QString::number(eDay) + "'" 246 + "-"+QString::number(eDay) + "'"
218 + ")"; 247 + ")";
219 248
220 qWarning("add %s", qu.latin1() ); 249 qWarning("add %s", qu.latin1() );
221 return qu; 250 return qu;
222 } 251 }
223 252
224 RemoveQuery::RemoveQuery(int uid ) 253 RemoveQuery::RemoveQuery(int uid )
225 : OSQLQuery(), m_uid( uid ) {} 254 : OSQLQuery(), m_uid( uid ) {}
226 RemoveQuery::~RemoveQuery() {} 255 RemoveQuery::~RemoveQuery() {}
227 QString RemoveQuery::query()const { 256 QString RemoveQuery::query()const {
228 QString qu = "DELETE from todolist where uid = " + QString::number(m_uid); 257 QString qu = "DELETE from todolist where uid = " + QString::number(m_uid);
229 return qu; 258 return qu;
230 } 259 }
231 260
232 261
233 ClearQuery::ClearQuery() 262 ClearQuery::ClearQuery()
234 : OSQLQuery() {} 263 : OSQLQuery() {}
235 ClearQuery::~ClearQuery() {} 264 ClearQuery::~ClearQuery() {}
236 QString ClearQuery::query()const { 265 QString ClearQuery::query()const {
237 QString qu = "drop table todolist"; 266 QString qu = "drop table todolist";
238 return qu; 267 return qu;
239 } 268 }
240 FindQuery::FindQuery(int uid) 269 FindQuery::FindQuery(int uid)
241 : OSQLQuery(), m_uid(uid ) { 270 : OSQLQuery(), m_uid(uid ) {
242 } 271 }
243 FindQuery::FindQuery(const QArray<int>& ints) 272 FindQuery::FindQuery(const QArray<int>& ints)
244 : OSQLQuery(), m_uids(ints){ 273 : OSQLQuery(), m_uids(ints){
245 } 274 }
246 FindQuery::~FindQuery() { 275 FindQuery::~FindQuery() {
247 } 276 }
248 QString FindQuery::query()const{ 277 QString FindQuery::query()const{
249 if (m_uids.count() == 0 ) 278 if (m_uids.count() == 0 )
250 return single(); 279 return single();
251 else 280 else
252 return multi(); 281 return multi();
253 } 282 }
254 QString FindQuery::single()const{ 283 QString FindQuery::single()const{
255 QString qu = "select * from todolist where uid = " + QString::number(m_uid); 284 QString qu = "select * from todolist where uid = " + QString::number(m_uid);
256 return qu; 285 return qu;
257 } 286 }
258 QString FindQuery::multi()const { 287 QString FindQuery::multi()const {
259 QString qu = "select * from todolist where "; 288 QString qu = "select * from todolist where ";
260 for (uint i = 0; i < m_uids.count(); i++ ) { 289 for (uint i = 0; i < m_uids.count(); i++ ) {
261 qu += " UID = " + QString::number( m_uids[i] ) + " OR"; 290 qu += " UID = " + QString::number( m_uids[i] ) + " OR";
262 } 291 }
263 qu.remove( qu.length()-2, 2 ); 292 qu.remove( qu.length()-2, 2 );
264 return qu; 293 return qu;
265 } 294 }
266 295
267 OverDueQuery::OverDueQuery(): OSQLQuery() {} 296 OverDueQuery::OverDueQuery(): OSQLQuery() {}
268 OverDueQuery::~OverDueQuery() {} 297 OverDueQuery::~OverDueQuery() {}
269 QString OverDueQuery::query()const { 298 QString OverDueQuery::query()const {
270 QDate date = QDate::currentDate(); 299 QDate date = QDate::currentDate();
271 QString str; 300 QString str;
272 str = QString("select uid from todolist where DueDate ='%1-%2-%3'").arg(date.year() ).arg(date.month() ).arg(date.day() ); 301 str = QString("select uid from todolist where DueDate ='%1-%2-%3'").arg(date.year() ).arg(date.month() ).arg(date.day() );
273 302
274 return str; 303 return str;
275 } 304 }
276 305
277 306
278 EffQuery::EffQuery( const QDate& start, const QDate& end, bool inc ) 307 EffQuery::EffQuery( const QDate& start, const QDate& end, bool inc )
279 : OSQLQuery(), m_start( start ), m_end( end ),m_inc(inc) {} 308 : OSQLQuery(), m_start( start ), m_end( end ),m_inc(inc) {}
280 EffQuery::~EffQuery() {} 309 EffQuery::~EffQuery() {}
281 QString EffQuery::query()const { 310 QString EffQuery::query()const {
282 return m_inc ? with() : out(); 311 return m_inc ? with() : out();
283 } 312 }
284 QString EffQuery::with()const { 313 QString EffQuery::with()const {
285 QString str; 314 QString str;
286 str = QString("select uid from todolist where ( DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6' ) OR DueDate = '0-0-0' ") 315 str = QString("select uid from todolist where ( DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6' ) OR DueDate = '0-0-0' ")
287 .arg( m_start.year() ).arg( m_start.month() ).arg( m_start.day() ) 316 .arg( m_start.year() ).arg( m_start.month() ).arg( m_start.day() )
288 .arg( m_end .year() ).arg( m_end .month() ).arg( m_end .day() ); 317 .arg( m_end .year() ).arg( m_end .month() ).arg( m_end .day() );
289 return str; 318 return str;
290 } 319 }
291 QString EffQuery::out()const { 320 QString EffQuery::out()const {
292 QString str; 321 QString str;
293 str = QString("select uid from todolist where DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6'") 322 str = QString("select uid from todolist where DueDate >= '%1-%2-%3' AND DueDate <= '%4-%5-%6'")
294 .arg(m_start.year() ).arg(m_start.month() ).arg( m_start.day() ) 323 .arg(m_start.year() ).arg(m_start.month() ).arg( m_start.day() )
295 .arg(m_end. year() ).arg(m_end. month() ).arg(m_end.day() ); 324 .arg(m_end. year() ).arg(m_end. month() ).arg(m_end.day() );
296 325
297 return str; 326 return str;
298 } 327 }
299}; 328};
300 329
330
331namespace Opie {
301OTodoAccessBackendSQL::OTodoAccessBackendSQL( const QString& file ) 332OTodoAccessBackendSQL::OTodoAccessBackendSQL( const QString& file )
302 : OTodoAccessBackend(), m_dict(15), m_driver(NULL), m_dirty(true) 333 : OTodoAccessBackend(), m_dict(15), m_driver(NULL), m_dirty(true)
303{ 334{
304 QString fi = file; 335 QString fi = file;
305 if ( fi.isEmpty() ) 336 if ( fi.isEmpty() )
306 fi = Global::applicationFileName( "todolist", "todolist.db" ); 337 fi = Global::applicationFileName( "todolist", "todolist.db" );
307 OSQLManager man; 338 OSQLManager man;
308 m_driver = man.standard(); 339 m_driver = man.standard();
309 m_driver->setUrl(fi); 340 m_driver->setUrl(fi);
310 // fillDict(); 341 // fillDict();
311} 342}
312 343
313OTodoAccessBackendSQL::~OTodoAccessBackendSQL(){ 344OTodoAccessBackendSQL::~OTodoAccessBackendSQL(){
314 if( m_driver ) 345 if( m_driver )
315 delete m_driver; 346 delete m_driver;
316} 347}
317 348
318bool OTodoAccessBackendSQL::load(){ 349bool OTodoAccessBackendSQL::load(){
319 if (!m_driver->open() ) 350 if (!m_driver->open() )
320 return false; 351 return false;
321 352
322 CreateQuery creat; 353 CreateQuery creat;
323 OSQLResult res = m_driver->query(&creat ); 354 OSQLResult res = m_driver->query(&creat );
324 355
325 m_dirty = true; 356 m_dirty = true;
326 return true; 357 return true;
327} 358}
328bool OTodoAccessBackendSQL::reload(){ 359bool OTodoAccessBackendSQL::reload(){
329 return load(); 360 return load();
330} 361}
331 362
332bool OTodoAccessBackendSQL::save(){ 363bool OTodoAccessBackendSQL::save(){
333 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers) 364 return m_driver->close(); // Shouldn't m_driver->sync be better than close ? (eilers)
334} 365}
335QArray<int> OTodoAccessBackendSQL::allRecords()const { 366QArray<int> OTodoAccessBackendSQL::allRecords()const {
336 if (m_dirty ) 367 if (m_dirty )
337 update(); 368 update();
338 369
339 return m_uids; 370 return m_uids;
340} 371}
341QArray<int> OTodoAccessBackendSQL::queryByExample( const OTodo& , int, const QDateTime& ){ 372QArray<int> OTodoAccessBackendSQL::queryByExample( const OTodo& , int, const QDateTime& ){
342 QArray<int> ints(0); 373 QArray<int> ints(0);
343 return ints; 374 return ints;
344} 375}
345OTodo OTodoAccessBackendSQL::find(int uid ) const{ 376OTodo OTodoAccessBackendSQL::find(int uid ) const{
346 FindQuery query( uid ); 377 FindQuery query( uid );
347 return todo( m_driver->query(&query) ); 378 return todo( m_driver->query(&query) );
348 379
349} 380}
350OTodo OTodoAccessBackendSQL::find( int uid, const QArray<int>& ints, 381OTodo OTodoAccessBackendSQL::find( int uid, const QArray<int>& ints,
351 uint cur, Frontend::CacheDirection dir ) const{ 382 uint cur, Frontend::CacheDirection dir ) const{
352 uint CACHE = readAhead(); 383 uint CACHE = readAhead();
353 qWarning("searching for %d", uid ); 384 qWarning("searching for %d", uid );
354 QArray<int> search( CACHE ); 385 QArray<int> search( CACHE );
355 uint size =0; 386 uint size =0;
356 OTodo to; 387 OTodo to;
357 388
358 // we try to cache CACHE items 389 // we try to cache CACHE items
359 switch( dir ) { 390 switch( dir ) {
360 /* forward */ 391 /* forward */
361 case 0: // FIXME: Not a good style to use magic numbers here (eilers) 392 case 0: // FIXME: Not a good style to use magic numbers here (eilers)
362 for (uint i = cur; i < ints.count() && size < CACHE; i++ ) { 393 for (uint i = cur; i < ints.count() && size < CACHE; i++ ) {
363 qWarning("size %d %d", size, ints[i] ); 394 qWarning("size %d %d", size, ints[i] );
364 search[size] = ints[i]; 395 search[size] = ints[i];
365 size++; 396 size++;
366 } 397 }
367 break; 398 break;
368 /* reverse */ 399 /* reverse */
369 case 1: // FIXME: Not a good style to use magic numbers here (eilers) 400 case 1: // FIXME: Not a good style to use magic numbers here (eilers)
370 for (uint i = cur; i != 0 && size < CACHE; i-- ) { 401 for (uint i = cur; i != 0 && size < CACHE; i-- ) {
371 search[size] = ints[i]; 402 search[size] = ints[i];
372 size++; 403 size++;
373 } 404 }
374 break; 405 break;
375 } 406 }
376 search.resize( size ); 407 search.resize( size );
377 FindQuery query( search ); 408 FindQuery query( search );
378 OSQLResult res = m_driver->query( &query ); 409 OSQLResult res = m_driver->query( &query );
379 if ( res.state() != OSQLResult::Success ) 410 if ( res.state() != OSQLResult::Success )
380 return to; 411 return to;
381 412
382 return todo( res ); 413 return todo( res );
383} 414}
384void OTodoAccessBackendSQL::clear() { 415void OTodoAccessBackendSQL::clear() {
385 ClearQuery cle; 416 ClearQuery cle;
386 OSQLResult res = m_driver->query( &cle ); 417 OSQLResult res = m_driver->query( &cle );
387 CreateQuery qu; 418 CreateQuery qu;
388 res = m_driver->query(&qu); 419 res = m_driver->query(&qu);
389} 420}
390bool OTodoAccessBackendSQL::add( const OTodo& t) { 421bool OTodoAccessBackendSQL::add( const OTodo& t) {
391 InsertQuery ins( t ); 422 InsertQuery ins( t );
392 OSQLResult res = m_driver->query( &ins ); 423 OSQLResult res = m_driver->query( &ins );
393 424
394 if ( res.state() == OSQLResult::Failure ) 425 if ( res.state() == OSQLResult::Failure )
395 return false; 426 return false;
396 int c = m_uids.count(); 427 int c = m_uids.count();
397 m_uids.resize( c+1 ); 428 m_uids.resize( c+1 );
398 m_uids[c] = t.uid(); 429 m_uids[c] = t.uid();
399 430
400 return true; 431 return true;
401} 432}
402bool OTodoAccessBackendSQL::remove( int uid ) { 433bool OTodoAccessBackendSQL::remove( int uid ) {
403 RemoveQuery rem( uid ); 434 RemoveQuery rem( uid );
404 OSQLResult res = m_driver->query(&rem ); 435 OSQLResult res = m_driver->query(&rem );
405 436
406 if ( res.state() == OSQLResult::Failure ) 437 if ( res.state() == OSQLResult::Failure )
407 return false; 438 return false;
408 439
409 m_dirty = true; 440 m_dirty = true;
410 return true; 441 return true;
411} 442}
412/* 443/*
413 * FIXME better set query 444 * FIXME better set query
414 * but we need the cache for that 445 * but we need the cache for that
415 * now we remove 446 * now we remove
416 */ 447 */
417bool OTodoAccessBackendSQL::replace( const OTodo& t) { 448bool OTodoAccessBackendSQL::replace( const OTodo& t) {
418 remove( t.uid() ); 449 remove( t.uid() );
419 bool b= add(t); 450 bool b= add(t);
420 m_dirty = false; // we changed some stuff but the UID stayed the same 451 m_dirty = false; // we changed some stuff but the UID stayed the same
421 return b; 452 return b;
422} 453}
423QArray<int> OTodoAccessBackendSQL::overDue() { 454QArray<int> OTodoAccessBackendSQL::overDue() {
424 OverDueQuery qu; 455 OverDueQuery qu;
425 return uids( m_driver->query(&qu ) ); 456 return uids( m_driver->query(&qu ) );
426} 457}
427QArray<int> OTodoAccessBackendSQL::effectiveToDos( const QDate& s, 458QArray<int> OTodoAccessBackendSQL::effectiveToDos( const QDate& s,
428 const QDate& t, 459 const QDate& t,
429 bool u) { 460 bool u) {
430 EffQuery ef(s, t, u ); 461 EffQuery ef(s, t, u );
431 return uids (m_driver->query(&ef) ); 462 return uids (m_driver->query(&ef) );
432} 463}
433/* 464/*
434 * 465 *
435 */ 466 */
436QArray<int> OTodoAccessBackendSQL::sorted( bool asc, int sortOrder, 467QArray<int> OTodoAccessBackendSQL::sorted( bool asc, int sortOrder,
437 int sortFilter, int cat ) { 468 int sortFilter, int cat ) {
438 qWarning("sorted %d, %d", asc, sortOrder ); 469 qWarning("sorted %d, %d", asc, sortOrder );
439 QString query; 470 QString query;
440 query = "select uid from todolist WHERE "; 471 query = "select uid from todolist WHERE ";
441 472
442 /* 473 /*
443 * Sort Filter stuff 474 * Sort Filter stuff
444 * not that straight forward 475 * not that straight forward
445 * FIXME: Replace magic numbers 476 * FIXME: Replace magic numbers
446 * 477 *
447 */ 478 */
448 /* Category */ 479 /* Category */
449 if ( sortFilter & 1 ) { 480 if ( sortFilter & 1 ) {
450 QString str; 481 QString str;
451 if (cat != 0 ) str = QString::number( cat ); 482 if (cat != 0 ) str = QString::number( cat );
452 query += " categories like '%" +str+"%' AND"; 483 query += " categories like '%" +str+"%' AND";
453 } 484 }
454 /* Show only overdue */ 485 /* Show only overdue */
455 if ( sortFilter & 2 ) { 486 if ( sortFilter & 2 ) {
456 QDate date = QDate::currentDate(); 487 QDate date = QDate::currentDate();
457 QString due; 488 QString due;
458 QString base; 489 QString base;
459 base = QString("DueDate <= '%1-%2-%3' AND completed = 0").arg( date.year() ).arg( date.month() ).arg( date.day() ); 490 base = QString("DueDate <= '%1-%2-%3' AND completed = 0").arg( date.year() ).arg( date.month() ).arg( date.day() );
460 query += " " + base + " AND"; 491 query += " " + base + " AND";
461 } 492 }
462 /* not show completed */ 493 /* not show completed */
463 if ( sortFilter & 4 ) { 494 if ( sortFilter & 4 ) {
464 query += " completed = 0 AND"; 495 query += " completed = 0 AND";
465 }else{ 496 }else{
466 query += " ( completed = 1 OR completed = 0) AND"; 497 query += " ( completed = 1 OR completed = 0) AND";
467 } 498 }
468 /* srtip the end */ 499 /* srtip the end */
469 query = query.remove( query.length()-3, 3 ); 500 query = query.remove( query.length()-3, 3 );
470 501
471 502
472 /* 503 /*
473 * sort order stuff 504 * sort order stuff
474 * quite straight forward 505 * quite straight forward
475 */ 506 */
476 query += "ORDER BY "; 507 query += "ORDER BY ";
477 switch( sortOrder ) { 508 switch( sortOrder ) {
478 /* completed */ 509 /* completed */
479 case 0: 510 case 0:
480 query += "completed"; 511 query += "completed";
481 break; 512 break;
482 case 1: 513 case 1:
483 query += "priority"; 514 query += "priority";
484 break; 515 break;
485 case 2: 516 case 2:
486 query += "summary"; 517 query += "summary";
487 break; 518 break;
488 case 3: 519 case 3:
489 query += "DueDate"; 520 query += "DueDate";
490 break; 521 break;
491 } 522 }
492 523
493 if ( !asc ) { 524 if ( !asc ) {
494 qWarning("not ascending!"); 525 qWarning("not ascending!");
495 query += " DESC"; 526 query += " DESC";
496 } 527 }
497 528
498 qWarning( query ); 529 qWarning( query );
499 OSQLRawQuery raw(query ); 530 OSQLRawQuery raw(query );
500 return uids( m_driver->query(&raw) ); 531 return uids( m_driver->query(&raw) );
501} 532}
502bool OTodoAccessBackendSQL::date( QDate& da, const QString& str ) const{ 533bool OTodoAccessBackendSQL::date( QDate& da, const QString& str ) const{
503 if ( str == "0-0-0" ) 534 if ( str == "0-0-0" )
504 return false; 535 return false;
505 else{ 536 else{
506 int day, year, month; 537 int day, year, month;
507 QStringList list = QStringList::split("-", str ); 538 QStringList list = QStringList::split("-", str );
508 year = list[0].toInt(); 539 year = list[0].toInt();
509 month = list[1].toInt(); 540 month = list[1].toInt();
510 day = list[2].toInt(); 541 day = list[2].toInt();
511 da.setYMD( year, month, day ); 542 da.setYMD( year, month, day );
512 return true; 543 return true;
513 } 544 }
514} 545}
515OTodo OTodoAccessBackendSQL::todo( const OSQLResult& res) const{ 546OTodo OTodoAccessBackendSQL::todo( const OSQLResult& res) const{
516 if ( res.state() == OSQLResult::Failure ) { 547 if ( res.state() == OSQLResult::Failure ) {
517 OTodo to; 548 OTodo to;
518 return to; 549 return to;
519 } 550 }
520 551
521 OSQLResultItem::ValueList list = res.results(); 552 OSQLResultItem::ValueList list = res.results();
522 OSQLResultItem::ValueList::Iterator it = list.begin(); 553 OSQLResultItem::ValueList::Iterator it = list.begin();
523 qWarning("todo1"); 554 qWarning("todo1");
524 OTodo to = todo( (*it) ); 555 OTodo to = todo( (*it) );
525 cache( to ); 556 cache( to );
526 ++it; 557 ++it;
527 558
528 for ( ; it != list.end(); ++it ) { 559 for ( ; it != list.end(); ++it ) {
529 qWarning("caching"); 560 qWarning("caching");
530 cache( todo( (*it) ) ); 561 cache( todo( (*it) ) );
531 } 562 }
532 return to; 563 return to;
533} 564}
534OTodo OTodoAccessBackendSQL::todo( OSQLResultItem& item )const { 565OTodo OTodoAccessBackendSQL::todo( OSQLResultItem& item )const {
535 qWarning("todo"); 566 qWarning("todo");
536 bool hasDueDate = false; QDate dueDate = QDate::currentDate(); 567 bool hasDueDate = false; QDate dueDate = QDate::currentDate();
537 hasDueDate = date( dueDate, item.data("DueDate") ); 568 hasDueDate = date( dueDate, item.data("DueDate") );
538 QStringList cats = QStringList::split(";", item.data("categories") ); 569 QStringList cats = QStringList::split(";", item.data("categories") );
539 570
540 qWarning("Item is completed: %d", item.data("completed").toInt() ); 571 qWarning("Item is completed: %d", item.data("completed").toInt() );
541 572
542 OTodo to( (bool)item.data("completed").toInt(), item.data("priority").toInt(), 573 OTodo to( (bool)item.data("completed").toInt(), item.data("priority").toInt(),
543 cats, item.data("summary"), item.data("description"), 574 cats, item.data("summary"), item.data("description"),
544 item.data("progress").toUShort(), hasDueDate, dueDate, 575 item.data("progress").toUShort(), hasDueDate, dueDate,
545 item.data("uid").toInt() ); 576 item.data("uid").toInt() );
546 577
547 bool isOk; 578 bool isOk;
548 int prioInt = QString( item.data("priority") ).toInt( &isOk ); 579 int prioInt = QString( item.data("priority") ).toInt( &isOk );
549 if ( isOk ) 580 if ( isOk )
550 to.setPriority( prioInt ); 581 to.setPriority( prioInt );
551 582
552 bool hasStartDate = false; QDate startDate = QDate::currentDate(); 583 bool hasStartDate = false; QDate startDate = QDate::currentDate();
553 hasStartDate = date( startDate, item.data("startdate") ); 584 hasStartDate = date( startDate, item.data("startdate") );
554 bool hasCompletedDate = false; QDate completedDate = QDate::currentDate(); 585 bool hasCompletedDate = false; QDate completedDate = QDate::currentDate();
555 hasCompletedDate = date( completedDate, item.data("completeddate") ); 586 hasCompletedDate = date( completedDate, item.data("completeddate") );
556 587
557 if ( hasStartDate ) 588 if ( hasStartDate )
558 to.setStartDate( startDate ); 589 to.setStartDate( startDate );
559 if ( hasCompletedDate ) 590 if ( hasCompletedDate )
560 to.setCompletedDate( completedDate ); 591 to.setCompletedDate( completedDate );
561 592
562 OPimNotifyManager& manager = to.notifiers(); 593 OPimNotifyManager& manager = to.notifiers();
563 manager.alarmsFromString( item.data("alarms") ); 594 manager.alarmsFromString( item.data("alarms") );
564 manager.remindersFromString( item.data("reminders") ); 595 manager.remindersFromString( item.data("reminders") );
565 596
566 OPimState pimState; 597 OPimState pimState;
567 pimState.setState( QString( item.data("state") ).toInt() ); 598 pimState.setState( QString( item.data("state") ).toInt() );
568 to.setState( pimState ); 599 to.setState( pimState );
569 600
570 QMap<int, QString> recMap; 601 QMap<int, QString> recMap;
571 recMap.insert( ORecur::RType , item.data("RType") ); 602 recMap.insert( ORecur::RType , item.data("RType") );
572 recMap.insert( ORecur::RWeekdays , item.data("RWeekdays") ); 603 recMap.insert( ORecur::RWeekdays , item.data("RWeekdays") );
573 recMap.insert( ORecur::RPosition , item.data("RPosition") ); 604 recMap.insert( ORecur::RPosition , item.data("RPosition") );
574 recMap.insert( ORecur::RFreq , item.data("RFreq") ); 605 recMap.insert( ORecur::RFreq , item.data("RFreq") );
575 recMap.insert( ORecur::RHasEndDate, item.data("RHasEndDate") ); 606 recMap.insert( ORecur::RHasEndDate, item.data("RHasEndDate") );
576 recMap.insert( ORecur::EndDate , item.data("EndDate") ); 607 recMap.insert( ORecur::EndDate , item.data("EndDate") );
577 recMap.insert( ORecur::Created , item.data("Created") ); 608 recMap.insert( ORecur::Created , item.data("Created") );
578 recMap.insert( ORecur::Exceptions , item.data("Exceptions") ); 609 recMap.insert( ORecur::Exceptions , item.data("Exceptions") );
579 610
580 ORecur recur; 611 ORecur recur;
581 recur.fromMap( recMap ); 612 recur.fromMap( recMap );
582 to.setRecurrence( recur ); 613 to.setRecurrence( recur );
583 614
584 return to; 615 return to;
585} 616}
586OTodo OTodoAccessBackendSQL::todo( int uid )const { 617OTodo OTodoAccessBackendSQL::todo( int uid )const {
587 FindQuery find( uid ); 618 FindQuery find( uid );
588 return todo( m_driver->query(&find) ); 619 return todo( m_driver->query(&find) );
589} 620}
590/* 621/*
591 * update the dict 622 * update the dict
592 */ 623 */
593void OTodoAccessBackendSQL::fillDict() { 624void OTodoAccessBackendSQL::fillDict() {
594 /* initialize dict */ 625 /* initialize dict */
595 /* 626 /*
596 * UPDATE dict if you change anything!!! 627 * UPDATE dict if you change anything!!!
597 * FIXME: Isn't this dict obsolete ? (eilers) 628 * FIXME: Isn't this dict obsolete ? (eilers)
598 */ 629 */
599 m_dict.setAutoDelete( TRUE ); 630 m_dict.setAutoDelete( TRUE );
600 m_dict.insert("Categories" , new int(OTodo::Category) ); 631 m_dict.insert("Categories" , new int(OTodo::Category) );
601 m_dict.insert("Uid" , new int(OTodo::Uid) ); 632 m_dict.insert("Uid" , new int(OTodo::Uid) );
602 m_dict.insert("HasDate" , new int(OTodo::HasDate) ); 633 m_dict.insert("HasDate" , new int(OTodo::HasDate) );
603 m_dict.insert("Completed" , new int(OTodo::Completed) ); 634 m_dict.insert("Completed" , new int(OTodo::Completed) );
604 m_dict.insert("Description" , new int(OTodo::Description) ); 635 m_dict.insert("Description" , new int(OTodo::Description) );
605 m_dict.insert("Summary" , new int(OTodo::Summary) ); 636 m_dict.insert("Summary" , new int(OTodo::Summary) );
606 m_dict.insert("Priority" , new int(OTodo::Priority) ); 637 m_dict.insert("Priority" , new int(OTodo::Priority) );
607 m_dict.insert("DateDay" , new int(OTodo::DateDay) ); 638 m_dict.insert("DateDay" , new int(OTodo::DateDay) );
608 m_dict.insert("DateMonth" , new int(OTodo::DateMonth) ); 639 m_dict.insert("DateMonth" , new int(OTodo::DateMonth) );
609 m_dict.insert("DateYear" , new int(OTodo::DateYear) ); 640 m_dict.insert("DateYear" , new int(OTodo::DateYear) );
610 m_dict.insert("Progress" , new int(OTodo::Progress) ); 641 m_dict.insert("Progress" , new int(OTodo::Progress) );
611 m_dict.insert("Completed", new int(OTodo::Completed) ); // Why twice ? (eilers) 642 m_dict.insert("Completed", new int(OTodo::Completed) ); // Why twice ? (eilers)
612 m_dict.insert("CrossReference", new int(OTodo::CrossReference) ); 643 m_dict.insert("CrossReference", new int(OTodo::CrossReference) );
613// m_dict.insert("HasAlarmDateTime",new int(OTodo::HasAlarmDateTime) ); // old stuff (eilers) 644// m_dict.insert("HasAlarmDateTime",new int(OTodo::HasAlarmDateTime) ); // old stuff (eilers)
614// m_dict.insert("AlarmDateTime", new int(OTodo::AlarmDateTime) ); // old stuff (eilers) 645// m_dict.insert("AlarmDateTime", new int(OTodo::AlarmDateTime) ); // old stuff (eilers)
615} 646}
616/* 647/*
617 * need to be const so let's fool the 648 * need to be const so let's fool the
618 * compiler :( 649 * compiler :(
619 */ 650 */
620void OTodoAccessBackendSQL::update()const { 651void OTodoAccessBackendSQL::update()const {
621 ((OTodoAccessBackendSQL*)this)->m_dirty = false; 652 ((OTodoAccessBackendSQL*)this)->m_dirty = false;
622 LoadQuery lo; 653 LoadQuery lo;
623 OSQLResult res = m_driver->query(&lo); 654 OSQLResult res = m_driver->query(&lo);
624 if ( res.state() != OSQLResult::Success ) 655 if ( res.state() != OSQLResult::Success )
625 return; 656 return;
626 657
627 ((OTodoAccessBackendSQL*)this)->m_uids = uids( res ); 658 ((OTodoAccessBackendSQL*)this)->m_uids = uids( res );
628} 659}
629QArray<int> OTodoAccessBackendSQL::uids( const OSQLResult& res) const{ 660QArray<int> OTodoAccessBackendSQL::uids( const OSQLResult& res) const{
630 661
631 OSQLResultItem::ValueList list = res.results(); 662 OSQLResultItem::ValueList list = res.results();
632 OSQLResultItem::ValueList::Iterator it; 663 OSQLResultItem::ValueList::Iterator it;
633 QArray<int> ints(list.count() ); 664 QArray<int> ints(list.count() );
634 qWarning(" count = %d", list.count() ); 665 qWarning(" count = %d", list.count() );
635 666
636 int i = 0; 667 int i = 0;
637 for (it = list.begin(); it != list.end(); ++it ) { 668 for (it = list.begin(); it != list.end(); ++it ) {
638 ints[i] = (*it).data("uid").toInt(); 669 ints[i] = (*it).data("uid").toInt();
639 i++; 670 i++;
640 } 671 }
641 return ints; 672 return ints;
642} 673}
643 674
644QArray<int> OTodoAccessBackendSQL::matchRegexp( const QRegExp &r ) const 675QArray<int> OTodoAccessBackendSQL::matchRegexp( const QRegExp &r ) const
645{ 676{
646 677
647#warning OTodoAccessBackendSQL::matchRegexp() not implemented !! 678#warning OTodoAccessBackendSQL::matchRegexp() not implemented !!
648 679
649#if 0 680#if 0
650 681
651 Copied from xml-backend by not adapted to sql (eilers) 682 Copied from xml-backend by not adapted to sql (eilers)
652 683
653 QArray<int> m_currentQuery( m_events.count() ); 684 QArray<int> m_currentQuery( m_events.count() );
654 uint arraycounter = 0; 685 uint arraycounter = 0;
655 686
656 687
657 688
658 QMap<int, OTodo>::ConstIterator it; 689 QMap<int, OTodo>::ConstIterator it;
659 for (it = m_events.begin(); it != m_events.end(); ++it ) { 690 for (it = m_events.begin(); it != m_events.end(); ++it ) {
660 if ( it.data().match( r ) ) 691 if ( it.data().match( r ) )
661 m_currentQuery[arraycounter++] = it.data().uid(); 692 m_currentQuery[arraycounter++] = it.data().uid();
662 693
663 } 694 }
664 // Shrink to fit.. 695 // Shrink to fit..
665 m_currentQuery.resize(arraycounter); 696 m_currentQuery.resize(arraycounter);
666 697
667 return m_currentQuery; 698 return m_currentQuery;
668#endif 699#endif
669 QArray<int> empty; 700 QArray<int> empty;
670 return empty; 701 return empty;
671} 702}
672QBitArray OTodoAccessBackendSQL::supports()const { 703QBitArray OTodoAccessBackendSQL::supports()const {
673 704
674 return sup(); 705 return sup();
675} 706}
676 707
677QBitArray OTodoAccessBackendSQL::sup() const{ 708QBitArray OTodoAccessBackendSQL::sup() const{
678 709
679 QBitArray ar( OTodo::CompletedDate + 1 ); 710 QBitArray ar( OTodo::CompletedDate + 1 );
680 ar.fill( true ); 711 ar.fill( true );
681 ar[OTodo::CrossReference] = false; 712 ar[OTodo::CrossReference] = false;
682 ar[OTodo::State ] = false; 713 ar[OTodo::State ] = false;
683 ar[OTodo::Reminders] = false; 714 ar[OTodo::Reminders] = false;
684 ar[OTodo::Notifiers] = false; 715 ar[OTodo::Notifiers] = false;
685 ar[OTodo::Maintainer] = false; 716 ar[OTodo::Maintainer] = false;
686 717
687 return ar; 718 return ar;
688} 719}
689 720
690void OTodoAccessBackendSQL::removeAllCompleted(){ 721void OTodoAccessBackendSQL::removeAllCompleted(){
691#warning OTodoAccessBackendSQL::removeAllCompleted() not implemented !! 722#warning OTodoAccessBackendSQL::removeAllCompleted() not implemented !!
692 723
693} 724}
725
726}
diff --git a/libopie2/opiepim/backend/otodoaccesssql.h b/libopie2/opiepim/backend/otodoaccesssql.h
index 1c55567..1a6f614 100644
--- a/libopie2/opiepim/backend/otodoaccesssql.h
+++ b/libopie2/opiepim/backend/otodoaccesssql.h
@@ -1,56 +1,88 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_ACCESS_SQL_H 29#ifndef OPIE_PIM_ACCESS_SQL_H
2#define OPIE_PIM_ACCESS_SQL_H 30#define OPIE_PIM_ACCESS_SQL_H
3 31
4#include <qasciidict.h> 32#include <qasciidict.h>
5 33
6#include "otodoaccessbackend.h" 34#include <opie2/otodoaccessbackend.h>
7 35
8class OSQLDriver; 36class OSQLDriver;
9class OSQLResult; 37class OSQLResult;
10class OSQLResultItem; 38class OSQLResultItem;
39
40namespace Opie {
41
11class OTodoAccessBackendSQL : public OTodoAccessBackend { 42class OTodoAccessBackendSQL : public OTodoAccessBackend {
12public: 43public:
13 OTodoAccessBackendSQL( const QString& file ); 44 OTodoAccessBackendSQL( const QString& file );
14 ~OTodoAccessBackendSQL(); 45 ~OTodoAccessBackendSQL();
15 46
16 bool load(); 47 bool load();
17 bool reload(); 48 bool reload();
18 bool save(); 49 bool save();
19 QArray<int> allRecords()const; 50 QArray<int> allRecords()const;
20 51
21 QArray<int> queryByExample( const OTodo& t, int settings, const QDateTime& d = QDateTime() ); 52 QArray<int> queryByExample( const OTodo& t, int settings, const QDateTime& d = QDateTime() );
22 OTodo find(int uid)const; 53 OTodo find(int uid)const;
23 OTodo find(int uid, const QArray<int>&, uint cur, Frontend::CacheDirection )const; 54 OTodo find(int uid, const QArray<int>&, uint cur, Frontend::CacheDirection )const;
24 void clear(); 55 void clear();
25 bool add( const OTodo& t ); 56 bool add( const OTodo& t );
26 bool remove( int uid ); 57 bool remove( int uid );
27 bool replace( const OTodo& t ); 58 bool replace( const OTodo& t );
28 59
29 QArray<int> overDue(); 60 QArray<int> overDue();
30 QArray<int> effectiveToDos( const QDate& start, 61 QArray<int> effectiveToDos( const QDate& start,
31 const QDate& end, bool includeNoDates ); 62 const QDate& end, bool includeNoDates );
32 QArray<int> sorted(bool asc, int sortOrder, int sortFilter, int cat ); 63 QArray<int> sorted(bool asc, int sortOrder, int sortFilter, int cat );
33 64
34 QBitArray supports()const; 65 QBitArray supports()const;
35 QArray<int> matchRegexp( const QRegExp &r ) const; 66 QArray<int> matchRegexp( const QRegExp &r ) const;
36 void removeAllCompleted(); 67 void removeAllCompleted();
37 68
38 69
39private: 70private:
40 void update()const; 71 void update()const;
41 void fillDict(); 72 void fillDict();
42 inline bool date( QDate& date, const QString& )const; 73 inline bool date( QDate& date, const QString& )const;
43 inline OTodo todo( const OSQLResult& )const; 74 inline OTodo todo( const OSQLResult& )const;
44 inline OTodo todo( OSQLResultItem& )const; 75 inline OTodo todo( OSQLResultItem& )const;
45 inline QArray<int> uids( const OSQLResult& )const; 76 inline QArray<int> uids( const OSQLResult& )const;
46 OTodo todo( int uid )const; 77 OTodo todo( int uid )const;
47 QBitArray sup() const; 78 QBitArray sup() const;
48 79
49 QAsciiDict<int> m_dict; 80 QAsciiDict<int> m_dict;
50 OSQLDriver* m_driver; 81 OSQLDriver* m_driver;
51 QArray<int> m_uids; 82 QArray<int> m_uids;
52 bool m_dirty : 1; 83 bool m_dirty : 1;
53}; 84};
54 85
86}
55 87
56#endif 88#endif
diff --git a/libopie2/opiepim/backend/otodoaccessvcal.cpp b/libopie2/opiepim/backend/otodoaccessvcal.cpp
index 6415952..e364ee2 100644
--- a/libopie2/opiepim/backend/otodoaccessvcal.cpp
+++ b/libopie2/opiepim/backend/otodoaccessvcal.cpp
@@ -1,249 +1,282 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qfile.h> 29#include <qfile.h>
2 30
3#include <qtopia/private/vobject_p.h> 31#include <qtopia/private/vobject_p.h>
4#include <qtopia/timeconversion.h> 32#include <qtopia/timeconversion.h>
5#include <qtopia/private/qfiledirect_p.h> 33#include <qtopia/private/qfiledirect_p.h>
6 34
7#include "otodoaccessvcal.h" 35#include <opie2/otodoaccessvcal.h>
36
37using namespace Opie;
8 38
9namespace { 39namespace {
10 static OTodo eventByVObj( VObject *obj ){ 40 static OTodo eventByVObj( VObject *obj ){
11 OTodo event; 41 OTodo event;
12 VObject *ob; 42 VObject *ob;
13 QCString name; 43 QCString name;
14 // no uid, attendees, ... and no fun 44 // no uid, attendees, ... and no fun
15 // description 45 // description
16 if( ( ob = isAPropertyOf( obj, VCDescriptionProp )) != 0 ){ 46 if( ( ob = isAPropertyOf( obj, VCDescriptionProp )) != 0 ){
17 name = vObjectStringZValue( ob ); 47 name = vObjectStringZValue( ob );
18#if 0 48#if 0
19 event.setDescription( name ); 49 event.setDescription( name );
20#else 50#else
21 event.setSummary( name ); 51 event.setSummary( name );
22#endif 52#endif
23 } 53 }
24 // summary 54 // summary
25 if ( ( ob = isAPropertyOf( obj, VCSummaryProp ) ) != 0 ) { 55 if ( ( ob = isAPropertyOf( obj, VCSummaryProp ) ) != 0 ) {
26 name = vObjectStringZValue( ob ); 56 name = vObjectStringZValue( ob );
27#if 0 57#if 0
28 event.setSummary( name ); 58 event.setSummary( name );
29#else 59#else
30 event.setDescription( name ); 60 event.setDescription( name );
31#endif 61#endif
32 } 62 }
33 // completed 63 // completed
34 if( ( ob = isAPropertyOf( obj, VCStatusProp )) != 0 ){ 64 if( ( ob = isAPropertyOf( obj, VCStatusProp )) != 0 ){
35 name = vObjectStringZValue( ob ); 65 name = vObjectStringZValue( ob );
36 if( name == "COMPLETED" ){ 66 if( name == "COMPLETED" ){
37 event.setCompleted( true ); 67 event.setCompleted( true );
38 }else{ 68 }else{
39 event.setCompleted( false ); 69 event.setCompleted( false );
40 } 70 }
41 }else 71 }else
42 event.setCompleted( false ); 72 event.setCompleted( false );
43 // priority 73 // priority
44 if ((ob = isAPropertyOf(obj, VCPriorityProp))) { 74 if ((ob = isAPropertyOf(obj, VCPriorityProp))) {
45 name = vObjectStringZValue( ob ); 75 name = vObjectStringZValue( ob );
46 bool ok; 76 bool ok;
47 event.setPriority(name.toInt(&ok) ); 77 event.setPriority(name.toInt(&ok) );
48 } 78 }
49 //due date 79 //due date
50 if((ob = isAPropertyOf(obj, VCDueProp)) ){ 80 if((ob = isAPropertyOf(obj, VCDueProp)) ){
51 event.setHasDueDate( true ); 81 event.setHasDueDate( true );
52 name = vObjectStringZValue( ob ); 82 name = vObjectStringZValue( ob );
53 event.setDueDate( TimeConversion::fromISO8601( name).date() ); 83 event.setDueDate( TimeConversion::fromISO8601( name).date() );
54 } 84 }
55 // categories 85 // categories
56 if((ob = isAPropertyOf( obj, VCCategoriesProp )) != 0 ){ 86 if((ob = isAPropertyOf( obj, VCCategoriesProp )) != 0 ){
57 name = vObjectStringZValue( ob ); 87 name = vObjectStringZValue( ob );
58 qWarning("Categories:%s", name.data() ); 88 qWarning("Categories:%s", name.data() );
59 } 89 }
60 90
61 event.setUid( 1 ); 91 event.setUid( 1 );
62 return event; 92 return event;
63 }; 93 };
64 static VObject *vobjByEvent( const OTodo &event ) { 94 static VObject *vobjByEvent( const OTodo &event ) {
65 VObject *task = newVObject( VCTodoProp ); 95 VObject *task = newVObject( VCTodoProp );
66 if( task == 0 ) 96 if( task == 0 )
67 return 0l; 97 return 0l;
68 98
69 if( event.hasDueDate() ) { 99 if( event.hasDueDate() ) {
70 QTime time(0, 0, 0); 100 QTime time(0, 0, 0);
71 QDateTime date(event.dueDate(), time ); 101 QDateTime date(event.dueDate(), time );
72 addPropValue( task, VCDueProp, 102 addPropValue( task, VCDueProp,
73 TimeConversion::toISO8601( date ) ); 103 TimeConversion::toISO8601( date ) );
74 } 104 }
75 105
76 if( event.isCompleted() ) 106 if( event.isCompleted() )
77 addPropValue( task, VCStatusProp, "COMPLETED"); 107 addPropValue( task, VCStatusProp, "COMPLETED");
78 108
79 QString string = QString::number(event.priority() ); 109 QString string = QString::number(event.priority() );
80 addPropValue( task, VCPriorityProp, string.local8Bit() ); 110 addPropValue( task, VCPriorityProp, string.local8Bit() );
81 111
82 addPropValue( task, VCCategoriesProp, 112 addPropValue( task, VCCategoriesProp,
83 event.idsToString( event.categories() ).local8Bit() ); 113 event.idsToString( event.categories() ).local8Bit() );
84 114
85#if 0 115#if 0
86 116
87 // There seems a misrepresentation between summary in otodoevent 117 // There seems a misrepresentation between summary in otodoevent
88 // and summary in vcard. 118 // and summary in vcard.
89 // The same with description.. 119 // The same with description..
90 // Description is summary and vice versa.. Argh.. (eilers) 120 // Description is summary and vice versa.. Argh.. (eilers)
91 121
92 122
93 addPropValue( task, VCDescriptionProp, 123 addPropValue( task, VCDescriptionProp,
94 event.description().local8Bit() ); 124 event.description().local8Bit() );
95 125
96 addPropValue( task, VCSummaryProp, 126 addPropValue( task, VCSummaryProp,
97 event.summary().local8Bit() ); 127 event.summary().local8Bit() );
98 128
99#else 129#else
100 addPropValue( task, VCDescriptionProp, 130 addPropValue( task, VCDescriptionProp,
101 event.summary().local8Bit() ); 131 event.summary().local8Bit() );
102 132
103 addPropValue( task, VCSummaryProp, 133 addPropValue( task, VCSummaryProp,
104 event.description().local8Bit() ); 134 event.description().local8Bit() );
105#endif 135#endif
106 return task; 136 return task;
107}; 137};
108} 138}
109 139
140namespace Opie {
110OTodoAccessVCal::OTodoAccessVCal( const QString& path ) 141OTodoAccessVCal::OTodoAccessVCal( const QString& path )
111 : m_dirty(false), m_file( path ) 142 : m_dirty(false), m_file( path )
112{ 143{
113} 144}
114OTodoAccessVCal::~OTodoAccessVCal() { 145OTodoAccessVCal::~OTodoAccessVCal() {
115} 146}
116bool OTodoAccessVCal::load() { 147bool OTodoAccessVCal::load() {
117 m_map.clear(); 148 m_map.clear();
118 m_dirty = false; 149 m_dirty = false;
119 150
120 VObject* vcal = 0l; 151 VObject* vcal = 0l;
121 vcal = Parse_MIME_FromFileName( QFile::encodeName(m_file).data() ); 152 vcal = Parse_MIME_FromFileName( QFile::encodeName(m_file).data() );
122 if (!vcal ) 153 if (!vcal )
123 return false; 154 return false;
124 155
125 // Iterate over the list 156 // Iterate over the list
126 VObjectIterator it; 157 VObjectIterator it;
127 VObject* vobj; 158 VObject* vobj;
128 159
129 initPropIterator(&it, vcal); 160 initPropIterator(&it, vcal);
130 161
131 while( moreIteration( &it ) ) { 162 while( moreIteration( &it ) ) {
132 vobj = ::nextVObject( &it ); 163 vobj = ::nextVObject( &it );
133 QCString name = ::vObjectName( vobj ); 164 QCString name = ::vObjectName( vobj );
134 if( name == VCTodoProp ){ 165 if( name == VCTodoProp ){
135 OTodo to = eventByVObj( vobj ); 166 OTodo to = eventByVObj( vobj );
136 m_map.insert( to.uid(), to ); 167 m_map.insert( to.uid(), to );
137 } 168 }
138 } 169 }
139 170
140 // Should I do a delete vcal? 171 // Should I do a delete vcal?
141 172
142 return true; 173 return true;
143} 174}
144bool OTodoAccessVCal::reload() { 175bool OTodoAccessVCal::reload() {
145 return load(); 176 return load();
146} 177}
147bool OTodoAccessVCal::save() { 178bool OTodoAccessVCal::save() {
148 if (!m_dirty ) 179 if (!m_dirty )
149 return true; 180 return true;
150 181
151 QFileDirect file( m_file ); 182 QFileDirect file( m_file );
152 if (!file.open(IO_WriteOnly ) ) 183 if (!file.open(IO_WriteOnly ) )
153 return false; 184 return false;
154 185
155 VObject *obj; 186 VObject *obj;
156 obj = newVObject( VCCalProp ); 187 obj = newVObject( VCCalProp );
157 addPropValue( obj, VCVersionProp, "1.0" ); 188 addPropValue( obj, VCVersionProp, "1.0" );
158 VObject *vo; 189 VObject *vo;
159 for(QMap<int, OTodo>::ConstIterator it=m_map.begin(); it !=m_map.end(); ++it ){ 190 for(QMap<int, OTodo>::ConstIterator it=m_map.begin(); it !=m_map.end(); ++it ){
160 vo = vobjByEvent( it.data() ); 191 vo = vobjByEvent( it.data() );
161 addVObjectProp(obj, vo ); 192 addVObjectProp(obj, vo );
162 } 193 }
163 writeVObject( file.directHandle(), obj ); 194 writeVObject( file.directHandle(), obj );
164 cleanVObject( obj ); 195 cleanVObject( obj );
165 cleanStrTbl(); 196 cleanStrTbl();
166 197
167 m_dirty = false; 198 m_dirty = false;
168 return true; 199 return true;
169} 200}
170void OTodoAccessVCal::clear() { 201void OTodoAccessVCal::clear() {
171 m_map.clear(); 202 m_map.clear();
172 m_dirty = true; 203 m_dirty = true;
173} 204}
174bool OTodoAccessVCal::add( const OTodo& to ) { 205bool OTodoAccessVCal::add( const OTodo& to ) {
175 m_map.insert( to.uid(), to ); 206 m_map.insert( to.uid(), to );
176 m_dirty = true; 207 m_dirty = true;
177 return true; 208 return true;
178} 209}
179bool OTodoAccessVCal::remove( int uid ) { 210bool OTodoAccessVCal::remove( int uid ) {
180 m_map.remove( uid ); 211 m_map.remove( uid );
181 m_dirty = true; 212 m_dirty = true;
182 return true; 213 return true;
183} 214}
184void OTodoAccessVCal::removeAllCompleted() { 215void OTodoAccessVCal::removeAllCompleted() {
185 for ( QMap<int, OTodo>::Iterator it = m_map.begin(); it != m_map.end(); ++it ) { 216 for ( QMap<int, OTodo>::Iterator it = m_map.begin(); it != m_map.end(); ++it ) {
186 if ( (*it).isCompleted() ) 217 if ( (*it).isCompleted() )
187 m_map.remove( it ); 218 m_map.remove( it );
188 } 219 }
189} 220}
190bool OTodoAccessVCal::replace( const OTodo& to ) { 221bool OTodoAccessVCal::replace( const OTodo& to ) {
191 m_map.replace( to.uid(), to ); 222 m_map.replace( to.uid(), to );
192 m_dirty = true; 223 m_dirty = true;
193 return true; 224 return true;
194} 225}
195OTodo OTodoAccessVCal::find(int uid )const { 226OTodo OTodoAccessVCal::find(int uid )const {
196 return m_map[uid]; 227 return m_map[uid];
197} 228}
198QArray<int> OTodoAccessVCal::sorted( bool, int, int, int ) { 229QArray<int> OTodoAccessVCal::sorted( bool, int, int, int ) {
199 QArray<int> ar(0); 230 QArray<int> ar(0);
200 return ar; 231 return ar;
201} 232}
202QArray<int> OTodoAccessVCal::allRecords()const { 233QArray<int> OTodoAccessVCal::allRecords()const {
203 QArray<int> ar( m_map.count() ); 234 QArray<int> ar( m_map.count() );
204 QMap<int, OTodo>::ConstIterator it; 235 QMap<int, OTodo>::ConstIterator it;
205 int i = 0; 236 int i = 0;
206 for ( it = m_map.begin(); it != m_map.end(); ++it ) { 237 for ( it = m_map.begin(); it != m_map.end(); ++it ) {
207 ar[i] = it.key(); 238 ar[i] = it.key();
208 i++; 239 i++;
209 } 240 }
210 return ar; 241 return ar;
211} 242}
212QArray<int> OTodoAccessVCal::matchRegexp(const QRegExp& /* r */)const { 243QArray<int> OTodoAccessVCal::matchRegexp(const QRegExp& /* r */)const {
213 QArray<int> ar(0); 244 QArray<int> ar(0);
214 return ar; 245 return ar;
215} 246}
216QArray<int> OTodoAccessVCal::queryByExample( const OTodo&, int, const QDateTime& ) { 247QArray<int> OTodoAccessVCal::queryByExample( const OTodo&, int, const QDateTime& ) {
217 QArray<int> ar(0); 248 QArray<int> ar(0);
218 return ar; 249 return ar;
219} 250}
220QArray<int> OTodoAccessVCal::effectiveToDos( const QDate& , 251QArray<int> OTodoAccessVCal::effectiveToDos( const QDate& ,
221 const QDate& , 252 const QDate& ,
222 bool ) { 253 bool ) {
223 QArray<int> ar(0); 254 QArray<int> ar(0);
224 return ar; 255 return ar;
225} 256}
226QArray<int> OTodoAccessVCal::overDue() { 257QArray<int> OTodoAccessVCal::overDue() {
227 QArray<int> ar(0); 258 QArray<int> ar(0);
228 return ar; 259 return ar;
229} 260}
230QBitArray OTodoAccessVCal::supports()const { 261QBitArray OTodoAccessVCal::supports()const {
231 static QBitArray ar = sup(); 262 static QBitArray ar = sup();
232 263
233 return ar; 264 return ar;
234} 265}
235QBitArray OTodoAccessVCal::sup() { 266QBitArray OTodoAccessVCal::sup() {
236 QBitArray ar ( OTodo::CompletedDate +1 ); 267 QBitArray ar ( OTodo::CompletedDate +1 );
237 ar.fill( true ); 268 ar.fill( true );
238 269
239 ar[OTodo::CrossReference] = false; 270 ar[OTodo::CrossReference] = false;
240 ar[OTodo::State ] = false; 271 ar[OTodo::State ] = false;
241 ar[OTodo::Reminders] = false; 272 ar[OTodo::Reminders] = false;
242 ar[OTodo::Notifiers] = false; 273 ar[OTodo::Notifiers] = false;
243 ar[OTodo::Maintainer] = false; 274 ar[OTodo::Maintainer] = false;
244 ar[OTodo::Progress] = false; 275 ar[OTodo::Progress] = false;
245 ar[OTodo::Alarms ] = false; 276 ar[OTodo::Alarms ] = false;
246 ar[OTodo::Recurrence] = false; 277 ar[OTodo::Recurrence] = false;
247 278
248 return ar; 279 return ar;
249} 280}
281
282}
diff --git a/libopie2/opiepim/backend/otodoaccessvcal.h b/libopie2/opiepim/backend/otodoaccessvcal.h
index 2b17147..f9323fb 100644
--- a/libopie2/opiepim/backend/otodoaccessvcal.h
+++ b/libopie2/opiepim/backend/otodoaccessvcal.h
@@ -1,40 +1,72 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_OTODO_ACCESS_VCAL_H 29#ifndef OPIE_OTODO_ACCESS_VCAL_H
2#define OPIE_OTODO_ACCESS_VCAL_H 30#define OPIE_OTODO_ACCESS_VCAL_H
3 31
4#include "otodoaccessbackend.h" 32#include <opie2/otodoaccessbackend.h>
33
34namespace Opie {
5 35
6class OTodoAccessVCal : public OTodoAccessBackend { 36class OTodoAccessVCal : public OTodoAccessBackend {
7public: 37public:
8 OTodoAccessVCal(const QString& ); 38 OTodoAccessVCal(const QString& );
9 ~OTodoAccessVCal(); 39 ~OTodoAccessVCal();
10 40
11 bool load(); 41 bool load();
12 bool reload(); 42 bool reload();
13 bool save(); 43 bool save();
14 44
15 QArray<int> allRecords()const; 45 QArray<int> allRecords()const;
16 QArray<int> matchRegexp(const QRegExp &r) const; 46 QArray<int> matchRegexp(const QRegExp &r) const;
17 QArray<int> queryByExample( const OTodo& t, int sort, const QDateTime& d = QDateTime() ); 47 QArray<int> queryByExample( const OTodo& t, int sort, const QDateTime& d = QDateTime() );
18 QArray<int> effectiveToDos( const QDate& start, 48 QArray<int> effectiveToDos( const QDate& start,
19 const QDate& end, 49 const QDate& end,
20 bool includeNoDates ); 50 bool includeNoDates );
21 QArray<int> overDue(); 51 QArray<int> overDue();
22 QArray<int> sorted( bool asc, int sortOrder, int sortFilter, 52 QArray<int> sorted( bool asc, int sortOrder, int sortFilter,
23 int cat ); 53 int cat );
24 OTodo find(int uid)const; 54 OTodo find(int uid)const;
25 void clear(); 55 void clear();
26 bool add( const OTodo& ); 56 bool add( const OTodo& );
27 bool remove( int uid ); 57 bool remove( int uid );
28 bool replace( const OTodo& ); 58 bool replace( const OTodo& );
29 59
30 void removeAllCompleted(); 60 void removeAllCompleted();
31 virtual QBitArray supports()const; 61 virtual QBitArray supports()const;
32 62
33private: 63private:
34 static QBitArray sup(); 64 static QBitArray sup();
35 bool m_dirty : 1; 65 bool m_dirty : 1;
36 QString m_file; 66 QString m_file;
37 QMap<int, OTodo> m_map; 67 QMap<int, OTodo> m_map;
38}; 68};
39 69
70}
71
40#endif 72#endif
diff --git a/libopie2/opiepim/backend/otodoaccessxml.cpp b/libopie2/opiepim/backend/otodoaccessxml.cpp
index 4a5cb33..2d50ecd 100644
--- a/libopie2/opiepim/backend/otodoaccessxml.cpp
+++ b/libopie2/opiepim/backend/otodoaccessxml.cpp
@@ -1,876 +1,909 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <errno.h> 29#include <errno.h>
2#include <fcntl.h> 30#include <fcntl.h>
3 31
4#include <sys/mman.h> 32#include <sys/mman.h>
5#include <sys/stat.h> 33#include <sys/stat.h>
6#include <sys/types.h> 34#include <sys/types.h>
7 35
8#include <unistd.h> 36#include <unistd.h>
9 37
10 38
11#include <qfile.h> 39#include <qfile.h>
12#include <qvector.h> 40#include <qvector.h>
13 41
14#include <qpe/global.h> 42#include <qpe/global.h>
15#include <qpe/stringutil.h> 43#include <qpe/stringutil.h>
16#include <qpe/timeconversion.h> 44#include <qpe/timeconversion.h>
17 45
18#include "oconversion.h" 46#include <opie2/oconversion.h>
19#include "opimstate.h" 47#include <opie2/opimstate.h>
20#include "otimezone.h" 48#include <opie2/otimezone.h>
21#include "opimnotifymanager.h" 49#include <opie2/opimnotifymanager.h>
22#include "orecur.h" 50#include <opie2/orecur.h>
23#include "otodoaccessxml.h" 51#include <opie2/otodoaccessxml.h>
52
53using namespace Opie;
24 54
25namespace { 55namespace {
26 time_t rp_end; 56 time_t rp_end;
27 ORecur* rec; 57 ORecur* rec;
28 ORecur *recur() { 58 ORecur *recur() {
29 if (!rec ) rec = new ORecur; 59 if (!rec ) rec = new ORecur;
30 return rec; 60 return rec;
31 } 61 }
32 int snd; 62 int snd;
33 enum MoreAttributes { 63 enum MoreAttributes {
34 FRType = OTodo::CompletedDate + 2, 64 FRType = OTodo::CompletedDate + 2,
35 FRWeekdays, 65 FRWeekdays,
36 FRPosition, 66 FRPosition,
37 FRFreq, 67 FRFreq,
38 FRHasEndDate, 68 FRHasEndDate,
39 FREndDate, 69 FREndDate,
40 FRStart, 70 FRStart,
41 FREnd 71 FREnd
42 }; 72 };
43 // FROM TT again 73 // FROM TT again
44char *strstrlen(const char *haystack, int hLen, const char* needle, int nLen) 74char *strstrlen(const char *haystack, int hLen, const char* needle, int nLen)
45{ 75{
46 char needleChar; 76 char needleChar;
47 char haystackChar; 77 char haystackChar;
48 if (!needle || !haystack || !hLen || !nLen) 78 if (!needle || !haystack || !hLen || !nLen)
49 return 0; 79 return 0;
50 80
51 const char* hsearch = haystack; 81 const char* hsearch = haystack;
52 82
53 if ((needleChar = *needle++) != 0) { 83 if ((needleChar = *needle++) != 0) {
54 nLen--; //(to make up for needle++) 84 nLen--; //(to make up for needle++)
55 do { 85 do {
56 do { 86 do {
57 if ((haystackChar = *hsearch++) == 0) 87 if ((haystackChar = *hsearch++) == 0)
58 return (0); 88 return (0);
59 if (hsearch >= haystack + hLen) 89 if (hsearch >= haystack + hLen)
60 return (0); 90 return (0);
61 } while (haystackChar != needleChar); 91 } while (haystackChar != needleChar);
62 } while (strncmp(hsearch, needle, QMIN(hLen - (hsearch - haystack), nLen)) != 0); 92 } while (strncmp(hsearch, needle, QMIN(hLen - (hsearch - haystack), nLen)) != 0);
63 hsearch--; 93 hsearch--;
64 } 94 }
65 return ((char *)hsearch); 95 return ((char *)hsearch);
66} 96}
67} 97}
68 98
99namespace Opie {
69 100
70OTodoAccessXML::OTodoAccessXML( const QString& appName, 101OTodoAccessXML::OTodoAccessXML( const QString& appName,
71 const QString& fileName ) 102 const QString& fileName )
72 : OTodoAccessBackend(), m_app( appName ), m_opened( false ), m_changed( false ) 103 : OTodoAccessBackend(), m_app( appName ), m_opened( false ), m_changed( false )
73{ 104{
74 if (!fileName.isEmpty() ) 105 if (!fileName.isEmpty() )
75 m_file = fileName; 106 m_file = fileName;
76 else 107 else
77 m_file = Global::applicationFileName( "todolist", "todolist.xml" ); 108 m_file = Global::applicationFileName( "todolist", "todolist.xml" );
78} 109}
79OTodoAccessXML::~OTodoAccessXML() { 110OTodoAccessXML::~OTodoAccessXML() {
80 111
81} 112}
82bool OTodoAccessXML::load() { 113bool OTodoAccessXML::load() {
83 rec = 0; 114 rec = 0;
84 m_opened = true; 115 m_opened = true;
85 m_changed = false; 116 m_changed = false;
86 /* initialize dict */ 117 /* initialize dict */
87 /* 118 /*
88 * UPDATE dict if you change anything!!! 119 * UPDATE dict if you change anything!!!
89 */ 120 */
90 QAsciiDict<int> dict(26); 121 QAsciiDict<int> dict(26);
91 dict.setAutoDelete( TRUE ); 122 dict.setAutoDelete( TRUE );
92 dict.insert("Categories" , new int(OTodo::Category) ); 123 dict.insert("Categories" , new int(OTodo::Category) );
93 dict.insert("Uid" , new int(OTodo::Uid) ); 124 dict.insert("Uid" , new int(OTodo::Uid) );
94 dict.insert("HasDate" , new int(OTodo::HasDate) ); 125 dict.insert("HasDate" , new int(OTodo::HasDate) );
95 dict.insert("Completed" , new int(OTodo::Completed) ); 126 dict.insert("Completed" , new int(OTodo::Completed) );
96 dict.insert("Description" , new int(OTodo::Description) ); 127 dict.insert("Description" , new int(OTodo::Description) );
97 dict.insert("Summary" , new int(OTodo::Summary) ); 128 dict.insert("Summary" , new int(OTodo::Summary) );
98 dict.insert("Priority" , new int(OTodo::Priority) ); 129 dict.insert("Priority" , new int(OTodo::Priority) );
99 dict.insert("DateDay" , new int(OTodo::DateDay) ); 130 dict.insert("DateDay" , new int(OTodo::DateDay) );
100 dict.insert("DateMonth" , new int(OTodo::DateMonth) ); 131 dict.insert("DateMonth" , new int(OTodo::DateMonth) );
101 dict.insert("DateYear" , new int(OTodo::DateYear) ); 132 dict.insert("DateYear" , new int(OTodo::DateYear) );
102 dict.insert("Progress" , new int(OTodo::Progress) ); 133 dict.insert("Progress" , new int(OTodo::Progress) );
103 dict.insert("CompletedDate", new int(OTodo::CompletedDate) ); 134 dict.insert("CompletedDate", new int(OTodo::CompletedDate) );
104 dict.insert("StartDate", new int(OTodo::StartDate) ); 135 dict.insert("StartDate", new int(OTodo::StartDate) );
105 dict.insert("CrossReference", new int(OTodo::CrossReference) ); 136 dict.insert("CrossReference", new int(OTodo::CrossReference) );
106 dict.insert("State", new int(OTodo::State) ); 137 dict.insert("State", new int(OTodo::State) );
107 dict.insert("Alarms", new int(OTodo::Alarms) ); 138 dict.insert("Alarms", new int(OTodo::Alarms) );
108 dict.insert("Reminders", new int(OTodo::Reminders) ); 139 dict.insert("Reminders", new int(OTodo::Reminders) );
109 dict.insert("Notifiers", new int(OTodo::Notifiers) ); 140 dict.insert("Notifiers", new int(OTodo::Notifiers) );
110 dict.insert("Maintainer", new int(OTodo::Maintainer) ); 141 dict.insert("Maintainer", new int(OTodo::Maintainer) );
111 dict.insert("rtype", new int(FRType) ); 142 dict.insert("rtype", new int(FRType) );
112 dict.insert("rweekdays", new int(FRWeekdays) ); 143 dict.insert("rweekdays", new int(FRWeekdays) );
113 dict.insert("rposition", new int(FRPosition) ); 144 dict.insert("rposition", new int(FRPosition) );
114 dict.insert("rfreq", new int(FRFreq) ); 145 dict.insert("rfreq", new int(FRFreq) );
115 dict.insert("start", new int(FRStart) ); 146 dict.insert("start", new int(FRStart) );
116 dict.insert("rhasenddate", new int(FRHasEndDate) ); 147 dict.insert("rhasenddate", new int(FRHasEndDate) );
117 dict.insert("enddt", new int(FREndDate) ); 148 dict.insert("enddt", new int(FREndDate) );
118 149
119 // here the custom XML parser from TT it's GPL 150 // here the custom XML parser from TT it's GPL
120 // but we want to push OpiePIM... to TT..... 151 // but we want to push OpiePIM... to TT.....
121 // mmap part from zecke :) 152 // mmap part from zecke :)
122 int fd = ::open( QFile::encodeName(m_file).data(), O_RDONLY ); 153 int fd = ::open( QFile::encodeName(m_file).data(), O_RDONLY );
123 struct stat attribut; 154 struct stat attribut;
124 if ( fd < 0 ) return false; 155 if ( fd < 0 ) return false;
125 156
126 if ( fstat(fd, &attribut ) == -1 ) { 157 if ( fstat(fd, &attribut ) == -1 ) {
127 ::close( fd ); 158 ::close( fd );
128 return false; 159 return false;
129 } 160 }
130 void* map_addr = ::mmap(NULL, attribut.st_size, PROT_READ, MAP_SHARED, fd, 0 ); 161 void* map_addr = ::mmap(NULL, attribut.st_size, PROT_READ, MAP_SHARED, fd, 0 );
131 if ( map_addr == ( (caddr_t)-1) ) { 162 if ( map_addr == ( (caddr_t)-1) ) {
132 ::close(fd ); 163 ::close(fd );
133 return false; 164 return false;
134 } 165 }
135 /* advise the kernel who we want to read it */ 166 /* advise the kernel who we want to read it */
136 ::madvise( map_addr, attribut.st_size, MADV_SEQUENTIAL ); 167 ::madvise( map_addr, attribut.st_size, MADV_SEQUENTIAL );
137 /* we do not the file any more */ 168 /* we do not the file any more */
138 ::close( fd ); 169 ::close( fd );
139 170
140 char* dt = (char*)map_addr; 171 char* dt = (char*)map_addr;
141 int len = attribut.st_size; 172 int len = attribut.st_size;
142 int i = 0; 173 int i = 0;
143 char *point; 174 char *point;
144 const char* collectionString = "<Task "; 175 const char* collectionString = "<Task ";
145 int strLen = strlen(collectionString); 176 int strLen = strlen(collectionString);
146 while ( ( point = strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0l ) { 177 while ( ( point = strstrlen( dt+i, len -i, collectionString, strLen ) ) != 0l ) {
147 i = point -dt; 178 i = point -dt;
148 i+= strLen; 179 i+= strLen;
149 qWarning("Found a start at %d %d", i, (point-dt) ); 180 qWarning("Found a start at %d %d", i, (point-dt) );
150 181
151 OTodo ev; 182 OTodo ev;
152 m_year = m_month = m_day = 0; 183 m_year = m_month = m_day = 0;
153 184
154 while ( TRUE ) { 185 while ( TRUE ) {
155 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') ) 186 while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') )
156 ++i; 187 ++i;
157 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') ) 188 if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') )
158 break; 189 break;
159 190
160 // we have another attribute, read it. 191 // we have another attribute, read it.
161 int j = i; 192 int j = i;
162 while ( j < len && dt[j] != '=' ) 193 while ( j < len && dt[j] != '=' )
163 ++j; 194 ++j;
164 QCString attr( dt+i, j-i+1); 195 QCString attr( dt+i, j-i+1);
165 196
166 i = ++j; // skip = 197 i = ++j; // skip =
167 198
168 // find the start of quotes 199 // find the start of quotes
169 while ( i < len && dt[i] != '"' ) 200 while ( i < len && dt[i] != '"' )
170 ++i; 201 ++i;
171 j = ++i; 202 j = ++i;
172 203
173 bool haveUtf = FALSE; 204 bool haveUtf = FALSE;
174 bool haveEnt = FALSE; 205 bool haveEnt = FALSE;
175 while ( j < len && dt[j] != '"' ) { 206 while ( j < len && dt[j] != '"' ) {
176 if ( ((unsigned char)dt[j]) > 0x7f ) 207 if ( ((unsigned char)dt[j]) > 0x7f )
177 haveUtf = TRUE; 208 haveUtf = TRUE;
178 if ( dt[j] == '&' ) 209 if ( dt[j] == '&' )
179 haveEnt = TRUE; 210 haveEnt = TRUE;
180 ++j; 211 ++j;
181 } 212 }
182 if ( i == j ) { 213 if ( i == j ) {
183 // empty value 214 // empty value
184 i = j + 1; 215 i = j + 1;
185 continue; 216 continue;
186 } 217 }
187 218
188 QCString value( dt+i, j-i+1 ); 219 QCString value( dt+i, j-i+1 );
189 i = j + 1; 220 i = j + 1;
190 221
191 QString str = (haveUtf ? QString::fromUtf8( value ) 222 QString str = (haveUtf ? QString::fromUtf8( value )
192 : QString::fromLatin1( value ) ); 223 : QString::fromLatin1( value ) );
193 if ( haveEnt ) 224 if ( haveEnt )
194 str = Qtopia::plainString( str ); 225 str = Qtopia::plainString( str );
195 226
196 /* 227 /*
197 * add key + value 228 * add key + value
198 */ 229 */
199 todo( &dict, ev, attr, str ); 230 todo( &dict, ev, attr, str );
200 231
201 } 232 }
202 /* 233 /*
203 * now add it 234 * now add it
204 */ 235 */
205 qWarning("End at %d", i ); 236 qWarning("End at %d", i );
206 if (m_events.contains( ev.uid() ) || ev.uid() == 0) { 237 if (m_events.contains( ev.uid() ) || ev.uid() == 0) {
207 ev.setUid( 1 ); 238 ev.setUid( 1 );
208 m_changed = true; 239 m_changed = true;
209 } 240 }
210 if ( ev.hasDueDate() ) { 241 if ( ev.hasDueDate() ) {
211 ev.setDueDate( QDate(m_year, m_month, m_day) ); 242 ev.setDueDate( QDate(m_year, m_month, m_day) );
212 } 243 }
213 if ( rec && rec->doesRecur() ) { 244 if ( rec && rec->doesRecur() ) {
214 OTimeZone utc = OTimeZone::utc(); 245 OTimeZone utc = OTimeZone::utc();
215 ORecur recu( *rec ); // call copy c'tor 246 ORecur recu( *rec ); // call copy c'tor
216 recu.setEndDate( utc.fromUTCDateTime( rp_end ).date() ); 247 recu.setEndDate( utc.fromUTCDateTime( rp_end ).date() );
217 recu.setStart( ev.dueDate() ); 248 recu.setStart( ev.dueDate() );
218 ev.setRecurrence( recu ); 249 ev.setRecurrence( recu );
219 } 250 }
220 m_events.insert(ev.uid(), ev ); 251 m_events.insert(ev.uid(), ev );
221 m_year = m_month = m_day = -1; 252 m_year = m_month = m_day = -1;
222 delete rec; 253 delete rec;
223 rec = 0; 254 rec = 0;
224 } 255 }
225 256
226 munmap(map_addr, attribut.st_size ); 257 munmap(map_addr, attribut.st_size );
227 258
228 qWarning("counts %d records loaded!", m_events.count() ); 259 qWarning("counts %d records loaded!", m_events.count() );
229 return true; 260 return true;
230} 261}
231bool OTodoAccessXML::reload() { 262bool OTodoAccessXML::reload() {
232 m_events.clear(); 263 m_events.clear();
233 return load(); 264 return load();
234} 265}
235bool OTodoAccessXML::save() { 266bool OTodoAccessXML::save() {
236// qWarning("saving"); 267// qWarning("saving");
237 if (!m_opened || !m_changed ) { 268 if (!m_opened || !m_changed ) {
238// qWarning("not saving"); 269// qWarning("not saving");
239 return true; 270 return true;
240 } 271 }
241 QString strNewFile = m_file + ".new"; 272 QString strNewFile = m_file + ".new";
242 QFile f( strNewFile ); 273 QFile f( strNewFile );
243 if (!f.open( IO_WriteOnly|IO_Raw ) ) 274 if (!f.open( IO_WriteOnly|IO_Raw ) )
244 return false; 275 return false;
245 276
246 int written; 277 int written;
247 QString out; 278 QString out;
248 out = "<!DOCTYPE Tasks>\n<Tasks>\n"; 279 out = "<!DOCTYPE Tasks>\n<Tasks>\n";
249 280
250 // for all todos 281 // for all todos
251 QMap<int, OTodo>::Iterator it; 282 QMap<int, OTodo>::Iterator it;
252 for (it = m_events.begin(); it != m_events.end(); ++it ) { 283 for (it = m_events.begin(); it != m_events.end(); ++it ) {
253 out+= "<Task " + toString( (*it) ) + " />\n"; 284 out+= "<Task " + toString( (*it) ) + " />\n";
254 QCString cstr = out.utf8(); 285 QCString cstr = out.utf8();
255 written = f.writeBlock( cstr.data(), cstr.length() ); 286 written = f.writeBlock( cstr.data(), cstr.length() );
256 287
257 /* less written then we wanted */ 288 /* less written then we wanted */
258 if ( written != (int)cstr.length() ) { 289 if ( written != (int)cstr.length() ) {
259 f.close(); 290 f.close();
260 QFile::remove( strNewFile ); 291 QFile::remove( strNewFile );
261 return false; 292 return false;
262 } 293 }
263 out = QString::null; 294 out = QString::null;
264 } 295 }
265 296
266 out += "</Tasks>"; 297 out += "</Tasks>";
267 QCString cstr = out.utf8(); 298 QCString cstr = out.utf8();
268 written = f.writeBlock( cstr.data(), cstr.length() ); 299 written = f.writeBlock( cstr.data(), cstr.length() );
269 300
270 if ( written != (int)cstr.length() ) { 301 if ( written != (int)cstr.length() ) {
271 f.close(); 302 f.close();
272 QFile::remove( strNewFile ); 303 QFile::remove( strNewFile );
273 return false; 304 return false;
274 } 305 }
275 /* flush before renaming */ 306 /* flush before renaming */
276 f.close(); 307 f.close();
277 308
278 if( ::rename( strNewFile.latin1(), m_file.latin1() ) < 0 ) { 309 if( ::rename( strNewFile.latin1(), m_file.latin1() ) < 0 ) {
279// qWarning("error renaming"); 310// qWarning("error renaming");
280 QFile::remove( strNewFile ); 311 QFile::remove( strNewFile );
281 } 312 }
282 313
283 m_changed = false; 314 m_changed = false;
284 return true; 315 return true;
285} 316}
286QArray<int> OTodoAccessXML::allRecords()const { 317QArray<int> OTodoAccessXML::allRecords()const {
287 QArray<int> ids( m_events.count() ); 318 QArray<int> ids( m_events.count() );
288 QMap<int, OTodo>::ConstIterator it; 319 QMap<int, OTodo>::ConstIterator it;
289 int i = 0; 320 int i = 0;
290 321
291 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 322 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
292 ids[i] = it.key(); 323 ids[i] = it.key();
293 i++; 324 i++;
294 } 325 }
295 return ids; 326 return ids;
296} 327}
297QArray<int> OTodoAccessXML::queryByExample( const OTodo&, int, const QDateTime& ) { 328QArray<int> OTodoAccessXML::queryByExample( const OTodo&, int, const QDateTime& ) {
298 QArray<int> ids(0); 329 QArray<int> ids(0);
299 return ids; 330 return ids;
300} 331}
301OTodo OTodoAccessXML::find( int uid )const { 332OTodo OTodoAccessXML::find( int uid )const {
302 OTodo todo; 333 OTodo todo;
303 todo.setUid( 0 ); // isEmpty() 334 todo.setUid( 0 ); // isEmpty()
304 QMap<int, OTodo>::ConstIterator it = m_events.find( uid ); 335 QMap<int, OTodo>::ConstIterator it = m_events.find( uid );
305 if ( it != m_events.end() ) 336 if ( it != m_events.end() )
306 todo = it.data(); 337 todo = it.data();
307 338
308 return todo; 339 return todo;
309} 340}
310void OTodoAccessXML::clear() { 341void OTodoAccessXML::clear() {
311 if (m_opened ) 342 if (m_opened )
312 m_changed = true; 343 m_changed = true;
313 344
314 m_events.clear(); 345 m_events.clear();
315} 346}
316bool OTodoAccessXML::add( const OTodo& todo ) { 347bool OTodoAccessXML::add( const OTodo& todo ) {
317// qWarning("add"); 348// qWarning("add");
318 m_changed = true; 349 m_changed = true;
319 m_events.insert( todo.uid(), todo ); 350 m_events.insert( todo.uid(), todo );
320 351
321 return true; 352 return true;
322} 353}
323bool OTodoAccessXML::remove( int uid ) { 354bool OTodoAccessXML::remove( int uid ) {
324 m_changed = true; 355 m_changed = true;
325 m_events.remove( uid ); 356 m_events.remove( uid );
326 357
327 return true; 358 return true;
328} 359}
329bool OTodoAccessXML::replace( const OTodo& todo) { 360bool OTodoAccessXML::replace( const OTodo& todo) {
330 m_changed = true; 361 m_changed = true;
331 m_events.replace( todo.uid(), todo ); 362 m_events.replace( todo.uid(), todo );
332 363
333 return true; 364 return true;
334} 365}
335QArray<int> OTodoAccessXML::effectiveToDos( const QDate& start, 366QArray<int> OTodoAccessXML::effectiveToDos( const QDate& start,
336 const QDate& end, 367 const QDate& end,
337 bool includeNoDates ) { 368 bool includeNoDates ) {
338 QArray<int> ids( m_events.count() ); 369 QArray<int> ids( m_events.count() );
339 QMap<int, OTodo>::Iterator it; 370 QMap<int, OTodo>::Iterator it;
340 371
341 int i = 0; 372 int i = 0;
342 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 373 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
343 if ( !it.data().hasDueDate() ) { 374 if ( !it.data().hasDueDate() ) {
344 if ( includeNoDates ) { 375 if ( includeNoDates ) {
345 ids[i] = it.key(); 376 ids[i] = it.key();
346 i++; 377 i++;
347 } 378 }
348 }else if ( it.data().dueDate() >= start && 379 }else if ( it.data().dueDate() >= start &&
349 it.data().dueDate() <= end ) { 380 it.data().dueDate() <= end ) {
350 ids[i] = it.key(); 381 ids[i] = it.key();
351 i++; 382 i++;
352 } 383 }
353 } 384 }
354 ids.resize( i ); 385 ids.resize( i );
355 return ids; 386 return ids;
356} 387}
357QArray<int> OTodoAccessXML::overDue() { 388QArray<int> OTodoAccessXML::overDue() {
358 QArray<int> ids( m_events.count() ); 389 QArray<int> ids( m_events.count() );
359 int i = 0; 390 int i = 0;
360 391
361 QMap<int, OTodo>::Iterator it; 392 QMap<int, OTodo>::Iterator it;
362 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 393 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
363 if ( it.data().isOverdue() ) { 394 if ( it.data().isOverdue() ) {
364 ids[i] = it.key(); 395 ids[i] = it.key();
365 i++; 396 i++;
366 } 397 }
367 } 398 }
368 ids.resize( i ); 399 ids.resize( i );
369 return ids; 400 return ids;
370} 401}
371 402
372 403
373/* private */ 404/* private */
374void OTodoAccessXML::todo( QAsciiDict<int>* dict, OTodo& ev, 405void OTodoAccessXML::todo( QAsciiDict<int>* dict, OTodo& ev,
375 const QCString& attr, const QString& val) { 406 const QCString& attr, const QString& val) {
376// qWarning("parse to do from XMLElement" ); 407// qWarning("parse to do from XMLElement" );
377 408
378 int *find=0; 409 int *find=0;
379 410
380 find = (*dict)[ attr.data() ]; 411 find = (*dict)[ attr.data() ];
381 if (!find ) { 412 if (!find ) {
382// qWarning("Unknown option" + it.key() ); 413// qWarning("Unknown option" + it.key() );
383 ev.setCustomField( attr, val ); 414 ev.setCustomField( attr, val );
384 return; 415 return;
385 } 416 }
386 417
387 switch( *find ) { 418 switch( *find ) {
388 case OTodo::Uid: 419 case OTodo::Uid:
389 ev.setUid( val.toInt() ); 420 ev.setUid( val.toInt() );
390 break; 421 break;
391 case OTodo::Category: 422 case OTodo::Category:
392 ev.setCategories( ev.idsFromString( val ) ); 423 ev.setCategories( ev.idsFromString( val ) );
393 break; 424 break;
394 case OTodo::HasDate: 425 case OTodo::HasDate:
395 ev.setHasDueDate( val.toInt() ); 426 ev.setHasDueDate( val.toInt() );
396 break; 427 break;
397 case OTodo::Completed: 428 case OTodo::Completed:
398 ev.setCompleted( val.toInt() ); 429 ev.setCompleted( val.toInt() );
399 break; 430 break;
400 case OTodo::Description: 431 case OTodo::Description:
401 ev.setDescription( val ); 432 ev.setDescription( val );
402 break; 433 break;
403 case OTodo::Summary: 434 case OTodo::Summary:
404 ev.setSummary( val ); 435 ev.setSummary( val );
405 break; 436 break;
406 case OTodo::Priority: 437 case OTodo::Priority:
407 ev.setPriority( val.toInt() ); 438 ev.setPriority( val.toInt() );
408 break; 439 break;
409 case OTodo::DateDay: 440 case OTodo::DateDay:
410 m_day = val.toInt(); 441 m_day = val.toInt();
411 break; 442 break;
412 case OTodo::DateMonth: 443 case OTodo::DateMonth:
413 m_month = val.toInt(); 444 m_month = val.toInt();
414 break; 445 break;
415 case OTodo::DateYear: 446 case OTodo::DateYear:
416 m_year = val.toInt(); 447 m_year = val.toInt();
417 break; 448 break;
418 case OTodo::Progress: 449 case OTodo::Progress:
419 ev.setProgress( val.toInt() ); 450 ev.setProgress( val.toInt() );
420 break; 451 break;
421 case OTodo::CompletedDate: 452 case OTodo::CompletedDate:
422 ev.setCompletedDate( OConversion::dateFromString( val ) ); 453 ev.setCompletedDate( OConversion::dateFromString( val ) );
423 break; 454 break;
424 case OTodo::StartDate: 455 case OTodo::StartDate:
425 ev.setStartDate( OConversion::dateFromString( val ) ); 456 ev.setStartDate( OConversion::dateFromString( val ) );
426 break; 457 break;
427 case OTodo::State: 458 case OTodo::State:
428 ev.setState( val.toInt() ); 459 ev.setState( val.toInt() );
429 break; 460 break;
430 case OTodo::Alarms:{ 461 case OTodo::Alarms:{
431 OPimNotifyManager &manager = ev.notifiers(); 462 OPimNotifyManager &manager = ev.notifiers();
432 QStringList als = QStringList::split(";", val ); 463 QStringList als = QStringList::split(";", val );
433 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) { 464 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) {
434 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty 465 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty
435 qWarning("alarm: %s", alarm.join("___").latin1() ); 466 qWarning("alarm: %s", alarm.join("___").latin1() );
436 qWarning("alarm[0]: %s %s", alarm[0].latin1(), OConversion::dateTimeFromString( alarm[0] ).toString().latin1() ); 467 qWarning("alarm[0]: %s %s", alarm[0].latin1(), OConversion::dateTimeFromString( alarm[0] ).toString().latin1() );
437 OPimAlarm al( alarm[2].toInt(), OConversion::dateTimeFromString( alarm[0] ), alarm[1].toInt() ); 468 OPimAlarm al( alarm[2].toInt(), OConversion::dateTimeFromString( alarm[0] ), alarm[1].toInt() );
438 manager.add( al ); 469 manager.add( al );
439 } 470 }
440 } 471 }
441 break; 472 break;
442 case OTodo::Reminders:{ 473 case OTodo::Reminders:{
443 OPimNotifyManager &manager = ev.notifiers(); 474 OPimNotifyManager &manager = ev.notifiers();
444 QStringList rems = QStringList::split(";", val ); 475 QStringList rems = QStringList::split(";", val );
445 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) { 476 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) {
446 OPimReminder rem( (*it).toInt() ); 477 OPimReminder rem( (*it).toInt() );
447 manager.add( rem ); 478 manager.add( rem );
448 } 479 }
449 } 480 }
450 break; 481 break;
451 case OTodo::CrossReference: 482 case OTodo::CrossReference:
452 { 483 {
453 /* 484 /*
454 * A cross refernce looks like 485 * A cross refernce looks like
455 * appname,id;appname,id 486 * appname,id;appname,id
456 * we need to split it up 487 * we need to split it up
457 */ 488 */
458 QStringList refs = QStringList::split(';', val ); 489 QStringList refs = QStringList::split(';', val );
459 QStringList::Iterator strIt; 490 QStringList::Iterator strIt;
460 for (strIt = refs.begin(); strIt != refs.end(); ++strIt ) { 491 for (strIt = refs.begin(); strIt != refs.end(); ++strIt ) {
461 int pos = (*strIt).find(','); 492 int pos = (*strIt).find(',');
462 if ( pos > -1 ) 493 if ( pos > -1 )
463 ; // ev.addRelation( (*strIt).left(pos), (*strIt).mid(pos+1).toInt() ); 494 ; // ev.addRelation( (*strIt).left(pos), (*strIt).mid(pos+1).toInt() );
464 495
465 } 496 }
466 break; 497 break;
467 } 498 }
468 /* Recurrence stuff below + post processing later */ 499 /* Recurrence stuff below + post processing later */
469 case FRType: 500 case FRType:
470 if ( val == "Daily" ) 501 if ( val == "Daily" )
471 recur()->setType( ORecur::Daily ); 502 recur()->setType( ORecur::Daily );
472 else if ( val == "Weekly" ) 503 else if ( val == "Weekly" )
473 recur()->setType( ORecur::Weekly); 504 recur()->setType( ORecur::Weekly);
474 else if ( val == "MonthlyDay" ) 505 else if ( val == "MonthlyDay" )
475 recur()->setType( ORecur::MonthlyDay ); 506 recur()->setType( ORecur::MonthlyDay );
476 else if ( val == "MonthlyDate" ) 507 else if ( val == "MonthlyDate" )
477 recur()->setType( ORecur::MonthlyDate ); 508 recur()->setType( ORecur::MonthlyDate );
478 else if ( val == "Yearly" ) 509 else if ( val == "Yearly" )
479 recur()->setType( ORecur::Yearly ); 510 recur()->setType( ORecur::Yearly );
480 else 511 else
481 recur()->setType( ORecur::NoRepeat ); 512 recur()->setType( ORecur::NoRepeat );
482 break; 513 break;
483 case FRWeekdays: 514 case FRWeekdays:
484 recur()->setDays( val.toInt() ); 515 recur()->setDays( val.toInt() );
485 break; 516 break;
486 case FRPosition: 517 case FRPosition:
487 recur()->setPosition( val.toInt() ); 518 recur()->setPosition( val.toInt() );
488 break; 519 break;
489 case FRFreq: 520 case FRFreq:
490 recur()->setFrequency( val.toInt() ); 521 recur()->setFrequency( val.toInt() );
491 break; 522 break;
492 case FRHasEndDate: 523 case FRHasEndDate:
493 recur()->setHasEndDate( val.toInt() ); 524 recur()->setHasEndDate( val.toInt() );
494 break; 525 break;
495 case FREndDate: { 526 case FREndDate: {
496 rp_end = (time_t) val.toLong(); 527 rp_end = (time_t) val.toLong();
497 break; 528 break;
498 } 529 }
499 default: 530 default:
500 ev.setCustomField( attr, val ); 531 ev.setCustomField( attr, val );
501 break; 532 break;
502 } 533 }
503} 534}
504 535
505// from PalmtopRecord... GPL ### FIXME 536// from PalmtopRecord... GPL ### FIXME
506namespace { 537namespace {
507QString customToXml(const QMap<QString, QString>& customMap ) 538QString customToXml(const QMap<QString, QString>& customMap )
508{ 539{
509 //qWarning(QString("writing custom %1").arg(customMap.count())); 540 //qWarning(QString("writing custom %1").arg(customMap.count()));
510 QString buf(" "); 541 QString buf(" ");
511 for ( QMap<QString, QString>::ConstIterator cit = customMap.begin(); 542 for ( QMap<QString, QString>::ConstIterator cit = customMap.begin();
512 cit != customMap.end(); ++cit) { 543 cit != customMap.end(); ++cit) {
513 // qWarning(".ITEM."); 544 // qWarning(".ITEM.");
514 buf += cit.key(); 545 buf += cit.key();
515 buf += "=\""; 546 buf += "=\"";
516 buf += Qtopia::escapeString(cit.data()); 547 buf += Qtopia::escapeString(cit.data());
517 buf += "\" "; 548 buf += "\" ";
518 } 549 }
519 return buf; 550 return buf;
520} 551}
521 552
522 553
523} 554}
524 555
525QString OTodoAccessXML::toString( const OTodo& ev )const { 556QString OTodoAccessXML::toString( const OTodo& ev )const {
526 QString str; 557 QString str;
527 558
528 str += "Completed=\"" + QString::number( ev.isCompleted() ) + "\" "; 559 str += "Completed=\"" + QString::number( ev.isCompleted() ) + "\" ";
529 str += "HasDate=\"" + QString::number( ev.hasDueDate() ) + "\" "; 560 str += "HasDate=\"" + QString::number( ev.hasDueDate() ) + "\" ";
530 str += "Priority=\"" + QString::number( ev.priority() ) + "\" "; 561 str += "Priority=\"" + QString::number( ev.priority() ) + "\" ";
531 str += "Progress=\"" + QString::number(ev.progress() ) + "\" "; 562 str += "Progress=\"" + QString::number(ev.progress() ) + "\" ";
532 563
533 str += "Categories=\"" + toString( ev.categories() ) + "\" "; 564 str += "Categories=\"" + toString( ev.categories() ) + "\" ";
534 str += "Description=\"" + Qtopia::escapeString( ev.description() ) + "\" "; 565 str += "Description=\"" + Qtopia::escapeString( ev.description() ) + "\" ";
535 str += "Summary=\"" + Qtopia::escapeString( ev.summary() ) + "\" "; 566 str += "Summary=\"" + Qtopia::escapeString( ev.summary() ) + "\" ";
536 567
537 if ( ev.hasDueDate() ) { 568 if ( ev.hasDueDate() ) {
538 str += "DateYear=\"" + QString::number( ev.dueDate().year() ) + "\" "; 569 str += "DateYear=\"" + QString::number( ev.dueDate().year() ) + "\" ";
539 str += "DateMonth=\"" + QString::number( ev.dueDate().month() ) + "\" "; 570 str += "DateMonth=\"" + QString::number( ev.dueDate().month() ) + "\" ";
540 str += "DateDay=\"" + QString::number( ev.dueDate().day() ) + "\" "; 571 str += "DateDay=\"" + QString::number( ev.dueDate().day() ) + "\" ";
541 } 572 }
542// qWarning( "Uid %d", ev.uid() ); 573// qWarning( "Uid %d", ev.uid() );
543 str += "Uid=\"" + QString::number( ev.uid() ) + "\" "; 574 str += "Uid=\"" + QString::number( ev.uid() ) + "\" ";
544 575
545// append the extra options 576// append the extra options
546 /* FIXME Qtopia::Record this is currently not 577 /* FIXME Qtopia::Record this is currently not
547 * possible you can set custom fields 578 * possible you can set custom fields
548 * but don' iterate over the list 579 * but don' iterate over the list
549 * I may do #define private protected 580 * I may do #define private protected
550 * for this case - cough --zecke 581 * for this case - cough --zecke
551 */ 582 */
552 /* 583 /*
553 QMap<QString, QString> extras = ev.extras(); 584 QMap<QString, QString> extras = ev.extras();
554 QMap<QString, QString>::Iterator extIt; 585 QMap<QString, QString>::Iterator extIt;
555 for (extIt = extras.begin(); extIt != extras.end(); ++extIt ) 586 for (extIt = extras.begin(); extIt != extras.end(); ++extIt )
556 str += extIt.key() + "=\"" + extIt.data() + "\" "; 587 str += extIt.key() + "=\"" + extIt.data() + "\" ";
557 */ 588 */
558 // cross refernce 589 // cross refernce
559 if ( ev.hasRecurrence() ) { 590 if ( ev.hasRecurrence() ) {
560 str += ev.recurrence().toString(); 591 str += ev.recurrence().toString();
561 } 592 }
562 if ( ev.hasStartDate() ) 593 if ( ev.hasStartDate() )
563 str += "StartDate=\""+ OConversion::dateToString( ev.startDate() ) +"\" "; 594 str += "StartDate=\""+ OConversion::dateToString( ev.startDate() ) +"\" ";
564 if ( ev.hasCompletedDate() ) 595 if ( ev.hasCompletedDate() )
565 str += "CompletedDate=\""+ OConversion::dateToString( ev.completedDate() ) +"\" "; 596 str += "CompletedDate=\""+ OConversion::dateToString( ev.completedDate() ) +"\" ";
566 if ( ev.hasState() ) 597 if ( ev.hasState() )
567 str += "State=\""+QString::number( ev.state().state() )+"\" "; 598 str += "State=\""+QString::number( ev.state().state() )+"\" ";
568 599
569 /* 600 /*
570 * save reminders and notifiers! 601 * save reminders and notifiers!
571 * DATE_TIME:DURATION:SOUND:NOT_USED_YET;OTHER_DATE_TIME:OTHER_DURATION:SOUND:.... 602 * DATE_TIME:DURATION:SOUND:NOT_USED_YET;OTHER_DATE_TIME:OTHER_DURATION:SOUND:....
572 */ 603 */
573 if ( ev.hasNotifiers() ) { 604 if ( ev.hasNotifiers() ) {
574 OPimNotifyManager manager = ev.notifiers(); 605 OPimNotifyManager manager = ev.notifiers();
575 OPimNotifyManager::Alarms alarms = manager.alarms(); 606 OPimNotifyManager::Alarms alarms = manager.alarms();
576 if (!alarms.isEmpty() ) { 607 if (!alarms.isEmpty() ) {
577 QStringList als; 608 QStringList als;
578 OPimNotifyManager::Alarms::Iterator it = alarms.begin(); 609 OPimNotifyManager::Alarms::Iterator it = alarms.begin();
579 for ( ; it != alarms.end(); ++it ) { 610 for ( ; it != alarms.end(); ++it ) {
580 /* only if time is valid */ 611 /* only if time is valid */
581 if ( (*it).dateTime().isValid() ) { 612 if ( (*it).dateTime().isValid() ) {
582 als << OConversion::dateTimeToString( (*it).dateTime() ) 613 als << OConversion::dateTimeToString( (*it).dateTime() )
583 + ":" + QString::number( (*it).duration() ) 614 + ":" + QString::number( (*it).duration() )
584 + ":" + QString::number( (*it).sound() ) 615 + ":" + QString::number( (*it).sound() )
585 + ":"; 616 + ":";
586 } 617 }
587 } 618 }
588 // now write the list 619 // now write the list
589 qWarning("als: %s", als.join("____________").latin1() ); 620 qWarning("als: %s", als.join("____________").latin1() );
590 str += "Alarms=\""+als.join(";") +"\" "; 621 str += "Alarms=\""+als.join(";") +"\" ";
591 } 622 }
592 623
593 /* 624 /*
594 * now the same for reminders but more easy. We just save the uid of the OEvent. 625 * now the same for reminders but more easy. We just save the uid of the OEvent.
595 */ 626 */
596 OPimNotifyManager::Reminders reminders = manager.reminders(); 627 OPimNotifyManager::Reminders reminders = manager.reminders();
597 if (!reminders.isEmpty() ) { 628 if (!reminders.isEmpty() ) {
598 OPimNotifyManager::Reminders::Iterator it = reminders.begin(); 629 OPimNotifyManager::Reminders::Iterator it = reminders.begin();
599 QStringList records; 630 QStringList records;
600 for ( ; it != reminders.end(); ++it ) { 631 for ( ; it != reminders.end(); ++it ) {
601 records << QString::number( (*it).recordUid() ); 632 records << QString::number( (*it).recordUid() );
602 } 633 }
603 str += "Reminders=\""+ records.join(";") +"\" "; 634 str += "Reminders=\""+ records.join(";") +"\" ";
604 } 635 }
605 } 636 }
606 str += customToXml( ev.toExtraMap() ); 637 str += customToXml( ev.toExtraMap() );
607 638
608 639
609 return str; 640 return str;
610} 641}
611QString OTodoAccessXML::toString( const QArray<int>& ints ) const { 642QString OTodoAccessXML::toString( const QArray<int>& ints ) const {
612 return Qtopia::Record::idsToString( ints ); 643 return Qtopia::Record::idsToString( ints );
613} 644}
614 645
615/* internal class for sorting 646/* internal class for sorting
616 * 647 *
617 * Inspired by todoxmlio.cpp from TT 648 * Inspired by todoxmlio.cpp from TT
618 */ 649 */
619 650
620struct OTodoXMLContainer { 651struct OTodoXMLContainer {
621 OTodo todo; 652 OTodo todo;
622}; 653};
623 654
624namespace { 655namespace {
625 inline QString string( const OTodo& todo) { 656 inline QString string( const OTodo& todo) {
626 return todo.summary().isEmpty() ? 657 return todo.summary().isEmpty() ?
627 todo.description().left(20 ) : 658 todo.description().left(20 ) :
628 todo.summary(); 659 todo.summary();
629 } 660 }
630 inline int completed( const OTodo& todo1, const OTodo& todo2) { 661 inline int completed( const OTodo& todo1, const OTodo& todo2) {
631 int ret = 0; 662 int ret = 0;
632 if ( todo1.isCompleted() ) ret++; 663 if ( todo1.isCompleted() ) ret++;
633 if ( todo2.isCompleted() ) ret--; 664 if ( todo2.isCompleted() ) ret--;
634 return ret; 665 return ret;
635 } 666 }
636 inline int priority( const OTodo& t1, const OTodo& t2) { 667 inline int priority( const OTodo& t1, const OTodo& t2) {
637 return ( t1.priority() - t2.priority() ); 668 return ( t1.priority() - t2.priority() );
638 } 669 }
639 inline int description( const OTodo& t1, const OTodo& t2) { 670 inline int description( const OTodo& t1, const OTodo& t2) {
640 return QString::compare( string(t1), string(t2) ); 671 return QString::compare( string(t1), string(t2) );
641 } 672 }
642 inline int deadline( const OTodo& t1, const OTodo& t2) { 673 inline int deadline( const OTodo& t1, const OTodo& t2) {
643 int ret = 0; 674 int ret = 0;
644 if ( t1.hasDueDate() && 675 if ( t1.hasDueDate() &&
645 t2.hasDueDate() ) 676 t2.hasDueDate() )
646 ret = t2.dueDate().daysTo( t1.dueDate() ); 677 ret = t2.dueDate().daysTo( t1.dueDate() );
647 else if ( t1.hasDueDate() ) 678 else if ( t1.hasDueDate() )
648 ret = -1; 679 ret = -1;
649 else if ( t2.hasDueDate() ) 680 else if ( t2.hasDueDate() )
650 ret = 1; 681 ret = 1;
651 else 682 else
652 ret = 0; 683 ret = 0;
653 684
654 return ret; 685 return ret;
655 } 686 }
656 687
657}; 688};
658 689
659/* 690/*
660 * Returns: 691 * Returns:
661 * 0 if item1 == item2 692 * 0 if item1 == item2
662 * 693 *
663 * non-zero if item1 != item2 694 * non-zero if item1 != item2
664 * 695 *
665 * This function returns int rather than bool so that reimplementations 696 * This function returns int rather than bool so that reimplementations
666 * can return one of three values and use it to sort by: 697 * can return one of three values and use it to sort by:
667 * 698 *
668 * 0 if item1 == item2 699 * 0 if item1 == item2
669 * 700 *
670 * > 0 (positive integer) if item1 > item2 701 * > 0 (positive integer) if item1 > item2
671 * 702 *
672 * < 0 (negative integer) if item1 < item2 703 * < 0 (negative integer) if item1 < item2
673 * 704 *
674 */ 705 */
675class OTodoXMLVector : public QVector<OTodoXMLContainer> { 706class OTodoXMLVector : public QVector<OTodoXMLContainer> {
676public: 707public:
677 OTodoXMLVector(int size, bool asc, int sort) 708 OTodoXMLVector(int size, bool asc, int sort)
678 : QVector<OTodoXMLContainer>( size ) 709 : QVector<OTodoXMLContainer>( size )
679 { 710 {
680 setAutoDelete( true ); 711 setAutoDelete( true );
681 m_asc = asc; 712 m_asc = asc;
682 m_sort = sort; 713 m_sort = sort;
683 } 714 }
684 /* return the summary/description */ 715 /* return the summary/description */
685 QString string( const OTodo& todo) { 716 QString string( const OTodo& todo) {
686 return todo.summary().isEmpty() ? 717 return todo.summary().isEmpty() ?
687 todo.description().left(20 ) : 718 todo.description().left(20 ) :
688 todo.summary(); 719 todo.summary();
689 } 720 }
690 /** 721 /**
691 * we take the sortorder( switch on it ) 722 * we take the sortorder( switch on it )
692 * 723 *
693 */ 724 */
694 int compareItems( Item d1, Item d2 ) { 725 int compareItems( Item d1, Item d2 ) {
695 bool seComp, sePrio, seDesc, seDeadline; 726 bool seComp, sePrio, seDesc, seDeadline;
696 seComp = sePrio = seDeadline = seDesc = false; 727 seComp = sePrio = seDeadline = seDesc = false;
697 int ret =0; 728 int ret =0;
698 OTodoXMLContainer* con1 = (OTodoXMLContainer*)d1; 729 OTodoXMLContainer* con1 = (OTodoXMLContainer*)d1;
699 OTodoXMLContainer* con2 = (OTodoXMLContainer*)d2; 730 OTodoXMLContainer* con2 = (OTodoXMLContainer*)d2;
700 731
701 /* same item */ 732 /* same item */
702 if ( con1->todo.uid() == con2->todo.uid() ) 733 if ( con1->todo.uid() == con2->todo.uid() )
703 return 0; 734 return 0;
704 735
705 switch ( m_sort ) { 736 switch ( m_sort ) {
706 /* completed */ 737 /* completed */
707 case 0: { 738 case 0: {
708 ret = completed( con1->todo, con2->todo ); 739 ret = completed( con1->todo, con2->todo );
709 seComp = TRUE; 740 seComp = TRUE;
710 break; 741 break;
711 } 742 }
712 /* priority */ 743 /* priority */
713 case 1: { 744 case 1: {
714 ret = priority( con1->todo, con2->todo ); 745 ret = priority( con1->todo, con2->todo );
715 sePrio = TRUE; 746 sePrio = TRUE;
716 break; 747 break;
717 } 748 }
718 /* description */ 749 /* description */
719 case 2: { 750 case 2: {
720 ret = description( con1->todo, con2->todo ); 751 ret = description( con1->todo, con2->todo );
721 seDesc = TRUE; 752 seDesc = TRUE;
722 break; 753 break;
723 } 754 }
724 /* deadline */ 755 /* deadline */
725 case 3: { 756 case 3: {
726 ret = deadline( con1->todo, con2->todo ); 757 ret = deadline( con1->todo, con2->todo );
727 seDeadline = TRUE; 758 seDeadline = TRUE;
728 break; 759 break;
729 } 760 }
730 default: 761 default:
731 ret = 0; 762 ret = 0;
732 break; 763 break;
733 }; 764 };
734 /* 765 /*
735 * FIXME do better sorting if the first sort criteria 766 * FIXME do better sorting if the first sort criteria
736 * ret equals 0 start with complete and so on... 767 * ret equals 0 start with complete and so on...
737 */ 768 */
738 769
739 /* twist it we're not ascending*/ 770 /* twist it we're not ascending*/
740 if (!m_asc) 771 if (!m_asc)
741 ret = ret * -1; 772 ret = ret * -1;
742 773
743 if ( ret ) 774 if ( ret )
744 return ret; 775 return ret;
745 776
746 // default did not gave difference let's try it other way around 777 // default did not gave difference let's try it other way around
747 /* 778 /*
748 * General try if already checked if not test 779 * General try if already checked if not test
749 * and return 780 * and return
750 * 1.Completed 781 * 1.Completed
751 * 2.Priority 782 * 2.Priority
752 * 3.Description 783 * 3.Description
753 * 4.DueDate 784 * 4.DueDate
754 */ 785 */
755 if (!seComp ) { 786 if (!seComp ) {
756 if ( (ret = completed( con1->todo, con2->todo ) ) ) { 787 if ( (ret = completed( con1->todo, con2->todo ) ) ) {
757 if (!m_asc ) ret *= -1; 788 if (!m_asc ) ret *= -1;
758 return ret; 789 return ret;
759 } 790 }
760 } 791 }
761 if (!sePrio ) { 792 if (!sePrio ) {
762 if ( (ret = priority( con1->todo, con2->todo ) ) ) { 793 if ( (ret = priority( con1->todo, con2->todo ) ) ) {
763 if (!m_asc ) ret *= -1; 794 if (!m_asc ) ret *= -1;
764 return ret; 795 return ret;
765 } 796 }
766 } 797 }
767 if (!seDesc ) { 798 if (!seDesc ) {
768 if ( (ret = description(con1->todo, con2->todo ) ) ) { 799 if ( (ret = description(con1->todo, con2->todo ) ) ) {
769 if (!m_asc) ret *= -1; 800 if (!m_asc) ret *= -1;
770 return ret; 801 return ret;
771 } 802 }
772 } 803 }
773 if (!seDeadline) { 804 if (!seDeadline) {
774 if ( (ret = deadline( con1->todo, con2->todo ) ) ) { 805 if ( (ret = deadline( con1->todo, con2->todo ) ) ) {
775 if (!m_asc) ret *= -1; 806 if (!m_asc) ret *= -1;
776 return ret; 807 return ret;
777 } 808 }
778 } 809 }
779 810
780 return 0; 811 return 0;
781 } 812 }
782 private: 813 private:
783 bool m_asc; 814 bool m_asc;
784 int m_sort; 815 int m_sort;
785 816
786}; 817};
787 818
788QArray<int> OTodoAccessXML::sorted( bool asc, int sortOrder, 819QArray<int> OTodoAccessXML::sorted( bool asc, int sortOrder,
789 int sortFilter, int cat ) { 820 int sortFilter, int cat ) {
790 OTodoXMLVector vector(m_events.count(), asc,sortOrder ); 821 OTodoXMLVector vector(m_events.count(), asc,sortOrder );
791 QMap<int, OTodo>::Iterator it; 822 QMap<int, OTodo>::Iterator it;
792 int item = 0; 823 int item = 0;
793 824
794 bool bCat = sortFilter & 1 ? true : false; 825 bool bCat = sortFilter & 1 ? true : false;
795 bool bOnly = sortFilter & 2 ? true : false; 826 bool bOnly = sortFilter & 2 ? true : false;
796 bool comp = sortFilter & 4 ? true : false; 827 bool comp = sortFilter & 4 ? true : false;
797 for ( it = m_events.begin(); it != m_events.end(); ++it ) { 828 for ( it = m_events.begin(); it != m_events.end(); ++it ) {
798 829
799 /* show category */ 830 /* show category */
800 /* -1 == unfiled */ 831 /* -1 == unfiled */
801 if ( bCat && cat == -1 ) { 832 if ( bCat && cat == -1 ) {
802 if(!(*it).categories().isEmpty() ) 833 if(!(*it).categories().isEmpty() )
803 continue; 834 continue;
804 }else if ( bCat && cat != 0) 835 }else if ( bCat && cat != 0)
805 if (!(*it).categories().contains( cat ) ) { 836 if (!(*it).categories().contains( cat ) ) {
806 continue; 837 continue;
807 } 838 }
808 /* isOverdue but we should not show overdue - why?*/ 839 /* isOverdue but we should not show overdue - why?*/
809/* if ( (*it).isOverdue() && !bOnly ) { 840/* if ( (*it).isOverdue() && !bOnly ) {
810 qWarning("item is overdue but !bOnly"); 841 qWarning("item is overdue but !bOnly");
811 continue; 842 continue;
812 } 843 }
813*/ 844*/
814 if ( !(*it).isOverdue() && bOnly ) { 845 if ( !(*it).isOverdue() && bOnly ) {
815 continue; 846 continue;
816 } 847 }
817 848
818 if ((*it).isCompleted() && comp ) { 849 if ((*it).isCompleted() && comp ) {
819 continue; 850 continue;
820 } 851 }
821 852
822 853
823 OTodoXMLContainer* con = new OTodoXMLContainer(); 854 OTodoXMLContainer* con = new OTodoXMLContainer();
824 con->todo = (*it); 855 con->todo = (*it);
825 vector.insert(item, con ); 856 vector.insert(item, con );
826 item++; 857 item++;
827 } 858 }
828 vector.resize( item ); 859 vector.resize( item );
829 /* sort it now */ 860 /* sort it now */
830 vector.sort(); 861 vector.sort();
831 /* now get the uids */ 862 /* now get the uids */
832 QArray<int> array( vector.count() ); 863 QArray<int> array( vector.count() );
833 for (uint i= 0; i < vector.count(); i++ ) { 864 for (uint i= 0; i < vector.count(); i++ ) {
834 array[i] = ( vector.at(i) )->todo.uid(); 865 array[i] = ( vector.at(i) )->todo.uid();
835 } 866 }
836 return array; 867 return array;
837}; 868};
838void OTodoAccessXML::removeAllCompleted() { 869void OTodoAccessXML::removeAllCompleted() {
839 QMap<int, OTodo> events = m_events; 870 QMap<int, OTodo> events = m_events;
840 for ( QMap<int, OTodo>::Iterator it = m_events.begin(); it != m_events.end(); ++it ) { 871 for ( QMap<int, OTodo>::Iterator it = m_events.begin(); it != m_events.end(); ++it ) {
841 if ( (*it).isCompleted() ) 872 if ( (*it).isCompleted() )
842 events.remove( it.key() ); 873 events.remove( it.key() );
843 } 874 }
844 m_events = events; 875 m_events = events;
845} 876}
846QBitArray OTodoAccessXML::supports()const { 877QBitArray OTodoAccessXML::supports()const {
847 static QBitArray ar = sup(); 878 static QBitArray ar = sup();
848 return ar; 879 return ar;
849} 880}
850QBitArray OTodoAccessXML::sup() { 881QBitArray OTodoAccessXML::sup() {
851 QBitArray ar( OTodo::CompletedDate +1 ); 882 QBitArray ar( OTodo::CompletedDate +1 );
852 ar.fill( true ); 883 ar.fill( true );
853 ar[OTodo::CrossReference] = false; 884 ar[OTodo::CrossReference] = false;
854 ar[OTodo::State ] = false; 885 ar[OTodo::State ] = false;
855 ar[OTodo::Reminders] = false; 886 ar[OTodo::Reminders] = false;
856 ar[OTodo::Notifiers] = false; 887 ar[OTodo::Notifiers] = false;
857 ar[OTodo::Maintainer] = false; 888 ar[OTodo::Maintainer] = false;
858 889
859 return ar; 890 return ar;
860} 891}
861QArray<int> OTodoAccessXML::matchRegexp( const QRegExp &r ) const 892QArray<int> OTodoAccessXML::matchRegexp( const QRegExp &r ) const
862{ 893{
863 QArray<int> m_currentQuery( m_events.count() ); 894 QArray<int> m_currentQuery( m_events.count() );
864 uint arraycounter = 0; 895 uint arraycounter = 0;
865 896
866 QMap<int, OTodo>::ConstIterator it; 897 QMap<int, OTodo>::ConstIterator it;
867 for (it = m_events.begin(); it != m_events.end(); ++it ) { 898 for (it = m_events.begin(); it != m_events.end(); ++it ) {
868 if ( it.data().match( r ) ) 899 if ( it.data().match( r ) )
869 m_currentQuery[arraycounter++] = it.data().uid(); 900 m_currentQuery[arraycounter++] = it.data().uid();
870 901
871 } 902 }
872 // Shrink to fit.. 903 // Shrink to fit..
873 m_currentQuery.resize(arraycounter); 904 m_currentQuery.resize(arraycounter);
874 905
875 return m_currentQuery; 906 return m_currentQuery;
876} 907}
908
909}
diff --git a/libopie2/opiepim/backend/otodoaccessxml.h b/libopie2/opiepim/backend/otodoaccessxml.h
index e4850a1..d634398 100644
--- a/libopie2/opiepim/backend/otodoaccessxml.h
+++ b/libopie2/opiepim/backend/otodoaccessxml.h
@@ -1,60 +1,89 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_TODO_ACCESS_XML_H 29#ifndef OPIE_TODO_ACCESS_XML_H
2#define OPIE_TODO_ACCESS_XML_H 30#define OPIE_TODO_ACCESS_XML_H
3 31
4#include <qasciidict.h> 32#include <qasciidict.h>
5#include <qmap.h> 33#include <qmap.h>
6 34
7#include "otodoaccessbackend.h" 35#include <opie2/otodoaccessbackend.h>
8 36
9namespace Opie { 37namespace Opie {
10 class XMLElement; 38 class XMLElement;
11};
12 39
13class OTodoAccessXML : public OTodoAccessBackend { 40class OTodoAccessXML : public OTodoAccessBackend {
14public: 41public:
15 /** 42 /**
16 * fileName if Empty we will use the default path 43 * fileName if Empty we will use the default path
17 */ 44 */
18 OTodoAccessXML( const QString& appName, 45 OTodoAccessXML( const QString& appName,
19 const QString& fileName = QString::null ); 46 const QString& fileName = QString::null );
20 ~OTodoAccessXML(); 47 ~OTodoAccessXML();
21 48
22 bool load(); 49 bool load();
23 bool reload(); 50 bool reload();
24 bool save(); 51 bool save();
25 52
26 QArray<int> allRecords()const; 53 QArray<int> allRecords()const;
27 QArray<int> matchRegexp(const QRegExp &r) const; 54 QArray<int> matchRegexp(const QRegExp &r) const;
28 QArray<int> queryByExample( const OTodo&, int querysettings, const QDateTime& d = QDateTime() ); 55 QArray<int> queryByExample( const OTodo&, int querysettings, const QDateTime& d = QDateTime() );
29 OTodo find( int uid )const; 56 OTodo find( int uid )const;
30 void clear(); 57 void clear();
31 bool add( const OTodo& ); 58 bool add( const OTodo& );
32 bool remove( int uid ); 59 bool remove( int uid );
33 void removeAllCompleted(); 60 void removeAllCompleted();
34 bool replace( const OTodo& ); 61 bool replace( const OTodo& );
35 62
36 /* our functions */ 63 /* our functions */
37 QArray<int> effectiveToDos( const QDate& start, 64 QArray<int> effectiveToDos( const QDate& start,
38 const QDate& end, 65 const QDate& end,
39 bool includeNoDates ); 66 bool includeNoDates );
40 QArray<int> overDue(); 67 QArray<int> overDue();
41 QArray<int> sorted( bool asc, int sortOrder, 68 QArray<int> sorted( bool asc, int sortOrder,
42 int sortFilter, int cat ); 69 int sortFilter, int cat );
43 QBitArray supports()const; 70 QBitArray supports()const;
44private: 71private:
45 static QBitArray sup(); 72 static QBitArray sup();
46 void todo( QAsciiDict<int>*, OTodo&,const QCString&,const QString& ); 73 void todo( QAsciiDict<int>*, OTodo&,const QCString&,const QString& );
47 QString toString( const OTodo& )const; 74 QString toString( const OTodo& )const;
48 QString toString( const QArray<int>& ints ) const; 75 QString toString( const QArray<int>& ints ) const;
49 QMap<int, OTodo> m_events; 76 QMap<int, OTodo> m_events;
50 QString m_file; 77 QString m_file;
51 QString m_app; 78 QString m_app;
52 bool m_opened : 1; 79 bool m_opened : 1;
53 bool m_changed : 1; 80 bool m_changed : 1;
54 class OTodoAccessXMLPrivate; 81 class OTodoAccessXMLPrivate;
55 OTodoAccessXMLPrivate* d; 82 OTodoAccessXMLPrivate* d;
56 int m_year, m_month, m_day; 83 int m_year, m_month, m_day;
57 84
58}; 85};
59 86
87};
88
60#endif 89#endif
diff --git a/libopie2/opiepim/core/core.pro b/libopie2/opiepim/core/core.pro
new file mode 100644
index 0000000..dae37f1
--- a/dev/null
+++ b/libopie2/opiepim/core/core.pro
@@ -0,0 +1,21 @@
1HEADERS += core/oconversion.h \
2 core/opimcache.h \
3 core/opimmaintainer.h \
4 core/opimresolver.h \
5 core/opimstate.h \
6 core/opimxref.h \
7 core/opimxrefmanager.h \
8 core/opimxrefpartner.h \
9 core/orecur.h \
10 core/otemplatebase.h \
11 core/otimezone.h \
12
13SOURCES += core/oconversion.cpp \
14 core/opimmaintainer.cpp \
15 core/opimresolver.cpp \
16 core/opimstate.cpp \
17 core/opimxref.cpp \
18 core/opimxrefmanager.cpp \
19 core/opimxrefpartner.cpp \
20 core/orecur.cpp \
21 core/otimezone.cpp \
diff --git a/libopie2/opiepim/core/ocontactaccess.cpp b/libopie2/opiepim/core/ocontactaccess.cpp
index 2e3ec1f..f67a40c 100644
--- a/libopie2/opiepim/core/ocontactaccess.cpp
+++ b/libopie2/opiepim/core/ocontactaccess.cpp
@@ -1,168 +1,152 @@
1/* 1/*
2 * Class to manage the Contacts. 2 This file is part of the Opie Project
3 * 3 Copyright (C) The Main Author <main-author@whereever.org>
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 * 5 .=l.
6 * ===================================================================== 6 .>+-=
7 *This program is free software; you can redistribute it and/or 7 _;:, .> :=|. This program is free software; you can
8 *modify it under the terms of the GNU Library General Public 8.> <`_, > . <= redistribute it and/or modify it under
9 * License as published by the Free Software Foundation; either 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10 * version 2 of the License, or (at your option) any later version. 10.="- .-=="i, .._ License as published by the Free Software
11 * ===================================================================== 11 - . .-<_> .<> Foundation; either version 2 of the License,
12 * Info: This class could just work with a change in the header-file 12 ._= =} : or (at your option) any later version.
13 * of the Contact class ! Therefore our libopie only compiles 13 .%`+i> _;_.
14 * with our version of libqpe 14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
15 * ===================================================================== 30 * =====================================================================
16 * ToDo: XML-Backend: Automatic reload if something was changed... 31 * ToDo: XML-Backend: Automatic reload if something was changed...
17 * 32 *
18 * 33 *
19 * =====================================================================
20 * Version: $Id$
21 * =====================================================================
22 * History:
23 * $Log$
24 * Revision 1.8 2003/05/08 13:55:09 tille
25 * search stuff
26 * and match, toRichText & toShortText in oevent
27 *
28 * Revision 1.7 2002/11/13 14:14:51 eilers
29 * Added sorted for Contacts..
30 *
31 * Revision 1.6 2002/11/01 15:10:42 eilers
32 * Added regExp-search in database for all fields in a contact.
33 *
34 * Revision 1.5 2002/10/16 10:52:40 eilers
35 * Added some docu to the interface and now using the cache infrastucture by zecke.. :)
36 *
37 * Revision 1.4 2002/10/14 16:21:54 eilers
38 * Some minor interface updates
39 *
40 * Revision 1.3 2002/10/07 17:34:24 eilers
41 * added OBackendFactory for advanced backend access
42 *
43 * Revision 1.2 2002/10/02 16:18:11 eilers
44 * debugged and seems to work almost perfectly ..
45 *
46 * Revision 1.1 2002/09/27 17:11:44 eilers
47 * Added API for accessing the Contact-Database ! It is compiling, but
48 * please do not expect that anything is working !
49 * I will debug that stuff in the next time ..
50 * Please read README_COMPILE for compiling !
51 *
52 *
53 */ 34 */
54 35
55#include "ocontactaccess.h" 36#include "ocontactaccess.h"
56#include "obackendfactory.h" 37#include "obackendfactory.h"
57 38
58#include <qasciidict.h> 39#include <qasciidict.h>
59#include <qdatetime.h> 40#include <qdatetime.h>
60#include <qfile.h> 41#include <qfile.h>
61#include <qregexp.h> 42#include <qregexp.h>
62#include <qlist.h> 43#include <qlist.h>
63#include <qcopchannel_qws.h> 44#include <qcopchannel_qws.h>
64 45
65//#include <qpe/qcopenvelope_qws.h> 46//#include <qpe/qcopenvelope_qws.h>
66#include <qpe/global.h> 47#include <qpe/global.h>
67 48
68#include <errno.h> 49#include <errno.h>
69#include <fcntl.h> 50#include <fcntl.h>
70#include <unistd.h> 51#include <unistd.h>
71#include <stdlib.h> 52#include <stdlib.h>
72 53
73#include "ocontactaccessbackend_xml.h" 54#include <opie2/ocontactaccessbackend_xml.h>
74 55
56namespace Opie {
75 57
76OContactAccess::OContactAccess ( const QString appname, const QString , 58OContactAccess::OContactAccess ( const QString appname, const QString ,
77 OContactAccessBackend* end, bool autosync ): 59 OContactAccessBackend* end, bool autosync ):
78 OPimAccessTemplate<OContact>( end ) 60 OPimAccessTemplate<OContact>( end )
79{ 61{
80 /* take care of the backend. If there is no one defined, we 62 /* take care of the backend. If there is no one defined, we
81 * will use the XML-Backend as default (until we have a cute SQL-Backend..). 63 * will use the XML-Backend as default (until we have a cute SQL-Backend..).
82 */ 64 */
83 if( end == 0 ) { 65 if( end == 0 ) {
84 qWarning ("Using BackendFactory !"); 66 qWarning ("Using BackendFactory !");
85 end = OBackendFactory<OContactAccessBackend>::Default( "contact", appname ); 67 end = OBackendFactory<OContactAccessBackend>::Default( "contact", appname );
86 } 68 }
87 // Set backend locally and in template 69 // Set backend locally and in template
88 m_backEnd = end; 70 m_backEnd = end;
89 OPimAccessTemplate<OContact>::setBackEnd (end); 71 OPimAccessTemplate<OContact>::setBackEnd (end);
90 72
91 73
92 /* Connect signal of external db change to function */ 74 /* Connect signal of external db change to function */
93 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this ); 75 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this );
94 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)), 76 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)),
95 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 77 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
96 if ( autosync ){ 78 if ( autosync ){
97 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this ); 79 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this );
98 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)), 80 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)),
99 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 81 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
100 } 82 }
101 83
102 84
103} 85}
104OContactAccess::~OContactAccess () 86OContactAccess::~OContactAccess ()
105{ 87{
106 /* The user may forget to save the changed database, therefore try to 88 /* The user may forget to save the changed database, therefore try to
107 * do it for him.. 89 * do it for him..
108 */ 90 */
109 save(); 91 save();
110 // delete m_backEnd; is done by template.. 92 // delete m_backEnd; is done by template..
111} 93}
112 94
113 95
114bool OContactAccess::save () 96bool OContactAccess::save ()
115{ 97{
116 /* If the database was changed externally, we could not save the 98 /* If the database was changed externally, we could not save the
117 * Data. This will remove added items which is unacceptable ! 99 * Data. This will remove added items which is unacceptable !
118 * Therefore: Reload database and merge the data... 100 * Therefore: Reload database and merge the data...
119 */ 101 */
120 if ( OPimAccessTemplate<OContact>::wasChangedExternally() ) 102 if ( OPimAccessTemplate<OContact>::wasChangedExternally() )
121 reload(); 103 reload();
122 104
123 bool status = OPimAccessTemplate<OContact>::save(); 105 bool status = OPimAccessTemplate<OContact>::save();
124 if ( !status ) return false; 106 if ( !status ) return false;
125 107
126 /* Now tell everyone that new data is available. 108 /* Now tell everyone that new data is available.
127 */ 109 */
128 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" ); 110 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" );
129 111
130 return true; 112 return true;
131} 113}
132 114
133const uint OContactAccess::querySettings() 115const uint OContactAccess::querySettings()
134{ 116{
135 return ( m_backEnd->querySettings() ); 117 return ( m_backEnd->querySettings() );
136} 118}
137 119
138bool OContactAccess::hasQuerySettings ( int querySettings ) const 120bool OContactAccess::hasQuerySettings ( int querySettings ) const
139{ 121{
140 return ( m_backEnd->hasQuerySettings ( querySettings ) ); 122 return ( m_backEnd->hasQuerySettings ( querySettings ) );
141} 123}
142ORecordList<OContact> OContactAccess::sorted( bool ascending, int sortOrder, int sortFilter, int cat ) const 124ORecordList<OContact> OContactAccess::sorted( bool ascending, int sortOrder, int sortFilter, int cat ) const
143{ 125{
144 QArray<int> matchingContacts = m_backEnd -> sorted( ascending, sortOrder, sortFilter, cat ); 126 QArray<int> matchingContacts = m_backEnd -> sorted( ascending, sortOrder, sortFilter, cat );
145 return ( ORecordList<OContact>(matchingContacts, this) ); 127 return ( ORecordList<OContact>(matchingContacts, this) );
146} 128}
147 129
148 130
149bool OContactAccess::wasChangedExternally()const 131bool OContactAccess::wasChangedExternally()const
150{ 132{
151 return ( m_backEnd->wasChangedExternally() ); 133 return ( m_backEnd->wasChangedExternally() );
152} 134}
153 135
154 136
155void OContactAccess::copMessage( const QCString &msg, const QByteArray & ) 137void OContactAccess::copMessage( const QCString &msg, const QByteArray & )
156{ 138{
157 if ( msg == "addressbookUpdated()" ){ 139 if ( msg == "addressbookUpdated()" ){
158 qWarning ("OContactAccess: Received addressbokUpdated()"); 140 qWarning ("OContactAccess: Received addressbokUpdated()");
159 emit signalChanged ( this ); 141 emit signalChanged ( this );
160 } else if ( msg == "flush()" ) { 142 } else if ( msg == "flush()" ) {
161 qWarning ("OContactAccess: Received flush()"); 143 qWarning ("OContactAccess: Received flush()");
162 save (); 144 save ();
163 } else if ( msg == "reload()" ) { 145 } else if ( msg == "reload()" ) {
164 qWarning ("OContactAccess: Received reload()"); 146 qWarning ("OContactAccess: Received reload()");
165 reload (); 147 reload ();
166 emit signalChanged ( this ); 148 emit signalChanged ( this );
167 } 149 }
168} 150}
151
152}
diff --git a/libopie2/opiepim/core/ocontactaccess.h b/libopie2/opiepim/core/ocontactaccess.h
index bd6da40..505c87b 100644
--- a/libopie2/opiepim/core/ocontactaccess.h
+++ b/libopie2/opiepim/core/ocontactaccess.h
@@ -1,193 +1,158 @@
1/* 1/*
2 * Class to manage the Contacts. 2 This file is part of the Opie Project
3 * 3 Copyright (C) The Main Author <main-author@whereever.org>
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 * Copyright (c) 2002 by Holger Freyther (zecke@handhelds.org) 5 .=l.
6 * 6 .>+-=
7 * ===================================================================== 7 _;:, .> :=|. This program is free software; you can
8 *This program is free software; you can redistribute it and/or 8.> <`_, > . <= redistribute it and/or modify it under
9 *modify it under the terms of the GNU Library General Public 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10 * License as published by the Free Software Foundation; 10.="- .-=="i, .._ License as published by the Free Software
11 * either version 2 of the License, or (at your option) any later 11 - . .-<_> .<> Foundation; either version 2 of the License,
12 * version. 12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29/*
13 * ===================================================================== 30 * =====================================================================
14 * ToDo: Define enum for query settings 31 * ToDo: Define enum for query settings
15 * ===================================================================== 32 * =====================================================================
16 * Version: $Id$
17 * =====================================================================
18 * History:
19 * $Log$
20 * Revision 1.10 2003/12/22 10:19:26 eilers
21 * Finishing implementation of sql-backend for datebook. But I have to
22 * port the PIM datebook application to use it, before I could debug the
23 * whole stuff.
24 * Thus, PIM-Database backend is finished, but highly experimental. And some
25 * parts are still generic. For instance, the "queryByExample()" methods are
26 * not (or not fully) implemented. Todo: custom-entries not stored.
27 * The big show stopper: matchRegExp() (needed by OpieSearch) needs regular
28 * expression search in the database, which is not supported by sqlite !
29 * Therefore we need either an extended sqlite or a workaround which would
30 * be very slow and memory consuming..
31 *
32 * Revision 1.9 2003/08/01 12:30:16 eilers
33 * Merging changes from BRANCH_1_0 to HEAD
34 *
35 * Revision 1.8.2.1 2003/06/30 14:34:19 eilers
36 * Patches from Zecke:
37 * Fixing and cleaning up extraMap handling
38 * Adding d_ptr for binary compatibility in the future
39 *
40 * Revision 1.8 2003/05/08 13:55:09 tille
41 * search stuff
42 * and match, toRichText & toShortText in oevent
43 *
44 * Revision 1.7 2003/04/13 18:07:10 zecke
45 * More API doc
46 * QString -> const QString&
47 * QString = 0l -> QString::null
48 *
49 * Revision 1.6 2003/01/02 14:27:12 eilers
50 * Improved query by example: Search by date is possible.. First step
51 * for a today plugin for birthdays..
52 *
53 * Revision 1.5 2002/11/13 14:14:51 eilers
54 * Added sorted for Contacts..
55 *
56 * Revision 1.4 2002/11/01 15:10:42 eilers
57 * Added regExp-search in database for all fields in a contact.
58 *
59 * Revision 1.3 2002/10/16 10:52:40 eilers
60 * Added some docu to the interface and now using the cache infrastucture by zecke.. :)
61 *
62 * Revision 1.2 2002/10/14 16:21:54 eilers
63 * Some minor interface updates
64 *
65 * Revision 1.1 2002/09/27 17:11:44 eilers
66 * Added API for accessing the Contact-Database ! It is compiling, but
67 * please do not expect that anything is working !
68 * I will debug that stuff in the next time ..
69 * Please read README_COMPILE for compiling !
70 *
71 * =====================================================================
72 */ 33 */
73#ifndef _OCONTACTACCESS_H 34#ifndef _OCONTACTACCESS_H
74#define _OCONTACTACCESS_H 35#define _OCONTACTACCESS_H
75 36
76#include <qobject.h> 37#include <qobject.h>
77 38
78#include <qpe/qcopenvelope_qws.h> 39#include <qpe/qcopenvelope_qws.h>
79 40
80#include <qvaluelist.h> 41#include <qvaluelist.h>
81#include <qfileinfo.h> 42#include <qfileinfo.h>
82 43
83#include "ocontact.h" 44#include <opie2/ocontact.h>
84#include "ocontactaccessbackend.h" 45#include <opie2/ocontactaccessbackend.h>
85#include "opimaccesstemplate.h" 46#include <opie2/opimaccesstemplate.h>
86 47
48namespace Opie {
87/** 49/**
88 * Class to access the contacts database. 50 * Class to access the contacts database.
89 * This is just a frontend for the real database handling which is 51 * This is just a frontend for the real database handling which is
90 * done by the backend. 52 * done by the backend.
91 * This class is used to access the Contacts on a system. This class as any OPIE PIM 53 * This class is used to access the Contacts on a system. This class as any OPIE PIM
92 * class is backend independent. 54 * class is backend independent.
93 * @author Stefan Eilers, Holger Freyther 55 * @author Stefan Eilers, Holger Freyther
94 * @see OPimAccessTemplate 56 * @see OPimAccessTemplate
95 */ 57 */
96class OContactAccess: public QObject, public OPimAccessTemplate<OContact> 58class OContactAccess: public QObject, public OPimAccessTemplate<OContact>
97{ 59{
98 Q_OBJECT 60 Q_OBJECT
99 61
100 public: 62 public:
101 /** 63 /**
102 * Create Database with contacts (addressbook). 64 * Create Database with contacts (addressbook).
103 * @param appname Name of application which wants access to the database 65 * @param appname Name of application which wants access to the database
104 * (i.e. "todolist") 66 * (i.e. "todolist")
105 * @param filename The name of the database file. If not set, the default one 67 * @param filename The name of the database file. If not set, the default one
106 * is used. 68 * is used.
107 * @param backend Pointer to an alternative Backend. If not set, we will use 69 * @param backend Pointer to an alternative Backend. If not set, we will use
108 * the default backend. 70 * the default backend.
109 * @param handlesync If <b>true</b> the database stores the current state 71 * @param handlesync If <b>true</b> the database stores the current state
110 * automatically if it receives the signals <i>flush()</i> and <i>reload()</i> 72 * automatically if it receives the signals <i>flush()</i> and <i>reload()</i>
111 * which are used before and after synchronisation. If the application wants 73 * which are used before and after synchronisation. If the application wants
112 * to react itself, it should be disabled by setting it to <b>false</b> 74 * to react itself, it should be disabled by setting it to <b>false</b>
113 * @see OContactAccessBackend 75 * @see OContactAccessBackend
114 */ 76 */
115 OContactAccess (const QString appname, const QString filename = 0l, 77 OContactAccess (const QString appname, const QString filename = 0l,
116 OContactAccessBackend* backend = 0l, bool handlesync = true); 78 OContactAccessBackend* backend = 0l, bool handlesync = true);
117 ~OContactAccess (); 79 ~OContactAccess ();
118 80
119 /** Constants for query. 81 /** Constants for query.
120 * Use this constants to set the query parameters. 82 * Use this constants to set the query parameters.
121 * Note: <i>query_IgnoreCase</i> just make sense with one of the other attributes ! 83 * Note: <i>query_IgnoreCase</i> just make sense with one of the other attributes !
122 * @see queryByExample() 84 * @see queryByExample()
123 */ 85 */
124 enum QuerySettings { 86 enum QuerySettings {
125 WildCards = 0x0001, 87 WildCards = 0x0001,
126 IgnoreCase = 0x0002, 88 IgnoreCase = 0x0002,
127 RegExp = 0x0004, 89 RegExp = 0x0004,
128 ExactMatch = 0x0008, 90 ExactMatch = 0x0008,
129 MatchOne = 0x0010, // Only one Entry must match 91 MatchOne = 0x0010, // Only one Entry must match
130 DateDiff = 0x0020, // Find all entries from today until given date 92 DateDiff = 0x0020, // Find all entries from today until given date
131 DateYear = 0x0040, // The year matches 93 DateYear = 0x0040, // The year matches
132 DateMonth = 0x0080, // The month matches 94 DateMonth = 0x0080, // The month matches
133 DateDay = 0x0100, // The day matches 95 DateDay = 0x0100, // The day matches
134 }; 96 };
135 97
136 98
137 /** Return all Contacts in a sorted manner. 99 /** Return all Contacts in a sorted manner.
138 * @param ascending true: Sorted in acending order. 100 * @param ascending true: Sorted in acending order.
139 * @param sortOrder Currently not implemented. Just defined to stay compatible to otodoaccess 101 * @param sortOrder Currently not implemented. Just defined to stay compatible to otodoaccess
140 * @param sortFilter Currently not implemented. Just defined to stay compatible to otodoaccess 102 * @param sortFilter Currently not implemented. Just defined to stay compatible to otodoaccess
141 * @param cat Currently not implemented. Just defined to stay compatible to otodoaccess 103 * @param cat Currently not implemented. Just defined to stay compatible to otodoaccess
142 */ 104 */
143 List sorted( bool ascending, int sortOrder, int sortFilter, int cat ) const; 105 List sorted( bool ascending, int sortOrder, int sortFilter, int cat ) const;
144 106
145 /** Return all possible settings. 107 /** Return all possible settings.
146 * @return All settings provided by the current backend 108 * @return All settings provided by the current backend
147 * (i.e.: query_WildCards & query_IgnoreCase) 109 * (i.e.: query_WildCards & query_IgnoreCase)
148 */ 110 */
149 const uint querySettings(); 111 const uint querySettings();
150 112
151 /** Check whether settings are correct. 113 /** Check whether settings are correct.
152 * @return <i>true</i> if the given settings are correct and possible. 114 * @return <i>true</i> if the given settings are correct and possible.
153 */ 115 */
154 bool hasQuerySettings ( int querySettings ) const; 116 bool hasQuerySettings ( int querySettings ) const;
155 117
156 /** 118 /**
157 * if the resource was changed externally. 119 * if the resource was changed externally.
158 * You should use the signal instead of polling possible changes ! 120 * You should use the signal instead of polling possible changes !
159 */ 121 */
160 bool wasChangedExternally()const; 122 bool wasChangedExternally()const;
161 123
162 124
163 /** Save contacts database. 125 /** Save contacts database.
164 * Save is more a "commit". After calling this function, all changes are public available. 126 * Save is more a "commit". After calling this function, all changes are public available.
165 * @return true if successful 127 * @return true if successful
166 */ 128 */
167 bool save(); 129 bool save();
168 130
169 signals: 131 signals:
170 /* Signal is emitted if the database was changed. Therefore 132 /* Signal is emitted if the database was changed. Therefore
171 * we may need to reload to stay consistent. 133 * we may need to reload to stay consistent.
172 * @param which Pointer to the database who created this event. This pointer 134 * @param which Pointer to the database who created this event. This pointer
173 * is useful if an application has to handle multiple databases at the same time. 135 * is useful if an application has to handle multiple databases at the same time.
174 * @see reload() 136 * @see reload()
175 */ 137 */
176 void signalChanged ( const OContactAccess *which ); 138 void signalChanged ( const OContactAccess *which );
177 139
178 140
179 private: 141 private:
180 // class OContactAccessPrivate; 142 // class OContactAccessPrivate;
181 // OContactAccessPrivate* d; 143 // OContactAccessPrivate* d;
182 OContactAccessBackend *m_backEnd; 144 OContactAccessBackend *m_backEnd;
183 bool m_loading:1; 145 bool m_loading:1;
184 146
185 private slots: 147 private slots:
186 void copMessage( const QCString &msg, const QByteArray &data ); 148 void copMessage( const QCString &msg, const QByteArray &data );
187 149
188 private: 150 private:
189 class Private; 151 class Private;
190 Private *d; 152 Private *d;
191 153
192}; 154};
155
156}
157
193#endif 158#endif
diff --git a/libopie2/opiepim/core/oconversion.cpp b/libopie2/opiepim/core/oconversion.cpp
index 0d15414..b7eebef 100644
--- a/libopie2/opiepim/core/oconversion.cpp
+++ b/libopie2/opiepim/core/oconversion.cpp
@@ -1,113 +1,132 @@
1/********************************************************************** 1/*
2** Copyright (C) 2003 by Stefan Eilers (eilers.stefan@epost.de) 2 This file is part of the Opie Project
3** 3 Copyright (C) The Main Author <main-author@whereever.org>
4** This file may be distributed and/or modified under the terms of the 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5** GNU Lesser General Public License version 2 as published by the Free Software 5 .=l.
6** Foundation and appearing in the file LICENSE.GPL included in the 6 .>+-=
7** packaging of this file. 7 _;:, .> :=|. This program is free software; you can
8** 8.> <`_, > . <= redistribute it and/or modify it under
9** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 10.="- .-=="i, .._ License as published by the Free Software
11** 11 - . .-<_> .<> Foundation; either version 2 of the License,
12**********************************************************************/ 12 ._= =} : or (at your option) any later version.
13 13 .%`+i> _;_.
14#include "oconversion.h" 14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
30#include <opie2/oconversion.h>
15#include <qpe/timeconversion.h> 31#include <qpe/timeconversion.h>
16 32
17 33
34namespace Opie {
35
18QString OConversion::dateToString( const QDate &d ) 36QString OConversion::dateToString( const QDate &d )
19{ 37{
20 if ( d.isNull() || !d.isValid() ) 38 if ( d.isNull() || !d.isValid() )
21 return QString::null; 39 return QString::null;
22 40
23 // ISO format in year, month, day (YYYYMMDD); e.g. 20021231 41 // ISO format in year, month, day (YYYYMMDD); e.g. 20021231
24 QString year = QString::number( d.year() ); 42 QString year = QString::number( d.year() );
25 QString month = QString::number( d.month() ); 43 QString month = QString::number( d.month() );
26 month = month.rightJustify( 2, '0' ); 44 month = month.rightJustify( 2, '0' );
27 QString day = QString::number( d.day() ); 45 QString day = QString::number( d.day() );
28 day = day.rightJustify( 2, '0' ); 46 day = day.rightJustify( 2, '0' );
29 47
30 QString str = year + month + day; 48 QString str = year + month + day;
31 //qDebug( "\tPimContact dateToStr = %s", str.latin1() ); 49 //qDebug( "\tPimContact dateToStr = %s", str.latin1() );
32 50
33 return str; 51 return str;
34} 52}
35 53
36QDate OConversion::dateFromString( const QString& s ) 54QDate OConversion::dateFromString( const QString& s )
37{ 55{
38 QDate date; 56 QDate date;
39 57
40 if ( s.isEmpty() ) 58 if ( s.isEmpty() )
41 return date; 59 return date;
42 60
43 // Be backward compatible to old Opie format: 61 // Be backward compatible to old Opie format:
44 // Try to load old format. If it fails, try new ISO-Format! 62 // Try to load old format. If it fails, try new ISO-Format!
45 date = TimeConversion::fromString ( s ); 63 date = TimeConversion::fromString ( s );
46 if ( date.isValid() ) 64 if ( date.isValid() )
47 return date; 65 return date;
48 66
49 // Read ISO-Format (YYYYMMDD) 67 // Read ISO-Format (YYYYMMDD)
50 int year = s.mid(0, 4).toInt(); 68 int year = s.mid(0, 4).toInt();
51 int month = s.mid(4,2).toInt(); 69 int month = s.mid(4,2).toInt();
52 int day = s.mid(6,2).toInt(); 70 int day = s.mid(6,2).toInt();
53 71
54 // do some quick sanity checking -eilers 72 // do some quick sanity checking -eilers
55 // but we isValid() again? -zecke 73 // but we isValid() again? -zecke
56 if ( year < 1900 || year > 3000 ) { 74 if ( year < 1900 || year > 3000 ) {
57 qWarning( "PimContact year is not in range"); 75 qWarning( "PimContact year is not in range");
58 return date; 76 return date;
59 } 77 }
60 if ( month < 0 || month > 12 ) { 78 if ( month < 0 || month > 12 ) {
61 qWarning( "PimContact month is not in range"); 79 qWarning( "PimContact month is not in range");
62 return date; 80 return date;
63 } 81 }
64 if ( day < 0 || day > 31 ) { 82 if ( day < 0 || day > 31 ) {
65 qWarning( "PimContact day is not in range"); 83 qWarning( "PimContact day is not in range");
66 return date; 84 return date;
67 } 85 }
68 86
69 date.setYMD( year, month, day ); 87 date.setYMD( year, month, day );
70 if ( !date.isValid() ) { 88 if ( !date.isValid() ) {
71 qWarning( "PimContact date is not valid"); 89 qWarning( "PimContact date is not valid");
72 return date; 90 return date;
73 } 91 }
74 92
75 return date; 93 return date;
76} 94}
77QString OConversion::dateTimeToString( const QDateTime& dt ) { 95QString OConversion::dateTimeToString( const QDateTime& dt ) {
78 if (!dt.isValid() || dt.isNull() ) return QString::null; 96 if (!dt.isValid() || dt.isNull() ) return QString::null;
79 97
80 QString year = QString::number( dt.date().year() ); 98 QString year = QString::number( dt.date().year() );
81 QString month = QString::number( dt.date().month() ); 99 QString month = QString::number( dt.date().month() );
82 QString day = QString::number( dt.date().day() ); 100 QString day = QString::number( dt.date().day() );
83 101
84 QString hour = QString::number( dt.time().hour() ); 102 QString hour = QString::number( dt.time().hour() );
85 QString min = QString::number( dt.time().minute() ); 103 QString min = QString::number( dt.time().minute() );
86 QString sec = QString::number( dt.time().second() ); 104 QString sec = QString::number( dt.time().second() );
87 105
88 month = month.rightJustify( 2, '0' ); 106 month = month.rightJustify( 2, '0' );
89 day = day. rightJustify( 2, '0' ); 107 day = day. rightJustify( 2, '0' );
90 hour = hour. rightJustify( 2, '0' ); 108 hour = hour. rightJustify( 2, '0' );
91 min = min. rightJustify( 2, '0' ); 109 min = min. rightJustify( 2, '0' );
92 sec = sec. rightJustify( 2, '0' ); 110 sec = sec. rightJustify( 2, '0' );
93 111
94 QString str = day + month + year + hour + min + sec; 112 QString str = day + month + year + hour + min + sec;
95 113
96 return str; 114 return str;
97} 115}
98QDateTime OConversion::dateTimeFromString( const QString& str) { 116QDateTime OConversion::dateTimeFromString( const QString& str) {
99 117
100 if ( str.isEmpty() ) return QDateTime(); 118 if ( str.isEmpty() ) return QDateTime();
101 int day = str.mid(0, 2).toInt(); 119 int day = str.mid(0, 2).toInt();
102 int month = str.mid(2, 2).toInt(); 120 int month = str.mid(2, 2).toInt();
103 int year = str.mid(4, 4).toInt(); 121 int year = str.mid(4, 4).toInt();
104 int hour = str.mid(8, 2).toInt(); 122 int hour = str.mid(8, 2).toInt();
105 int min = str.mid(10, 2).toInt(); 123 int min = str.mid(10, 2).toInt();
106 int sec = str.mid(12, 2).toInt(); 124 int sec = str.mid(12, 2).toInt();
107 125
108 QDate date( year, month, day ); 126 QDate date( year, month, day );
109 QTime time( hour, min, sec ); 127 QTime time( hour, min, sec );
110 QDateTime dt( date, time ); 128 QDateTime dt( date, time );
111 return dt; 129 return dt;
112} 130}
113 131
132} \ No newline at end of file
diff --git a/libopie2/opiepim/core/oconversion.h b/libopie2/opiepim/core/oconversion.h
index 4c0a497..3c4fdf3 100644
--- a/libopie2/opiepim/core/oconversion.h
+++ b/libopie2/opiepim/core/oconversion.h
@@ -1,48 +1,62 @@
1/********************************************************************** 1/*
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2 This file is part of the Opie Project
3** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) 3 Copyright (C) The Main Author <main-author@whereever.org>
4** 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5** This file may be distributed and/or modified under the terms of the 5 .=l.
6** GNU General Public License version 2 as published by the Free Software 6 .>+-=
7** Foundation and appearing in the file LICENSE.GPL included in the 7 _;:, .> :=|. This program is free software; you can
8** packaging of this file. 8.> <`_, > . <= redistribute it and/or modify it under
9** 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 10.="- .-=="i, .._ License as published by the Free Software
11** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 11 - . .-<_> .<> Foundation; either version 2 of the License,
12** 12 ._= =} : or (at your option) any later version.
13** See http://www.trolltech.com/gpl/ for GPL licensing information. 13 .%`+i> _;_.
14** 14 .i_,=:_. -<s. This program is distributed in the hope that
15** Contact info@trolltech.com if any conditions of this licensing are 15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16** not clear to you. 16 : .. .:, . . . without even the implied warranty of
17**********************************************************************/ 17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
18 29
19#ifndef __oconversion_h__ 30#ifndef __oconversion_h__
20#define __oconversion_h__ 31#define __oconversion_h__
21 32
22/* #include <time.h> */ 33/* #include <time.h> */
23/* #include <sys/types.h> */ 34/* #include <sys/types.h> */
24#include <qdatetime.h> 35#include <qdatetime.h>
25 36
26/* FIXME namespace? -zecke */ 37namespace Opie {
38
27class OConversion 39class OConversion
28{ 40{
29public: 41public:
30 static QString dateToString( const QDate &d ); 42 static QString dateToString( const QDate &d );
31 static QDate dateFromString( const QString &datestr ); 43 static QDate dateFromString( const QString &datestr );
32 44
33 /** 45 /**
34 * simple function to store DateTime as string and read from string 46 * simple function to store DateTime as string and read from string
35 * no timezone changing is done 47 * no timezone changing is done
36 * DDMMYYYYHHMMSS is the simple format 48 * DDMMYYYYHHMMSS is the simple format
37 */ 49 */
38 static QString dateTimeToString( const QDateTime& ); 50 static QString dateTimeToString( const QDateTime& );
39 static QDateTime dateTimeFromString( const QString& ); 51 static QDateTime dateTimeFromString( const QString& );
40 52
41private: 53private:
42 class Private; 54 class Private;
43 Private* d; 55 Private* d;
44 56
45}; 57};
46 58
59}
60
47#endif // __oconversion_h__ 61#endif // __oconversion_h__
48 62
diff --git a/libopie2/opiepim/core/odatebookaccess.cpp b/libopie2/opiepim/core/odatebookaccess.cpp
index d95fed6..8c527f6 100644
--- a/libopie2/opiepim/core/odatebookaccess.cpp
+++ b/libopie2/opiepim/core/odatebookaccess.cpp
@@ -1,81 +1,112 @@
1#include "obackendfactory.h" 1/*
2#include "odatebookaccess.h" 2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29#include <opie2/obackendfactory.h>
30#include <opie2/odatebookaccess.h>
3 31
32namespace Opie {
4/** 33/**
5 * Simple constructor 34 * Simple constructor
6 * It takes a ODateBookAccessBackend as parent. If it is 0 the default implementation 35 * It takes a ODateBookAccessBackend as parent. If it is 0 the default implementation
7 * will be used! 36 * will be used!
8 * @param back The backend to be used or 0 for the default backend 37 * @param back The backend to be used or 0 for the default backend
9 * @param ac What kind of access is intended 38 * @param ac What kind of access is intended
10 */ 39 */
11ODateBookAccess::ODateBookAccess( ODateBookAccessBackend* back, enum Access ac ) 40ODateBookAccess::ODateBookAccess( ODateBookAccessBackend* back, enum Access ac )
12 : OPimAccessTemplate<OEvent>( back ) 41 : OPimAccessTemplate<OEvent>( back )
13{ 42{
14 if (!back ) 43 if (!back )
15 back = OBackendFactory<ODateBookAccessBackend>::Default("datebook", QString::null ); 44 back = OBackendFactory<ODateBookAccessBackend>::Default("datebook", QString::null );
16 45
17 m_backEnd = back; 46 m_backEnd = back;
18 setBackEnd( m_backEnd ); 47 setBackEnd( m_backEnd );
19} 48}
20ODateBookAccess::~ODateBookAccess() { 49ODateBookAccess::~ODateBookAccess() {
21} 50}
22 51
23/** 52/**
24 * @return all events available 53 * @return all events available
25 */ 54 */
26ODateBookAccess::List ODateBookAccess::rawEvents()const { 55ODateBookAccess::List ODateBookAccess::rawEvents()const {
27 QArray<int> ints = m_backEnd->rawEvents(); 56 QArray<int> ints = m_backEnd->rawEvents();
28 57
29 List lis( ints, this ); 58 List lis( ints, this );
30 return lis; 59 return lis;
31} 60}
32 61
33/** 62/**
34 * @return all repeating events 63 * @return all repeating events
35 */ 64 */
36ODateBookAccess::List ODateBookAccess::rawRepeats()const { 65ODateBookAccess::List ODateBookAccess::rawRepeats()const {
37 QArray<int> ints = m_backEnd->rawRepeats(); 66 QArray<int> ints = m_backEnd->rawRepeats();
38 67
39 List lis( ints, this ); 68 List lis( ints, this );
40 return lis; 69 return lis;
41} 70}
42 71
43/** 72/**
44 * @return all non repeating events 73 * @return all non repeating events
45 */ 74 */
46ODateBookAccess::List ODateBookAccess::nonRepeats()const { 75ODateBookAccess::List ODateBookAccess::nonRepeats()const {
47 QArray<int> ints = m_backEnd->nonRepeats(); 76 QArray<int> ints = m_backEnd->nonRepeats();
48 77
49 List lis( ints, this ); 78 List lis( ints, this );
50 return lis; 79 return lis;
51} 80}
52 81
53/** 82/**
54 * @return dates in the time span between from and to 83 * @return dates in the time span between from and to
55 * @param from Include all events from... 84 * @param from Include all events from...
56 * @param to Include all events to... 85 * @param to Include all events to...
57 */ 86 */
58OEffectiveEvent::ValueList ODateBookAccess::effectiveEvents( const QDate& from, const QDate& to ) const { 87OEffectiveEvent::ValueList ODateBookAccess::effectiveEvents( const QDate& from, const QDate& to ) const {
59 return m_backEnd->effectiveEvents( from, to ); 88 return m_backEnd->effectiveEvents( from, to );
60} 89}
61/** 90/**
62 * @return all events at a given datetime 91 * @return all events at a given datetime
63 */ 92 */
64OEffectiveEvent::ValueList ODateBookAccess::effectiveEvents( const QDateTime& start ) const { 93OEffectiveEvent::ValueList ODateBookAccess::effectiveEvents( const QDateTime& start ) const {
65 return m_backEnd->effectiveEvents( start ); 94 return m_backEnd->effectiveEvents( start );
66} 95}
67 96
68/** 97/**
69 * @return non repeating dates in the time span between from and to 98 * @return non repeating dates in the time span between from and to
70 * @param from Include all events from... 99 * @param from Include all events from...
71 * @param to Include all events to... 100 * @param to Include all events to...
72 */ 101 */
73OEffectiveEvent::ValueList ODateBookAccess::effectiveNonRepeatingEvents( const QDate& from, const QDate& to ) const { 102OEffectiveEvent::ValueList ODateBookAccess::effectiveNonRepeatingEvents( const QDate& from, const QDate& to ) const {
74 return m_backEnd->effectiveNonRepeatingEvents( from, to ); 103 return m_backEnd->effectiveNonRepeatingEvents( from, to );
75} 104}
76/** 105/**
77 * @return all non repeating events at a given datetime 106 * @return all non repeating events at a given datetime
78 */ 107 */
79OEffectiveEvent::ValueList ODateBookAccess::effectiveNonRepeatingEvents( const QDateTime& start ) const { 108OEffectiveEvent::ValueList ODateBookAccess::effectiveNonRepeatingEvents( const QDateTime& start ) const {
80 return m_backEnd->effectiveNonRepeatingEvents( start ); 109 return m_backEnd->effectiveNonRepeatingEvents( start );
81} 110}
111
112}
diff --git a/libopie2/opiepim/core/odatebookaccess.h b/libopie2/opiepim/core/odatebookaccess.h
index 62196da..38dc754 100644
--- a/libopie2/opiepim/core/odatebookaccess.h
+++ b/libopie2/opiepim/core/odatebookaccess.h
@@ -1,44 +1,75 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_DATE_BOOK_ACCESS_H 29#ifndef OPIE_DATE_BOOK_ACCESS_H
2#define OPIE_DATE_BOOK_ACCESS_H 30#define OPIE_DATE_BOOK_ACCESS_H
3 31
4#include "odatebookaccessbackend.h" 32#include "odatebookaccessbackend.h"
5#include "opimaccesstemplate.h" 33#include "opimaccesstemplate.h"
6 34
7#include "oevent.h" 35#include <opie2/oevent.h>
8 36
37namespace Opie {
9/** 38/**
10 * This is the object orientated datebook database. It'll use OBackendFactory 39 * This is the object orientated datebook database. It'll use OBackendFactory
11 * to query for a backend. 40 * to query for a backend.
12 * All access to the datebook should be done via this class. 41 * All access to the datebook should be done via this class.
13 * Make sure to load and save the datebook this is not part of 42 * Make sure to load and save the datebook this is not part of
14 * destructing and creating the object 43 * destructing and creating the object
15 * 44 *
16 * @author Holger Freyther, Stefan Eilers 45 * @author Holger Freyther, Stefan Eilers
17 */ 46 */
18class ODateBookAccess : public OPimAccessTemplate<OEvent> { 47class ODateBookAccess : public OPimAccessTemplate<OEvent> {
19public: 48public:
20 ODateBookAccess( ODateBookAccessBackend* = 0l, enum Access acc = Random ); 49 ODateBookAccess( ODateBookAccessBackend* = 0l, enum Access acc = Random );
21 ~ODateBookAccess(); 50 ~ODateBookAccess();
22 51
23 /* return all events */ 52 /* return all events */
24 List rawEvents()const; 53 List rawEvents()const;
25 54
26 /* return repeating events */ 55 /* return repeating events */
27 List rawRepeats()const; 56 List rawRepeats()const;
28 57
29 /* return non repeating events */ 58 /* return non repeating events */
30 List nonRepeats()const; 59 List nonRepeats()const;
31 60
32 /* return non repeating events (from,to) */ 61 /* return non repeating events (from,to) */
33 OEffectiveEvent::ValueList effectiveEvents( const QDate& from, const QDate& to ) const; 62 OEffectiveEvent::ValueList effectiveEvents( const QDate& from, const QDate& to ) const;
34 OEffectiveEvent::ValueList effectiveEvents( const QDateTime& start ) const; 63 OEffectiveEvent::ValueList effectiveEvents( const QDateTime& start ) const;
35 OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDate& from, const QDate& to ) const; 64 OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDate& from, const QDate& to ) const;
36 OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDateTime& start ) const; 65 OEffectiveEvent::ValueList effectiveNonRepeatingEvents( const QDateTime& start ) const;
37 66
38private: 67private:
39 ODateBookAccessBackend* m_backEnd; 68 ODateBookAccessBackend* m_backEnd;
40 class Private; 69 class Private;
41 Private* d; 70 Private* d;
42}; 71};
43 72
73}
74
44#endif 75#endif
diff --git a/libopie2/opiepim/core/opimaccesstemplate.h b/libopie2/opiepim/core/opimaccesstemplate.h
index ecbeb68..5826cbc 100644
--- a/libopie2/opiepim/core/opimaccesstemplate.h
+++ b/libopie2/opiepim/core/opimaccesstemplate.h
@@ -1,302 +1,335 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_ACCESS_TEMPLATE_H 29#ifndef OPIE_PIM_ACCESS_TEMPLATE_H
2#define OPIE_PIM_ACCESS_TEMPLATE_H 30#define OPIE_PIM_ACCESS_TEMPLATE_H
3 31
4#include <qarray.h> 32#include <qarray.h>
5 33
6#include <opie/opimrecord.h> 34#include <opie2/opimrecord.h>
7#include <opie/opimaccessbackend.h> 35#include <opie2/opimaccessbackend.h>
8#include <opie/orecordlist.h> 36#include <opie2/orecordlist.h>
9 37
10#include "opimcache.h" 38#include <opie2/opimcache.h>
11#include "otemplatebase.h" 39#include <opie2/otemplatebase.h>
40
41namespace Opie {
12 42
13class OPimAccessTemplatePrivate; 43class OPimAccessTemplatePrivate;
14/** 44/**
15 * Thats the frontend to our OPIE PIM 45 * Thats the frontend to our OPIE PIM
16 * Library. Either you want to use it's 46 * Library. Either you want to use it's
17 * interface or you want to implement 47 * interface or you want to implement
18 * your own Access lib 48 * your own Access lib
19 * Just create a OPimRecord and inherit from 49 * Just create a OPimRecord and inherit from
20 * the plugins 50 * the plugins
21 */ 51 */
22 52
23template <class T = OPimRecord > 53template <class T = OPimRecord >
24class OPimAccessTemplate : public OTemplateBase<T> { 54class OPimAccessTemplate : public OTemplateBase<T> {
25public: 55public:
26 enum Access { 56 enum Access {
27 Random = 0, 57 Random = 0,
28 SortedAccess 58 SortedAccess
29 }; 59 };
30 typedef ORecordList<T> List; 60 typedef ORecordList<T> List;
31 typedef OPimAccessBackend<T> BackEnd; 61 typedef OPimAccessBackend<T> BackEnd;
32 typedef OPimCache<T> Cache; 62 typedef OPimCache<T> Cache;
33 63
34 /** 64 /**
35 * c'tor BackEnd 65 * c'tor BackEnd
36 * enum Access a small hint on how to handle the backend 66 * enum Access a small hint on how to handle the backend
37 */ 67 */
38 OPimAccessTemplate( BackEnd* end); 68 OPimAccessTemplate( BackEnd* end);
39 69
40 virtual ~OPimAccessTemplate(); 70 virtual ~OPimAccessTemplate();
41 71
42 /** 72 /**
43 * load from the backend 73 * load from the backend
44 */ 74 */
45 bool load(); 75 bool load();
46 76
47 /** Reload database. 77 /** Reload database.
48 * You should execute this function if the external database 78 * You should execute this function if the external database
49 * was changed. 79 * was changed.
50 * This function will load the external database and afterwards 80 * This function will load the external database and afterwards
51 * rejoin the local changes. Therefore the local database will be set consistent. 81 * rejoin the local changes. Therefore the local database will be set consistent.
52 */ 82 */
53 virtual bool reload(); 83 virtual bool reload();
54 84
55 /** Save contacts database. 85 /** Save contacts database.
56 * Save is more a "commit". After calling this function, all changes are public available. 86 * Save is more a "commit". After calling this function, all changes are public available.
57 * @return true if successful 87 * @return true if successful
58 */ 88 */
59 bool save(); 89 bool save();
60 90
61 /** 91 /**
62 * if the resource was changed externally 92 * if the resource was changed externally
63 * You should use the signal handling instead of polling possible changes ! 93 * You should use the signal handling instead of polling possible changes !
64 * zecke: Do you implement a signal for otodoaccess ? 94 * zecke: Do you implement a signal for otodoaccess ?
65 */ 95 */
66 bool wasChangedExternally()const; 96 bool wasChangedExternally()const;
67 97
68 /** 98 /**
69 * return a List of records 99 * return a List of records
70 * you can iterate over them 100 * you can iterate over them
71 */ 101 */
72 virtual List allRecords()const; 102 virtual List allRecords()const;
73 103
74 /** 104 /**
75 * return a List of records 105 * return a List of records
76 * that match the regex 106 * that match the regex
77 */ 107 */
78 virtual List matchRegexp( const QRegExp &r ) const; 108 virtual List matchRegexp( const QRegExp &r ) const;
79 109
80 /** 110 /**
81 * queryByExample. 111 * queryByExample.
82 * @see otodoaccess, ocontactaccess 112 * @see otodoaccess, ocontactaccess
83 */ 113 */
84 virtual List queryByExample( const T& t, int querySettings, const QDateTime& d = QDateTime() ); 114 virtual List queryByExample( const T& t, int querySettings, const QDateTime& d = QDateTime() );
85 115
86 /** 116 /**
87 * find the OPimRecord uid 117 * find the OPimRecord uid
88 */ 118 */
89 virtual T find( int uid )const; 119 virtual T find( int uid )const;
90 120
91 /** 121 /**
92 * read ahead cache find method ;) 122 * read ahead cache find method ;)
93 */ 123 */
94 virtual T find( int uid, const QArray<int>&, 124 virtual T find( int uid, const QArray<int>&,
95 uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; 125 uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const;
96 126
97 /* invalidate cache here */ 127 /* invalidate cache here */
98 /** 128 /**
99 * clears the backend and invalidates the backend 129 * clears the backend and invalidates the backend
100 */ 130 */
101 void clear() ; 131 void clear() ;
102 132
103 /** 133 /**
104 * add T to the backend 134 * add T to the backend
105 * @param t The item to add. 135 * @param t The item to add.
106 * @return <i>true</i> if added successfully. 136 * @return <i>true</i> if added successfully.
107 */ 137 */
108 virtual bool add( const T& t ) ; 138 virtual bool add( const T& t ) ;
109 bool add( const OPimRecord& ); 139 bool add( const OPimRecord& );
110 140
111 /* only the uid matters */ 141 /* only the uid matters */
112 /** 142 /**
113 * remove T from the backend 143 * remove T from the backend
114 * @param t The item to remove 144 * @param t The item to remove
115 * @return <i>true</i> if successful. 145 * @return <i>true</i> if successful.
116 */ 146 */
117 virtual bool remove( const T& t ); 147 virtual bool remove( const T& t );
118 148
119 /** 149 /**
120 * remove the OPimRecord with uid 150 * remove the OPimRecord with uid
121 * @param uid The ID of the item to remove 151 * @param uid The ID of the item to remove
122 * @return <i>true</i> if successful. 152 * @return <i>true</i> if successful.
123 */ 153 */
124 bool remove( int uid ); 154 bool remove( int uid );
125 bool remove( const OPimRecord& ); 155 bool remove( const OPimRecord& );
126 156
127 /** 157 /**
128 * replace T from backend 158 * replace T from backend
129 * @param t The item to replace 159 * @param t The item to replace
130 * @return <i>true</i> if successful. 160 * @return <i>true</i> if successful.
131 */ 161 */
132 virtual bool replace( const T& t) ; 162 virtual bool replace( const T& t) ;
133 163
134 void setReadAhead( uint count ); 164 void setReadAhead( uint count );
135 /** 165 /**
136 * @internal 166 * @internal
137 */ 167 */
138 void cache( const T& )const; 168 void cache( const T& )const;
139 void setSaneCacheSize( int ); 169 void setSaneCacheSize( int );
140 170
141 QArray<int> records()const; 171 QArray<int> records()const;
142protected: 172protected:
143 /** 173 /**
144 * invalidate the cache 174 * invalidate the cache
145 */ 175 */
146 void invalidateCache(); 176 void invalidateCache();
147 177
148 void setBackEnd( BackEnd* end ); 178 void setBackEnd( BackEnd* end );
149 /** 179 /**
150 * returns the backend 180 * returns the backend
151 */ 181 */
152 BackEnd* backEnd(); 182 BackEnd* backEnd();
153 BackEnd* m_backEnd; 183 BackEnd* m_backEnd;
154 Cache m_cache; 184 Cache m_cache;
155 185
156private: 186private:
157 OPimAccessTemplatePrivate *d; 187 OPimAccessTemplatePrivate *d;
158 188
159}; 189};
160 190
161template <class T> 191template <class T>
162OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) 192OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end )
163 : OTemplateBase<T>(), m_backEnd( end ) 193 : OTemplateBase<T>(), m_backEnd( end )
164{ 194{
165 if (end ) 195 if (end )
166 end->setFrontend( this ); 196 end->setFrontend( this );
167} 197}
168template <class T> 198template <class T>
169OPimAccessTemplate<T>::~OPimAccessTemplate() { 199OPimAccessTemplate<T>::~OPimAccessTemplate() {
170 qWarning("~OPimAccessTemplate<T>"); 200 qWarning("~OPimAccessTemplate<T>");
171 delete m_backEnd; 201 delete m_backEnd;
172} 202}
173template <class T> 203template <class T>
174bool OPimAccessTemplate<T>::load() { 204bool OPimAccessTemplate<T>::load() {
175 invalidateCache(); 205 invalidateCache();
176 return m_backEnd->load(); 206 return m_backEnd->load();
177} 207}
178template <class T> 208template <class T>
179bool OPimAccessTemplate<T>::reload() { 209bool OPimAccessTemplate<T>::reload() {
180 invalidateCache(); // zecke: I think this should be added (se) 210 invalidateCache(); // zecke: I think this should be added (se)
181 return m_backEnd->reload(); 211 return m_backEnd->reload();
182} 212}
183template <class T> 213template <class T>
184bool OPimAccessTemplate<T>::save() { 214bool OPimAccessTemplate<T>::save() {
185 return m_backEnd->save(); 215 return m_backEnd->save();
186} 216}
187template <class T> 217template <class T>
188typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { 218typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const {
189 QArray<int> ints = m_backEnd->allRecords(); 219 QArray<int> ints = m_backEnd->allRecords();
190 List lis(ints, this ); 220 List lis(ints, this );
191 return lis; 221 return lis;
192} 222}
193template <class T> 223template <class T>
194typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::matchRegexp( const QRegExp &r )const { 224typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::matchRegexp( const QRegExp &r )const {
195 QArray<int> ints = m_backEnd->matchRegexp( r ); 225 QArray<int> ints = m_backEnd->matchRegexp( r );
196 List lis(ints, this ); 226 List lis(ints, this );
197 return lis; 227 return lis;
198} 228}
199template <class T> 229template <class T>
200QArray<int> OPimAccessTemplate<T>::records()const { 230QArray<int> OPimAccessTemplate<T>::records()const {
201 return m_backEnd->allRecords(); 231 return m_backEnd->allRecords();
202} 232}
203template <class T> 233template <class T>
204typename OPimAccessTemplate<T>::List 234typename OPimAccessTemplate<T>::List
205OPimAccessTemplate<T>::queryByExample( const T& t, int settings, const QDateTime& d ) { 235OPimAccessTemplate<T>::queryByExample( const T& t, int settings, const QDateTime& d ) {
206 QArray<int> ints = m_backEnd->queryByExample( t, settings, d ); 236 QArray<int> ints = m_backEnd->queryByExample( t, settings, d );
207 237
208 List lis(ints, this ); 238 List lis(ints, this );
209 return lis; 239 return lis;
210} 240}
211template <class T> 241template <class T>
212T OPimAccessTemplate<T>::find( int uid ) const{ 242T OPimAccessTemplate<T>::find( int uid ) const{
213 T t = m_backEnd->find( uid ); 243 T t = m_backEnd->find( uid );
214 cache( t ); 244 cache( t );
215 return t; 245 return t;
216} 246}
217template <class T> 247template <class T>
218T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, 248T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar,
219 uint current, typename OTemplateBase<T>::CacheDirection dir )const { 249 uint current, typename OTemplateBase<T>::CacheDirection dir )const {
220 /* 250 /*
221 * better do T.isEmpty() 251 * better do T.isEmpty()
222 * after a find this way we would 252 * after a find this way we would
223 * avoid two finds in QCache... 253 * avoid two finds in QCache...
224 */ 254 */
225 // qWarning("find it now %d", uid ); 255 // qWarning("find it now %d", uid );
226 if (m_cache.contains( uid ) ) { 256 if (m_cache.contains( uid ) ) {
227 return m_cache.find( uid ); 257 return m_cache.find( uid );
228 } 258 }
229 259
230 T t = m_backEnd->find( uid, ar, current, dir ); 260 T t = m_backEnd->find( uid, ar, current, dir );
231 cache( t ); 261 cache( t );
232 return t; 262 return t;
233} 263}
234template <class T> 264template <class T>
235void OPimAccessTemplate<T>::clear() { 265void OPimAccessTemplate<T>::clear() {
236 invalidateCache(); 266 invalidateCache();
237 m_backEnd->clear(); 267 m_backEnd->clear();
238} 268}
239template <class T> 269template <class T>
240bool OPimAccessTemplate<T>::add( const T& t ) { 270bool OPimAccessTemplate<T>::add( const T& t ) {
241 cache( t ); 271 cache( t );
242 return m_backEnd->add( t ); 272 return m_backEnd->add( t );
243} 273}
244template <class T> 274template <class T>
245bool OPimAccessTemplate<T>::add( const OPimRecord& rec) { 275bool OPimAccessTemplate<T>::add( const OPimRecord& rec) {
246 /* same type */ 276 /* same type */
247 if ( rec.rtti() == T::rtti() ) { 277 if ( rec.rtti() == T::rtti() ) {
248 const T &t = static_cast<const T&>(rec); 278 const T &t = static_cast<const T&>(rec);
249 return add(t); 279 return add(t);
250 } 280 }
251 return false; 281 return false;
252} 282}
253template <class T> 283template <class T>
254bool OPimAccessTemplate<T>::remove( const T& t ) { 284bool OPimAccessTemplate<T>::remove( const T& t ) {
255 return remove( t.uid() ); 285 return remove( t.uid() );
256} 286}
257template <class T> 287template <class T>
258bool OPimAccessTemplate<T>::remove( int uid ) { 288bool OPimAccessTemplate<T>::remove( int uid ) {
259 m_cache.remove( uid ); 289 m_cache.remove( uid );
260 return m_backEnd->remove( uid ); 290 return m_backEnd->remove( uid );
261} 291}
262template <class T> 292template <class T>
263bool OPimAccessTemplate<T>::remove( const OPimRecord& rec) { 293bool OPimAccessTemplate<T>::remove( const OPimRecord& rec) {
264 return remove( rec.uid() ); 294 return remove( rec.uid() );
265} 295}
266template <class T> 296template <class T>
267bool OPimAccessTemplate<T>::replace( const T& t ) { 297bool OPimAccessTemplate<T>::replace( const T& t ) {
268 m_cache.replace( t ); 298 m_cache.replace( t );
269 return m_backEnd->replace( t ); 299 return m_backEnd->replace( t );
270} 300}
271template <class T> 301template <class T>
272void OPimAccessTemplate<T>::invalidateCache() { 302void OPimAccessTemplate<T>::invalidateCache() {
273 m_cache.invalidate(); 303 m_cache.invalidate();
274} 304}
275template <class T> 305template <class T>
276typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { 306typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() {
277 return m_backEnd; 307 return m_backEnd;
278} 308}
279template <class T> 309template <class T>
280bool OPimAccessTemplate<T>::wasChangedExternally()const { 310bool OPimAccessTemplate<T>::wasChangedExternally()const {
281 return false; 311 return false;
282} 312}
283template <class T> 313template <class T>
284void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { 314void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) {
285 m_backEnd = end; 315 m_backEnd = end;
286 if (m_backEnd ) 316 if (m_backEnd )
287 m_backEnd->setFrontend( this ); 317 m_backEnd->setFrontend( this );
288} 318}
289template <class T> 319template <class T>
290void OPimAccessTemplate<T>::cache( const T& t ) const{ 320void OPimAccessTemplate<T>::cache( const T& t ) const{
291 /* hacky we need to work around the const*/ 321 /* hacky we need to work around the const*/
292 ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); 322 ((OPimAccessTemplate<T>*)this)->m_cache.add( t );
293} 323}
294template <class T> 324template <class T>
295void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { 325void OPimAccessTemplate<T>::setSaneCacheSize( int size ) {
296 m_cache.setSize( size ); 326 m_cache.setSize( size );
297} 327}
298template <class T> 328template <class T>
299void OPimAccessTemplate<T>::setReadAhead( uint count ) { 329void OPimAccessTemplate<T>::setReadAhead( uint count ) {
300 m_backEnd->setReadAhead( count ); 330 m_backEnd->setReadAhead( count );
301} 331}
332
333}
334
302#endif 335#endif
diff --git a/libopie2/opiepim/core/opimcache.h b/libopie2/opiepim/core/opimcache.h
index 7f7cff5..e70a910 100644
--- a/libopie2/opiepim/core/opimcache.h
+++ b/libopie2/opiepim/core/opimcache.h
@@ -1,131 +1,162 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_CACHE_H 29#ifndef OPIE_PIM_CACHE_H
2#define OPIE_PIM_CACHE_H 30#define OPIE_PIM_CACHE_H
3 31
4#include <qintcache.h> 32#include <qintcache.h>
5 33
6#include "opimrecord.h" 34#include <opie2/opimrecord.h>
7 35
36namespace Opie {
8class OPimCacheItemPrivate; 37class OPimCacheItemPrivate;
9 38
10template <class T = OPimRecord> 39template <class T = OPimRecord>
11class OPimCacheItem { 40class OPimCacheItem {
12public: 41public:
13 OPimCacheItem( const T& t = T() ); 42 OPimCacheItem( const T& t = T() );
14 OPimCacheItem( const OPimCacheItem& ); 43 OPimCacheItem( const OPimCacheItem& );
15 ~OPimCacheItem(); 44 ~OPimCacheItem();
16 45
17 OPimCacheItem &operator=( const OPimCacheItem& ); 46 OPimCacheItem &operator=( const OPimCacheItem& );
18 47
19 T record()const; 48 T record()const;
20 void setRecord( const T& ); 49 void setRecord( const T& );
21private: 50private:
22 T m_t; 51 T m_t;
23 OPimCacheItemPrivate *d; 52 OPimCacheItemPrivate *d;
24}; 53};
25 54
26 55
27class OPimCachePrivate; 56class OPimCachePrivate;
28/** 57/**
29 * OPimCache for caching the items 58 * OPimCache for caching the items
30 * We support adding, removing 59 * We support adding, removing
31 * and finding 60 * and finding
32 */ 61 */
33template <class T = OPimRecord> 62template <class T = OPimRecord>
34class OPimCache { 63class OPimCache {
35public: 64public:
36 typedef OPimCacheItem<T> Item; 65 typedef OPimCacheItem<T> Item;
37 OPimCache(); 66 OPimCache();
38 OPimCache( const OPimCache& ); 67 OPimCache( const OPimCache& );
39 ~OPimCache(); 68 ~OPimCache();
40 69
41 OPimCache &operator=( const OPimCache& ); 70 OPimCache &operator=( const OPimCache& );
42 71
43 bool contains(int uid)const; 72 bool contains(int uid)const;
44 void invalidate(); 73 void invalidate();
45 void setSize( int size ); 74 void setSize( int size );
46 75
47 T find(int uid )const; 76 T find(int uid )const;
48 void add( const T& ); 77 void add( const T& );
49 void remove( int uid ); 78 void remove( int uid );
50 void replace( const T& ); 79 void replace( const T& );
51 80
52private: 81private:
53 QIntCache<Item> m_cache; 82 QIntCache<Item> m_cache;
54 OPimCachePrivate* d; 83 OPimCachePrivate* d;
55}; 84};
56 85
57// Implementation 86// Implementation
58template <class T> 87template <class T>
59OPimCacheItem<T>::OPimCacheItem( const T& t ) 88OPimCacheItem<T>::OPimCacheItem( const T& t )
60 : m_t(t) { 89 : m_t(t) {
61} 90}
62template <class T> 91template <class T>
63OPimCacheItem<T>::~OPimCacheItem() { 92OPimCacheItem<T>::~OPimCacheItem() {
64 93
65} 94}
66template <class T> 95template <class T>
67T OPimCacheItem<T>::record()const { 96T OPimCacheItem<T>::record()const {
68 return m_t; 97 return m_t;
69} 98}
70template <class T> 99template <class T>
71void OPimCacheItem<T>::setRecord( const T& t ) { 100void OPimCacheItem<T>::setRecord( const T& t ) {
72 m_t = t; 101 m_t = t;
73} 102}
74// Cache 103// Cache
75template <class T> 104template <class T>
76OPimCache<T>::OPimCache() 105OPimCache<T>::OPimCache()
77 : m_cache(100, 53 ) 106 : m_cache(100, 53 )
78{ 107{
79 m_cache.setAutoDelete( TRUE ); 108 m_cache.setAutoDelete( TRUE );
80} 109}
81template <class T> 110template <class T>
82OPimCache<T>::~OPimCache() { 111OPimCache<T>::~OPimCache() {
83 112
84} 113}
85template <class T> 114template <class T>
86bool OPimCache<T>::contains(int uid )const { 115bool OPimCache<T>::contains(int uid )const {
87 Item* it = m_cache.find( uid, FALSE ); 116 Item* it = m_cache.find( uid, FALSE );
88 if (!it) 117 if (!it)
89 return false; 118 return false;
90 return true; 119 return true;
91} 120}
92template <class T> 121template <class T>
93void OPimCache<T>::invalidate() { 122void OPimCache<T>::invalidate() {
94 m_cache.clear(); 123 m_cache.clear();
95} 124}
96template <class T> 125template <class T>
97void OPimCache<T>::setSize( int size ) { 126void OPimCache<T>::setSize( int size ) {
98 m_cache.setMaxCost( size ); 127 m_cache.setMaxCost( size );
99} 128}
100template <class T> 129template <class T>
101T OPimCache<T>::find(int uid )const { 130T OPimCache<T>::find(int uid )const {
102 Item *it = m_cache.find( uid ); 131 Item *it = m_cache.find( uid );
103 if (it) 132 if (it)
104 return it->record(); 133 return it->record();
105 return T(); 134 return T();
106} 135}
107template <class T> 136template <class T>
108void OPimCache<T>::add( const T& t ) { 137void OPimCache<T>::add( const T& t ) {
109 Item* it = 0l; 138 Item* it = 0l;
110 it = m_cache.find(t.uid(), FALSE ); 139 it = m_cache.find(t.uid(), FALSE );
111 140
112 if (it ) 141 if (it )
113 it->setRecord( t ); 142 it->setRecord( t );
114 143
115 it = new Item( t ); 144 it = new Item( t );
116 if (!m_cache.insert( t.uid(), it ) ) 145 if (!m_cache.insert( t.uid(), it ) )
117 delete it; 146 delete it;
118} 147}
119template <class T> 148template <class T>
120void OPimCache<T>::remove( int uid ) { 149void OPimCache<T>::remove( int uid ) {
121 m_cache.remove( uid ); 150 m_cache.remove( uid );
122} 151}
123template <class T> 152template <class T>
124void OPimCache<T>::replace( const T& t) { 153void OPimCache<T>::replace( const T& t) {
125 Item *it = m_cache.find( t.uid() ); 154 Item *it = m_cache.find( t.uid() );
126 if ( it ) { 155 if ( it ) {
127 it->setRecord( t ); 156 it->setRecord( t );
128 } 157 }
129} 158}
130 159
160}
161
131#endif 162#endif
diff --git a/libopie2/opiepim/core/opimmaintainer.cpp b/libopie2/opiepim/core/opimmaintainer.cpp
index 92cb25a..b2eff12 100644
--- a/libopie2/opiepim/core/opimmaintainer.cpp
+++ b/libopie2/opiepim/core/opimmaintainer.cpp
@@ -1,37 +1,69 @@
1#include "opimmaintainer.h" 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
2 29
30#include <opie2/opimmaintainer.h>
31
32namespace Opie {
3OPimMaintainer::OPimMaintainer( int mode, int uid ) 33OPimMaintainer::OPimMaintainer( int mode, int uid )
4 : m_mode(mode), m_uid(uid ) 34 : m_mode(mode), m_uid(uid )
5{} 35{}
6OPimMaintainer::~OPimMaintainer() { 36OPimMaintainer::~OPimMaintainer() {
7} 37}
8OPimMaintainer::OPimMaintainer( const OPimMaintainer& main ) { 38OPimMaintainer::OPimMaintainer( const OPimMaintainer& main ) {
9 *this = main; 39 *this = main;
10} 40}
11OPimMaintainer &OPimMaintainer::operator=( const OPimMaintainer& main ) { 41OPimMaintainer &OPimMaintainer::operator=( const OPimMaintainer& main ) {
12 m_mode = main.m_mode; 42 m_mode = main.m_mode;
13 m_uid = main.m_uid; 43 m_uid = main.m_uid;
14 44
15 return *this; 45 return *this;
16} 46}
17bool OPimMaintainer::operator==( const OPimMaintainer& main ) { 47bool OPimMaintainer::operator==( const OPimMaintainer& main ) {
18 if (m_mode != main.m_mode ) return false; 48 if (m_mode != main.m_mode ) return false;
19 if (m_uid != main.m_uid ) return false; 49 if (m_uid != main.m_uid ) return false;
20 50
21 return true; 51 return true;
22} 52}
23bool OPimMaintainer::operator!=( const OPimMaintainer& main ) { 53bool OPimMaintainer::operator!=( const OPimMaintainer& main ) {
24 return !(*this == main ); 54 return !(*this == main );
25} 55}
26int OPimMaintainer::mode()const { 56int OPimMaintainer::mode()const {
27 return m_mode; 57 return m_mode;
28} 58}
29int OPimMaintainer::uid()const { 59int OPimMaintainer::uid()const {
30 return m_uid; 60 return m_uid;
31} 61}
32void OPimMaintainer::setMode( int mo) { 62void OPimMaintainer::setMode( int mo) {
33 m_mode = mo; 63 m_mode = mo;
34} 64}
35void OPimMaintainer::setUid( int uid ) { 65void OPimMaintainer::setUid( int uid ) {
36 m_uid = uid; 66 m_uid = uid;
37} 67}
68
69}
diff --git a/libopie2/opiepim/core/opimmaintainer.h b/libopie2/opiepim/core/opimmaintainer.h
index 793d066..46bc9d2 100644
--- a/libopie2/opiepim/core/opimmaintainer.h
+++ b/libopie2/opiepim/core/opimmaintainer.h
@@ -1,40 +1,71 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_MAINTAINER_H 29#ifndef OPIE_PIM_MAINTAINER_H
2#define OPIE_PIM_MAINTAINER_H 30#define OPIE_PIM_MAINTAINER_H
3 31
4#include <qstring.h> 32#include <qstring.h>
5 33
34namespace Opie {
6/** 35/**
7 * Who maintains what? 36 * Who maintains what?
8 */ 37 */
9class OPimMaintainer { 38class OPimMaintainer {
10public: 39public:
11 enum Mode { Undefined = -1, 40 enum Mode { Undefined = -1,
12 Nothing = 0, 41 Nothing = 0,
13 Responsible, 42 Responsible,
14 DoneBy, 43 DoneBy,
15 Coordinating, 44 Coordinating,
16 }; 45 };
17 OPimMaintainer( int mode = Undefined, int uid = 0); 46 OPimMaintainer( int mode = Undefined, int uid = 0);
18 OPimMaintainer( const OPimMaintainer& ); 47 OPimMaintainer( const OPimMaintainer& );
19 ~OPimMaintainer(); 48 ~OPimMaintainer();
20 49
21 OPimMaintainer &operator=( const OPimMaintainer& ); 50 OPimMaintainer &operator=( const OPimMaintainer& );
22 bool operator==( const OPimMaintainer& ); 51 bool operator==( const OPimMaintainer& );
23 bool operator!=( const OPimMaintainer& ); 52 bool operator!=( const OPimMaintainer& );
24 53
25 54
26 int mode()const; 55 int mode()const;
27 int uid()const; 56 int uid()const;
28 57
29 void setMode( int mode ); 58 void setMode( int mode );
30 void setUid( int uid ); 59 void setUid( int uid );
31 60
32private: 61private:
33 int m_mode; 62 int m_mode;
34 int m_uid; 63 int m_uid;
35 class Private; 64 class Private;
36 Private *d; 65 Private *d;
37 66
38}; 67};
39 68
69}
70
40#endif 71#endif
diff --git a/libopie2/opiepim/core/opimnotify.cpp b/libopie2/opiepim/core/opimnotify.cpp
index af5514b..c61f9da 100644
--- a/libopie2/opiepim/core/opimnotify.cpp
+++ b/libopie2/opiepim/core/opimnotify.cpp
@@ -1,227 +1,258 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qshared.h> 29#include <qshared.h>
2 30
3#include "opimnotify.h" 31#include <opie2/opimnotify.h>
32
33namespace Opie {
4 34
5struct OPimNotify::Data : public QShared { 35struct OPimNotify::Data : public QShared {
6 Data() : QShared(),dur(-1),parent(0) { 36 Data() : QShared(),dur(-1),parent(0) {
7 37
8 } 38 }
9 QDateTime start; 39 QDateTime start;
10 int dur; 40 int dur;
11 QString application; 41 QString application;
12 int parent; 42 int parent;
13}; 43};
14 44
15OPimNotify::OPimNotify( const QDateTime& start, int duration, int parent ) { 45OPimNotify::OPimNotify( const QDateTime& start, int duration, int parent ) {
16 data = new Data; 46 data = new Data;
17 data->start = start; 47 data->start = start;
18 data->dur = duration; 48 data->dur = duration;
19 data->parent = parent; 49 data->parent = parent;
20} 50}
21OPimNotify::OPimNotify( const OPimNotify& noti) 51OPimNotify::OPimNotify( const OPimNotify& noti)
22 : data( noti.data ) 52 : data( noti.data )
23{ 53{
24 data->ref(); 54 data->ref();
25} 55}
26OPimNotify::~OPimNotify() { 56OPimNotify::~OPimNotify() {
27 if ( data->deref() ) { 57 if ( data->deref() ) {
28 delete data; 58 delete data;
29 data = 0l; 59 data = 0l;
30 } 60 }
31} 61}
32 62
33OPimNotify &OPimNotify::operator=( const OPimNotify& noti) { 63OPimNotify &OPimNotify::operator=( const OPimNotify& noti) {
34 noti.data->ref(); 64 noti.data->ref();
35 deref(); 65 deref();
36 data = noti.data; 66 data = noti.data;
37 67
38 return *this; 68 return *this;
39} 69}
40bool OPimNotify::operator==( const OPimNotify& noti ) { 70bool OPimNotify::operator==( const OPimNotify& noti ) {
41 if ( data == noti.data ) return true; 71 if ( data == noti.data ) return true;
42 if ( data->dur != noti.data->dur ) return false; 72 if ( data->dur != noti.data->dur ) return false;
43 if ( data->parent != noti.data->parent ) return false; 73 if ( data->parent != noti.data->parent ) return false;
44 if ( data->application != noti.data->application ) return false; 74 if ( data->application != noti.data->application ) return false;
45 if ( data->start != noti.data->start ) return false; 75 if ( data->start != noti.data->start ) return false;
46 76
47 return true; 77 return true;
48} 78}
49QDateTime OPimNotify::dateTime()const { 79QDateTime OPimNotify::dateTime()const {
50 return data->start; 80 return data->start;
51} 81}
52QString OPimNotify::service()const { 82QString OPimNotify::service()const {
53 return data->application; 83 return data->application;
54} 84}
55int OPimNotify::parent()const { 85int OPimNotify::parent()const {
56 return data->parent; 86 return data->parent;
57} 87}
58int OPimNotify::duration()const { 88int OPimNotify::duration()const {
59 return data->dur; 89 return data->dur;
60} 90}
61QDateTime OPimNotify::endTime()const { 91QDateTime OPimNotify::endTime()const {
62 return QDateTime( data->start.date(), data->start.time().addSecs( data->dur) ); 92 return QDateTime( data->start.date(), data->start.time().addSecs( data->dur) );
63} 93}
64void OPimNotify::setDateTime( const QDateTime& time ) { 94void OPimNotify::setDateTime( const QDateTime& time ) {
65 copyIntern(); 95 copyIntern();
66 data->start = time; 96 data->start = time;
67} 97}
68void OPimNotify::setDuration( int dur ) { 98void OPimNotify::setDuration( int dur ) {
69 copyIntern(); 99 copyIntern();
70 data->dur = dur; 100 data->dur = dur;
71} 101}
72void OPimNotify::setParent( int uid ) { 102void OPimNotify::setParent( int uid ) {
73 copyIntern(); 103 copyIntern();
74 data->parent = uid; 104 data->parent = uid;
75} 105}
76void OPimNotify::setService( const QString& str ) { 106void OPimNotify::setService( const QString& str ) {
77 copyIntern(); 107 copyIntern();
78 data->application = str; 108 data->application = str;
79} 109}
80void OPimNotify::copyIntern() { 110void OPimNotify::copyIntern() {
81 if ( data->count != 1 ) { 111 if ( data->count != 1 ) {
82 data->deref(); 112 data->deref();
83 Data* dat = new Data; 113 Data* dat = new Data;
84 dat->start = data->start; 114 dat->start = data->start;
85 dat->dur = data->dur; 115 dat->dur = data->dur;
86 dat->application = data->application; 116 dat->application = data->application;
87 dat->parent = data->parent; 117 dat->parent = data->parent;
88 data = dat; 118 data = dat;
89 } 119 }
90} 120}
91void OPimNotify::deref() { 121void OPimNotify::deref() {
92 if ( data->deref() ) { 122 if ( data->deref() ) {
93 delete data; 123 delete data;
94 data = 0; 124 data = 0;
95 } 125 }
96} 126}
97 127
98/***********************************************************/ 128/***********************************************************/
99struct OPimAlarm::Data : public QShared { 129struct OPimAlarm::Data : public QShared {
100 Data() : QShared() { 130 Data() : QShared() {
101 sound = 1; 131 sound = 1;
102 } 132 }
103 int sound; 133 int sound;
104 QString file; 134 QString file;
105}; 135};
106OPimAlarm::OPimAlarm( int sound, const QDateTime& start, int duration, int parent ) 136OPimAlarm::OPimAlarm( int sound, const QDateTime& start, int duration, int parent )
107 : OPimNotify( start, duration, parent ) 137 : OPimNotify( start, duration, parent )
108{ 138{
109 data = new Data; 139 data = new Data;
110 data->sound = sound; 140 data->sound = sound;
111} 141}
112OPimAlarm::OPimAlarm( const OPimAlarm& al) 142OPimAlarm::OPimAlarm( const OPimAlarm& al)
113 : OPimNotify(al), data( al.data ) 143 : OPimNotify(al), data( al.data )
114{ 144{
115 data->ref(); 145 data->ref();
116} 146}
117OPimAlarm::~OPimAlarm() { 147OPimAlarm::~OPimAlarm() {
118 if ( data->deref() ) { 148 if ( data->deref() ) {
119 delete data; 149 delete data;
120 data = 0l; 150 data = 0l;
121 } 151 }
122} 152}
123OPimAlarm &OPimAlarm::operator=( const OPimAlarm& al) 153OPimAlarm &OPimAlarm::operator=( const OPimAlarm& al)
124{ 154{
125 OPimNotify::operator=( al ); 155 OPimNotify::operator=( al );
126 deref(); 156 deref();
127 al.data->ref(); 157 al.data->ref();
128 158
129 data = al.data; 159 data = al.data;
130 160
131 161
132 return *this; 162 return *this;
133} 163}
134bool OPimAlarm::operator==( const OPimAlarm& al) { 164bool OPimAlarm::operator==( const OPimAlarm& al) {
135 if ( data->sound != al.data->sound ) return false; 165 if ( data->sound != al.data->sound ) return false;
136 else if ( data->sound == Custom && data->file != al.data->file ) 166 else if ( data->sound == Custom && data->file != al.data->file )
137 return false; 167 return false;
138 168
139 return OPimNotify::operator==( al ); 169 return OPimNotify::operator==( al );
140} 170}
141QString OPimAlarm::type()const { 171QString OPimAlarm::type()const {
142 return QString::fromLatin1("OPimAlarm"); 172 return QString::fromLatin1("OPimAlarm");
143} 173}
144int OPimAlarm::sound()const { 174int OPimAlarm::sound()const {
145 return data->sound; 175 return data->sound;
146} 176}
147QString OPimAlarm::file()const { 177QString OPimAlarm::file()const {
148 return data->file; 178 return data->file;
149} 179}
150void OPimAlarm::setSound( int snd) { 180void OPimAlarm::setSound( int snd) {
151 copyIntern(); 181 copyIntern();
152 data->sound = snd; 182 data->sound = snd;
153} 183}
154void OPimAlarm::setFile( const QString& sound ) { 184void OPimAlarm::setFile( const QString& sound ) {
155 copyIntern(); 185 copyIntern();
156 data->file = sound; 186 data->file = sound;
157} 187}
158void OPimAlarm::deref() { 188void OPimAlarm::deref() {
159 if ( data->deref() ) { 189 if ( data->deref() ) {
160 delete data; 190 delete data;
161 data = 0l; 191 data = 0l;
162 } 192 }
163} 193}
164void OPimAlarm::copyIntern() { 194void OPimAlarm::copyIntern() {
165 if ( data->count != 1 ) { 195 if ( data->count != 1 ) {
166 data->deref(); 196 data->deref();
167 Data *newDat = new Data; 197 Data *newDat = new Data;
168 newDat->sound = data->sound; 198 newDat->sound = data->sound;
169 newDat->file = data->file; 199 newDat->file = data->file;
170 data = newDat; 200 data = newDat;
171 } 201 }
172} 202}
173/************************/ 203/************************/
174struct OPimReminder::Data : public QShared { 204struct OPimReminder::Data : public QShared {
175 Data() : QShared(), record( 0) { 205 Data() : QShared(), record( 0) {
176 } 206 }
177 int record; 207 int record;
178 208
179}; 209};
180OPimReminder::OPimReminder( int uid, const QDateTime& start, int dur, int parent ) 210OPimReminder::OPimReminder( int uid, const QDateTime& start, int dur, int parent )
181 : OPimNotify( start, dur, parent ) 211 : OPimNotify( start, dur, parent )
182{ 212{
183 data = new Data; 213 data = new Data;
184 data->record = uid; 214 data->record = uid;
185} 215}
186OPimReminder::OPimReminder( const OPimReminder& rem ) 216OPimReminder::OPimReminder( const OPimReminder& rem )
187 : OPimNotify( rem ), data( rem.data ) 217 : OPimNotify( rem ), data( rem.data )
188{ 218{
189 data->ref(); 219 data->ref();
190} 220}
191OPimReminder& OPimReminder::operator=( const OPimReminder& rem) { 221OPimReminder& OPimReminder::operator=( const OPimReminder& rem) {
192 OPimNotify::operator=(rem ); 222 OPimNotify::operator=(rem );
193 223
194 deref(); 224 deref();
195 rem.data->ref(); 225 rem.data->ref();
196 data = rem.data; 226 data = rem.data;
197 227
198 return *this; 228 return *this;
199} 229}
200bool OPimReminder::operator==( const OPimReminder& rem) { 230bool OPimReminder::operator==( const OPimReminder& rem) {
201 if ( data->record != rem.data->record ) return false; 231 if ( data->record != rem.data->record ) return false;
202 232
203 return OPimNotify::operator==( rem ); 233 return OPimNotify::operator==( rem );
204} 234}
205QString OPimReminder::type()const { 235QString OPimReminder::type()const {
206 return QString::fromLatin1("OPimReminder"); 236 return QString::fromLatin1("OPimReminder");
207} 237}
208int OPimReminder::recordUid()const { 238int OPimReminder::recordUid()const {
209 return data->record; 239 return data->record;
210} 240}
211void OPimReminder::setRecordUid( int uid ) { 241void OPimReminder::setRecordUid( int uid ) {
212 copyIntern(); 242 copyIntern();
213 data->record = uid; 243 data->record = uid;
214} 244}
215void OPimReminder::deref() { 245void OPimReminder::deref() {
216 if ( data->deref() ) { 246 if ( data->deref() ) {
217 delete data; 247 delete data;
218 data = 0l; 248 data = 0l;
219 } 249 }
220} 250}
221void OPimReminder::copyIntern() { 251void OPimReminder::copyIntern() {
222 if ( data->count != 1 ) { 252 if ( data->count != 1 ) {
223 Data* da = new Data; 253 Data* da = new Data;
224 da->record = data->record; 254 da->record = data->record;
225 data = da; 255 data = da;
226 } 256 }
227} 257}
258}
diff --git a/libopie2/opiepim/core/opimnotify.h b/libopie2/opiepim/core/opimnotify.h
index 58417db..fed3970 100644
--- a/libopie2/opiepim/core/opimnotify.h
+++ b/libopie2/opiepim/core/opimnotify.h
@@ -1,144 +1,176 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_NOTIFY_H 29#ifndef OPIE_PIM_NOTIFY_H
2#define OPIE_PIM_NOTIFY_H 30#define OPIE_PIM_NOTIFY_H
3 31
4#include <qdatetime.h> 32#include <qdatetime.h>
5#include <qvaluelist.h> 33#include <qvaluelist.h>
6 34
35
36namespace Opie {
7/** 37/**
8 * This is the base class of Notifiers. Possible 38 * This is the base class of Notifiers. Possible
9 * notifiers would be Alarms, Reminders 39 * notifiers would be Alarms, Reminders
10 * What they share is that they have 40 * What they share is that they have
11 * A DateTime, Type, Duration 41 * A DateTime, Type, Duration
12 * This is what this base class takes care of 42 * This is what this base class takes care of
13 * on top of that it's shared 43 * on top of that it's shared
14 */ 44 */
15/* 45/*
16 * TALK to eilers: have a class OPimDuration which sets the Duration 46 * TALK to eilers: have a class OPimDuration which sets the Duration
17 * given on the Due/Start Date? -zecke 47 * given on the Due/Start Date? -zecke
18 * discuss: do we need a uid for the notify? -zecke 48 * discuss: do we need a uid for the notify? -zecke
19 */ 49 */
20class OPimNotify { 50class OPimNotify {
21public: 51public:
22 typedef QValueList<OPimNotify> ValueList; 52 typedef QValueList<OPimNotify> ValueList;
23 OPimNotify( const QDateTime& start = QDateTime(), int duration = 0, int parent = 0 ); 53 OPimNotify( const QDateTime& start = QDateTime(), int duration = 0, int parent = 0 );
24 OPimNotify( const OPimNotify& ); 54 OPimNotify( const OPimNotify& );
25 virtual ~OPimNotify(); 55 virtual ~OPimNotify();
26 56
27 OPimNotify &operator=(const OPimNotify& ); 57 OPimNotify &operator=(const OPimNotify& );
28 bool operator==( const OPimNotify& ); 58 bool operator==( const OPimNotify& );
29 59
30 virtual QString type()const = 0; 60 virtual QString type()const = 0;
31 61
32 /** start date */ 62 /** start date */
33 QDateTime dateTime()const; 63 QDateTime dateTime()const;
34 QString service()const; 64 QString service()const;
35 65
36 /** 66 /**
37 * RETURN the parent uid 67 * RETURN the parent uid
38 */ 68 */
39 int parent()const; 69 int parent()const;
40 70
41 /** 71 /**
42 * in Seconds 72 * in Seconds
43 */ 73 */
44 int duration()const; 74 int duration()const;
45 75
46 /** 76 /**
47 * Start Time + Duration 77 * Start Time + Duration
48 */ 78 */
49 QDateTime endTime()const; 79 QDateTime endTime()const;
50 80
51 void setDateTime( const QDateTime& ); 81 void setDateTime( const QDateTime& );
52 void setDuration( int dur ); 82 void setDuration( int dur );
53 void setParent(int uid ); 83 void setParent(int uid );
54 void setService( const QString& ); 84 void setService( const QString& );
55 85
56 86
57private: 87private:
58 inline void copyIntern(); 88 inline void copyIntern();
59 void deref(); 89 void deref();
60 struct Data; 90 struct Data;
61 Data* data; 91 Data* data;
62 92
63 /* d-pointer */ 93 /* d-pointer */
64 class NotifyPrivate; 94 class NotifyPrivate;
65 NotifyPrivate* d; 95 NotifyPrivate* d;
66 96
67}; 97};
68/** 98/**
69 * An alarm is a sound/mail/buzzer played/send 99 * An alarm is a sound/mail/buzzer played/send
70 * at a given time to inform about 100 * at a given time to inform about
71 * an Event 101 * an Event
72 */ 102 */
73class OPimAlarm : public OPimNotify { 103class OPimAlarm : public OPimNotify {
74public: 104public:
75 enum Sound{Loud=1, Silent=0, Custom=2 }; 105 enum Sound{Loud=1, Silent=0, Custom=2 };
76 OPimAlarm( int sound = Silent, const QDateTime& start = QDateTime(), int duration = 0, int parent = 0 ); 106 OPimAlarm( int sound = Silent, const QDateTime& start = QDateTime(), int duration = 0, int parent = 0 );
77 OPimAlarm( const OPimAlarm& ); 107 OPimAlarm( const OPimAlarm& );
78 ~OPimAlarm(); 108 ~OPimAlarm();
79 109
80 OPimAlarm &operator=( const OPimAlarm& ); 110 OPimAlarm &operator=( const OPimAlarm& );
81 bool operator==( const OPimAlarm& ); 111 bool operator==( const OPimAlarm& );
82 QString type()const; 112 QString type()const;
83 113
84 int sound()const; 114 int sound()const;
85 QString file()const; 115 QString file()const;
86 116
87 void setSound( int ); 117 void setSound( int );
88 /* only when sound is custom... */ 118 /* only when sound is custom... */
89 void setFile( const QString& sound ); 119 void setFile( const QString& sound );
90 120
91private: 121private:
92 void deref(); 122 void deref();
93 void copyIntern(); 123 void copyIntern();
94 struct Data; 124 struct Data;
95 Data * data; 125 Data * data;
96 126
97 class Private; 127 class Private;
98 Private* d; 128 Private* d;
99 129
100}; 130};
101 131
102/** 132/**
103 * A Reminder will be put into the 133 * A Reminder will be put into the
104 * datebook 134 * datebook
105 * Note that the returned dateTime() may be not valid. 135 * Note that the returned dateTime() may be not valid.
106 * In these cases one must resolve the uid and get the OEvent 136 * In these cases one must resolve the uid and get the OEvent
107 */ 137 */
108class OPimReminder : public OPimNotify { 138class OPimReminder : public OPimNotify {
109public: 139public:
110 140
111 /** 141 /**
112 * c'tor of a reminder 142 * c'tor of a reminder
113 * @param uid The uid of the Record inside the Datebook 143 * @param uid The uid of the Record inside the Datebook
114 * @param start the StartDate invalid for all day... 144 * @param start the StartDate invalid for all day...
115 * @param duration The duration of the event ( -1 for all day ) 145 * @param duration The duration of the event ( -1 for all day )
116 * @param parent The 'parent' record of this reminder 146 * @param parent The 'parent' record of this reminder
117 */ 147 */
118 OPimReminder( int uid = 0, const QDateTime& start = QDateTime(), 148 OPimReminder( int uid = 0, const QDateTime& start = QDateTime(),
119 int duration = 0, int parent = 0 ); 149 int duration = 0, int parent = 0 );
120 OPimReminder( const OPimReminder& ); 150 OPimReminder( const OPimReminder& );
121 OPimReminder &operator=(const OPimReminder& ); 151 OPimReminder &operator=(const OPimReminder& );
122 152
123 QString type()const; 153 QString type()const;
124 154
125 bool operator==( const OPimReminder& ); 155 bool operator==( const OPimReminder& );
126 156
127 /** 157 /**
128 * the uid of the alarm 158 * the uid of the alarm
129 * inside the 'datebook' application 159 * inside the 'datebook' application
130 */ 160 */
131 int recordUid()const; 161 int recordUid()const;
132 void setRecordUid( int uid ); 162 void setRecordUid( int uid );
133 163
134private: 164private:
135 void deref(); 165 void deref();
136 void copyIntern(); 166 void copyIntern();
137 167
138 struct Data; 168 struct Data;
139 Data* data; 169 Data* data;
140 class Private; 170 class Private;
141 Private *d; 171 Private *d;
142}; 172};
143 173
174}
175
144#endif 176#endif
diff --git a/libopie2/opiepim/core/opimnotifymanager.cpp b/libopie2/opiepim/core/opimnotifymanager.cpp
index d6f0ead..1771fad 100644
--- a/libopie2/opiepim/core/opimnotifymanager.cpp
+++ b/libopie2/opiepim/core/opimnotifymanager.cpp
@@ -1,162 +1,193 @@
1#include "opimnotifymanager.h" 1/*
2 2 This file is part of the Opie Project
3#include "oconversion.h" 3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29#include <opie2/opimnotifymanager.h>
30
31#include <opie2/oconversion.h>
4 32
5#include <qstringlist.h> 33#include <qstringlist.h>
6 34
35namespace Opie {
36
7OPimNotifyManager::OPimNotifyManager( const Reminders& rem, const Alarms& al) 37OPimNotifyManager::OPimNotifyManager( const Reminders& rem, const Alarms& al)
8 : m_rem( rem ), m_al( al ) 38 : m_rem( rem ), m_al( al )
9{} 39{}
10OPimNotifyManager::~OPimNotifyManager() { 40OPimNotifyManager::~OPimNotifyManager() {
11} 41}
12/* use static_cast and type instead of dynamic... */ 42/* use static_cast and type instead of dynamic... */
13void OPimNotifyManager::add( const OPimNotify& noti) { 43void OPimNotifyManager::add( const OPimNotify& noti) {
14 if ( noti.type() == QString::fromLatin1("OPimReminder") ) { 44 if ( noti.type() == QString::fromLatin1("OPimReminder") ) {
15 const OPimReminder& rem = static_cast<const OPimReminder&>(noti); 45 const OPimReminder& rem = static_cast<const OPimReminder&>(noti);
16 m_rem.append( rem ); 46 m_rem.append( rem );
17 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) { 47 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) {
18 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti); 48 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti);
19 m_al.append( al ); 49 m_al.append( al );
20 } 50 }
21} 51}
22void OPimNotifyManager::remove( const OPimNotify& noti) { 52void OPimNotifyManager::remove( const OPimNotify& noti) {
23 if ( noti.type() == QString::fromLatin1("OPimReminder") ) { 53 if ( noti.type() == QString::fromLatin1("OPimReminder") ) {
24 const OPimReminder& rem = static_cast<const OPimReminder&>(noti); 54 const OPimReminder& rem = static_cast<const OPimReminder&>(noti);
25 m_rem.remove( rem ); 55 m_rem.remove( rem );
26 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) { 56 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) {
27 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti); 57 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti);
28 m_al.remove( al ); 58 m_al.remove( al );
29 } 59 }
30} 60}
31void OPimNotifyManager::replace( const OPimNotify& noti) { 61void OPimNotifyManager::replace( const OPimNotify& noti) {
32 if ( noti.type() == QString::fromLatin1("OPimReminder") ) { 62 if ( noti.type() == QString::fromLatin1("OPimReminder") ) {
33 const OPimReminder& rem = static_cast<const OPimReminder&>(noti); 63 const OPimReminder& rem = static_cast<const OPimReminder&>(noti);
34 m_rem.remove( rem ); 64 m_rem.remove( rem );
35 m_rem.append( rem ); 65 m_rem.append( rem );
36 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) { 66 }else if ( noti.type() == QString::fromLatin1("OPimAlarm") ) {
37 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti); 67 const OPimAlarm& al = static_cast<const OPimAlarm&>(noti);
38 m_al.remove( al ); 68 m_al.remove( al );
39 m_al.append( al ); 69 m_al.append( al );
40 } 70 }
41} 71}
42OPimNotifyManager::Reminders OPimNotifyManager::reminders()const { 72OPimNotifyManager::Reminders OPimNotifyManager::reminders()const {
43 return m_rem; 73 return m_rem;
44} 74}
45OPimNotifyManager::Alarms OPimNotifyManager::alarms()const { 75OPimNotifyManager::Alarms OPimNotifyManager::alarms()const {
46 return m_al; 76 return m_al;
47} 77}
48OPimAlarm OPimNotifyManager::alarmAtDateTime( const QDateTime& when, bool& found ) const { 78OPimAlarm OPimNotifyManager::alarmAtDateTime( const QDateTime& when, bool& found ) const {
49 Alarms::ConstIterator it; 79 Alarms::ConstIterator it;
50 found = true; 80 found = true;
51 81
52 for ( it = m_al.begin(); it != m_al.end(); ++it ){ 82 for ( it = m_al.begin(); it != m_al.end(); ++it ){
53 if ( (*it).dateTime() == when ) 83 if ( (*it).dateTime() == when )
54 return (*it); 84 return (*it);
55 } 85 }
56 86
57 // Fall through if nothing could be found 87 // Fall through if nothing could be found
58 found = false; 88 found = false;
59 OPimAlarm empty; 89 OPimAlarm empty;
60 return empty; 90 return empty;
61} 91}
62 92
63 93
64void OPimNotifyManager::setAlarms( const Alarms& al) { 94void OPimNotifyManager::setAlarms( const Alarms& al) {
65 m_al = al; 95 m_al = al;
66} 96}
67void OPimNotifyManager::setReminders( const Reminders& rem) { 97void OPimNotifyManager::setReminders( const Reminders& rem) {
68 m_rem = rem; 98 m_rem = rem;
69} 99}
70/* FIXME!!! */ 100/* FIXME!!! */
71/** 101/**
72 * The idea is to check if the provider for our service 102 * The idea is to check if the provider for our service
73 * is online 103 * is online
74 * if it is we will use QCOP 104 * if it is we will use QCOP
75 * if not the Factory to get the backend... 105 * if not the Factory to get the backend...
76 * Qtopia1.6 services would be kewl to have here.... 106 * Qtopia1.6 services would be kewl to have here....
77 */ 107 */
78void OPimNotifyManager::registerNotify( const OPimNotify& ) { 108void OPimNotifyManager::registerNotify( const OPimNotify& ) {
79 109
80} 110}
81/* FIXME!!! */ 111/* FIXME!!! */
82/** 112/**
83 * same as above... 113 * same as above...
84 * Also implement Url model 114 * Also implement Url model
85 * have a MainWindow.... 115 * have a MainWindow....
86 */ 116 */
87void OPimNotifyManager::deregister( const OPimNotify& ) { 117void OPimNotifyManager::deregister( const OPimNotify& ) {
88 118
89} 119}
90 120
91bool OPimNotifyManager::isEmpty()const { 121bool OPimNotifyManager::isEmpty()const {
92 qWarning("is Empty called on OPimNotifyManager %d %d", m_rem.count(), m_al.count() ); 122 qWarning("is Empty called on OPimNotifyManager %d %d", m_rem.count(), m_al.count() );
93 if ( m_rem.isEmpty() && m_al.isEmpty() ) return true; 123 if ( m_rem.isEmpty() && m_al.isEmpty() ) return true;
94 else return false; 124 else return false;
95} 125}
96 126
97// Taken from otodoaccessxml.. 127// Taken from otodoaccessxml..
98QString OPimNotifyManager::alarmsToString() const 128QString OPimNotifyManager::alarmsToString() const
99{ 129{
100 QString str; 130 QString str;
101 131
102 OPimNotifyManager::Alarms alarms = m_al; 132 OPimNotifyManager::Alarms alarms = m_al;
103 if ( !alarms.isEmpty() ) { 133 if ( !alarms.isEmpty() ) {
104 QStringList als; 134 QStringList als;
105 OPimNotifyManager::Alarms::Iterator it = alarms.begin(); 135 OPimNotifyManager::Alarms::Iterator it = alarms.begin();
106 for ( ; it != alarms.end(); ++it ) { 136 for ( ; it != alarms.end(); ++it ) {
107 /* only if time is valid */ 137 /* only if time is valid */
108 if ( (*it).dateTime().isValid() ) { 138 if ( (*it).dateTime().isValid() ) {
109 als << OConversion::dateTimeToString( (*it).dateTime() ) 139 als << OConversion::dateTimeToString( (*it).dateTime() )
110 + ":" + QString::number( (*it).duration() ) 140 + ":" + QString::number( (*it).duration() )
111 + ":" + QString::number( (*it).sound() ) 141 + ":" + QString::number( (*it).sound() )
112 + ":"; 142 + ":";
113 } 143 }
114 } 144 }
115 // now write the list 145 // now write the list
116 qWarning("als: %s", als.join("____________").latin1() ); 146 qWarning("als: %s", als.join("____________").latin1() );
117 str = als.join(";"); 147 str = als.join(";");
118 } 148 }
119 149
120 return str; 150 return str;
121} 151}
122QString OPimNotifyManager::remindersToString() const 152QString OPimNotifyManager::remindersToString() const
123{ 153{
124 QString str; 154 QString str;
125 155
126 OPimNotifyManager::Reminders reminders = m_rem; 156 OPimNotifyManager::Reminders reminders = m_rem;
127 if (!reminders.isEmpty() ) { 157 if (!reminders.isEmpty() ) {
128 OPimNotifyManager::Reminders::Iterator it = reminders.begin(); 158 OPimNotifyManager::Reminders::Iterator it = reminders.begin();
129 QStringList records; 159 QStringList records;
130 for ( ; it != reminders.end(); ++it ) { 160 for ( ; it != reminders.end(); ++it ) {
131 records << QString::number( (*it).recordUid() ); 161 records << QString::number( (*it).recordUid() );
132 } 162 }
133 str = records.join(";"); 163 str = records.join(";");
134 } 164 }
135 165
136 return str; 166 return str;
137} 167}
138 168
139void OPimNotifyManager::alarmsFromString( const QString& str ) 169void OPimNotifyManager::alarmsFromString( const QString& str )
140{ 170{
141 QStringList als = QStringList::split(";", str ); 171 QStringList als = QStringList::split(";", str );
142 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) { 172 for (QStringList::Iterator it = als.begin(); it != als.end(); ++it ) {
143 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty 173 QStringList alarm = QStringList::split(":", (*it), TRUE ); // allow empty
144 qWarning("alarm: %s", alarm.join("___").latin1() ); 174 qWarning("alarm: %s", alarm.join("___").latin1() );
145 qWarning("alarm[0]: %s %s", alarm[0].latin1(), 175 qWarning("alarm[0]: %s %s", alarm[0].latin1(),
146 OConversion::dateTimeFromString( alarm[0] ).toString().latin1() ); 176 OConversion::dateTimeFromString( alarm[0] ).toString().latin1() );
147 OPimAlarm al( alarm[2].toInt(), OConversion::dateTimeFromString( alarm[0] ), 177 OPimAlarm al( alarm[2].toInt(), OConversion::dateTimeFromString( alarm[0] ),
148 alarm[1].toInt() ); 178 alarm[1].toInt() );
149 add( al ); 179 add( al );
150 } 180 }
151} 181}
152 182
153void OPimNotifyManager::remindersFromString( const QString& str ) 183void OPimNotifyManager::remindersFromString( const QString& str )
154{ 184{
155 185
156 QStringList rems = QStringList::split(";", str ); 186 QStringList rems = QStringList::split(";", str );
157 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) { 187 for (QStringList::Iterator it = rems.begin(); it != rems.end(); ++it ) {
158 OPimReminder rem( (*it).toInt() ); 188 OPimReminder rem( (*it).toInt() );
159 add( rem ); 189 add( rem );
160 } 190 }
161 191
162} 192}
193}
diff --git a/libopie2/opiepim/core/opimnotifymanager.h b/libopie2/opiepim/core/opimnotifymanager.h
index f3c22f9..0272e5d 100644
--- a/libopie2/opiepim/core/opimnotifymanager.h
+++ b/libopie2/opiepim/core/opimnotifymanager.h
@@ -1,91 +1,122 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_NOTIFY_MANAGER_H 29#ifndef OPIE_PIM_NOTIFY_MANAGER_H
2#define OPIE_PIM_NOTIFY_MANAGER_H 30#define OPIE_PIM_NOTIFY_MANAGER_H
3 31
4#include <qvaluelist.h> 32#include <qvaluelist.h>
5 33
6#include <opie/opimnotify.h> 34#include <opie2/opimnotify.h>
7 35
36namespace Opie {
8/** 37/**
9 * The notify manager keeps track of the Notifiers.... 38 * The notify manager keeps track of the Notifiers....
10 */ 39 */
11class OPimNotifyManager { 40class OPimNotifyManager {
12public: 41public:
13 typedef QValueList<OPimReminder> Reminders; 42 typedef QValueList<OPimReminder> Reminders;
14 typedef QValueList<OPimAlarm> Alarms; 43 typedef QValueList<OPimAlarm> Alarms;
15 OPimNotifyManager( const Reminders& rems = Reminders(), const Alarms& alarms = Alarms() ); 44 OPimNotifyManager( const Reminders& rems = Reminders(), const Alarms& alarms = Alarms() );
16 ~OPimNotifyManager(); 45 ~OPimNotifyManager();
17 46
18 /* we will cast it for you ;) */ 47 /* we will cast it for you ;) */
19 void add( const OPimNotify& ); 48 void add( const OPimNotify& );
20 void remove( const OPimNotify& ); 49 void remove( const OPimNotify& );
21 /* replaces all with this one! */ 50 /* replaces all with this one! */
22 void replace( const OPimNotify& ); 51 void replace( const OPimNotify& );
23 52
24 Reminders reminders()const; 53 Reminders reminders()const;
25 54
26 /** 55 /**
27 * Return 56 * Return
28 */ 57 */
29 Alarms alarms()const; 58 Alarms alarms()const;
30 59
31 /** 60 /**
32 * Return alarm at DateTime "when". If more than one is registered at this 61 * Return alarm at DateTime "when". If more than one is registered at this
33 * DateTime, the first one is returned. 62 * DateTime, the first one is returned.
34 * If none was found, an empty Alarm is returned. 63 * If none was found, an empty Alarm is returned.
35 * @param when The date and time of the returned alarm 64 * @param when The date and time of the returned alarm
36 * @param found Returns true if anything was found. 65 * @param found Returns true if anything was found.
37 * @return Returns the found alarm at given DateTime. It is empty if found is false 66 * @return Returns the found alarm at given DateTime. It is empty if found is false
38 * (nothing could be found at given date and time) 67 * (nothing could be found at given date and time)
39 */ 68 */
40 OPimAlarm alarmAtDateTime( const QDateTime& when, bool& found ) const; 69 OPimAlarm alarmAtDateTime( const QDateTime& when, bool& found ) const;
41 70
42 void setAlarms( const Alarms& ); 71 void setAlarms( const Alarms& );
43 void setReminders( const Reminders& ); 72 void setReminders( const Reminders& );
44 73
45 /* register is a Ansi C keyword... */ 74 /* register is a Ansi C keyword... */
46 /** 75 /**
47 * This function will register the Notify to the Alarm Server 76 * This function will register the Notify to the Alarm Server
48 * or datebook depending on the type of the notify 77 * or datebook depending on the type of the notify
49 */ 78 */
50 void registerNotify( const OPimNotify& ); 79 void registerNotify( const OPimNotify& );
51 80
52 /** 81 /**
53 * this will do the opposite.. 82 * this will do the opposite..
54 */ 83 */
55 void deregister( const OPimNotify& ); 84 void deregister( const OPimNotify& );
56 85
57 bool isEmpty()const; 86 bool isEmpty()const;
58 87
59 /** 88 /**
60 * Return all alarms as string 89 * Return all alarms as string
61 */ 90 */
62 QString alarmsToString() const; 91 QString alarmsToString() const;
63 /** 92 /**
64 * Return all notifiers as string 93 * Return all notifiers as string
65 */ 94 */
66 QString remindersToString() const; 95 QString remindersToString() const;
67 96
68 /** 97 /**
69 * Convert string to alarms 98 * Convert string to alarms
70 * @param str String created by alarmsToString() 99 * @param str String created by alarmsToString()
71 */ 100 */
72 void alarmsFromString( const QString& str ); 101 void alarmsFromString( const QString& str );
73 102
74 /** 103 /**
75 * Convert string to reminders 104 * Convert string to reminders
76 * @param str String created by remindersToString() 105 * @param str String created by remindersToString()
77 */ 106 */
78 void remindersFromString( const QString& str ); 107 void remindersFromString( const QString& str );
79 108
80 109
81 110
82private: 111private:
83 Reminders m_rem; 112 Reminders m_rem;
84 Alarms m_al; 113 Alarms m_al;
85 114
86 class Private; 115 class Private;
87 Private *d; 116 Private *d;
88 117
89}; 118};
90 119
120}
121
91#endif 122#endif
diff --git a/libopie2/opiepim/core/opimrecord.cpp b/libopie2/opiepim/core/opimrecord.cpp
index 2365748..72bb372 100644
--- a/libopie2/opiepim/core/opimrecord.cpp
+++ b/libopie2/opiepim/core/opimrecord.cpp
@@ -1,182 +1,213 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qarray.h> 29#include <qarray.h>
2 30
3#include <qpe/categories.h> 31#include <qpe/categories.h>
4#include <qpe/categoryselect.h> 32#include <qpe/categoryselect.h>
5 33
6#include "opimrecord.h" 34#include <opie2/opimrecord.h>
7 35
36namespace Opie {
8Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); 37Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia );
9 38
10 39
11OPimRecord::OPimRecord( int uid ) 40OPimRecord::OPimRecord( int uid )
12 : Qtopia::Record() { 41 : Qtopia::Record() {
13 42
14 m_lastHit = -1; 43 m_lastHit = -1;
15 setUid( uid ); 44 setUid( uid );
16} 45}
17OPimRecord::~OPimRecord() { 46OPimRecord::~OPimRecord() {
18} 47}
19OPimRecord::OPimRecord( const OPimRecord& rec ) 48OPimRecord::OPimRecord( const OPimRecord& rec )
20 : Qtopia::Record( rec ) 49 : Qtopia::Record( rec )
21{ 50{
22 (*this) = rec; 51 (*this) = rec;
23} 52}
24 53
25OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { 54OPimRecord &OPimRecord::operator=( const OPimRecord& rec) {
26 if ( this == &rec ) return *this; 55 if ( this == &rec ) return *this;
27 56
28 Qtopia::Record::operator=( rec ); 57 Qtopia::Record::operator=( rec );
29 m_xrefman = rec.m_xrefman; 58 m_xrefman = rec.m_xrefman;
30 m_lastHit = rec.m_lastHit; 59 m_lastHit = rec.m_lastHit;
31 60
32 return *this; 61 return *this;
33} 62}
34/* 63/*
35 * category names 64 * category names
36 */ 65 */
37QStringList OPimRecord::categoryNames( const QString& appname ) const { 66QStringList OPimRecord::categoryNames( const QString& appname ) const {
38 QStringList list; 67 QStringList list;
39 QArray<int> cats = categories(); 68 QArray<int> cats = categories();
40 Categories catDB; 69 Categories catDB;
41 catDB.load( categoryFileName() ); 70 catDB.load( categoryFileName() );
42 71
43 for (uint i = 0; i < cats.count(); i++ ) { 72 for (uint i = 0; i < cats.count(); i++ ) {
44 list << catDB.label( appname, cats[i] ); 73 list << catDB.label( appname, cats[i] );
45 } 74 }
46 75
47 return list; 76 return list;
48} 77}
49void OPimRecord::setCategoryNames( const QStringList& ) { 78void OPimRecord::setCategoryNames( const QStringList& ) {
50 79
51} 80}
52void OPimRecord::addCategoryName( const QString& ) { 81void OPimRecord::addCategoryName( const QString& ) {
53 Categories catDB; 82 Categories catDB;
54 catDB.load( categoryFileName() ); 83 catDB.load( categoryFileName() );
55 84
56 85
57} 86}
58bool OPimRecord::isEmpty()const { 87bool OPimRecord::isEmpty()const {
59 return ( uid() == 0 ); 88 return ( uid() == 0 );
60} 89}
61/*QString OPimRecord::crossToString()const { 90/*QString OPimRecord::crossToString()const {
62 QString str; 91 QString str;
63 QMap<QString, QArray<int> >::ConstIterator it; 92 QMap<QString, QArray<int> >::ConstIterator it;
64 for (it = m_relations.begin(); it != m_relations.end(); ++it ) { 93 for (it = m_relations.begin(); it != m_relations.end(); ++it ) {
65 QArray<int> id = it.data(); 94 QArray<int> id = it.data();
66 for ( uint i = 0; i < id.size(); ++i ) { 95 for ( uint i = 0; i < id.size(); ++i ) {
67 str += it.key() + "," + QString::number( i ) + ";"; 96 str += it.key() + "," + QString::number( i ) + ";";
68 } 97 }
69 } 98 }
70 str = str.remove( str.length()-1, 1); // strip the ; 99 str = str.remove( str.length()-1, 1); // strip the ;
71 //qWarning("IDS " + str ); 100 //qWarning("IDS " + str );
72 101
73 return str; 102 return str;
74 }*/ 103 }*/
75/* if uid = 1 assign a new one */ 104/* if uid = 1 assign a new one */
76void OPimRecord::setUid( int uid ) { 105void OPimRecord::setUid( int uid ) {
77 if ( uid == 1) 106 if ( uid == 1)
78 uid = uidGen().generate(); 107 uid = uidGen().generate();
79 108
80 Qtopia::Record::setUid( uid ); 109 Qtopia::Record::setUid( uid );
81}; 110};
82Qtopia::UidGen &OPimRecord::uidGen() { 111Qtopia::UidGen &OPimRecord::uidGen() {
83 return m_uidGen; 112 return m_uidGen;
84} 113}
85OPimXRefManager &OPimRecord::xrefmanager() { 114OPimXRefManager &OPimRecord::xrefmanager() {
86 return m_xrefman; 115 return m_xrefman;
87} 116}
88int OPimRecord::rtti(){ 117int OPimRecord::rtti(){
89 return 0; 118 return 0;
90} 119}
91 120
92/** 121/**
93 * now let's put our data into the stream 122 * now let's put our data into the stream
94 */ 123 */
95/* 124/*
96 * First read UID 125 * First read UID
97 * Categories 126 * Categories
98 * XRef 127 * XRef
99 */ 128 */
100bool OPimRecord::loadFromStream( QDataStream& stream ) { 129bool OPimRecord::loadFromStream( QDataStream& stream ) {
101 int Int; 130 int Int;
102 uint UInt; 131 uint UInt;
103 stream >> Int; 132 stream >> Int;
104 setUid(Int); 133 setUid(Int);
105 134
106 /** Categories */ 135 /** Categories */
107 stream >> UInt; 136 stream >> UInt;
108 QArray<int> array(UInt); 137 QArray<int> array(UInt);
109 for (uint i = 0; i < UInt; i++ ) { 138 for (uint i = 0; i < UInt; i++ ) {
110 stream >> array[i]; 139 stream >> array[i];
111 } 140 }
112 setCategories( array ); 141 setCategories( array );
113 142
114 /* 143 /*
115 * now we do the X-Ref stuff 144 * now we do the X-Ref stuff
116 */ 145 */
117 OPimXRef xref; 146 OPimXRef xref;
118 stream >> UInt; 147 stream >> UInt;
119 for ( uint i = 0; i < UInt; i++ ) { 148 for ( uint i = 0; i < UInt; i++ ) {
120 xref.setPartner( OPimXRef::One, partner( stream ) ); 149 xref.setPartner( OPimXRef::One, partner( stream ) );
121 xref.setPartner( OPimXRef::Two, partner( stream ) ); 150 xref.setPartner( OPimXRef::Two, partner( stream ) );
122 m_xrefman.add( xref ); 151 m_xrefman.add( xref );
123 } 152 }
124 153
125 return true; 154 return true;
126} 155}
127bool OPimRecord::saveToStream( QDataStream& stream )const { 156bool OPimRecord::saveToStream( QDataStream& stream )const {
128 /** UIDs */ 157 /** UIDs */
129 158
130 stream << uid(); 159 stream << uid();
131 160
132 /** Categories */ 161 /** Categories */
133 stream << categories().count(); 162 stream << categories().count();
134 for ( uint i = 0; i < categories().count(); i++ ) { 163 for ( uint i = 0; i < categories().count(); i++ ) {
135 stream << categories()[i]; 164 stream << categories()[i];
136 } 165 }
137 166
138 /* 167 /*
139 * first the XRef count 168 * first the XRef count
140 * then the xrefs 169 * then the xrefs
141 */ 170 */
142 stream << m_xrefman.list().count(); 171 stream << m_xrefman.list().count();
143 for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); 172 for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin();
144 it != m_xrefman.list().end(); ++it ) { 173 it != m_xrefman.list().end(); ++it ) {
145 flush( (*it).partner( OPimXRef::One), stream ); 174 flush( (*it).partner( OPimXRef::One), stream );
146 flush( (*it).partner( OPimXRef::Two), stream ); 175 flush( (*it).partner( OPimXRef::Two), stream );
147 } 176 }
148 return true; 177 return true;
149} 178}
150void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ 179void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{
151 str << par.service(); 180 str << par.service();
152 str << par.uid(); 181 str << par.uid();
153 str << par.field(); 182 str << par.field();
154} 183}
155OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { 184OPimXRefPartner OPimRecord::partner( QDataStream& stream ) {
156 OPimXRefPartner par; 185 OPimXRefPartner par;
157 QString str; 186 QString str;
158 int i; 187 int i;
159 188
160 stream >> str; 189 stream >> str;
161 par.setService( str ); 190 par.setService( str );
162 191
163 stream >> i; 192 stream >> i;
164 par.setUid( i ); 193 par.setUid( i );
165 194
166 stream >> i ; 195 stream >> i ;
167 par.setField( i ); 196 par.setField( i );
168 197
169 return par; 198 return par;
170} 199}
171void OPimRecord::setLastHitField( int lastHit )const { 200void OPimRecord::setLastHitField( int lastHit )const {
172 m_lastHit = lastHit; 201 m_lastHit = lastHit;
173} 202}
174int OPimRecord::lastHitField()const{ 203int OPimRecord::lastHitField()const{
175 return m_lastHit; 204 return m_lastHit;
176} 205}
177QMap<QString, QString> OPimRecord::toExtraMap()const { 206QMap<QString, QString> OPimRecord::toExtraMap()const {
178 return customMap; 207 return customMap;
179} 208}
180void OPimRecord::setExtraMap( const QMap<QString, QString>& map) { 209void OPimRecord::setExtraMap( const QMap<QString, QString>& map) {
181 customMap = map; 210 customMap = map;
182} 211}
212
213}
diff --git a/libopie2/opiepim/core/opimrecord.h b/libopie2/opiepim/core/opimrecord.h
index 3d774e2..63a3a98 100644
--- a/libopie2/opiepim/core/opimrecord.h
+++ b/libopie2/opiepim/core/opimrecord.h
@@ -1,158 +1,187 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_RECORD_H 29#ifndef OPIE_PIM_RECORD_H
2#define OPIE_PIM_RECORD_H 30#define OPIE_PIM_RECORD_H
3 31
4#include <qdatastream.h> 32#include <qdatastream.h>
5#include <qmap.h> 33#include <qmap.h>
6#include <qstring.h> 34#include <qstring.h>
7#include <qstringlist.h> 35#include <qstringlist.h>
8 36
9/* 37/*
10 * we need to get customMap which is private... 38 * we need to get customMap which is private...
11 */ 39 */
12#define private protected 40#define private protected
13#include <qpe/palmtoprecord.h> 41#include <qpe/palmtoprecord.h>
14#undef private 42#undef private
15 43
16#include <opie/opimxrefmanager.h> 44#include <opie2/opimxrefmanager.h>
17 45
46namespace Opie {
18/** 47/**
19 * This is the base class for 48 * This is the base class for
20 * all PIM Records 49 * all PIM Records
21 * 50 *
22 */ 51 */
23class OPimRecord : public Qtopia::Record { 52class OPimRecord : public Qtopia::Record {
24public: 53public:
25 /** 54 /**
26 * c'tor 55 * c'tor
27 * uid of 0 isEmpty 56 * uid of 0 isEmpty
28 * uid of 1 will be assigned a new one 57 * uid of 1 will be assigned a new one
29 */ 58 */
30 OPimRecord(int uid = 0); 59 OPimRecord(int uid = 0);
31 ~OPimRecord(); 60 ~OPimRecord();
32 61
33 /** 62 /**
34 * copy c'tor 63 * copy c'tor
35 */ 64 */
36 OPimRecord( const OPimRecord& rec ); 65 OPimRecord( const OPimRecord& rec );
37 66
38 /** 67 /**
39 * copy operator 68 * copy operator
40 */ 69 */
41 OPimRecord &operator=( const OPimRecord& ); 70 OPimRecord &operator=( const OPimRecord& );
42 71
43 /** 72 /**
44 * category names resolved 73 * category names resolved
45 */ 74 */
46 QStringList categoryNames( const QString& appname )const; 75 QStringList categoryNames( const QString& appname )const;
47 76
48 /** 77 /**
49 * set category names they will be resolved 78 * set category names they will be resolved
50 */ 79 */
51 void setCategoryNames( const QStringList& ); 80 void setCategoryNames( const QStringList& );
52 81
53 /** 82 /**
54 * addCategoryName adds a name 83 * addCategoryName adds a name
55 * to the internal category list 84 * to the internal category list
56 */ 85 */
57 void addCategoryName( const QString& ); 86 void addCategoryName( const QString& );
58 87
59 /** 88 /**
60 * if a Record isEmpty 89 * if a Record isEmpty
61 * it's empty if it's 0 90 * it's empty if it's 0
62 */ 91 */
63 virtual bool isEmpty()const; 92 virtual bool isEmpty()const;
64 93
65 /** 94 /**
66 * toRichText summary 95 * toRichText summary
67 */ 96 */
68 virtual QString toRichText()const = 0; 97 virtual QString toRichText()const = 0;
69 98
70 /** 99 /**
71 * a small one line summary 100 * a small one line summary
72 */ 101 */
73 virtual QString toShortText()const = 0; 102 virtual QString toShortText()const = 0;
74 103
75 /** 104 /**
76 * the name of the Record 105 * the name of the Record
77 */ 106 */
78 virtual QString type()const = 0; 107 virtual QString type()const = 0;
79 108
80 /** 109 /**
81 * matches the Records the regular expression? 110 * matches the Records the regular expression?
82 */ 111 */
83 virtual bool match( const QString &regexp ) const 112 virtual bool match( const QString &regexp ) const
84 {setLastHitField( -1 ); 113 {setLastHitField( -1 );
85 return Qtopia::Record::match(QRegExp(regexp));}; 114 return Qtopia::Record::match(QRegExp(regexp));};
86 115
87 /** 116 /**
88 * if implemented this function returns which item has been 117 * if implemented this function returns which item has been
89 * last hit by the match() function. 118 * last hit by the match() function.
90 * or -1 if not implemented or no hit has occured 119 * or -1 if not implemented or no hit has occured
91 */ 120 */
92 int lastHitField()const; 121 int lastHitField()const;
93 122
94 /** 123 /**
95 * converts the internal structure to a map 124 * converts the internal structure to a map
96 */ 125 */
97 virtual QMap<int, QString> toMap()const = 0; 126 virtual QMap<int, QString> toMap()const = 0;
98 // virtual fromMap( const <int, QString>& map ) = 0; // Should be added in the future (eilers) 127 // virtual fromMap( const <int, QString>& map ) = 0; // Should be added in the future (eilers)
99 128
100 /** 129 /**
101 * key value representation of extra items 130 * key value representation of extra items
102 */ 131 */
103 QMap<QString, QString> toExtraMap()const; 132 QMap<QString, QString> toExtraMap()const;
104 void setExtraMap( const QMap<QString, QString>& ); 133 void setExtraMap( const QMap<QString, QString>& );
105 134
106 /** 135 /**
107 * the name for a recordField 136 * the name for a recordField
108 */ 137 */
109 virtual QString recordField(int)const = 0; 138 virtual QString recordField(int)const = 0;
110 139
111 /** 140 /**
112 * returns a reference of the 141 * returns a reference of the
113 * Cross Reference Manager 142 * Cross Reference Manager
114 * Partner 'One' is THIS PIM RECORD! 143 * Partner 'One' is THIS PIM RECORD!
115 * 'Two' is the Partner where we link to 144 * 'Two' is the Partner where we link to
116 */ 145 */
117 OPimXRefManager& xrefmanager(); 146 OPimXRefManager& xrefmanager();
118 147
119 /** 148 /**
120 * set the uid 149 * set the uid
121 */ 150 */
122 virtual void setUid( int uid ); 151 virtual void setUid( int uid );
123 152
124 /* 153 /*
125 * used inside the Templates for casting 154 * used inside the Templates for casting
126 * REIMPLEMENT in your .... 155 * REIMPLEMENT in your ....
127 */ 156 */
128 static int rtti(); 157 static int rtti();
129 158
130 /** 159 /**
131 * some marshalling and de marshalling code 160 * some marshalling and de marshalling code
132 * saves the OPimRecord 161 * saves the OPimRecord
133 * to and from a DataStream 162 * to and from a DataStream
134 */ 163 */
135 virtual bool loadFromStream(QDataStream& ); 164 virtual bool loadFromStream(QDataStream& );
136 virtual bool saveToStream( QDataStream& stream )const; 165 virtual bool saveToStream( QDataStream& stream )const;
137 166
138protected: 167protected:
139 // need to be const cause it is called from const methods 168 // need to be const cause it is called from const methods
140 mutable int m_lastHit; 169 mutable int m_lastHit;
141 void setLastHitField( int lastHit )const; 170 void setLastHitField( int lastHit )const;
142 Qtopia::UidGen &uidGen(); 171 Qtopia::UidGen &uidGen();
143// QString crossToString()const; 172// QString crossToString()const;
144 173
145private: 174private:
146 class OPimRecordPrivate; 175 class OPimRecordPrivate;
147 OPimRecordPrivate *d; 176 OPimRecordPrivate *d;
148 OPimXRefManager m_xrefman; 177 OPimXRefManager m_xrefman;
149 static Qtopia::UidGen m_uidGen; 178 static Qtopia::UidGen m_uidGen;
150 179
151private: 180private:
152 void flush( const OPimXRefPartner&, QDataStream& stream )const; 181 void flush( const OPimXRefPartner&, QDataStream& stream )const;
153 OPimXRefPartner partner( QDataStream& ); 182 OPimXRefPartner partner( QDataStream& );
154}; 183};
155 184
156 185}
157 186
158#endif 187#endif
diff --git a/libopie2/opiepim/core/opimresolver.cpp b/libopie2/opiepim/core/opimresolver.cpp
index 4ebbd6e..eceabcb 100644
--- a/libopie2/opiepim/core/opimresolver.cpp
+++ b/libopie2/opiepim/core/opimresolver.cpp
@@ -1,198 +1,230 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qcopchannel_qws.h> 29#include <qcopchannel_qws.h>
2 30
3#include <qpe/qcopenvelope_qws.h> 31#include <qpe/qcopenvelope_qws.h>
4 32
5#include "otodoaccess.h" 33#include <opie2/otodoaccess.h>
6#include "ocontactaccess.h" 34#include <opie2/ocontactaccess.h>
7 35
8//#include "opimfactory.h" 36//#include "opimfactory.h"
9#include "opimresolver.h" 37#include <opie2/opimresolver.h>
38
39namespace Opie {
10 40
11OPimResolver* OPimResolver::m_self = 0l; 41OPimResolver* OPimResolver::m_self = 0l;
12 42
13OPimResolver::OPimResolver() { 43OPimResolver::OPimResolver() {
14 /* the built in channels */ 44 /* the built in channels */
15 m_builtIns << "Todolist" << "Addressbook" << "Datebook"; 45 m_builtIns << "Todolist" << "Addressbook" << "Datebook";
16} 46}
17OPimResolver* OPimResolver::self() { 47OPimResolver* OPimResolver::self() {
18 if (!m_self) 48 if (!m_self)
19 m_self = new OPimResolver(); 49 m_self = new OPimResolver();
20 50
21 return m_self; 51 return m_self;
22} 52}
23 53
24/* 54/*
25 * FIXME use a cache here too 55 * FIXME use a cache here too
26 */ 56 */
27OPimRecord* OPimResolver::record( const QString& service, int uid ) { 57OPimRecord* OPimResolver::record( const QString& service, int uid ) {
28 OPimRecord* rec = 0l; 58 OPimRecord* rec = 0l;
29 OPimBase* base = backend( service ); 59 OPimBase* base = backend( service );
30 60
31 if ( base ) 61 if ( base )
32 rec = base->record( uid ); 62 rec = base->record( uid );
33 delete base; 63 delete base;
34 64
35 return rec; 65 return rec;
36} 66}
37OPimRecord* OPimResolver::record( const QString& service ) { 67OPimRecord* OPimResolver::record( const QString& service ) {
38 return record( serviceId( service ) ); 68 return record( serviceId( service ) );
39} 69}
40OPimRecord* OPimResolver::record( int rtti ) { 70OPimRecord* OPimResolver::record( int rtti ) {
41 OPimRecord* rec = 0l; 71 OPimRecord* rec = 0l;
42 switch( rtti ) { 72 switch( rtti ) {
43 case 1: /* todolist */ 73 case 1: /* todolist */
44 rec = new OTodo(); 74 rec = new OTodo();
45 case 2: /* contact */ 75 case 2: /* contact */
46 rec = new OContact(); 76 rec = new OContact();
47 default: 77 default:
48 break; 78 break;
49 } 79 }
50 /* 80 /*
51 * FIXME resolve externally 81 * FIXME resolve externally
52 */ 82 */
53 if (!rec ) { 83 if (!rec ) {
54 ; 84 ;
55 } 85 }
56 return 0l; 86 return 0l;
57} 87}
58bool OPimResolver::isBuiltIn( const QString& str) const{ 88bool OPimResolver::isBuiltIn( const QString& str) const{
59 return m_builtIns.contains( str ); 89 return m_builtIns.contains( str );
60} 90}
61QCString OPimResolver::qcopChannel( enum BuiltIn& built)const { 91QCString OPimResolver::qcopChannel( enum BuiltIn& built)const {
62 QCString str("QPE/"); 92 QCString str("QPE/");
63 switch( built ) { 93 switch( built ) {
64 case TodoList: 94 case TodoList:
65 str += "Todolist"; 95 str += "Todolist";
66 break; 96 break;
67 case DateBook: 97 case DateBook:
68 str += "Datebook"; 98 str += "Datebook";
69 break; 99 break;
70 case AddressBook: 100 case AddressBook:
71 str += "Addressbook"; 101 str += "Addressbook";
72 break; 102 break;
73 default: 103 default:
74 break; 104 break;
75 } 105 }
76 106
77 return str; 107 return str;
78} 108}
79QCString OPimResolver::qcopChannel( const QString& service )const { 109QCString OPimResolver::qcopChannel( const QString& service )const {
80 QCString str("QPE/"); 110 QCString str("QPE/");
81 str += service.latin1(); 111 str += service.latin1();
82 return str; 112 return str;
83} 113}
84/* 114/*
85 * Implement services!! 115 * Implement services!!
86 * FIXME 116 * FIXME
87 */ 117 */
88QCString OPimResolver::applicationChannel( enum BuiltIn& built)const { 118QCString OPimResolver::applicationChannel( enum BuiltIn& built)const {
89 QCString str("QPE/Application/"); 119 QCString str("QPE/Application/");
90 switch( built ) { 120 switch( built ) {
91 case TodoList: 121 case TodoList:
92 str += "todolist"; 122 str += "todolist";
93 break; 123 break;
94 case DateBook: 124 case DateBook:
95 str += "datebook"; 125 str += "datebook";
96 break; 126 break;
97 case AddressBook: 127 case AddressBook:
98 str += "addressbook"; 128 str += "addressbook";
99 break; 129 break;
100 } 130 }
101 131
102 return str; 132 return str;
103} 133}
104QCString OPimResolver::applicationChannel( const QString& service )const { 134QCString OPimResolver::applicationChannel( const QString& service )const {
105 QCString str("QPE/Application/"); 135 QCString str("QPE/Application/");
106 136
107 if ( isBuiltIn( service ) ) { 137 if ( isBuiltIn( service ) ) {
108 if ( service == "Todolist" ) 138 if ( service == "Todolist" )
109 str += "todolist"; 139 str += "todolist";
110 else if ( service == "Datebook" ) 140 else if ( service == "Datebook" )
111 str += "datebook"; 141 str += "datebook";
112 else if ( service == "Addressbook" ) 142 else if ( service == "Addressbook" )
113 str += "addressbook"; 143 str += "addressbook";
114 }else 144 }else
115 ; // FIXME for additional stuff 145 ; // FIXME for additional stuff
116 146
117 return str; 147 return str;
118} 148}
119QStringList OPimResolver::services()const { 149QStringList OPimResolver::services()const {
120 return m_builtIns; 150 return m_builtIns;
121} 151}
122QString OPimResolver::serviceName( int rtti ) const{ 152QString OPimResolver::serviceName( int rtti ) const{
123 QString str; 153 QString str;
124 switch ( rtti ) { 154 switch ( rtti ) {
125 case TodoList: 155 case TodoList:
126 str = "Todolist"; 156 str = "Todolist";
127 break; 157 break;
128 case DateBook: 158 case DateBook:
129 str = "Datebook"; 159 str = "Datebook";
130 break; 160 break;
131 case AddressBook: 161 case AddressBook:
132 str = "Addressbook"; 162 str = "Addressbook";
133 break; 163 break;
134 default: 164 default:
135 break; 165 break;
136 } 166 }
137 return str; 167 return str;
138 // FIXME me for 3rd party 168 // FIXME me for 3rd party
139} 169}
140int OPimResolver::serviceId( const QString& service ) { 170int OPimResolver::serviceId( const QString& service ) {
141 int rtti = 0; 171 int rtti = 0;
142 if ( service == "Todolist" ) 172 if ( service == "Todolist" )
143 rtti = TodoList; 173 rtti = TodoList;
144 else if ( service == "Datebook" ) 174 else if ( service == "Datebook" )
145 rtti = DateBook; 175 rtti = DateBook;
146 else if ( service == "Addressbook" ) 176 else if ( service == "Addressbook" )
147 rtti = AddressBook; 177 rtti = AddressBook;
148 178
149 return rtti; 179 return rtti;
150} 180}
151/** 181/**
152 * check if the 'service' is registered and if so we'll 182 * check if the 'service' is registered and if so we'll
153 */ 183 */
154bool OPimResolver::add( const QString& service, const OPimRecord& rec) { 184bool OPimResolver::add( const QString& service, const OPimRecord& rec) {
155 if ( QCopChannel::isRegistered( applicationChannel( service ) ) ) { 185 if ( QCopChannel::isRegistered( applicationChannel( service ) ) ) {
156 QByteArray data; 186 QByteArray data;
157 QDataStream arg(data, IO_WriteOnly ); 187 QDataStream arg(data, IO_WriteOnly );
158 if ( rec.saveToStream( arg ) ) { 188 if ( rec.saveToStream( arg ) ) {
159 QCopEnvelope env( applicationChannel( service ), "add(int,QByteArray)" ); 189 QCopEnvelope env( applicationChannel( service ), "add(int,QByteArray)" );
160 env << rec.rtti(); 190 env << rec.rtti();
161 env << data; 191 env << data;
162 }else 192 }else
163 return false; 193 return false;
164 }else{ 194 }else{
165 OPimBase* base = backend( service ); 195 OPimBase* base = backend( service );
166 if (!base ) return false; 196 if (!base ) return false;
167 197
168 base->load(); 198 base->load();
169 base->add( rec ); 199 base->add( rec );
170 base->save(); 200 base->save();
171 delete base; 201 delete base;
172 } 202 }
173 203
174 return true; 204 return true;
175} 205}
176OPimBase* OPimResolver::backend( const QString& service ) { 206OPimBase* OPimResolver::backend( const QString& service ) {
177 return backend( serviceId( service ) ); 207 return backend( serviceId( service ) );
178} 208}
179OPimBase* OPimResolver::backend( int rtti ) { 209OPimBase* OPimResolver::backend( int rtti ) {
180 OPimBase* base = 0l; 210 OPimBase* base = 0l;
181 switch( rtti ) { 211 switch( rtti ) {
182 case TodoList: 212 case TodoList:
183 base = new OTodoAccess(); 213 base = new OTodoAccess();
184 break; 214 break;
185 case DateBook: 215 case DateBook:
186 break; 216 break;
187 case AddressBook: 217 case AddressBook:
188 base = new OContactAccess("Resolver"); 218 base = new OContactAccess("Resolver");
189 break; 219 break;
190 default: 220 default:
191 break; 221 break;
192 } 222 }
193 // FIXME for 3rd party 223 // FIXME for 3rd party
194 if (!base ) 224 if (!base )
195 ; 225 ;
196 226
197 return base; 227 return base;
198} 228}
229
230}
diff --git a/libopie2/opiepim/core/opimresolver.h b/libopie2/opiepim/core/opimresolver.h
index 1ce1619..adc7c16 100644
--- a/libopie2/opiepim/core/opimresolver.h
+++ b/libopie2/opiepim/core/opimresolver.h
@@ -1,90 +1,121 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_RESOLVER 29#ifndef OPIE_PIM_RESOLVER
2#define OPIE_PIM_RESOLVER 30#define OPIE_PIM_RESOLVER
3 31
4#include <qstring.h> 32#include <qstring.h>
5#include <qvaluelist.h> 33#include <qvaluelist.h>
6 34
7#include <opie/otemplatebase.h> 35#include <opie2/otemplatebase.h>
8 36
37namespace Opie {
9/** 38/**
10 * OPimResolver is a MetaClass to access 39 * OPimResolver is a MetaClass to access
11 * available backends read only. 40 * available backends read only.
12 * It will be used to resolve uids + app names 41 * It will be used to resolve uids + app names
13 * to full informations 42 * to full informations
14 * to traverse through a list of alarms, reminders 43 * to traverse through a list of alarms, reminders
15 * to get access to built in PIM functionality 44 * to get access to built in PIM functionality
16 * and to more stuff 45 * and to more stuff
17 * THE PERFORMANCE will depend on THE BACKEND 46 * THE PERFORMANCE will depend on THE BACKEND
18 * USING XML is a waste of memory!!!!! 47 * USING XML is a waste of memory!!!!!
19 */ 48 */
20class OPimResolver { 49class OPimResolver {
21public: 50public:
22 enum BuiltIn { TodoList = 0, 51 enum BuiltIn { TodoList = 0,
23 DateBook, 52 DateBook,
24 AddressBook 53 AddressBook
25 }; 54 };
26 static OPimResolver* self(); 55 static OPimResolver* self();
27 56
28 57
29 /** 58 /**
30 * return a record for a uid 59 * return a record for a uid
31 * and an service 60 * and an service
32 * You've THE OWNERSHIP NOW! 61 * You've THE OWNERSHIP NOW!
33 */ 62 */
34 OPimRecord *record( const QString& service, int uid ); 63 OPimRecord *record( const QString& service, int uid );
35 64
36 /** 65 /**
37 * return the QCopChannel for service 66 * return the QCopChannel for service
38 * When we will use Qtopia Services it will be used here 67 * When we will use Qtopia Services it will be used here
39 */ 68 */
40 QCString qcopChannel( enum BuiltIn& )const; 69 QCString qcopChannel( enum BuiltIn& )const;
41 QCString qcopChannel( const QString& service )const; 70 QCString qcopChannel( const QString& service )const;
42 71
43 /** 72 /**
44 * The Application channel (QPE/Application/name) 73 * The Application channel (QPE/Application/name)
45 */ 74 */
46 QCString applicationChannel( enum BuiltIn& )const; 75 QCString applicationChannel( enum BuiltIn& )const;
47 QCString applicationChannel( const QString& service )const; 76 QCString applicationChannel( const QString& service )const;
48 77
49 /** 78 /**
50 * return a list of available services 79 * return a list of available services
51 */ 80 */
52 QStringList services()const; 81 QStringList services()const;
53 inline QString serviceName(int rrti )const; 82 inline QString serviceName(int rrti )const;
54 int serviceId( const QString& Service); 83 int serviceId( const QString& Service);
55 /** 84 /**
56 * add a record to a service... ;) 85 * add a record to a service... ;)
57 */ 86 */
58 bool add( const QString& service, const OPimRecord& ); 87 bool add( const QString& service, const OPimRecord& );
59 88
60 89
61 /** 90 /**
62 * record returns an empty record for a given service. 91 * record returns an empty record for a given service.
63 * Be sure to delete it!!! 92 * Be sure to delete it!!!
64 * 93 *
65 */ 94 */
66 OPimRecord* record( const QString& service ); 95 OPimRecord* record( const QString& service );
67 OPimRecord* record( int rtti ); 96 OPimRecord* record( int rtti );
68 97
69 /** 98 /**
70 * you can cast to your 99 * you can cast to your
71 */ 100 */
72 OPimBase* backend( const QString& service ); 101 OPimBase* backend( const QString& service );
73 OPimBase* backend( int rtti ); 102 OPimBase* backend( int rtti );
74private: 103private:
75 OPimResolver(); 104 OPimResolver();
76 void loadData(); 105 void loadData();
77 inline bool isBuiltIn( const QString& )const; 106 inline bool isBuiltIn( const QString& )const;
78 OPimRecord* recordExtern( const QString&, int ); 107 OPimRecord* recordExtern( const QString&, int );
79 OPimRecord* recordExtern( const QString& ); 108 OPimRecord* recordExtern( const QString& );
80 109
81 static OPimResolver* m_self; 110 static OPimResolver* m_self;
82 struct Data; 111 struct Data;
83 class Private; 112 class Private;
84 113
85 Data* data; 114 Data* data;
86 Private* d; 115 Private* d;
87 QStringList m_builtIns; 116 QStringList m_builtIns;
88}; 117};
89 118
119}
120
90#endif 121#endif
diff --git a/libopie2/opiepim/core/opimstate.cpp b/libopie2/opiepim/core/opimstate.cpp
index 6fb2feb..1013a1c 100644
--- a/libopie2/opiepim/core/opimstate.cpp
+++ b/libopie2/opiepim/core/opimstate.cpp
@@ -1,64 +1,95 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qshared.h> 29#include <qshared.h>
2 30
3#include "opimstate.h" 31#include "opimstate.h"
4 32
33namespace Opie {
5/* 34/*
6 * for one int this does not make 35 * for one int this does not make
7 * much sense but never the less 36 * much sense but never the less
8 * we will do it for the future 37 * we will do it for the future
9 */ 38 */
10struct OPimState::Data : public QShared { 39struct OPimState::Data : public QShared {
11 Data() : QShared(),state(Undefined) { 40 Data() : QShared(),state(Undefined) {
12 } 41 }
13 int state; 42 int state;
14}; 43};
15 44
16OPimState::OPimState( int state ) { 45OPimState::OPimState( int state ) {
17 data = new Data; 46 data = new Data;
18 data->state = state; 47 data->state = state;
19} 48}
20OPimState::OPimState( const OPimState& st) : 49OPimState::OPimState( const OPimState& st) :
21 data( st.data ) { 50 data( st.data ) {
22 /* ref up */ 51 /* ref up */
23 data->ref(); 52 data->ref();
24} 53}
25OPimState::~OPimState() { 54OPimState::~OPimState() {
26 if ( data->deref() ) { 55 if ( data->deref() ) {
27 delete data ; 56 delete data ;
28 data = 0; 57 data = 0;
29 } 58 }
30} 59}
31bool OPimState::operator==( const OPimState& st) { 60bool OPimState::operator==( const OPimState& st) {
32 if ( data->state == st.data->state ) return true; 61 if ( data->state == st.data->state ) return true;
33 62
34 return false; 63 return false;
35} 64}
36OPimState &OPimState::operator=( const OPimState& st) { 65OPimState &OPimState::operator=( const OPimState& st) {
37 st.data->ref(); 66 st.data->ref();
38 deref(); 67 deref();
39 data = st.data; 68 data = st.data;
40 69
41 return *this; 70 return *this;
42} 71}
43void OPimState::setState( int st) { 72void OPimState::setState( int st) {
44 copyInternally(); 73 copyInternally();
45 data->state = st; 74 data->state = st;
46} 75}
47int OPimState::state()const { 76int OPimState::state()const {
48 return data->state; 77 return data->state;
49} 78}
50void OPimState::deref() { 79void OPimState::deref() {
51 if ( data->deref() ) { 80 if ( data->deref() ) {
52 delete data; 81 delete data;
53 data = 0l; 82 data = 0l;
54 } 83 }
55} 84}
56void OPimState::copyInternally() { 85void OPimState::copyInternally() {
57 /* we need to change it */ 86 /* we need to change it */
58 if ( data->count != 1 ) { 87 if ( data->count != 1 ) {
59 data->deref(); 88 data->deref();
60 Data* d2 = new Data; 89 Data* d2 = new Data;
61 d2->state = data->state; 90 d2->state = data->state;
62 data = d2; 91 data = d2;
63 } 92 }
64} 93}
94
95}
diff --git a/libopie2/opiepim/core/opimstate.h b/libopie2/opiepim/core/opimstate.h
index cf6af46..78e8cd0 100644
--- a/libopie2/opiepim/core/opimstate.h
+++ b/libopie2/opiepim/core/opimstate.h
@@ -1,46 +1,75 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_STATE_H 29#ifndef OPIE_PIM_STATE_H
2#define OPIE_PIM_STATE_H 30#define OPIE_PIM_STATE_H
3 31
4#include <qstring.h> 32#include <qstring.h>
5 33
34namespace Opie {
6/** 35/**
7 * The State of a Task 36 * The State of a Task
8 * This class encapsules the state of a todo 37 * This class encapsules the state of a todo
9 * and it's shared too 38 * and it's shared too
10 */ 39 */
11/* 40/*
12 * in c a simple struct would be enough ;) 41 * in c a simple struct would be enough ;)
13 * g_new_state(); 42 * g_new_state();
14 * g_do_some_thing( state_t* ); 43 * g_do_some_thing( state_t* );
15 * ;) 44 * ;)
16 */ 45 */
17class OPimState { 46class OPimState {
18public: 47public:
19 enum State { 48 enum State {
20 Started = 0, 49 Started = 0,
21 Postponed, 50 Postponed,
22 Finished, 51 Finished,
23 NotStarted, 52 NotStarted,
24 Undefined 53 Undefined
25 }; 54 };
26 OPimState( int state = Undefined ); 55 OPimState( int state = Undefined );
27 OPimState( const OPimState& ); 56 OPimState( const OPimState& );
28 ~OPimState(); 57 ~OPimState();
29 58
30 bool operator==( const OPimState& ); 59 bool operator==( const OPimState& );
31 OPimState &operator=( const OPimState& ); 60 OPimState &operator=( const OPimState& );
32 void setState( int state); 61 void setState( int state);
33 int state()const; 62 int state()const;
34private: 63private:
35 void deref(); 64 void deref();
36 inline void copyInternally(); 65 inline void copyInternally();
37 66
38 struct Data; 67 struct Data;
39 Data* data; 68 Data* data;
40 69
41 class Private; 70 class Private;
42 Private *d; 71 Private *d;
43}; 72};
44 73
45 74}
46#endif 75#endif
diff --git a/libopie2/opiepim/core/opimxref.cpp b/libopie2/opiepim/core/opimxref.cpp
index 8eefbd8..85d3345 100644
--- a/libopie2/opiepim/core/opimxref.cpp
+++ b/libopie2/opiepim/core/opimxref.cpp
@@ -1,47 +1,79 @@
1#include "opimxref.h" 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29#include <opie2/opimxref.h>
30
31namespace Opie {
2 32
3OPimXRef::OPimXRef( const OPimXRefPartner& one, const OPimXRefPartner& two ) 33OPimXRef::OPimXRef( const OPimXRefPartner& one, const OPimXRefPartner& two )
4 : m_partners(2) 34 : m_partners(2)
5{ 35{
6 m_partners[0] = one; 36 m_partners[0] = one;
7 m_partners[1] = two; 37 m_partners[1] = two;
8} 38}
9OPimXRef::OPimXRef() 39OPimXRef::OPimXRef()
10 : m_partners(2) 40 : m_partners(2)
11{ 41{
12 42
13} 43}
14OPimXRef::OPimXRef( const OPimXRef& ref) { 44OPimXRef::OPimXRef( const OPimXRef& ref) {
15 *this = ref; 45 *this = ref;
16} 46}
17OPimXRef::~OPimXRef() { 47OPimXRef::~OPimXRef() {
18} 48}
19OPimXRef &OPimXRef::operator=( const OPimXRef& ref) { 49OPimXRef &OPimXRef::operator=( const OPimXRef& ref) {
20 m_partners = ref.m_partners; 50 m_partners = ref.m_partners;
21 m_partners.detach(); 51 m_partners.detach();
22 52
23 return* this; 53 return* this;
24} 54}
25bool OPimXRef::operator==( const OPimXRef& oper ) { 55bool OPimXRef::operator==( const OPimXRef& oper ) {
26 if ( m_partners == oper.m_partners ) return true; 56 if ( m_partners == oper.m_partners ) return true;
27 57
28 return false; 58 return false;
29} 59}
30OPimXRefPartner OPimXRef::partner( enum Partners par) const{ 60OPimXRefPartner OPimXRef::partner( enum Partners par) const{
31 return m_partners[par]; 61 return m_partners[par];
32} 62}
33void OPimXRef::setPartner( enum Partners par, const OPimXRefPartner& part) { 63void OPimXRef::setPartner( enum Partners par, const OPimXRefPartner& part) {
34 m_partners[par] = part; 64 m_partners[par] = part;
35} 65}
36bool OPimXRef::containsString( const QString& string ) const{ 66bool OPimXRef::containsString( const QString& string ) const{
37 if ( m_partners[One].service() == string || 67 if ( m_partners[One].service() == string ||
38 m_partners[Two].service() == string ) return true; 68 m_partners[Two].service() == string ) return true;
39 69
40 return false; 70 return false;
41} 71}
42bool OPimXRef::containsUid( int uid ) const{ 72bool OPimXRef::containsUid( int uid ) const{
43 if ( m_partners[One].uid() == uid || 73 if ( m_partners[One].uid() == uid ||
44 m_partners[Two].uid() == uid ) return true; 74 m_partners[Two].uid() == uid ) return true;
45 75
46 return false; 76 return false;
47} 77}
78
79}
diff --git a/libopie2/opiepim/core/opimxref.h b/libopie2/opiepim/core/opimxref.h
index 6852651..820c9c4 100644
--- a/libopie2/opiepim/core/opimxref.h
+++ b/libopie2/opiepim/core/opimxref.h
@@ -1,39 +1,71 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
1#ifndef OPIM_XREF_H 30#ifndef OPIM_XREF_H
2#define OPIM_XREF_H 31#define OPIM_XREF_H
3 32
4#include <qarray.h> 33#include <qarray.h>
5#include <qvaluelist.h> 34#include <qvaluelist.h>
6 35
7#include <opie/opimxrefpartner.h> 36#include <opie2/opimxrefpartner.h>
8 37
38namespace Opie {
9/** 39/**
10 * this is a Cross Referecne between 40 * this is a Cross Referecne between
11 * two Cross Reference Partners 41 * two Cross Reference Partners
12 */ 42 */
13class OPimXRef { 43class OPimXRef {
14public: 44public:
15 typedef QValueList<OPimXRef> ValueList; 45 typedef QValueList<OPimXRef> ValueList;
16 enum Partners { One, Two }; 46 enum Partners { One, Two };
17 OPimXRef( const OPimXRefPartner& ONE, const OPimXRefPartner& ); 47 OPimXRef( const OPimXRefPartner& ONE, const OPimXRefPartner& );
18 OPimXRef(); 48 OPimXRef();
19 OPimXRef( const OPimXRef& ); 49 OPimXRef( const OPimXRef& );
20 ~OPimXRef(); 50 ~OPimXRef();
21 51
22 OPimXRef &operator=( const OPimXRef& ); 52 OPimXRef &operator=( const OPimXRef& );
23 bool operator==( const OPimXRef& ); 53 bool operator==( const OPimXRef& );
24 54
25 OPimXRefPartner partner( enum Partners )const; 55 OPimXRefPartner partner( enum Partners )const;
26 56
27 void setPartner( enum Partners, const OPimXRefPartner& ); 57 void setPartner( enum Partners, const OPimXRefPartner& );
28 58
29 bool containsString( const QString& service)const; 59 bool containsString( const QString& service)const;
30 bool containsUid( int uid )const; 60 bool containsUid( int uid )const;
31 61
32private: 62private:
33 QArray<OPimXRefPartner> m_partners; 63 QArray<OPimXRefPartner> m_partners;
34 64
35 class Private; 65 class Private;
36 Private *d; 66 Private *d;
37}; 67};
38 68
69}
70
39#endif 71#endif
diff --git a/libopie2/opiepim/core/opimxrefmanager.cpp b/libopie2/opiepim/core/opimxrefmanager.cpp
index 58bfd24..bf6fed6 100644
--- a/libopie2/opiepim/core/opimxrefmanager.cpp
+++ b/libopie2/opiepim/core/opimxrefmanager.cpp
@@ -1,71 +1,102 @@
1#include "opimxrefmanager.h" 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29#include <opie2/opimxrefmanager.h>
2 30
31namespace Opie {
3 32
4OPimXRefManager::OPimXRefManager() { 33OPimXRefManager::OPimXRefManager() {
5} 34}
6OPimXRefManager::OPimXRefManager( const OPimXRefManager& ref) { 35OPimXRefManager::OPimXRefManager( const OPimXRefManager& ref) {
7 m_list = ref.m_list; 36 m_list = ref.m_list;
8} 37}
9OPimXRefManager::~OPimXRefManager() { 38OPimXRefManager::~OPimXRefManager() {
10} 39}
11OPimXRefManager &OPimXRefManager::operator=( const OPimXRefManager& ref) { 40OPimXRefManager &OPimXRefManager::operator=( const OPimXRefManager& ref) {
12 m_list = ref.m_list; 41 m_list = ref.m_list;
13 return *this; 42 return *this;
14} 43}
15bool OPimXRefManager::operator==( const OPimXRefManager& /*ref*/) { 44bool OPimXRefManager::operator==( const OPimXRefManager& /*ref*/) {
16 // if ( m_list == ref.m_list ) return true; 45 // if ( m_list == ref.m_list ) return true;
17 46
18 return false; 47 return false;
19} 48}
20void OPimXRefManager::add( const OPimXRef& ref) { 49void OPimXRefManager::add( const OPimXRef& ref) {
21 m_list.append( ref ); 50 m_list.append( ref );
22} 51}
23void OPimXRefManager::remove( const OPimXRef& ref) { 52void OPimXRefManager::remove( const OPimXRef& ref) {
24 m_list.remove( ref ); 53 m_list.remove( ref );
25} 54}
26void OPimXRefManager::replace( const OPimXRef& ref) { 55void OPimXRefManager::replace( const OPimXRef& ref) {
27 m_list.remove( ref ); 56 m_list.remove( ref );
28 m_list.append( ref ); 57 m_list.append( ref );
29} 58}
30void OPimXRefManager::clear() { 59void OPimXRefManager::clear() {
31 m_list.clear(); 60 m_list.clear();
32} 61}
33QStringList OPimXRefManager::apps()const { 62QStringList OPimXRefManager::apps()const {
34 OPimXRef::ValueList::ConstIterator it; 63 OPimXRef::ValueList::ConstIterator it;
35 QStringList list; 64 QStringList list;
36 65
37 QString str; 66 QString str;
38 for ( it = m_list.begin(); it != m_list.end(); ++it ) { 67 for ( it = m_list.begin(); it != m_list.end(); ++it ) {
39 str = (*it).partner( OPimXRef::One ).service(); 68 str = (*it).partner( OPimXRef::One ).service();
40 if ( !list.contains( str ) ) list << str; 69 if ( !list.contains( str ) ) list << str;
41 70
42 str = (*it).partner( OPimXRef::Two ).service(); 71 str = (*it).partner( OPimXRef::Two ).service();
43 if ( !list.contains( str ) ) list << str; 72 if ( !list.contains( str ) ) list << str;
44 } 73 }
45 return list; 74 return list;
46} 75}
47OPimXRef::ValueList OPimXRefManager::list()const { 76OPimXRef::ValueList OPimXRefManager::list()const {
48 return m_list; 77 return m_list;
49} 78}
50OPimXRef::ValueList OPimXRefManager::list( const QString& appName )const{ 79OPimXRef::ValueList OPimXRefManager::list( const QString& appName )const{
51 OPimXRef::ValueList list; 80 OPimXRef::ValueList list;
52 OPimXRef::ValueList::ConstIterator it; 81 OPimXRef::ValueList::ConstIterator it;
53 82
54 for ( it = m_list.begin(); it != m_list.end(); ++it ) { 83 for ( it = m_list.begin(); it != m_list.end(); ++it ) {
55 if ( (*it).containsString( appName ) ) 84 if ( (*it).containsString( appName ) )
56 list.append( (*it) ); 85 list.append( (*it) );
57 } 86 }
58 87
59 return list; 88 return list;
60} 89}
61OPimXRef::ValueList OPimXRefManager::list( int uid )const { 90OPimXRef::ValueList OPimXRefManager::list( int uid )const {
62 OPimXRef::ValueList list; 91 OPimXRef::ValueList list;
63 OPimXRef::ValueList::ConstIterator it; 92 OPimXRef::ValueList::ConstIterator it;
64 93
65 for ( it = m_list.begin(); it != m_list.end(); ++it ) { 94 for ( it = m_list.begin(); it != m_list.end(); ++it ) {
66 if ( (*it).containsUid( uid ) ) 95 if ( (*it).containsUid( uid ) )
67 list.append( (*it) ); 96 list.append( (*it) );
68 } 97 }
69 98
70 return list; 99 return list;
71} 100}
101
102}
diff --git a/libopie2/opiepim/core/opimxrefmanager.h b/libopie2/opiepim/core/opimxrefmanager.h
index c485e98..fa2d7f4 100644
--- a/libopie2/opiepim/core/opimxrefmanager.h
+++ b/libopie2/opiepim/core/opimxrefmanager.h
@@ -1,43 +1,74 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIM_XREF_MANAGER_H 29#ifndef OPIM_XREF_MANAGER_H
2#define OPIM_XREF_MANAGER_H 30#define OPIM_XREF_MANAGER_H
3 31
4#include <qstringlist.h> 32#include <qstringlist.h>
5 33
6#include <opie/opimxref.h> 34#include <opie2/opimxref.h>
7 35
36namespace Opie {
8/** 37/**
9 * This is a simple manager for 38 * This is a simple manager for
10 * OPimXRefs. 39 * OPimXRefs.
11 * It allows addition, removing, replacing 40 * It allows addition, removing, replacing
12 * clearing and 'querying' the XRef... 41 * clearing and 'querying' the XRef...
13 */ 42 */
14class OPimXRefManager { 43class OPimXRefManager {
15public: 44public:
16 OPimXRefManager(); 45 OPimXRefManager();
17 OPimXRefManager( const OPimXRefManager& ); 46 OPimXRefManager( const OPimXRefManager& );
18 ~OPimXRefManager(); 47 ~OPimXRefManager();
19 48
20 OPimXRefManager& operator=( const OPimXRefManager& ); 49 OPimXRefManager& operator=( const OPimXRefManager& );
21 bool operator==( const OPimXRefManager& ); 50 bool operator==( const OPimXRefManager& );
22 51
23 void add( const OPimXRef& ); 52 void add( const OPimXRef& );
24 void remove( const OPimXRef& ); 53 void remove( const OPimXRef& );
25 void replace( const OPimXRef& ); 54 void replace( const OPimXRef& );
26 55
27 void clear(); 56 void clear();
28 57
29 /** 58 /**
30 * apps participating 59 * apps participating
31 */ 60 */
32 QStringList apps()const; 61 QStringList apps()const;
33 OPimXRef::ValueList list()const; 62 OPimXRef::ValueList list()const;
34 OPimXRef::ValueList list( const QString& service )const; 63 OPimXRef::ValueList list( const QString& service )const;
35 OPimXRef::ValueList list( int uid )const; 64 OPimXRef::ValueList list( int uid )const;
36 65
37private: 66private:
38 OPimXRef::ValueList m_list; 67 OPimXRef::ValueList m_list;
39 class Private; 68 class Private;
40 Private *d; 69 Private *d;
41}; 70};
42 71
72}
73
43#endif 74#endif
diff --git a/libopie2/opiepim/core/opimxrefpartner.cpp b/libopie2/opiepim/core/opimxrefpartner.cpp
index 6ef3efb..f6ccc7f 100644
--- a/libopie2/opiepim/core/opimxrefpartner.cpp
+++ b/libopie2/opiepim/core/opimxrefpartner.cpp
@@ -1,43 +1,75 @@
1#include "opimxrefpartner.h" 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29#include <opie2/opimxrefpartner.h>
30
31namespace Opie {
2 32
3OPimXRefPartner::OPimXRefPartner( const QString& appName, 33OPimXRefPartner::OPimXRefPartner( const QString& appName,
4 int uid, int field ) 34 int uid, int field )
5 : m_app(appName), m_uid(uid), m_field( field ) { 35 : m_app(appName), m_uid(uid), m_field( field ) {
6} 36}
7OPimXRefPartner::OPimXRefPartner( const OPimXRefPartner& ref ) { 37OPimXRefPartner::OPimXRefPartner( const OPimXRefPartner& ref ) {
8 *this = ref; 38 *this = ref;
9} 39}
10OPimXRefPartner::~OPimXRefPartner() { 40OPimXRefPartner::~OPimXRefPartner() {
11} 41}
12OPimXRefPartner &OPimXRefPartner::operator=( const OPimXRefPartner& par ) { 42OPimXRefPartner &OPimXRefPartner::operator=( const OPimXRefPartner& par ) {
13 m_app = par.m_app; 43 m_app = par.m_app;
14 m_uid = par.m_uid; 44 m_uid = par.m_uid;
15 m_field = par.m_field; 45 m_field = par.m_field;
16 46
17 return *this; 47 return *this;
18} 48}
19bool OPimXRefPartner::operator==( const OPimXRefPartner& par ) { 49bool OPimXRefPartner::operator==( const OPimXRefPartner& par ) {
20 if ( m_app != par.m_app ) return false; 50 if ( m_app != par.m_app ) return false;
21 if ( m_uid != par.m_uid ) return false; 51 if ( m_uid != par.m_uid ) return false;
22 if ( m_field != par.m_field ) return false; 52 if ( m_field != par.m_field ) return false;
23 53
24 return true; 54 return true;
25} 55}
26QString OPimXRefPartner::service()const { 56QString OPimXRefPartner::service()const {
27 return m_app; 57 return m_app;
28} 58}
29int OPimXRefPartner::uid()const { 59int OPimXRefPartner::uid()const {
30 return m_uid; 60 return m_uid;
31} 61}
32int OPimXRefPartner::field()const { 62int OPimXRefPartner::field()const {
33 return m_field; 63 return m_field;
34} 64}
35void OPimXRefPartner::setService( const QString& appName ) { 65void OPimXRefPartner::setService( const QString& appName ) {
36 m_app = appName; 66 m_app = appName;
37} 67}
38void OPimXRefPartner::setUid( int uid ) { 68void OPimXRefPartner::setUid( int uid ) {
39 m_uid = uid; 69 m_uid = uid;
40} 70}
41void OPimXRefPartner::setField( int field ) { 71void OPimXRefPartner::setField( int field ) {
42 m_field = field; 72 m_field = field;
43} 73}
74
75}
diff --git a/libopie2/opiepim/core/opimxrefpartner.h b/libopie2/opiepim/core/opimxrefpartner.h
index d76e384..6853d5b 100644
--- a/libopie2/opiepim/core/opimxrefpartner.h
+++ b/libopie2/opiepim/core/opimxrefpartner.h
@@ -1,40 +1,70 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIM_XREF_PARTNER_H 29#ifndef OPIM_XREF_PARTNER_H
2#define OPIM_XREF_PARTNER_H 30#define OPIM_XREF_PARTNER_H
3 31
4#include <qstring.h> 32#include <qstring.h>
5 33
34namespace Opie {
6/** 35/**
7 * This class represents one partner 36 * This class represents one partner
8 * of a Cross Reference. 37 * of a Cross Reference.
9 * In Opie one application 38 * In Opie one application
10 * can link one uid 39 * can link one uid
11 * with one tableId( fieldId ) to another. 40 * with one tableId( fieldId ) to another.
12 */ 41 */
13class OPimXRefPartner { 42class OPimXRefPartner {
14public: 43public:
15 OPimXRefPartner( const QString& service = QString::null, 44 OPimXRefPartner( const QString& service = QString::null,
16 int uid = 0, int field = -1 ); 45 int uid = 0, int field = -1 );
17 OPimXRefPartner( const OPimXRefPartner& ); 46 OPimXRefPartner( const OPimXRefPartner& );
18 OPimXRefPartner& operator=( const OPimXRefPartner& ); 47 OPimXRefPartner& operator=( const OPimXRefPartner& );
19 ~OPimXRefPartner(); 48 ~OPimXRefPartner();
20 49
21 bool operator==(const OPimXRefPartner& ); 50 bool operator==(const OPimXRefPartner& );
22 51
23 QString service()const; 52 QString service()const;
24 int uid()const; 53 int uid()const;
25 int field()const; 54 int field()const;
26 55
27 void setService( const QString& service ); 56 void setService( const QString& service );
28 void setUid( int uid ); 57 void setUid( int uid );
29 void setField( int field ); 58 void setField( int field );
30private: 59private:
31 QString m_app; 60 QString m_app;
32 int m_uid; 61 int m_uid;
33 int m_field; 62 int m_field;
34 63
35 class Private; 64 class Private;
36 Private* d; 65 Private* d;
37}; 66};
38 67
68}
39 69
40#endif 70#endif
diff --git a/libopie2/opiepim/core/orecur.cpp b/libopie2/opiepim/core/orecur.cpp
index f46f22e..033f264 100644
--- a/libopie2/opiepim/core/orecur.cpp
+++ b/libopie2/opiepim/core/orecur.cpp
@@ -1,593 +1,625 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
1#include <time.h> 30#include <time.h>
2 31
3#include <qshared.h> 32#include <qshared.h>
4 33
5#include <qtopia/timeconversion.h> 34#include <qtopia/timeconversion.h>
6 35
7#include "otimezone.h" 36#include <opie2/otimezone.h>
8#include "orecur.h" 37#include <opie2/orecur.h>
9 38
39namespace Opie {
10struct ORecur::Data : public QShared { 40struct ORecur::Data : public QShared {
11 Data() : QShared() { 41 Data() : QShared() {
12 type = ORecur::NoRepeat; 42 type = ORecur::NoRepeat;
13 freq = -1; 43 freq = -1;
14 days = 0; 44 days = 0;
15 pos = 0; 45 pos = 0;
16 create = QDateTime::currentDateTime(); 46 create = QDateTime::currentDateTime();
17 hasEnd = FALSE; 47 hasEnd = FALSE;
18 end = QDate::currentDate(); 48 end = QDate::currentDate();
19 } 49 }
20 char days; // Q_UINT8 for 8 seven days;) 50 char days; // Q_UINT8 for 8 seven days;)
21 ORecur::RepeatType type; 51 ORecur::RepeatType type;
22 int freq; 52 int freq;
23 int pos; 53 int pos;
24 bool hasEnd : 1; 54 bool hasEnd : 1;
25 QDate end; 55 QDate end;
26 QDateTime create; 56 QDateTime create;
27 int rep; 57 int rep;
28 QString app; 58 QString app;
29 ExceptionList list; 59 ExceptionList list;
30 QDate start; 60 QDate start;
31}; 61};
32 62
33 63
34ORecur::ORecur() { 64ORecur::ORecur() {
35 data = new Data; 65 data = new Data;
36} 66}
37 67
38ORecur::ORecur( const QMap<int, QString>& map ) 68ORecur::ORecur( const QMap<int, QString>& map )
39{ 69{
40 ORecur(); 70 ORecur();
41 fromMap( map ); 71 fromMap( map );
42} 72}
43 73
44 74
45ORecur::ORecur( const ORecur& rec) 75ORecur::ORecur( const ORecur& rec)
46 : data( rec.data ) 76 : data( rec.data )
47{ 77{
48 data->ref(); 78 data->ref();
49} 79}
50ORecur::~ORecur() { 80ORecur::~ORecur() {
51 if ( data->deref() ) { 81 if ( data->deref() ) {
52 delete data; 82 delete data;
53 data = 0l; 83 data = 0l;
54 } 84 }
55} 85}
56void ORecur::deref() { 86void ORecur::deref() {
57 if ( data->deref() ) { 87 if ( data->deref() ) {
58 delete data; 88 delete data;
59 data = 0l; 89 data = 0l;
60 } 90 }
61} 91}
62bool ORecur::operator==( const ORecur& )const { 92bool ORecur::operator==( const ORecur& )const {
63 return false; 93 return false;
64} 94}
65ORecur &ORecur::operator=( const ORecur& re) { 95ORecur &ORecur::operator=( const ORecur& re) {
66 if ( *this == re ) return *this; 96 if ( *this == re ) return *this;
67 97
68 re.data->ref(); 98 re.data->ref();
69 deref(); 99 deref();
70 data = re.data; 100 data = re.data;
71 101
72 return *this; 102 return *this;
73} 103}
74bool ORecur::doesRecur()const { 104bool ORecur::doesRecur()const {
75 return !( type() == NoRepeat ); 105 return !( type() == NoRepeat );
76} 106}
77/* 107/*
78 * we try to be smart here 108 * we try to be smart here
79 * 109 *
80 */ 110 */
81bool ORecur::doesRecur( const QDate& date ) { 111bool ORecur::doesRecur( const QDate& date ) {
82 /* the day before the recurrance */ 112 /* the day before the recurrance */
83 QDate da = date.addDays(-1); 113 QDate da = date.addDays(-1);
84 114
85 QDate recur; 115 QDate recur;
86 if (!nextOcurrence( da, recur ) ) 116 if (!nextOcurrence( da, recur ) )
87 return false; 117 return false;
88 118
89 return (recur == date); 119 return (recur == date);
90} 120}
91// FIXME unuglify! 121// FIXME unuglify!
92// GPL from Datebookdb.cpp 122// GPL from Datebookdb.cpp
93// FIXME exception list! 123// FIXME exception list!
94bool ORecur::nextOcurrence( const QDate& from, QDate& next ) { 124bool ORecur::nextOcurrence( const QDate& from, QDate& next ) {
95 bool stillLooking; 125 bool stillLooking;
96 stillLooking = p_nextOccurrence( from, next ); 126 stillLooking = p_nextOccurrence( from, next );
97 while ( stillLooking && data->list.contains(next) ) 127 while ( stillLooking && data->list.contains(next) )
98 stillLooking = p_nextOccurrence( next.addDays(1), next ); 128 stillLooking = p_nextOccurrence( next.addDays(1), next );
99 129
100 return stillLooking; 130 return stillLooking;
101} 131}
102bool ORecur::p_nextOccurrence( const QDate& from, QDate& next ) { 132bool ORecur::p_nextOccurrence( const QDate& from, QDate& next ) {
103 133
104 // easy checks, first are we too far in the future or too far in the past? 134 // easy checks, first are we too far in the future or too far in the past?
105 QDate tmpDate; 135 QDate tmpDate;
106 int freq = frequency(); 136 int freq = frequency();
107 int diff, diff2, a; 137 int diff, diff2, a;
108 int iday, imonth, iyear; 138 int iday, imonth, iyear;
109 int dayOfWeek = 0; 139 int dayOfWeek = 0;
110 int firstOfWeek = 0; 140 int firstOfWeek = 0;
111 int weekOfMonth; 141 int weekOfMonth;
112 142
113 143
114 if (hasEndDate() && endDate() < from) 144 if (hasEndDate() && endDate() < from)
115 return FALSE; 145 return FALSE;
116 146
117 if (start() >= from ) { 147 if (start() >= from ) {
118 next = start(); 148 next = start();
119 return TRUE; 149 return TRUE;
120 } 150 }
121 151
122 switch ( type() ) { 152 switch ( type() ) {
123 case Weekly: 153 case Weekly:
124 /* weekly is just daily by 7 */ 154 /* weekly is just daily by 7 */
125 /* first convert the repeatPattern.Days() mask to the next 155 /* first convert the repeatPattern.Days() mask to the next
126 day of week valid after from */ 156 day of week valid after from */
127 dayOfWeek = from.dayOfWeek(); 157 dayOfWeek = from.dayOfWeek();
128 dayOfWeek--; /* we want 0-6, doco for above specs 1-7 */ 158 dayOfWeek--; /* we want 0-6, doco for above specs 1-7 */
129 159
130 /* this is done in case freq > 1 and from in week not 160 /* this is done in case freq > 1 and from in week not
131 for this round */ 161 for this round */
132 // firstOfWeek = 0; this is already done at decl. 162 // firstOfWeek = 0; this is already done at decl.
133 while(!((1 << firstOfWeek) & days() )) 163 while(!((1 << firstOfWeek) & days() ))
134 firstOfWeek++; 164 firstOfWeek++;
135 165
136 /* there is at least one 'day', or there would be no event */ 166 /* there is at least one 'day', or there would be no event */
137 while(!((1 << (dayOfWeek % 7)) & days() )) 167 while(!((1 << (dayOfWeek % 7)) & days() ))
138 dayOfWeek++; 168 dayOfWeek++;
139 169
140 dayOfWeek = dayOfWeek % 7; /* the actual day of week */ 170 dayOfWeek = dayOfWeek % 7; /* the actual day of week */
141 dayOfWeek -= start().dayOfWeek() -1; 171 dayOfWeek -= start().dayOfWeek() -1;
142 172
143 firstOfWeek = firstOfWeek % 7; /* the actual first of week */ 173 firstOfWeek = firstOfWeek % 7; /* the actual first of week */
144 firstOfWeek -= start().dayOfWeek() -1; 174 firstOfWeek -= start().dayOfWeek() -1;
145 175
146 // dayOfWeek may be negitive now 176 // dayOfWeek may be negitive now
147 // day of week is number of days to add to start day 177 // day of week is number of days to add to start day
148 178
149 freq *= 7; 179 freq *= 7;
150 // FALL-THROUGH !!!!! 180 // FALL-THROUGH !!!!!
151 case Daily: 181 case Daily:
152 // the add is for the possible fall through from weekly */ 182 // the add is for the possible fall through from weekly */
153 if(start().addDays(dayOfWeek) > from) { 183 if(start().addDays(dayOfWeek) > from) {
154 /* first week exception */ 184 /* first week exception */
155 next = QDate(start().addDays(dayOfWeek) ); 185 next = QDate(start().addDays(dayOfWeek) );
156 if ((next > endDate()) 186 if ((next > endDate())
157 && hasEndDate() ) 187 && hasEndDate() )
158 return FALSE; 188 return FALSE;
159 return TRUE; 189 return TRUE;
160 } 190 }
161 /* if from is middle of a non-week */ 191 /* if from is middle of a non-week */
162 192
163 diff = start().addDays(dayOfWeek).daysTo(from) % freq; 193 diff = start().addDays(dayOfWeek).daysTo(from) % freq;
164 diff2 = start().addDays(firstOfWeek).daysTo(from) % freq; 194 diff2 = start().addDays(firstOfWeek).daysTo(from) % freq;
165 195
166 if(diff != 0) 196 if(diff != 0)
167 diff = freq - diff; 197 diff = freq - diff;
168 if(diff2 != 0) 198 if(diff2 != 0)
169 diff2 = freq - diff2; 199 diff2 = freq - diff2;
170 diff = QMIN(diff, diff2); 200 diff = QMIN(diff, diff2);
171 201
172 next = QDate(from.addDays(diff)); 202 next = QDate(from.addDays(diff));
173 if ( (next > endDate()) 203 if ( (next > endDate())
174 && hasEndDate() ) 204 && hasEndDate() )
175 return FALSE; 205 return FALSE;
176 return TRUE; 206 return TRUE;
177 case MonthlyDay: 207 case MonthlyDay:
178 iday = from.day(); 208 iday = from.day();
179 iyear = from.year(); 209 iyear = from.year();
180 imonth = from.month(); 210 imonth = from.month();
181 /* find equivelent day of month for this month */ 211 /* find equivelent day of month for this month */
182 dayOfWeek = start().dayOfWeek(); 212 dayOfWeek = start().dayOfWeek();
183 weekOfMonth = (start().day() - 1) / 7; 213 weekOfMonth = (start().day() - 1) / 7;
184 214
185 /* work out when the next valid month is */ 215 /* work out when the next valid month is */
186 a = from.year() - start().year(); 216 a = from.year() - start().year();
187 a *= 12; 217 a *= 12;
188 a = a + (imonth - start().month()); 218 a = a + (imonth - start().month());
189 /* a is e.start()monthsFrom(from); */ 219 /* a is e.start()monthsFrom(from); */
190 if(a % freq) { 220 if(a % freq) {
191 a = freq - (a % freq); 221 a = freq - (a % freq);
192 imonth = from.month() + a; 222 imonth = from.month() + a;
193 if (imonth > 12) { 223 if (imonth > 12) {
194 imonth--; 224 imonth--;
195 iyear += imonth / 12; 225 iyear += imonth / 12;
196 imonth = imonth % 12; 226 imonth = imonth % 12;
197 imonth++; 227 imonth++;
198 } 228 }
199 } 229 }
200 /* imonth is now the first month after or on 230 /* imonth is now the first month after or on
201 from that matches the frequency given */ 231 from that matches the frequency given */
202 232
203 /* find for this month */ 233 /* find for this month */
204 tmpDate = QDate( iyear, imonth, 1 ); 234 tmpDate = QDate( iyear, imonth, 1 );
205 235
206 iday = 1; 236 iday = 1;
207 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7; 237 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7;
208 iday += 7 * weekOfMonth; 238 iday += 7 * weekOfMonth;
209 while (iday > tmpDate.daysInMonth()) { 239 while (iday > tmpDate.daysInMonth()) {
210 imonth += freq; 240 imonth += freq;
211 if (imonth > 12) { 241 if (imonth > 12) {
212 imonth--; 242 imonth--;
213 iyear += imonth / 12; 243 iyear += imonth / 12;
214 imonth = imonth % 12; 244 imonth = imonth % 12;
215 imonth++; 245 imonth++;
216 } 246 }
217 tmpDate = QDate( iyear, imonth, 1 ); 247 tmpDate = QDate( iyear, imonth, 1 );
218 /* these loops could go for a while, check end case now */ 248 /* these loops could go for a while, check end case now */
219 if ((tmpDate > endDate()) && hasEndDate() ) 249 if ((tmpDate > endDate()) && hasEndDate() )
220 return FALSE; 250 return FALSE;
221 iday = 1; 251 iday = 1;
222 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7; 252 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7;
223 iday += 7 * weekOfMonth; 253 iday += 7 * weekOfMonth;
224 } 254 }
225 tmpDate = QDate(iyear, imonth, iday); 255 tmpDate = QDate(iyear, imonth, iday);
226 256
227 if (tmpDate >= from) { 257 if (tmpDate >= from) {
228 next = tmpDate; 258 next = tmpDate;
229 if ((next > endDate() ) && hasEndDate() ) 259 if ((next > endDate() ) && hasEndDate() )
230 return FALSE; 260 return FALSE;
231 return TRUE; 261 return TRUE;
232 } 262 }
233 263
234 /* need to find the next iteration */ 264 /* need to find the next iteration */
235 do { 265 do {
236 imonth += freq; 266 imonth += freq;
237 if (imonth > 12) { 267 if (imonth > 12) {
238 imonth--; 268 imonth--;
239 iyear += imonth / 12; 269 iyear += imonth / 12;
240 imonth = imonth % 12; 270 imonth = imonth % 12;
241 imonth++; 271 imonth++;
242 } 272 }
243 tmpDate = QDate( iyear, imonth, 1 ); 273 tmpDate = QDate( iyear, imonth, 1 );
244 /* these loops could go for a while, check end case now */ 274 /* these loops could go for a while, check end case now */
245 if ((tmpDate > endDate()) && hasEndDate() ) 275 if ((tmpDate > endDate()) && hasEndDate() )
246 return FALSE; 276 return FALSE;
247 iday = 1; 277 iday = 1;
248 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7; 278 iday += (7 + dayOfWeek - tmpDate.dayOfWeek()) % 7;
249 iday += 7 * weekOfMonth; 279 iday += 7 * weekOfMonth;
250 } while (iday > tmpDate.daysInMonth()); 280 } while (iday > tmpDate.daysInMonth());
251 tmpDate = QDate(iyear, imonth, iday); 281 tmpDate = QDate(iyear, imonth, iday);
252 282
253 next = tmpDate; 283 next = tmpDate;
254 if ((next > endDate()) && hasEndDate() ) 284 if ((next > endDate()) && hasEndDate() )
255 return FALSE; 285 return FALSE;
256 return TRUE; 286 return TRUE;
257 case MonthlyDate: 287 case MonthlyDate:
258 iday = start().day(); 288 iday = start().day();
259 iyear = from.year(); 289 iyear = from.year();
260 imonth = from.month(); 290 imonth = from.month();
261 291
262 a = from.year() - start().year(); 292 a = from.year() - start().year();
263 a *= 12; 293 a *= 12;
264 a = a + (imonth - start().month()); 294 a = a + (imonth - start().month());
265 /* a is e.start()monthsFrom(from); */ 295 /* a is e.start()monthsFrom(from); */
266 if(a % freq) { 296 if(a % freq) {
267 a = freq - (a % freq); 297 a = freq - (a % freq);
268 imonth = from.month() + a; 298 imonth = from.month() + a;
269 if (imonth > 12) { 299 if (imonth > 12) {
270 imonth--; 300 imonth--;
271 iyear += imonth / 12; 301 iyear += imonth / 12;
272 imonth = imonth % 12; 302 imonth = imonth % 12;
273 imonth++; 303 imonth++;
274 } 304 }
275 } 305 }
276 /* imonth is now the first month after or on 306 /* imonth is now the first month after or on
277 from that matches the frequencey given */ 307 from that matches the frequencey given */
278 308
279 /* this could go for a while, worse case, 4*12 iterations, probably */ 309 /* this could go for a while, worse case, 4*12 iterations, probably */
280 while(!QDate::isValid(iyear, imonth, iday) ) { 310 while(!QDate::isValid(iyear, imonth, iday) ) {
281 imonth += freq; 311 imonth += freq;
282 if (imonth > 12) { 312 if (imonth > 12) {
283 imonth--; 313 imonth--;
284 iyear += imonth / 12; 314 iyear += imonth / 12;
285 imonth = imonth % 12; 315 imonth = imonth % 12;
286 imonth++; 316 imonth++;
287 } 317 }
288 /* these loops could go for a while, check end case now */ 318 /* these loops could go for a while, check end case now */
289 if ((QDate(iyear, imonth, 1) > endDate()) && hasEndDate() ) 319 if ((QDate(iyear, imonth, 1) > endDate()) && hasEndDate() )
290 return FALSE; 320 return FALSE;
291 } 321 }
292 322
293 if(QDate(iyear, imonth, iday) >= from) { 323 if(QDate(iyear, imonth, iday) >= from) {
294 /* done */ 324 /* done */
295 next = QDate(iyear, imonth, iday); 325 next = QDate(iyear, imonth, iday);
296 if ((next > endDate()) && hasEndDate() ) 326 if ((next > endDate()) && hasEndDate() )
297 return FALSE; 327 return FALSE;
298 return TRUE; 328 return TRUE;
299 } 329 }
300 330
301 /* ok, need to cycle */ 331 /* ok, need to cycle */
302 imonth += freq; 332 imonth += freq;
303 imonth--; 333 imonth--;
304 iyear += imonth / 12; 334 iyear += imonth / 12;
305 imonth = imonth % 12; 335 imonth = imonth % 12;
306 imonth++; 336 imonth++;
307 337
308 while(!QDate::isValid(iyear, imonth, iday) ) { 338 while(!QDate::isValid(iyear, imonth, iday) ) {
309 imonth += freq; 339 imonth += freq;
310 imonth--; 340 imonth--;
311 iyear += imonth / 12; 341 iyear += imonth / 12;
312 imonth = imonth % 12; 342 imonth = imonth % 12;
313 imonth++; 343 imonth++;
314 if ((QDate(iyear, imonth, 1) > endDate()) && hasEndDate() ) 344 if ((QDate(iyear, imonth, 1) > endDate()) && hasEndDate() )
315 return FALSE; 345 return FALSE;
316 } 346 }
317 347
318 next = QDate(iyear, imonth, iday); 348 next = QDate(iyear, imonth, iday);
319 if ((next > endDate()) && hasEndDate() ) 349 if ((next > endDate()) && hasEndDate() )
320 return FALSE; 350 return FALSE;
321 return TRUE; 351 return TRUE;
322 case Yearly: 352 case Yearly:
323 iday = start().day(); 353 iday = start().day();
324 imonth = start().month(); 354 imonth = start().month();
325 iyear = from.year(); // after all, we want to start in this year 355 iyear = from.year(); // after all, we want to start in this year
326 356
327 diff = 1; 357 diff = 1;
328 if(imonth == 2 && iday > 28) { 358 if(imonth == 2 && iday > 28) {
329 /* leap year, and it counts, calculate actual frequency */ 359 /* leap year, and it counts, calculate actual frequency */
330 if(freq % 4) 360 if(freq % 4)
331 if (freq % 2) 361 if (freq % 2)
332 freq = freq * 4; 362 freq = freq * 4;
333 else 363 else
334 freq = freq * 2; 364 freq = freq * 2;
335 /* else divides by 4 already, leave freq alone */ 365 /* else divides by 4 already, leave freq alone */
336 diff = 4; 366 diff = 4;
337 } 367 }
338 368
339 a = from.year() - start().year(); 369 a = from.year() - start().year();
340 if(a % freq) { 370 if(a % freq) {
341 a = freq - (a % freq); 371 a = freq - (a % freq);
342 iyear = iyear + a; 372 iyear = iyear + a;
343 } 373 }
344 374
345 /* under the assumption we won't hit one of the special not-leap years twice */ 375 /* under the assumption we won't hit one of the special not-leap years twice */
346 if(!QDate::isValid(iyear, imonth, iday)) { 376 if(!QDate::isValid(iyear, imonth, iday)) {
347 /* must have been skipping by leap years and hit one that wasn't, (e.g. 2100) */ 377 /* must have been skipping by leap years and hit one that wasn't, (e.g. 2100) */
348 iyear += freq; 378 iyear += freq;
349 } 379 }
350 380
351 if(QDate(iyear, imonth, iday) >= from) { 381 if(QDate(iyear, imonth, iday) >= from) {
352 next = QDate(iyear, imonth, iday); 382 next = QDate(iyear, imonth, iday);
353 383
354 if ((next > endDate()) && hasEndDate() ) 384 if ((next > endDate()) && hasEndDate() )
355 return FALSE; 385 return FALSE;
356 return TRUE; 386 return TRUE;
357 } 387 }
358 /* iyear == from.year(), need to advance again */ 388 /* iyear == from.year(), need to advance again */
359 iyear += freq; 389 iyear += freq;
360 /* under the assumption we won't hit one of the special not-leap years twice */ 390 /* under the assumption we won't hit one of the special not-leap years twice */
361 if(!QDate::isValid(iyear, imonth, iday)) { 391 if(!QDate::isValid(iyear, imonth, iday)) {
362 /* must have been skipping by leap years and hit one that wasn't, (e.g. 2100) */ 392 /* must have been skipping by leap years and hit one that wasn't, (e.g. 2100) */
363 iyear += freq; 393 iyear += freq;
364 } 394 }
365 395
366 next = QDate(iyear, imonth, iday); 396 next = QDate(iyear, imonth, iday);
367 if ((next > endDate()) && hasEndDate() ) 397 if ((next > endDate()) && hasEndDate() )
368 return FALSE; 398 return FALSE;
369 return TRUE; 399 return TRUE;
370 default: 400 default:
371 return FALSE; 401 return FALSE;
372 } 402 }
373} 403}
374ORecur::RepeatType ORecur::type()const{ 404ORecur::RepeatType ORecur::type()const{
375 return data->type; 405 return data->type;
376} 406}
377int ORecur::frequency()const { 407int ORecur::frequency()const {
378 return data->freq; 408 return data->freq;
379} 409}
380int ORecur::position()const { 410int ORecur::position()const {
381 return data->pos; 411 return data->pos;
382} 412}
383char ORecur::days() const{ 413char ORecur::days() const{
384 return data->days; 414 return data->days;
385} 415}
386bool ORecur::hasEndDate()const { 416bool ORecur::hasEndDate()const {
387 return data->hasEnd; 417 return data->hasEnd;
388} 418}
389QDate ORecur::endDate()const { 419QDate ORecur::endDate()const {
390 return data->end; 420 return data->end;
391} 421}
392QDate ORecur::start()const{ 422QDate ORecur::start()const{
393 return data->start; 423 return data->start;
394} 424}
395QDateTime ORecur::createdDateTime()const { 425QDateTime ORecur::createdDateTime()const {
396 return data->create; 426 return data->create;
397} 427}
398int ORecur::repetition()const { 428int ORecur::repetition()const {
399 return data->rep; 429 return data->rep;
400} 430}
401QString ORecur::service()const { 431QString ORecur::service()const {
402 return data->app; 432 return data->app;
403} 433}
404ORecur::ExceptionList& ORecur::exceptions() { 434ORecur::ExceptionList& ORecur::exceptions() {
405 return data->list; 435 return data->list;
406} 436}
407void ORecur::setType( const RepeatType& z) { 437void ORecur::setType( const RepeatType& z) {
408 checkOrModify(); 438 checkOrModify();
409 data->type = z; 439 data->type = z;
410} 440}
411void ORecur::setFrequency( int freq ) { 441void ORecur::setFrequency( int freq ) {
412 checkOrModify(); 442 checkOrModify();
413 data->freq = freq; 443 data->freq = freq;
414} 444}
415void ORecur::setPosition( int pos ) { 445void ORecur::setPosition( int pos ) {
416 checkOrModify(); 446 checkOrModify();
417 data->pos = pos; 447 data->pos = pos;
418} 448}
419void ORecur::setDays( char c ) { 449void ORecur::setDays( char c ) {
420 checkOrModify(); 450 checkOrModify();
421 data->days = c; 451 data->days = c;
422} 452}
423void ORecur::setEndDate( const QDate& dt) { 453void ORecur::setEndDate( const QDate& dt) {
424 checkOrModify(); 454 checkOrModify();
425 data->end = dt; 455 data->end = dt;
426} 456}
427void ORecur::setCreatedDateTime( const QDateTime& t) { 457void ORecur::setCreatedDateTime( const QDateTime& t) {
428 checkOrModify(); 458 checkOrModify();
429 data->create = t; 459 data->create = t;
430} 460}
431void ORecur::setHasEndDate( bool b) { 461void ORecur::setHasEndDate( bool b) {
432 checkOrModify(); 462 checkOrModify();
433 data->hasEnd = b; 463 data->hasEnd = b;
434} 464}
435void ORecur::setRepitition( int rep ) { 465void ORecur::setRepitition( int rep ) {
436 checkOrModify(); 466 checkOrModify();
437 data->rep = rep; 467 data->rep = rep;
438} 468}
439void ORecur::setService( const QString& app ) { 469void ORecur::setService( const QString& app ) {
440 checkOrModify(); 470 checkOrModify();
441 data->app = app; 471 data->app = app;
442} 472}
443void ORecur::setStart( const QDate& dt ) { 473void ORecur::setStart( const QDate& dt ) {
444 checkOrModify(); 474 checkOrModify();
445 data->start = dt; 475 data->start = dt;
446} 476}
447void ORecur::checkOrModify() { 477void ORecur::checkOrModify() {
448 if ( data->count != 1 ) { 478 if ( data->count != 1 ) {
449 data->deref(); 479 data->deref();
450 Data* d2 = new Data; 480 Data* d2 = new Data;
451 d2->days = data->days; 481 d2->days = data->days;
452 d2->type = data->type; 482 d2->type = data->type;
453 d2->freq = data->freq; 483 d2->freq = data->freq;
454 d2->pos = data->pos; 484 d2->pos = data->pos;
455 d2->hasEnd = data->hasEnd; 485 d2->hasEnd = data->hasEnd;
456 d2->end = data->end; 486 d2->end = data->end;
457 d2->create = data->create; 487 d2->create = data->create;
458 d2->rep = data->rep; 488 d2->rep = data->rep;
459 d2->app = data->app; 489 d2->app = data->app;
460 d2->list = data->list; 490 d2->list = data->list;
461 d2->start = data->start; 491 d2->start = data->start;
462 data = d2; 492 data = d2;
463 } 493 }
464} 494}
465QString ORecur::toString()const { 495QString ORecur::toString()const {
466 QString buf; 496 QString buf;
467 QMap<int, QString> recMap = toMap(); 497 QMap<int, QString> recMap = toMap();
468 498
469 buf += " rtype=\""; 499 buf += " rtype=\"";
470 buf += recMap[ORecur::RType]; 500 buf += recMap[ORecur::RType];
471 buf += "\""; 501 buf += "\"";
472 if (data->days > 0 ) 502 if (data->days > 0 )
473 buf += " rweekdays=\"" + recMap[ORecur::RWeekdays] + "\""; 503 buf += " rweekdays=\"" + recMap[ORecur::RWeekdays] + "\"";
474 if ( data->pos != 0 ) 504 if ( data->pos != 0 )
475 buf += " rposition=\"" + recMap[ORecur::RPosition] + "\""; 505 buf += " rposition=\"" + recMap[ORecur::RPosition] + "\"";
476 506
477 buf += " rfreq=\"" + recMap[ORecur::RFreq] + "\""; 507 buf += " rfreq=\"" + recMap[ORecur::RFreq] + "\"";
478 buf += " rhasenddate=\"" + recMap[ORecur::RHasEndDate]+ "\""; 508 buf += " rhasenddate=\"" + recMap[ORecur::RHasEndDate]+ "\"";
479 if ( data->hasEnd ) 509 if ( data->hasEnd )
480 buf += " enddt=\"" 510 buf += " enddt=\""
481 + recMap[ORecur::EndDate] 511 + recMap[ORecur::EndDate]
482 + "\""; 512 + "\"";
483 buf += " created=\"" + recMap[ORecur::Created] + "\""; 513 buf += " created=\"" + recMap[ORecur::Created] + "\"";
484 514
485 if ( data->list.isEmpty() ) return buf; 515 if ( data->list.isEmpty() ) return buf;
486 buf += " exceptions=\""; 516 buf += " exceptions=\"";
487 buf += recMap[ORecur::Exceptions]; 517 buf += recMap[ORecur::Exceptions];
488 buf += "\" "; 518 buf += "\" ";
489 519
490 return buf; 520 return buf;
491} 521}
492 522
493QString ORecur::rTypeString() const 523QString ORecur::rTypeString() const
494{ 524{
495 QString retString; 525 QString retString;
496 switch ( data->type ) { 526 switch ( data->type ) {
497 case ORecur::Daily: 527 case ORecur::Daily:
498 retString = "Daily"; 528 retString = "Daily";
499 break; 529 break;
500 case ORecur::Weekly: 530 case ORecur::Weekly:
501 retString = "Weekly"; 531 retString = "Weekly";
502 break; 532 break;
503 case ORecur::MonthlyDay: 533 case ORecur::MonthlyDay:
504 retString = "MonthlyDay"; 534 retString = "MonthlyDay";
505 break; 535 break;
506 case ORecur::MonthlyDate: 536 case ORecur::MonthlyDate:
507 retString = "MonthlyDate"; 537 retString = "MonthlyDate";
508 break; 538 break;
509 case ORecur::Yearly: 539 case ORecur::Yearly:
510 retString = "Yearly"; 540 retString = "Yearly";
511 break; 541 break;
512 default: 542 default:
513 retString = "NoRepeat"; 543 retString = "NoRepeat";
514 break; 544 break;
515 545
516 } 546 }
517 547
518 return retString; 548 return retString;
519} 549}
520 550
521QMap<QString, ORecur::RepeatType> ORecur::rTypeValueConvertMap() const 551QMap<QString, ORecur::RepeatType> ORecur::rTypeValueConvertMap() const
522{ 552{
523 QMap<QString, RepeatType> convertMap; 553 QMap<QString, RepeatType> convertMap;
524 554
525 convertMap.insert( QString( "Daily" ), ORecur::Daily ); 555 convertMap.insert( QString( "Daily" ), ORecur::Daily );
526 convertMap.insert( QString( "Weekly" ), ORecur::Weekly ); 556 convertMap.insert( QString( "Weekly" ), ORecur::Weekly );
527 convertMap.insert( QString( "MonthlyDay" ), ORecur::MonthlyDay ); 557 convertMap.insert( QString( "MonthlyDay" ), ORecur::MonthlyDay );
528 convertMap.insert( QString( "MonthlyDate" ), ORecur::MonthlyDate ); 558 convertMap.insert( QString( "MonthlyDate" ), ORecur::MonthlyDate );
529 convertMap.insert( QString( "Yearly" ), ORecur::Yearly ); 559 convertMap.insert( QString( "Yearly" ), ORecur::Yearly );
530 convertMap.insert( QString( "NoRepeat" ), ORecur::NoRepeat ); 560 convertMap.insert( QString( "NoRepeat" ), ORecur::NoRepeat );
531 561
532 return convertMap; 562 return convertMap;
533} 563}
534 564
535 565
536QMap<int, QString> ORecur::toMap() const 566QMap<int, QString> ORecur::toMap() const
537{ 567{
538 QMap<int, QString> retMap; 568 QMap<int, QString> retMap;
539 569
540 retMap.insert( ORecur::RType, rTypeString() ); 570 retMap.insert( ORecur::RType, rTypeString() );
541 retMap.insert( ORecur::RWeekdays, QString::number( static_cast<int>( data->days ) ) ); 571 retMap.insert( ORecur::RWeekdays, QString::number( static_cast<int>( data->days ) ) );
542 retMap.insert( ORecur::RPosition, QString::number(data->pos ) ); 572 retMap.insert( ORecur::RPosition, QString::number(data->pos ) );
543 retMap.insert( ORecur::RFreq, QString::number( data->freq ) ); 573 retMap.insert( ORecur::RFreq, QString::number( data->freq ) );
544 retMap.insert( ORecur::RHasEndDate, QString::number( static_cast<int>( data->hasEnd ) ) ); 574 retMap.insert( ORecur::RHasEndDate, QString::number( static_cast<int>( data->hasEnd ) ) );
545 if( data -> hasEnd ) 575 if( data -> hasEnd )
546 retMap.insert( ORecur::EndDate, QString::number( OTimeZone::utc().fromUTCDateTime( QDateTime( data->end, QTime(12,0,0) ) ) ) ); 576 retMap.insert( ORecur::EndDate, QString::number( OTimeZone::utc().fromUTCDateTime( QDateTime( data->end, QTime(12,0,0) ) ) ) );
547 retMap.insert( ORecur::Created, QString::number( OTimeZone::utc().fromUTCDateTime( data->create ) ) ); 577 retMap.insert( ORecur::Created, QString::number( OTimeZone::utc().fromUTCDateTime( data->create ) ) );
548 578
549 if ( data->list.isEmpty() ) return retMap; 579 if ( data->list.isEmpty() ) return retMap;
550 580
551 // save exceptions list here!! 581 // save exceptions list here!!
552 ExceptionList::ConstIterator it; 582 ExceptionList::ConstIterator it;
553 ExceptionList list = data->list; 583 ExceptionList list = data->list;
554 QString exceptBuf; 584 QString exceptBuf;
555 QDate date; 585 QDate date;
556 for ( it = list.begin(); it != list.end(); ++it ) { 586 for ( it = list.begin(); it != list.end(); ++it ) {
557 date = (*it); 587 date = (*it);
558 if ( it != list.begin() ) exceptBuf += " "; 588 if ( it != list.begin() ) exceptBuf += " ";
559 589
560 exceptBuf += QCString().sprintf("%04d%02d%02d", date.year(), date.month(), date.day() ); 590 exceptBuf += QCString().sprintf("%04d%02d%02d", date.year(), date.month(), date.day() );
561 } 591 }
562 592
563 retMap.insert( ORecur::Exceptions, exceptBuf ); 593 retMap.insert( ORecur::Exceptions, exceptBuf );
564 594
565 return retMap; 595 return retMap;
566} 596}
567 597
568void ORecur::fromMap( const QMap<int, QString>& map ) 598void ORecur::fromMap( const QMap<int, QString>& map )
569{ 599{
570 QMap<QString, RepeatType> repTypeMap = rTypeValueConvertMap(); 600 QMap<QString, RepeatType> repTypeMap = rTypeValueConvertMap();
571 601
572 data -> type = repTypeMap[ map [ORecur::RType] ]; 602 data -> type = repTypeMap[ map [ORecur::RType] ];
573 data -> days = (char) map[ ORecur::RWeekdays ].toInt(); 603 data -> days = (char) map[ ORecur::RWeekdays ].toInt();
574 data -> pos = map[ ORecur::RPosition ].toInt(); 604 data -> pos = map[ ORecur::RPosition ].toInt();
575 data -> freq = map[ ORecur::RFreq ].toInt(); 605 data -> freq = map[ ORecur::RFreq ].toInt();
576 data -> hasEnd= map[ ORecur::RHasEndDate ].toInt() ? true : false; 606 data -> hasEnd= map[ ORecur::RHasEndDate ].toInt() ? true : false;
577 OTimeZone utc = OTimeZone::utc(); 607 OTimeZone utc = OTimeZone::utc();
578 if ( data -> hasEnd ){ 608 if ( data -> hasEnd ){
579 data -> end = utc.fromUTCDateTime( (time_t) map[ ORecur::EndDate ].toLong() ).date(); 609 data -> end = utc.fromUTCDateTime( (time_t) map[ ORecur::EndDate ].toLong() ).date();
580 } 610 }
581 data -> create = utc.fromUTCDateTime( (time_t) map[ ORecur::Created ].toLong() ).date(); 611 data -> create = utc.fromUTCDateTime( (time_t) map[ ORecur::Created ].toLong() ).date();
582 612
583#if 0 613#if 0
584 // FIXME: Exceptions currently not supported... 614 // FIXME: Exceptions currently not supported...
585 // Convert the list of exceptions from QString into ExceptionList 615 // Convert the list of exceptions from QString into ExceptionList
586 data -> list.clear(); 616 data -> list.clear();
587 QString exceptStr = map[ ORecur::Exceptions ]; 617 QString exceptStr = map[ ORecur::Exceptions ];
588 QStringList exceptList = QStringList::split( " ", exceptStr ); 618 QStringList exceptList = QStringList::split( " ", exceptStr );
589 ... 619 ...
590#endif 620#endif
591 621
592 622
593} 623}
624
625} \ No newline at end of file
diff --git a/libopie2/opiepim/core/orecur.h b/libopie2/opiepim/core/orecur.h
index d7ecd90..60508f5 100644
--- a/libopie2/opiepim/core/orecur.h
+++ b/libopie2/opiepim/core/orecur.h
@@ -1,107 +1,134 @@
1/* 1/*
2 * GPL from TT 2 This file is part of the Opie Project
3 */ 3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
4 29
5#ifndef OPIE_RECUR_H 30#ifndef OPIE_RECUR_H
6#define OPIE_RECUR_H 31#define OPIE_RECUR_H
7 32
8#include <sys/types.h> 33#include <sys/types.h>
9 34
10#include <qdatetime.h> 35#include <qdatetime.h>
11#include <qvaluelist.h> 36#include <qvaluelist.h>
12#include <qmap.h> 37#include <qmap.h>
13 38
14 39
40namespace Opie {
15/** 41/**
16 * Class to handle Recurrencies.. 42 * Class to handle Recurrencies..
17 */ 43 */
18 44
19class ORecur { 45class ORecur {
20public: 46public:
21 typedef QValueList<QDate> ExceptionList; 47 typedef QValueList<QDate> ExceptionList;
22 enum RepeatType{ NoRepeat = -1, Daily, Weekly, MonthlyDay, 48 enum RepeatType{ NoRepeat = -1, Daily, Weekly, MonthlyDay,
23 MonthlyDate, Yearly }; 49 MonthlyDate, Yearly };
24 enum Days { MON = 0x01, TUE = 0x02, WED = 0x04, THU = 0x08, 50 enum Days { MON = 0x01, TUE = 0x02, WED = 0x04, THU = 0x08,
25 FRI = 0x10, SAT = 0x20, SUN = 0x40 }; 51 FRI = 0x10, SAT = 0x20, SUN = 0x40 };
26 enum Fields{ RType = 0, RWeekdays, RPosition, RFreq, RHasEndDate, 52 enum Fields{ RType = 0, RWeekdays, RPosition, RFreq, RHasEndDate,
27 EndDate, Created, Exceptions }; 53 EndDate, Created, Exceptions };
28 54
29 ORecur(); 55 ORecur();
30 ORecur( const QMap<int, QString>& map ); 56 ORecur( const QMap<int, QString>& map );
31 ORecur( const ORecur& ); 57 ORecur( const ORecur& );
32 ~ORecur(); 58 ~ORecur();
33 59
34 ORecur &operator=( const ORecur& ); 60 ORecur &operator=( const ORecur& );
35 bool operator==(const ORecur& )const; 61 bool operator==(const ORecur& )const;
36 62
37 bool doesRecur()const; 63 bool doesRecur()const;
38 /* if it recurrs on that day */ 64 /* if it recurrs on that day */
39 bool doesRecur( const QDate& ); 65 bool doesRecur( const QDate& );
40 RepeatType type()const; 66 RepeatType type()const;
41 int frequency()const; 67 int frequency()const;
42 int position()const; 68 int position()const;
43 char days()const; 69 char days()const;
44 bool hasEndDate()const; 70 bool hasEndDate()const;
45 QDate start()const; 71 QDate start()const;
46 QDate endDate()const; 72 QDate endDate()const;
47 QDateTime createdDateTime()const; 73 QDateTime createdDateTime()const;
48 /** 74 /**
49 * starting on monday=0, sunday=6 75 * starting on monday=0, sunday=6
50 * for convience 76 * for convience
51 */ 77 */
52 bool repeatOnWeekDay( int day )const; 78 bool repeatOnWeekDay( int day )const;
53 79
54 /** 80 /**
55 * FromWhereToStart is not included!!! 81 * FromWhereToStart is not included!!!
56 */ 82 */
57 bool nextOcurrence( const QDate& FromWhereToStart, QDate &recurDate ); 83 bool nextOcurrence( const QDate& FromWhereToStart, QDate &recurDate );
58 84
59 /** 85 /**
60 * The module this ORecur belongs to 86 * The module this ORecur belongs to
61 */ 87 */
62 QString service()const; 88 QString service()const;
63 89
64 /* 90 /*
65 * reference to the exception list 91 * reference to the exception list
66 */ 92 */
67 ExceptionList &exceptions(); 93 ExceptionList &exceptions();
68 94
69 /** 95 /**
70 * the current repetition 96 * the current repetition
71 */ 97 */
72 int repetition()const; 98 int repetition()const;
73 99
74 void setType( const RepeatType& ); 100 void setType( const RepeatType& );
75 void setFrequency( int freq ); 101 void setFrequency( int freq );
76 void setPosition( int pos ); 102 void setPosition( int pos );
77 void setDays( char c); 103 void setDays( char c);
78 void setEndDate( const QDate& dt ); 104 void setEndDate( const QDate& dt );
79 void setStart( const QDate& dt ); 105 void setStart( const QDate& dt );
80 void setCreatedDateTime( const QDateTime& ); 106 void setCreatedDateTime( const QDateTime& );
81 void setHasEndDate( bool b ); 107 void setHasEndDate( bool b );
82 void setRepitition(int ); 108 void setRepitition(int );
83 109
84 void setService( const QString& ser ); 110 void setService( const QString& ser );
85 111
86 QMap<int, QString> toMap() const; 112 QMap<int, QString> toMap() const;
87 void fromMap( const QMap<int, QString>& map ); 113 void fromMap( const QMap<int, QString>& map );
88 114
89 /* almost internal */ 115 /* almost internal */
90 QString toString()const; 116 QString toString()const;
91private: 117private:
92 bool p_nextOccurrence( const QDate& from, QDate& next ); 118 bool p_nextOccurrence( const QDate& from, QDate& next );
93 void deref(); 119 void deref();
94 inline void checkOrModify(); 120 inline void checkOrModify();
95 121
96 /* Converts rType to String */ 122 /* Converts rType to String */
97 QString rTypeString() const; 123 QString rTypeString() const;
98 /* Returns a map to convert Stringname for RType to RepeatType */ 124 /* Returns a map to convert Stringname for RType to RepeatType */
99 QMap<QString, RepeatType> rTypeValueConvertMap() const; 125 QMap<QString, RepeatType> rTypeValueConvertMap() const;
100 126
101 class Data; 127 class Data;
102 Data* data; 128 Data* data;
103 class ORecurPrivate; 129 class ORecurPrivate;
104 ORecurPrivate *d; 130 ORecurPrivate *d;
105}; 131};
106 132
133}
107#endif 134#endif
diff --git a/libopie2/opiepim/core/otemplatebase.h b/libopie2/opiepim/core/otemplatebase.h
index cadac74..17d9961 100644
--- a/libopie2/opiepim/core/otemplatebase.h
+++ b/libopie2/opiepim/core/otemplatebase.h
@@ -1,98 +1,129 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_TEMPLATE_BASE_H 29#ifndef OPIE_TEMPLATE_BASE_H
2#define OPIE_TEMPLATE_BASE_H 30#define OPIE_TEMPLATE_BASE_H
3 31
4#include <qarray.h> 32#include <qarray.h>
5 33
6#include <opie/opimrecord.h> 34#include <opie2/opimrecord.h>
7 35
8 36
37namespace Opie {
9/** 38/**
10 * Templates do not have a base class, This is why 39 * Templates do not have a base class, This is why
11 * we've this class 40 * we've this class
12 * this is here to give us the possibility 41 * this is here to give us the possibility
13 * to have a common base class 42 * to have a common base class
14 * You may not want to use that interface internaly 43 * You may not want to use that interface internaly
15 * POOR mans interface 44 * POOR mans interface
16 */ 45 */
17class OPimBasePrivate; 46class OPimBasePrivate;
18struct OPimBase { 47struct OPimBase {
19 /** 48 /**
20 * return the rtti 49 * return the rtti
21 */ 50 */
22 virtual int rtti()= 0; 51 virtual int rtti()= 0;
23 virtual OPimRecord* record()const = 0; 52 virtual OPimRecord* record()const = 0;
24 virtual OPimRecord* record(int uid)const = 0; 53 virtual OPimRecord* record(int uid)const = 0;
25 virtual bool add( const OPimRecord& ) = 0; 54 virtual bool add( const OPimRecord& ) = 0;
26 virtual bool remove( int uid ) = 0; 55 virtual bool remove( int uid ) = 0;
27 virtual bool remove( const OPimRecord& ) = 0; 56 virtual bool remove( const OPimRecord& ) = 0;
28 virtual void clear() = 0; 57 virtual void clear() = 0;
29 virtual bool load() = 0; 58 virtual bool load() = 0;
30 virtual bool save() = 0; 59 virtual bool save() = 0;
31 virtual QArray<int> records()const = 0; 60 virtual QArray<int> records()const = 0;
32 /* 61 /*
33 * ADD editing here? 62 * ADD editing here?
34 * -zecke 63 * -zecke
35 */ 64 */
36private: 65private:
37 OPimBasePrivate* d; 66 OPimBasePrivate* d;
38 67
39}; 68};
40/** 69/**
41 * internal template base 70 * internal template base
42 * T needs to implement the copy c'tor!!! 71 * T needs to implement the copy c'tor!!!
43 */ 72 */
44class OTemplateBasePrivate; 73class OTemplateBasePrivate;
45template <class T = OPimRecord> 74template <class T = OPimRecord>
46class OTemplateBase : public OPimBase { 75class OTemplateBase : public OPimBase {
47public: 76public:
48 enum CacheDirection { Forward=0, Reverse }; 77 enum CacheDirection { Forward=0, Reverse };
49 OTemplateBase() { 78 OTemplateBase() {
50 }; 79 };
51 virtual ~OTemplateBase() { 80 virtual ~OTemplateBase() {
52 } 81 }
53 virtual T find( int uid )const = 0; 82 virtual T find( int uid )const = 0;
54 83
55 /** 84 /**
56 * read ahead find 85 * read ahead find
57 */ 86 */
58 virtual T find( int uid, const QArray<int>& items, 87 virtual T find( int uid, const QArray<int>& items,
59 uint current, CacheDirection dir = Forward )const = 0; 88 uint current, CacheDirection dir = Forward )const = 0;
60 virtual void cache( const T& )const = 0; 89 virtual void cache( const T& )const = 0;
61 virtual void setSaneCacheSize( int ) = 0; 90 virtual void setSaneCacheSize( int ) = 0;
62 91
63 /* reimplement of OPimBase */ 92 /* reimplement of OPimBase */
64 int rtti(); 93 int rtti();
65 OPimRecord* record()const; 94 OPimRecord* record()const;
66 OPimRecord* record(int uid )const; 95 OPimRecord* record(int uid )const;
67 static T* rec(); 96 static T* rec();
68 97
69private: 98private:
70 OTemplateBasePrivate *d; 99 OTemplateBasePrivate *d;
71}; 100};
72 101
73/* 102/*
74 * implementation 103 * implementation
75 */ 104 */
76template <class T> 105template <class T>
77int 106int
78OTemplateBase<T>::rtti() { 107OTemplateBase<T>::rtti() {
79 return T::rtti(); 108 return T::rtti();
80} 109}
81template <class T> 110template <class T>
82OPimRecord* OTemplateBase<T>::record()const { 111OPimRecord* OTemplateBase<T>::record()const {
83 T* t = new T; 112 T* t = new T;
84 return t; 113 return t;
85} 114}
86template <class T> 115template <class T>
87OPimRecord* OTemplateBase<T>::record(int uid )const { 116OPimRecord* OTemplateBase<T>::record(int uid )const {
88 T t2 = find(uid ); 117 T t2 = find(uid );
89 T* t1 = new T(t2); 118 T* t1 = new T(t2);
90 119
91 return t1; 120 return t1;
92}; 121};
93template <class T> 122template <class T>
94T* OTemplateBase<T>::rec() { 123T* OTemplateBase<T>::rec() {
95 return new T; 124 return new T;
96} 125}
97 126
127}
128
98#endif 129#endif
diff --git a/libopie2/opiepim/core/otimezone.cpp b/libopie2/opiepim/core/otimezone.cpp
index 34659c3..dab68af 100644
--- a/libopie2/opiepim/core/otimezone.cpp
+++ b/libopie2/opiepim/core/otimezone.cpp
@@ -1,113 +1,146 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
1#include <stdio.h> 30#include <stdio.h>
2#include <stdlib.h> 31#include <stdlib.h>
3 32
4#include <sys/types.h> 33#include <sys/types.h>
5 34
6#include "otimezone.h" 35#include <opie2/otimezone.h>
7 36
8namespace { 37namespace Opie {
9 38
10 QDateTime utcTime( time_t t) { 39 QDateTime utcTime( time_t t) {
11 tm* broken = ::gmtime( &t ); 40 tm* broken = ::gmtime( &t );
12 QDateTime ret; 41 QDateTime ret;
13 ret.setDate( QDate( broken->tm_year + 1900, broken->tm_mon +1, broken->tm_mday ) ); 42 ret.setDate( QDate( broken->tm_year + 1900, broken->tm_mon +1, broken->tm_mday ) );
14 ret.setTime( QTime( broken->tm_hour, broken->tm_min, broken->tm_sec ) ); 43 ret.setTime( QTime( broken->tm_hour, broken->tm_min, broken->tm_sec ) );
15 return ret; 44 return ret;
16 } 45 }
17 QDateTime utcTime( time_t t, const QString& zone) { 46 QDateTime utcTime( time_t t, const QString& zone) {
18 QCString org = ::getenv( "TZ" ); 47 QCString org = ::getenv( "TZ" );
19#ifndef Q_OS_MACX // Following line causes bus errors on Mac 48#ifndef Q_OS_MACX // Following line causes bus errors on Mac
20 ::setenv( "TZ", zone.latin1(), true ); 49 ::setenv( "TZ", zone.latin1(), true );
21 ::tzset(); 50 ::tzset();
22 51
23 tm* broken = ::localtime( &t ); 52 tm* broken = ::localtime( &t );
24 ::setenv( "TZ", org, true ); 53 ::setenv( "TZ", org, true );
25#else 54#else
26#warning "Need a replacement for MacOSX!!" 55#warning "Need a replacement for MacOSX!!"
27 tm* broken = ::localtime( &t ); 56 tm* broken = ::localtime( &t );
28#endif 57#endif
29 58
30 QDateTime ret; 59 QDateTime ret;
31 ret.setDate( QDate( broken->tm_year + 1900, broken->tm_mon +1, broken->tm_mday ) ); 60 ret.setDate( QDate( broken->tm_year + 1900, broken->tm_mon +1, broken->tm_mday ) );
32 ret.setTime( QTime( broken->tm_hour, broken->tm_min, broken->tm_sec ) ); 61 ret.setTime( QTime( broken->tm_hour, broken->tm_min, broken->tm_sec ) );
33 62
34 return ret; 63 return ret;
35 } 64 }
36 time_t to_Time_t( const QDateTime& utc, const QString& str ) { 65 time_t to_Time_t( const QDateTime& utc, const QString& str ) {
37 QDate d = utc.date(); 66 QDate d = utc.date();
38 QTime t = utc.time(); 67 QTime t = utc.time();
39 68
40 tm broken; 69 tm broken;
41 broken.tm_year = d.year() - 1900; 70 broken.tm_year = d.year() - 1900;
42 broken.tm_mon = d.month() - 1; 71 broken.tm_mon = d.month() - 1;
43 broken.tm_mday = d.day(); 72 broken.tm_mday = d.day();
44 broken.tm_hour = t.hour(); 73 broken.tm_hour = t.hour();
45 broken.tm_min = t.minute(); 74 broken.tm_min = t.minute();
46 broken.tm_sec = t.second(); 75 broken.tm_sec = t.second();
47 76
48 QCString org = ::getenv( "TZ" ); 77 QCString org = ::getenv( "TZ" );
49#ifndef Q_OS_MACX // Following line causes bus errors on Mac 78#ifndef Q_OS_MACX // Following line causes bus errors on Mac
50 ::setenv( "TZ", str.latin1(), true ); 79 ::setenv( "TZ", str.latin1(), true );
51 ::tzset(); 80 ::tzset();
52 81
53 time_t ti = ::mktime( &broken ); 82 time_t ti = ::mktime( &broken );
54 ::setenv( "TZ", org, true ); 83 ::setenv( "TZ", org, true );
55#else 84#else
56#warning "Need a replacement for MacOSX!!" 85#warning "Need a replacement for MacOSX!!"
57 time_t ti = ::mktime( &broken ); 86 time_t ti = ::mktime( &broken );
58#endif 87#endif
59 return ti; 88 return ti;
60 } 89 }
61} 90}
91
92namespace Opie {
62OTimeZone::OTimeZone( const ZoneName& zone ) 93OTimeZone::OTimeZone( const ZoneName& zone )
63 : m_name(zone) { 94 : m_name(zone) {
64} 95}
65OTimeZone::~OTimeZone() { 96OTimeZone::~OTimeZone() {
66} 97}
67 98
68bool OTimeZone::isValid()const { 99bool OTimeZone::isValid()const {
69 return !m_name.isEmpty(); 100 return !m_name.isEmpty();
70} 101}
71 102
72/* 103/*
73 * we will get the current timezone 104 * we will get the current timezone
74 * and ask it to convert to the timezone date 105 * and ask it to convert to the timezone date
75 */ 106 */
76QDateTime OTimeZone::toLocalDateTime( const QDateTime& dt) { 107QDateTime OTimeZone::toLocalDateTime( const QDateTime& dt) {
77 return OTimeZone::current().toDateTime( dt, *this ); 108 return OTimeZone::current().toDateTime( dt, *this );
78} 109}
79QDateTime OTimeZone::toUTCDateTime( const QDateTime& dt ) { 110QDateTime OTimeZone::toUTCDateTime( const QDateTime& dt ) {
80 return OTimeZone::utc().toDateTime( dt, *this ); 111 return OTimeZone::utc().toDateTime( dt, *this );
81} 112}
82QDateTime OTimeZone::fromUTCDateTime( time_t t) { 113QDateTime OTimeZone::fromUTCDateTime( time_t t) {
83 return utcTime( t ); 114 return utcTime( t );
84} 115}
85QDateTime OTimeZone::toDateTime( time_t t) { 116QDateTime OTimeZone::toDateTime( time_t t) {
86 return utcTime( t, m_name ); 117 return utcTime( t, m_name );
87} 118}
88/* 119/*
89 * convert dt to utc using zone.m_name 120 * convert dt to utc using zone.m_name
90 * convert utc -> timeZoneDT using this->m_name 121 * convert utc -> timeZoneDT using this->m_name
91 */ 122 */
92QDateTime OTimeZone::toDateTime( const QDateTime& dt, const OTimeZone& zone ) { 123QDateTime OTimeZone::toDateTime( const QDateTime& dt, const OTimeZone& zone ) {
93 time_t utc = to_Time_t( dt, zone.m_name ); 124 time_t utc = to_Time_t( dt, zone.m_name );
94 qWarning("%d %s", utc, zone.m_name.latin1() ); 125 qWarning("%d %s", utc, zone.m_name.latin1() );
95 return utcTime( utc, m_name ); 126 return utcTime( utc, m_name );
96} 127}
97time_t OTimeZone::fromDateTime( const QDateTime& time ) { 128time_t OTimeZone::fromDateTime( const QDateTime& time ) {
98 return to_Time_t( time, m_name ); 129 return to_Time_t( time, m_name );
99} 130}
100time_t OTimeZone::fromUTCDateTime( const QDateTime& time ) { 131time_t OTimeZone::fromUTCDateTime( const QDateTime& time ) {
101 return to_Time_t( time, "UTC" ); 132 return to_Time_t( time, "UTC" );
102} 133}
103OTimeZone OTimeZone::current() { 134OTimeZone OTimeZone::current() {
104 QCString str = ::getenv("TZ"); 135 QCString str = ::getenv("TZ");
105 OTimeZone zone( str ); 136 OTimeZone zone( str );
106 return zone; 137 return zone;
107} 138}
108OTimeZone OTimeZone::utc() { 139OTimeZone OTimeZone::utc() {
109 return OTimeZone("UTC"); 140 return OTimeZone("UTC");
110} 141}
111QString OTimeZone::timeZone()const { 142QString OTimeZone::timeZone()const {
112 return m_name; 143 return m_name;
113} 144}
145
146}
diff --git a/libopie2/opiepim/core/otimezone.h b/libopie2/opiepim/core/otimezone.h
index bb08349..28ae6cb 100644
--- a/libopie2/opiepim/core/otimezone.h
+++ b/libopie2/opiepim/core/otimezone.h
@@ -1,71 +1,102 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
1#ifndef OPIE_TIME_ZONE_H 30#ifndef OPIE_TIME_ZONE_H
2#define OPIE_TIME_ZONE_H 31#define OPIE_TIME_ZONE_H
3 32
4#include <time.h> 33#include <time.h>
5#include <qdatetime.h> 34#include <qdatetime.h>
6 35
36namespace Opie
37{
7/** 38/**
8 * A very primitive class to convert time 39 * A very primitive class to convert time
9 * from one timezone to another 40 * from one timezone to another
10 * and to localtime 41 * and to localtime
11 * and time_t 42 * and time_t
12 */ 43 */
13class OTimeZone { 44class OTimeZone {
14 public: 45 public:
15 typedef QString ZoneName; 46 typedef QString ZoneName;
16 OTimeZone( const ZoneName& = ZoneName::null ); 47 OTimeZone( const ZoneName& = ZoneName::null );
17 virtual ~OTimeZone(); // just in case. 48 virtual ~OTimeZone(); // just in case.
18 49
19 bool isValid()const; 50 bool isValid()const;
20 51
21 /** 52 /**
22 * converts the QDateTime to a DateTime 53 * converts the QDateTime to a DateTime
23 * in the local timezone 54 * in the local timezone
24 * if QDateTime is 25th Jan and takes place in Europe/Berlin at 12h 55 * if QDateTime is 25th Jan and takes place in Europe/Berlin at 12h
25 * and the current timezone is Europe/London the returned 56 * and the current timezone is Europe/London the returned
26 * time will be 11h. 57 * time will be 11h.
27 */ 58 */
28 QDateTime toLocalDateTime( const QDateTime& dt ); 59 QDateTime toLocalDateTime( const QDateTime& dt );
29 60
30 /** 61 /**
31 * converts the QDateTime to UTC time 62 * converts the QDateTime to UTC time
32 */ 63 */
33 QDateTime toUTCDateTime( const QDateTime& dt ); 64 QDateTime toUTCDateTime( const QDateTime& dt );
34 65
35 /** 66 /**
36 * reads the time_t into a QDateTime using UTC as timezone! 67 * reads the time_t into a QDateTime using UTC as timezone!
37 */ 68 */
38 QDateTime fromUTCDateTime( time_t ); 69 QDateTime fromUTCDateTime( time_t );
39 70
40 /** 71 /**
41 * converts the time_t to the time in the timezone 72 * converts the time_t to the time in the timezone
42 */ 73 */
43 QDateTime toDateTime( time_t ); 74 QDateTime toDateTime( time_t );
44 75
45 /** 76 /**
46 * converts the QDateTime from one timezone to this timeZone 77 * converts the QDateTime from one timezone to this timeZone
47 */ 78 */
48 QDateTime toDateTime( const QDateTime&, const OTimeZone& timeZone ); 79 QDateTime toDateTime( const QDateTime&, const OTimeZone& timeZone );
49 80
50 /** 81 /**
51 * converts the date time into a time_t. It takes the timezone into account 82 * converts the date time into a time_t. It takes the timezone into account
52 */ 83 */
53 time_t fromDateTime( const QDateTime& ); 84 time_t fromDateTime( const QDateTime& );
54 85
55 /** 86 /**
56 * converts the datetime with timezone UTC 87 * converts the datetime with timezone UTC
57 */ 88 */
58 time_t fromUTCDateTime( const QDateTime& ); 89 time_t fromUTCDateTime( const QDateTime& );
59 90
60 static OTimeZone current(); 91 static OTimeZone current();
61 static OTimeZone utc(); 92 static OTimeZone utc();
62 93
63 QString timeZone()const; 94 QString timeZone()const;
64 private: 95 private:
65 ZoneName m_name; 96 ZoneName m_name;
66 class Private; 97 class Private;
67 Private* d; 98 Private* d;
68}; 99};
69 100};
70 101
71#endif 102#endif
diff --git a/libopie2/opiepim/core/otodoaccess.cpp b/libopie2/opiepim/core/otodoaccess.cpp
index 37f6fbc..2a3695d 100644
--- a/libopie2/opiepim/core/otodoaccess.cpp
+++ b/libopie2/opiepim/core/otodoaccess.cpp
@@ -1,62 +1,93 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qdatetime.h> 29#include <qdatetime.h>
2 30
3#include <qpe/alarmserver.h> 31#include <qpe/alarmserver.h>
4 32
5// #include "otodoaccesssql.h" 33// #include "otodoaccesssql.h"
6#include "otodoaccess.h" 34#include <opie2/otodoaccess.h>
7#include "obackendfactory.h" 35#include <opie2/obackendfactory.h>
8 36
37namespace Opie {
9OTodoAccess::OTodoAccess( OTodoAccessBackend* end, enum Access ) 38OTodoAccess::OTodoAccess( OTodoAccessBackend* end, enum Access )
10 : QObject(), OPimAccessTemplate<OTodo>( end ), m_todoBackEnd( end ) 39 : QObject(), OPimAccessTemplate<OTodo>( end ), m_todoBackEnd( end )
11{ 40{
12// if (end == 0l ) 41// if (end == 0l )
13// m_todoBackEnd = new OTodoAccessBackendSQL( QString::null); 42// m_todoBackEnd = new OTodoAccessBackendSQL( QString::null);
14 43
15 // Zecke: Du musst hier noch für das XML-Backend einen Appnamen übergeben ! 44 // Zecke: Du musst hier noch fr das XML-Backend einen Appnamen bergeben !
16 if (end == 0l ) 45 if (end == 0l )
17 m_todoBackEnd = OBackendFactory<OTodoAccessBackend>::Default ("todo", QString::null); 46 m_todoBackEnd = OBackendFactory<OTodoAccessBackend>::Default ("todo", QString::null);
18 47
19 setBackEnd( m_todoBackEnd ); 48 setBackEnd( m_todoBackEnd );
20} 49}
21OTodoAccess::~OTodoAccess() { 50OTodoAccess::~OTodoAccess() {
22// qWarning("~OTodoAccess"); 51// qWarning("~OTodoAccess");
23} 52}
24void OTodoAccess::mergeWith( const QValueList<OTodo>& list ) { 53void OTodoAccess::mergeWith( const QValueList<OTodo>& list ) {
25 QValueList<OTodo>::ConstIterator it; 54 QValueList<OTodo>::ConstIterator it;
26 for ( it = list.begin(); it != list.end(); ++it ) { 55 for ( it = list.begin(); it != list.end(); ++it ) {
27 replace( (*it) ); 56 replace( (*it) );
28 } 57 }
29} 58}
30OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, 59OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start,
31 const QDate& end, 60 const QDate& end,
32 bool includeNoDates ) { 61 bool includeNoDates ) {
33 QArray<int> ints = m_todoBackEnd->effectiveToDos( start, end, includeNoDates ); 62 QArray<int> ints = m_todoBackEnd->effectiveToDos( start, end, includeNoDates );
34 63
35 List lis( ints, this ); 64 List lis( ints, this );
36 return lis; 65 return lis;
37} 66}
38OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, 67OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start,
39 bool includeNoDates ) { 68 bool includeNoDates ) {
40 return effectiveToDos( start, QDate::currentDate(), 69 return effectiveToDos( start, QDate::currentDate(),
41 includeNoDates ); 70 includeNoDates );
42} 71}
43OTodoAccess::List OTodoAccess::overDue() { 72OTodoAccess::List OTodoAccess::overDue() {
44 List lis( m_todoBackEnd->overDue(), this ); 73 List lis( m_todoBackEnd->overDue(), this );
45 return lis; 74 return lis;
46} 75}
47/* sort order */ 76/* sort order */
48OTodoAccess::List OTodoAccess::sorted( bool ascending, int sort,int filter, int cat ) { 77OTodoAccess::List OTodoAccess::sorted( bool ascending, int sort,int filter, int cat ) {
49 QArray<int> ints = m_todoBackEnd->sorted( ascending, sort, 78 QArray<int> ints = m_todoBackEnd->sorted( ascending, sort,
50 filter, cat ); 79 filter, cat );
51 OTodoAccess::List list( ints, this ); 80 OTodoAccess::List list( ints, this );
52 return list; 81 return list;
53} 82}
54void OTodoAccess::removeAllCompleted() { 83void OTodoAccess::removeAllCompleted() {
55 m_todoBackEnd->removeAllCompleted(); 84 m_todoBackEnd->removeAllCompleted();
56} 85}
57QBitArray OTodoAccess::backendSupport( const QString& ) const{ 86QBitArray OTodoAccess::backendSupport( const QString& ) const{
58 return m_todoBackEnd->supports(); 87 return m_todoBackEnd->supports();
59} 88}
60bool OTodoAccess::backendSupports( int attr, const QString& ar) const{ 89bool OTodoAccess::backendSupports( int attr, const QString& ar) const{
61 return backendSupport(ar).testBit( attr ); 90 return backendSupport(ar).testBit( attr );
62} 91}
92
93}
diff --git a/libopie2/opiepim/core/otodoaccess.h b/libopie2/opiepim/core/otodoaccess.h
index 916923f..e13d277 100644
--- a/libopie2/opiepim/core/otodoaccess.h
+++ b/libopie2/opiepim/core/otodoaccess.h
@@ -1,105 +1,136 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_TODO_ACCESS_H 29#ifndef OPIE_TODO_ACCESS_H
2#define OPIE_TODO_ACCESS_H 30#define OPIE_TODO_ACCESS_H
3 31
4#include <qobject.h> 32#include <qobject.h>
5#include <qvaluelist.h> 33#include <qvaluelist.h>
6 34
7#include "otodo.h" 35#include <opie2/otodo.h>
8#include "otodoaccessbackend.h" 36#include <opie2/otodoaccessbackend.h>
9#include "opimaccesstemplate.h" 37#include <opie2/opimaccesstemplate.h>
10 38
39namespace Opie {
11 40
12/** 41/**
13 * OTodoAccess 42 * OTodoAccess
14 * the class to get access to 43 * the class to get access to
15 * the todolist 44 * the todolist
16 */ 45 */
17class OTodoAccess : public QObject, public OPimAccessTemplate<OTodo> { 46class OTodoAccess : public QObject, public OPimAccessTemplate<OTodo> {
18 Q_OBJECT 47 Q_OBJECT
19public: 48public:
20 enum SortOrder { Completed = 0, 49 enum SortOrder { Completed = 0,
21 Priority, 50 Priority,
22 Description, 51 Description,
23 Deadline }; 52 Deadline };
24 enum SortFilter{ Category =1, 53 enum SortFilter{ Category =1,
25 OnlyOverDue= 2, 54 OnlyOverDue= 2,
26 DoNotShowCompleted =4 }; 55 DoNotShowCompleted =4 };
27 /** 56 /**
28 * if you use 0l 57 * if you use 0l
29 * the default resource will be 58 * the default resource will be
30 * picked up 59 * picked up
31 */ 60 */
32 OTodoAccess( OTodoAccessBackend* = 0l, enum Access acc = Random ); 61 OTodoAccess( OTodoAccessBackend* = 0l, enum Access acc = Random );
33 ~OTodoAccess(); 62 ~OTodoAccess();
34 63
35 64
36 /* our functions here */ 65 /* our functions here */
37 /** 66 /**
38 * include todos from start to end 67 * include todos from start to end
39 * includeNoDates whether or not to include 68 * includeNoDates whether or not to include
40 * events with no dates 69 * events with no dates
41 */ 70 */
42 List effectiveToDos( const QDate& start, 71 List effectiveToDos( const QDate& start,
43 const QDate& end, 72 const QDate& end,
44 bool includeNoDates = true ); 73 bool includeNoDates = true );
45 74
46 /** 75 /**
47 * start 76 * start
48 * end date taken from the currentDate() 77 * end date taken from the currentDate()
49 */ 78 */
50 List effectiveToDos( const QDate& start, 79 List effectiveToDos( const QDate& start,
51 bool includeNoDates = true ); 80 bool includeNoDates = true );
52 81
53 82
54 /** 83 /**
55 * return overdue OTodos 84 * return overdue OTodos
56 */ 85 */
57 List overDue(); 86 List overDue();
58 87
59 /** 88 /**
60 * 89 *
61 */ 90 */
62 List sorted( bool ascending, int sortOrder, int sortFilter, int cat ); 91 List sorted( bool ascending, int sortOrder, int sortFilter, int cat );
63 92
64 /** 93 /**
65 * merge a list of OTodos into 94 * merge a list of OTodos into
66 * the resource 95 * the resource
67 */ 96 */
68 void mergeWith( const QValueList<OTodo>& ); 97 void mergeWith( const QValueList<OTodo>& );
69 98
70 /** 99 /**
71 * delete all already completed items 100 * delete all already completed items
72 */ 101 */
73 void removeAllCompleted(); 102 void removeAllCompleted();
74 103
75 /** 104 /**
76 * request information about what a backend supports. 105 * request information about what a backend supports.
77 * Supports in the sense of beeing able to store. 106 * Supports in the sense of beeing able to store.
78 * This is related to the enum in OTodo 107 * This is related to the enum in OTodo
79 * 108 *
80 * @param backend Will be used in the future when we support multiple backend 109 * @param backend Will be used in the future when we support multiple backend
81 */ 110 */
82 QBitArray backendSupport( const QString& backend = QString::null )const; 111 QBitArray backendSupport( const QString& backend = QString::null )const;
83 112
84 /** 113 /**
85 * see above but for a specefic attribute. This method was added for convience 114 * see above but for a specefic attribute. This method was added for convience
86 * @param attr The attribute to be queried for 115 * @param attr The attribute to be queried for
87 * @param backend Will be used in the future when we support multiple backends 116 * @param backend Will be used in the future when we support multiple backends
88 */ 117 */
89 bool backendSupports( int attr, const QString& backend = QString::null )const; 118 bool backendSupports( int attr, const QString& backend = QString::null )const;
90signals: 119signals:
91 /** 120 /**
92 * if the OTodoAccess was changed 121 * if the OTodoAccess was changed
93 */ 122 */
94 void changed( const OTodoAccess* ); 123 void changed( const OTodoAccess* );
95 void changed( const OTodoAccess*, int uid ); 124 void changed( const OTodoAccess*, int uid );
96 void added( const OTodoAccess*, int uid ); 125 void added( const OTodoAccess*, int uid );
97 void removed( const OTodoAccess*, int uid ); 126 void removed( const OTodoAccess*, int uid );
98private: 127private:
99 int m_cat; 128 int m_cat;
100 OTodoAccessBackend* m_todoBackEnd; 129 OTodoAccessBackend* m_todoBackEnd;
101 class OTodoAccessPrivate; 130 class OTodoAccessPrivate;
102 OTodoAccessPrivate* d; 131 OTodoAccessPrivate* d;
103}; 132};
104 133
134}
135
105#endif 136#endif
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp
index fcf3b26..f1a22a7 100644
--- a/libopie2/opiepim/ocontact.cpp
+++ b/libopie2/opiepim/ocontact.cpp
@@ -1,1207 +1,1238 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
29
1/********************************************************************** 30/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 31** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) 32** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de)
4** 33**
5** This file may be distributed and/or modified under the terms of the 34** This file may be distributed and/or modified under the terms of the
6** GNU General Public License version 2 as published by the Free Software 35** GNU General Public License version 2 as published by the Free Software
7** Foundation and appearing in the file LICENSE.GPL included in the 36** Foundation and appearing in the file LICENSE.GPL included in the
8** packaging of this file. 37** packaging of this file.
9** 38**
10** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 39** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
11** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 40** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
12** 41**
13** See http://www.trolltech.com/gpl/ for GPL licensing information. 42** See http://www.trolltech.com/gpl/ for GPL licensing information.
14** 43**
15** Contact info@trolltech.com if any conditions of this licensing are 44** Contact info@trolltech.com if any conditions of this licensing are
16** not clear to you. 45** not clear to you.
17** 46**
18**********************************************************************/ 47**********************************************************************/
19 48
20#define QTOPIA_INTERNAL_CONTACT_MRE 49#define QTOPIA_INTERNAL_CONTACT_MRE
21 50
22#include "ocontact.h" 51#include <opie2/ocontact.h>
23#include "opimresolver.h" 52#include <opie2/opimresolver.h>
24#include "oconversion.h" 53#include <opie2/oconversion.h>
25 54
26#include <qpe/stringutil.h> 55#include <qpe/stringutil.h>
27#include <qpe/timestring.h> 56#include <qpe/timestring.h>
28#include <qpe/config.h> 57#include <qpe/config.h>
29 58
30#include <qobject.h> 59#include <qobject.h>
31#include <qregexp.h> 60#include <qregexp.h>
32#include <qstylesheet.h> 61#include <qstylesheet.h>
33#include <qfileinfo.h> 62#include <qfileinfo.h>
34#include <qmap.h> 63#include <qmap.h>
35 64
36#include <stdio.h> 65#include <stdio.h>
37 66
38/*! 67/*!
39 \class Contact contact.h 68 \class Contact contact.h
40 \brief The Contact class holds the data of an address book entry. 69 \brief The Contact class holds the data of an address book entry.
41 70
42 This data includes information the name of the person, contact 71 This data includes information the name of the person, contact
43 information, and business information such as deparment and job title. 72 information, and business information such as deparment and job title.
44 73
45 \ingroup qtopiaemb 74 \ingroup qtopiaemb
46 \ingroup qtopiadesktop 75 \ingroup qtopiadesktop
47*/ 76*/
48 77
49 78
79namespace Opie {
50/*! 80/*!
51 Creates a new, empty contact. 81 Creates a new, empty contact.
52*/ 82*/
53OContact::OContact() 83OContact::OContact()
54 : OPimRecord(), mMap(), d( 0 ) 84 : OPimRecord(), mMap(), d( 0 )
55{ 85{
56} 86}
57 87
58/*! 88/*!
59 \internal 89 \internal
60 Creates a new contact. The properties of the contact are 90 Creates a new contact. The properties of the contact are
61 set from \a fromMap. 91 set from \a fromMap.
62*/ 92*/
63OContact::OContact( const QMap<int, QString> &fromMap ) : 93OContact::OContact( const QMap<int, QString> &fromMap ) :
64 OPimRecord(), mMap( fromMap ), d( 0 ) 94 OPimRecord(), mMap( fromMap ), d( 0 )
65{ 95{
66 QString cats = mMap[ Qtopia::AddressCategory ]; 96 QString cats = mMap[ Qtopia::AddressCategory ];
67 if ( !cats.isEmpty() ) 97 if ( !cats.isEmpty() )
68 setCategories( idsFromString( cats ) ); 98 setCategories( idsFromString( cats ) );
69 99
70 QString uidStr = find( Qtopia::AddressUid ); 100 QString uidStr = find( Qtopia::AddressUid );
71 101
72 if ( uidStr.isEmpty() || (uidStr.toInt() == 0) ){ 102 if ( uidStr.isEmpty() || (uidStr.toInt() == 0) ){
73 qWarning( "Invalid UID found. Generate new one.." ); 103 qWarning( "Invalid UID found. Generate new one.." );
74 setUid( uidGen().generate() ); 104 setUid( uidGen().generate() );
75 }else 105 }else
76 setUid( uidStr.toInt() ); 106 setUid( uidStr.toInt() );
77 107
78// if ( !uidStr.isEmpty() ) 108// if ( !uidStr.isEmpty() )
79 // setUid( uidStr.toInt() ); 109 // setUid( uidStr.toInt() );
80} 110}
81 111
82/*! 112/*!
83 Destroys a contact. 113 Destroys a contact.
84*/ 114*/
85OContact::~OContact() 115OContact::~OContact()
86{ 116{
87} 117}
88 118
89/*! \fn void OContact::setTitle( const QString &str ) 119/*! \fn void OContact::setTitle( const QString &str )
90 Sets the title of the contact to \a str. 120 Sets the title of the contact to \a str.
91*/ 121*/
92 122
93/*! \fn void OContact::setFirstName( const QString &str ) 123/*! \fn void OContact::setFirstName( const QString &str )
94 Sets the first name of the contact to \a str. 124 Sets the first name of the contact to \a str.
95*/ 125*/
96 126
97/*! \fn void OContact::setMiddleName( const QString &str ) 127/*! \fn void OContact::setMiddleName( const QString &str )
98 Sets the middle name of the contact to \a str. 128 Sets the middle name of the contact to \a str.
99*/ 129*/
100 130
101/*! \fn void OContact::setLastName( const QString &str ) 131/*! \fn void OContact::setLastName( const QString &str )
102 Sets the last name of the contact to \a str. 132 Sets the last name of the contact to \a str.
103*/ 133*/
104 134
105/*! \fn void OContact::setSuffix( const QString &str ) 135/*! \fn void OContact::setSuffix( const QString &str )
106 Sets the suffix of the contact to \a str. 136 Sets the suffix of the contact to \a str.
107*/ 137*/
108 138
109/*! \fn void OContact::setFileAs( const QString &str ) 139/*! \fn void OContact::setFileAs( const QString &str )
110 Sets the contact to filed as \a str. 140 Sets the contact to filed as \a str.
111*/ 141*/
112 142
113/*! \fn void OContact::setDefaultEmail( const QString &str ) 143/*! \fn void OContact::setDefaultEmail( const QString &str )
114 Sets the default email of the contact to \a str. 144 Sets the default email of the contact to \a str.
115*/ 145*/
116 146
117/*! \fn void OContact::setHomeStreet( const QString &str ) 147/*! \fn void OContact::setHomeStreet( const QString &str )
118 Sets the home street address of the contact to \a str. 148 Sets the home street address of the contact to \a str.
119*/ 149*/
120 150
121/*! \fn void OContact::setHomeCity( const QString &str ) 151/*! \fn void OContact::setHomeCity( const QString &str )
122 Sets the home city of the contact to \a str. 152 Sets the home city of the contact to \a str.
123*/ 153*/
124 154
125/*! \fn void OContact::setHomeState( const QString &str ) 155/*! \fn void OContact::setHomeState( const QString &str )
126 Sets the home state of the contact to \a str. 156 Sets the home state of the contact to \a str.
127*/ 157*/
128 158
129/*! \fn void OContact::setHomeZip( const QString &str ) 159/*! \fn void OContact::setHomeZip( const QString &str )
130 Sets the home zip code of the contact to \a str. 160 Sets the home zip code of the contact to \a str.
131*/ 161*/
132 162
133/*! \fn void OContact::setHomeCountry( const QString &str ) 163/*! \fn void OContact::setHomeCountry( const QString &str )
134 Sets the home country of the contact to \a str. 164 Sets the home country of the contact to \a str.
135*/ 165*/
136 166
137/*! \fn void OContact::setHomePhone( const QString &str ) 167/*! \fn void OContact::setHomePhone( const QString &str )
138 Sets the home phone number of the contact to \a str. 168 Sets the home phone number of the contact to \a str.
139*/ 169*/
140 170
141/*! \fn void OContact::setHomeFax( const QString &str ) 171/*! \fn void OContact::setHomeFax( const QString &str )
142 Sets the home fax number of the contact to \a str. 172 Sets the home fax number of the contact to \a str.
143*/ 173*/
144 174
145/*! \fn void OContact::setHomeMobile( const QString &str ) 175/*! \fn void OContact::setHomeMobile( const QString &str )
146 Sets the home mobile phone number of the contact to \a str. 176 Sets the home mobile phone number of the contact to \a str.
147*/ 177*/
148 178
149/*! \fn void OContact::setHomeWebpage( const QString &str ) 179/*! \fn void OContact::setHomeWebpage( const QString &str )
150 Sets the home webpage of the contact to \a str. 180 Sets the home webpage of the contact to \a str.
151*/ 181*/
152 182
153/*! \fn void OContact::setCompany( const QString &str ) 183/*! \fn void OContact::setCompany( const QString &str )
154 Sets the company for contact to \a str. 184 Sets the company for contact to \a str.
155*/ 185*/
156 186
157/*! \fn void OContact::setJobTitle( const QString &str ) 187/*! \fn void OContact::setJobTitle( const QString &str )
158 Sets the job title of the contact to \a str. 188 Sets the job title of the contact to \a str.
159*/ 189*/
160 190
161/*! \fn void OContact::setDepartment( const QString &str ) 191/*! \fn void OContact::setDepartment( const QString &str )
162 Sets the department for contact to \a str. 192 Sets the department for contact to \a str.
163*/ 193*/
164 194
165/*! \fn void OContact::setOffice( const QString &str ) 195/*! \fn void OContact::setOffice( const QString &str )
166 Sets the office for contact to \a str. 196 Sets the office for contact to \a str.
167*/ 197*/
168 198
169/*! \fn void OContact::setBusinessStreet( const QString &str ) 199/*! \fn void OContact::setBusinessStreet( const QString &str )
170 Sets the business street address of the contact to \a str. 200 Sets the business street address of the contact to \a str.
171*/ 201*/
172 202
173/*! \fn void OContact::setBusinessCity( const QString &str ) 203/*! \fn void OContact::setBusinessCity( const QString &str )
174 Sets the business city of the contact to \a str. 204 Sets the business city of the contact to \a str.
175*/ 205*/
176 206
177/*! \fn void OContact::setBusinessState( const QString &str ) 207/*! \fn void OContact::setBusinessState( const QString &str )
178 Sets the business state of the contact to \a str. 208 Sets the business state of the contact to \a str.
179*/ 209*/
180 210
181/*! \fn void OContact::setBusinessZip( const QString &str ) 211/*! \fn void OContact::setBusinessZip( const QString &str )
182 Sets the business zip code of the contact to \a str. 212 Sets the business zip code of the contact to \a str.
183*/ 213*/
184 214
185/*! \fn void OContact::setBusinessCountry( const QString &str ) 215/*! \fn void OContact::setBusinessCountry( const QString &str )
186 Sets the business country of the contact to \a str. 216 Sets the business country of the contact to \a str.
187*/ 217*/
188 218
189/*! \fn void OContact::setBusinessPhone( const QString &str ) 219/*! \fn void OContact::setBusinessPhone( const QString &str )
190 Sets the business phone number of the contact to \a str. 220 Sets the business phone number of the contact to \a str.
191*/ 221*/
192 222
193/*! \fn void OContact::setBusinessFax( const QString &str ) 223/*! \fn void OContact::setBusinessFax( const QString &str )
194 Sets the business fax number of the contact to \a str. 224 Sets the business fax number of the contact to \a str.
195*/ 225*/
196 226
197/*! \fn void OContact::setBusinessMobile( const QString &str ) 227/*! \fn void OContact::setBusinessMobile( const QString &str )
198 Sets the business mobile phone number of the contact to \a str. 228 Sets the business mobile phone number of the contact to \a str.
199*/ 229*/
200 230
201/*! \fn void OContact::setBusinessPager( const QString &str ) 231/*! \fn void OContact::setBusinessPager( const QString &str )
202 Sets the business pager number of the contact to \a str. 232 Sets the business pager number of the contact to \a str.
203*/ 233*/
204 234
205/*! \fn void OContact::setBusinessWebpage( const QString &str ) 235/*! \fn void OContact::setBusinessWebpage( const QString &str )
206 Sets the business webpage of the contact to \a str. 236 Sets the business webpage of the contact to \a str.
207*/ 237*/
208 238
209/*! \fn void OContact::setProfession( const QString &str ) 239/*! \fn void OContact::setProfession( const QString &str )
210 Sets the profession of the contact to \a str. 240 Sets the profession of the contact to \a str.
211*/ 241*/
212 242
213/*! \fn void OContact::setAssistant( const QString &str ) 243/*! \fn void OContact::setAssistant( const QString &str )
214 Sets the assistant of the contact to \a str. 244 Sets the assistant of the contact to \a str.
215*/ 245*/
216 246
217/*! \fn void OContact::setManager( const QString &str ) 247/*! \fn void OContact::setManager( const QString &str )
218 Sets the manager of the contact to \a str. 248 Sets the manager of the contact to \a str.
219*/ 249*/
220 250
221/*! \fn void OContact::setSpouse( const QString &str ) 251/*! \fn void OContact::setSpouse( const QString &str )
222 Sets the spouse of the contact to \a str. 252 Sets the spouse of the contact to \a str.
223*/ 253*/
224 254
225/*! \fn void OContact::setGender( const QString &str ) 255/*! \fn void OContact::setGender( const QString &str )
226 Sets the gender of the contact to \a str. 256 Sets the gender of the contact to \a str.
227*/ 257*/
228 258
229/*! \fn void OContact::setNickname( const QString &str ) 259/*! \fn void OContact::setNickname( const QString &str )
230 Sets the nickname of the contact to \a str. 260 Sets the nickname of the contact to \a str.
231*/ 261*/
232 262
233/*! \fn void OContact::setNotes( const QString &str ) 263/*! \fn void OContact::setNotes( const QString &str )
234 Sets the notes about the contact to \a str. 264 Sets the notes about the contact to \a str.
235*/ 265*/
236 266
237/*! \fn QString OContact::title() const 267/*! \fn QString OContact::title() const
238 Returns the title of the contact. 268 Returns the title of the contact.
239*/ 269*/
240 270
241/*! \fn QString OContact::firstName() const 271/*! \fn QString OContact::firstName() const
242 Returns the first name of the contact. 272 Returns the first name of the contact.
243*/ 273*/
244 274
245/*! \fn QString OContact::middleName() const 275/*! \fn QString OContact::middleName() const
246 Returns the middle name of the contact. 276 Returns the middle name of the contact.
247*/ 277*/
248 278
249/*! \fn QString OContact::lastName() const 279/*! \fn QString OContact::lastName() const
250 Returns the last name of the contact. 280 Returns the last name of the contact.
251*/ 281*/
252 282
253/*! \fn QString OContact::suffix() const 283/*! \fn QString OContact::suffix() const
254 Returns the suffix of the contact. 284 Returns the suffix of the contact.
255*/ 285*/
256 286
257/*! \fn QString OContact::fileAs() const 287/*! \fn QString OContact::fileAs() const
258 Returns the string the contact is filed as. 288 Returns the string the contact is filed as.
259*/ 289*/
260 290
261/*! \fn QString OContact::defaultEmail() const 291/*! \fn QString OContact::defaultEmail() const
262 Returns the default email address of the contact. 292 Returns the default email address of the contact.
263*/ 293*/
264 294
265/*! \fn QString OContact::emails() const 295/*! \fn QString OContact::emails() const
266 Returns the list of email address for a contact separated by ';'s in a single 296 Returns the list of email address for a contact separated by ';'s in a single
267 string. 297 string.
268*/ 298*/
269 299
270/*! \fn QString OContact::homeStreet() const 300/*! \fn QString OContact::homeStreet() const
271 Returns the home street address of the contact. 301 Returns the home street address of the contact.
272*/ 302*/
273 303
274/*! \fn QString OContact::homeCity() const 304/*! \fn QString OContact::homeCity() const
275 Returns the home city of the contact. 305 Returns the home city of the contact.
276*/ 306*/
277 307
278/*! \fn QString OContact::homeState() const 308/*! \fn QString OContact::homeState() const
279 Returns the home state of the contact. 309 Returns the home state of the contact.
280*/ 310*/
281 311
282/*! \fn QString OContact::homeZip() const 312/*! \fn QString OContact::homeZip() const
283 Returns the home zip of the contact. 313 Returns the home zip of the contact.
284*/ 314*/
285 315
286/*! \fn QString OContact::homeCountry() const 316/*! \fn QString OContact::homeCountry() const
287 Returns the home country of the contact. 317 Returns the home country of the contact.
288*/ 318*/
289 319
290/*! \fn QString OContact::homePhone() const 320/*! \fn QString OContact::homePhone() const
291 Returns the home phone number of the contact. 321 Returns the home phone number of the contact.
292*/ 322*/
293 323
294/*! \fn QString OContact::homeFax() const 324/*! \fn QString OContact::homeFax() const
295 Returns the home fax number of the contact. 325 Returns the home fax number of the contact.
296*/ 326*/
297 327
298/*! \fn QString OContact::homeMobile() const 328/*! \fn QString OContact::homeMobile() const
299 Returns the home mobile number of the contact. 329 Returns the home mobile number of the contact.
300*/ 330*/
301 331
302/*! \fn QString OContact::homeWebpage() const 332/*! \fn QString OContact::homeWebpage() const
303 Returns the home webpage of the contact. 333 Returns the home webpage of the contact.
304*/ 334*/
305 335
306/*! \fn QString OContact::company() const 336/*! \fn QString OContact::company() const
307 Returns the company for the contact. 337 Returns the company for the contact.
308*/ 338*/
309 339
310/*! \fn QString OContact::department() const 340/*! \fn QString OContact::department() const
311 Returns the department for the contact. 341 Returns the department for the contact.
312*/ 342*/
313 343
314/*! \fn QString OContact::office() const 344/*! \fn QString OContact::office() const
315 Returns the office for the contact. 345 Returns the office for the contact.
316*/ 346*/
317 347
318/*! \fn QString OContact::jobTitle() const 348/*! \fn QString OContact::jobTitle() const
319 Returns the job title of the contact. 349 Returns the job title of the contact.
320*/ 350*/
321 351
322/*! \fn QString OContact::profession() const 352/*! \fn QString OContact::profession() const
323 Returns the profession of the contact. 353 Returns the profession of the contact.
324*/ 354*/
325 355
326/*! \fn QString OContact::assistant() const 356/*! \fn QString OContact::assistant() const
327 Returns the assistant of the contact. 357 Returns the assistant of the contact.
328*/ 358*/
329 359
330/*! \fn QString OContact::manager() const 360/*! \fn QString OContact::manager() const
331 Returns the manager of the contact. 361 Returns the manager of the contact.
332*/ 362*/
333 363
334/*! \fn QString OContact::businessStreet() const 364/*! \fn QString OContact::businessStreet() const
335 Returns the business street address of the contact. 365 Returns the business street address of the contact.
336*/ 366*/
337 367
338/*! \fn QString OContact::businessCity() const 368/*! \fn QString OContact::businessCity() const
339 Returns the business city of the contact. 369 Returns the business city of the contact.
340*/ 370*/
341 371
342/*! \fn QString OContact::businessState() const 372/*! \fn QString OContact::businessState() const
343 Returns the business state of the contact. 373 Returns the business state of the contact.
344*/ 374*/
345 375
346/*! \fn QString OContact::businessZip() const 376/*! \fn QString OContact::businessZip() const
347 Returns the business zip of the contact. 377 Returns the business zip of the contact.
348*/ 378*/
349 379
350/*! \fn QString OContact::businessCountry() const 380/*! \fn QString OContact::businessCountry() const
351 Returns the business country of the contact. 381 Returns the business country of the contact.
352*/ 382*/
353 383
354/*! \fn QString OContact::businessPhone() const 384/*! \fn QString OContact::businessPhone() const
355 Returns the business phone number of the contact. 385 Returns the business phone number of the contact.
356*/ 386*/
357 387
358/*! \fn QString OContact::businessFax() const 388/*! \fn QString OContact::businessFax() const
359 Returns the business fax number of the contact. 389 Returns the business fax number of the contact.
360*/ 390*/
361 391
362/*! \fn QString OContact::businessMobile() const 392/*! \fn QString OContact::businessMobile() const
363 Returns the business mobile number of the contact. 393 Returns the business mobile number of the contact.
364*/ 394*/
365 395
366/*! \fn QString OContact::businessPager() const 396/*! \fn QString OContact::businessPager() const
367 Returns the business pager number of the contact. 397 Returns the business pager number of the contact.
368*/ 398*/
369 399
370/*! \fn QString OContact::businessWebpage() const 400/*! \fn QString OContact::businessWebpage() const
371 Returns the business webpage of the contact. 401 Returns the business webpage of the contact.
372*/ 402*/
373 403
374/*! \fn QString OContact::spouse() const 404/*! \fn QString OContact::spouse() const
375 Returns the spouse of the contact. 405 Returns the spouse of the contact.
376*/ 406*/
377 407
378/*! \fn QString OContact::gender() const 408/*! \fn QString OContact::gender() const
379 Returns the gender of the contact. 409 Returns the gender of the contact.
380*/ 410*/
381 411
382/*! \fn QString OContact::nickname() const 412/*! \fn QString OContact::nickname() const
383 Returns the nickname of the contact. 413 Returns the nickname of the contact.
384*/ 414*/
385 415
386/*! \fn QString OContact::children() const 416/*! \fn QString OContact::children() const
387 Returns the children of the contact. 417 Returns the children of the contact.
388*/ 418*/
389 419
390/*! \fn QString OContact::notes() const 420/*! \fn QString OContact::notes() const
391 Returns the notes relating to the the contact. 421 Returns the notes relating to the the contact.
392*/ 422*/
393 423
394/*! \fn QString OContact::groups() const 424/*! \fn QString OContact::groups() const
395 \internal 425 \internal
396 Returns the groups for the contact. 426 Returns the groups for the contact.
397*/ 427*/
398 428
399/*! \fn QStringList OContact::groupList() const 429/*! \fn QStringList OContact::groupList() const
400 \internal 430 \internal
401*/ 431*/
402 432
403/*! \fn QString OContact::field(int) const 433/*! \fn QString OContact::field(int) const
404 \internal 434 \internal
405*/ 435*/
406 436
407/*! \fn void OContact::saveJournal( journal_action, const QString & = QString::null ) 437/*! \fn void OContact::saveJournal( journal_action, const QString & = QString::null )
408 \internal 438 \internal
409*/ 439*/
410 440
411/*! \fn void OContact::setUid( int id ) 441/*! \fn void OContact::setUid( int id )
412 \internal 442 \internal
413 Sets the uid for this record to \a id. 443 Sets the uid for this record to \a id.
414*/ 444*/
415 445
416/*! \enum OContact::journal_action 446/*! \enum OContact::journal_action
417 \internal 447 \internal
418*/ 448*/
419 449
420/*! 450/*!
421 \internal 451 \internal
422*/ 452*/
423QMap<int, QString> OContact::toMap() const 453QMap<int, QString> OContact::toMap() const
424{ 454{
425 QMap<int, QString> map = mMap; 455 QMap<int, QString> map = mMap;
426 QString cats = idsToString( categories() ); 456 QString cats = idsToString( categories() );
427 if ( !cats.isEmpty() ) 457 if ( !cats.isEmpty() )
428 map.insert( Qtopia::AddressCategory, cats ); 458 map.insert( Qtopia::AddressCategory, cats );
429 return map; 459 return map;
430} 460}
431 461
432/*! 462/*!
433 Returns a rich text formatted QString representing the contents the contact. 463 Returns a rich text formatted QString representing the contents the contact.
434*/ 464*/
435QString OContact::toRichText() const 465QString OContact::toRichText() const
436{ 466{
437 QString text; 467 QString text;
438 QString value, comp, state; 468 QString value, comp, state;
439 QString str; 469 QString str;
440 bool marker = false; 470 bool marker = false;
441 471
442 Config cfg("qpe"); 472 Config cfg("qpe");
443 cfg.setGroup("Appearance"); 473 cfg.setGroup("Appearance");
444 int addressformat = cfg.readNumEntry( "AddressFormat", Zip_City_State ); 474 int addressformat = cfg.readNumEntry( "AddressFormat", Zip_City_State );
445 475
446 // name, jobtitle and company 476 // name, jobtitle and company
447 if ( !(value = fullName()).isEmpty() ) 477 if ( !(value = fullName()).isEmpty() )
448 text += "<b><h3><img src=\"addressbook/AddressBook\"> " + Qtopia::escapeString(value) + "</h3></b>"; 478 text += "<b><h3><img src=\"addressbook/AddressBook\"> " + Qtopia::escapeString(value) + "</h3></b>";
449 479
450 if ( !(value = jobTitle()).isEmpty() ) 480 if ( !(value = jobTitle()).isEmpty() )
451 text += Qtopia::escapeString(value) + " "; 481 text += Qtopia::escapeString(value) + " ";
452 482
453 comp = company(); 483 comp = company();
454 if ( !(value = department()).isEmpty() ) { 484 if ( !(value = department()).isEmpty() ) {
455 text += Qtopia::escapeString(value); 485 text += Qtopia::escapeString(value);
456 if ( comp ) 486 if ( comp )
457 text += ", " + Qtopia::escapeString(comp); 487 text += ", " + Qtopia::escapeString(comp);
458 }else if ( comp ) 488 }else if ( comp )
459 text += "<br>" + Qtopia::escapeString(comp); 489 text += "<br>" + Qtopia::escapeString(comp);
460 text += "<br><hr>"; 490 text += "<br><hr>";
461 491
462 // defailt email 492 // defailt email
463 QString defEmail = defaultEmail(); 493 QString defEmail = defaultEmail();
464 if ( !defEmail.isEmpty() ){ 494 if ( !defEmail.isEmpty() ){
465 text += "<b><img src=\"addressbook/email\"> " + QObject::tr("Default Email: ") + "</b>" 495 text += "<b><img src=\"addressbook/email\"> " + QObject::tr("Default Email: ") + "</b>"
466 + Qtopia::escapeString(defEmail); 496 + Qtopia::escapeString(defEmail);
467 marker = true; 497 marker = true;
468 } 498 }
469 499
470 // business address 500 // business address
471 if ( !businessStreet().isEmpty() || !businessCity().isEmpty() || 501 if ( !businessStreet().isEmpty() || !businessCity().isEmpty() ||
472 !businessZip().isEmpty() || !businessCountry().isEmpty() ) { 502 !businessZip().isEmpty() || !businessCountry().isEmpty() ) {
473 text += QObject::tr( "<br><b>Work Address:</b>" ); 503 text += QObject::tr( "<br><b>Work Address:</b>" );
474 marker = true; 504 marker = true;
475 } 505 }
476 506
477 if ( !(value = businessStreet()).isEmpty() ){ 507 if ( !(value = businessStreet()).isEmpty() ){
478 text += "<br>" + Qtopia::escapeString(value); 508 text += "<br>" + Qtopia::escapeString(value);
479 marker = true; 509 marker = true;
480 } 510 }
481 511
482 switch( addressformat ){ 512 switch( addressformat ){
483 case Zip_City_State:{ // Zip_Code City, State 513 case Zip_City_State:{ // Zip_Code City, State
484 state = businessState(); 514 state = businessState();
485 if ( !(value = businessZip()).isEmpty() ){ 515 if ( !(value = businessZip()).isEmpty() ){
486 text += "<br>" + Qtopia::escapeString(value) + " "; 516 text += "<br>" + Qtopia::escapeString(value) + " ";
487 marker = true; 517 marker = true;
488 518
489 } 519 }
490 if ( !(value = businessCity()).isEmpty() ) { 520 if ( !(value = businessCity()).isEmpty() ) {
491 marker = true; 521 marker = true;
492 if ( businessZip().isEmpty() && !businessStreet().isEmpty() ) 522 if ( businessZip().isEmpty() && !businessStreet().isEmpty() )
493 text += "<br>"; 523 text += "<br>";
494 text += Qtopia::escapeString(value); 524 text += Qtopia::escapeString(value);
495 if ( state ) 525 if ( state )
496 text += ", " + Qtopia::escapeString(state); 526 text += ", " + Qtopia::escapeString(state);
497 } else if ( !state.isEmpty() ){ 527 } else if ( !state.isEmpty() ){
498 text += "<br>" + Qtopia::escapeString(state); 528 text += "<br>" + Qtopia::escapeString(state);
499 marker = true; 529 marker = true;
500 } 530 }
501 break; 531 break;
502 } 532 }
503 case City_State_Zip:{ // City, State Zip_Code 533 case City_State_Zip:{ // City, State Zip_Code
504 state = businessState(); 534 state = businessState();
505 if ( !(value = businessCity()).isEmpty() ) { 535 if ( !(value = businessCity()).isEmpty() ) {
506 marker = true; 536 marker = true;
507 text += "<br>" + Qtopia::escapeString(value); 537 text += "<br>" + Qtopia::escapeString(value);
508 if ( state ) 538 if ( state )
509 text += ", " + Qtopia::escapeString(state); 539 text += ", " + Qtopia::escapeString(state);
510 } else if ( !state.isEmpty() ){ 540 } else if ( !state.isEmpty() ){
511 text += "<br>" + Qtopia::escapeString(state); 541 text += "<br>" + Qtopia::escapeString(state);
512 marker = true; 542 marker = true;
513 } 543 }
514 if ( !(value = businessZip()).isEmpty() ){ 544 if ( !(value = businessZip()).isEmpty() ){
515 text += " " + Qtopia::escapeString(value); 545 text += " " + Qtopia::escapeString(value);
516 marker = true; 546 marker = true;
517 } 547 }
518 break; 548 break;
519 } 549 }
520 } 550 }
521 551
522 if ( !(value = businessCountry()).isEmpty() ){ 552 if ( !(value = businessCountry()).isEmpty() ){
523 text += "<br>" + Qtopia::escapeString(value); 553 text += "<br>" + Qtopia::escapeString(value);
524 marker = true; 554 marker = true;
525 } 555 }
526 556
527 // rest of Business data 557 // rest of Business data
528 str = office(); 558 str = office();
529 if ( !str.isEmpty() ){ 559 if ( !str.isEmpty() ){
530 text += "<br><b>" + QObject::tr("Office: ") + "</b>" 560 text += "<br><b>" + QObject::tr("Office: ") + "</b>"
531 + Qtopia::escapeString(str); 561 + Qtopia::escapeString(str);
532 marker = true; 562 marker = true;
533 } 563 }
534 str = businessWebpage(); 564 str = businessWebpage();
535 if ( !str.isEmpty() ){ 565 if ( !str.isEmpty() ){
536 text += "<br><b><img src=\"addressbook/webpagework\"> " + QObject::tr("Business Web Page: ") + "</b>" 566 text += "<br><b><img src=\"addressbook/webpagework\"> " + QObject::tr("Business Web Page: ") + "</b>"
537 + Qtopia::escapeString(str); 567 + Qtopia::escapeString(str);
538 marker = true; 568 marker = true;
539 } 569 }
540 str = businessPhone(); 570 str = businessPhone();
541 if ( !str.isEmpty() ){ 571 if ( !str.isEmpty() ){
542 text += "<br><b><img src=\"addressbook/phonework\"> " + QObject::tr("Business Phone: ") + "</b>" 572 text += "<br><b><img src=\"addressbook/phonework\"> " + QObject::tr("Business Phone: ") + "</b>"
543 + Qtopia::escapeString(str); 573 + Qtopia::escapeString(str);
544 marker = true; 574 marker = true;
545 } 575 }
546 str = businessFax(); 576 str = businessFax();
547 if ( !str.isEmpty() ){ 577 if ( !str.isEmpty() ){
548 text += "<br><b><img src=\"addressbook/faxwork\"> " + QObject::tr("Business Fax: ") + "</b>" 578 text += "<br><b><img src=\"addressbook/faxwork\"> " + QObject::tr("Business Fax: ") + "</b>"
549 + Qtopia::escapeString(str); 579 + Qtopia::escapeString(str);
550 marker = true; 580 marker = true;
551 } 581 }
552 str = businessMobile(); 582 str = businessMobile();
553 if ( !str.isEmpty() ){ 583 if ( !str.isEmpty() ){
554 text += "<br><b><img src=\"addressbook/mobilework\"> " + QObject::tr("Business Mobile: ") + "</b>" 584 text += "<br><b><img src=\"addressbook/mobilework\"> " + QObject::tr("Business Mobile: ") + "</b>"
555 + Qtopia::escapeString(str); 585 + Qtopia::escapeString(str);
556 marker = true; 586 marker = true;
557 } 587 }
558 str = businessPager(); 588 str = businessPager();
559 if ( !str.isEmpty() ){ 589 if ( !str.isEmpty() ){
560 text += "<br><b>" + QObject::tr("Business Pager: ") + "</b>" 590 text += "<br><b>" + QObject::tr("Business Pager: ") + "</b>"
561 + Qtopia::escapeString(str); 591 + Qtopia::escapeString(str);
562 marker = true; 592 marker = true;
563 } 593 }
564 594
565 // text += "<br>"; 595 // text += "<br>";
566 596
567 // home address 597 // home address
568 if ( !homeStreet().isEmpty() || !homeCity().isEmpty() || 598 if ( !homeStreet().isEmpty() || !homeCity().isEmpty() ||
569 !homeZip().isEmpty() || !homeCountry().isEmpty() ) { 599 !homeZip().isEmpty() || !homeCountry().isEmpty() ) {
570 text += QObject::tr( "<br><b>Home Address:</b>" ); 600 text += QObject::tr( "<br><b>Home Address:</b>" );
571 marker = true; 601 marker = true;
572 } 602 }
573 603
574 if ( !(value = homeStreet()).isEmpty() ){ 604 if ( !(value = homeStreet()).isEmpty() ){
575 text += "<br>" + Qtopia::escapeString(value); 605 text += "<br>" + Qtopia::escapeString(value);
576 marker = true; 606 marker = true;
577 } 607 }
578 608
579 switch( addressformat ){ 609 switch( addressformat ){
580 case Zip_City_State:{ // Zip_Code City, State 610 case Zip_City_State:{ // Zip_Code City, State
581 state = homeState(); 611 state = homeState();
582 if ( !(value = homeZip()).isEmpty() ){ 612 if ( !(value = homeZip()).isEmpty() ){
583 text += "<br>" + Qtopia::escapeString(value) + " "; 613 text += "<br>" + Qtopia::escapeString(value) + " ";
584 marker = true; 614 marker = true;
585 } 615 }
586 if ( !(value = homeCity()).isEmpty() ) { 616 if ( !(value = homeCity()).isEmpty() ) {
587 marker = true; 617 marker = true;
588 if ( homeZip().isEmpty() && !homeStreet().isEmpty() ) 618 if ( homeZip().isEmpty() && !homeStreet().isEmpty() )
589 text += "<br>"; 619 text += "<br>";
590 text += Qtopia::escapeString(value); 620 text += Qtopia::escapeString(value);
591 if ( !state.isEmpty() ) 621 if ( !state.isEmpty() )
592 text += ", " + Qtopia::escapeString(state); 622 text += ", " + Qtopia::escapeString(state);
593 } else if (!state.isEmpty()) { 623 } else if (!state.isEmpty()) {
594 text += "<br>" + Qtopia::escapeString(state); 624 text += "<br>" + Qtopia::escapeString(state);
595 marker = true; 625 marker = true;
596 } 626 }
597 break; 627 break;
598 } 628 }
599 case City_State_Zip:{ // City, State Zip_Code 629 case City_State_Zip:{ // City, State Zip_Code
600 state = homeState(); 630 state = homeState();
601 if ( !(value = homeCity()).isEmpty() ) { 631 if ( !(value = homeCity()).isEmpty() ) {
602 marker = true; 632 marker = true;
603 text += "<br>" + Qtopia::escapeString(value); 633 text += "<br>" + Qtopia::escapeString(value);
604 if ( state ) 634 if ( state )
605 text += ", " + Qtopia::escapeString(state); 635 text += ", " + Qtopia::escapeString(state);
606 } else if ( !state.isEmpty() ){ 636 } else if ( !state.isEmpty() ){
607 text += "<br>" + Qtopia::escapeString(state); 637 text += "<br>" + Qtopia::escapeString(state);
608 marker = true; 638 marker = true;
609 } 639 }
610 if ( !(value = homeZip()).isEmpty() ){ 640 if ( !(value = homeZip()).isEmpty() ){
611 text += " " + Qtopia::escapeString(value); 641 text += " " + Qtopia::escapeString(value);
612 marker = true; 642 marker = true;
613 } 643 }
614 break; 644 break;
615 } 645 }
616 } 646 }
617 647
618 if ( !(value = homeCountry()).isEmpty() ){ 648 if ( !(value = homeCountry()).isEmpty() ){
619 text += "<br>" + Qtopia::escapeString(value); 649 text += "<br>" + Qtopia::escapeString(value);
620 marker = true; 650 marker = true;
621 } 651 }
622 652
623 // rest of Home data 653 // rest of Home data
624 str = homeWebpage(); 654 str = homeWebpage();
625 if ( !str.isEmpty() ){ 655 if ( !str.isEmpty() ){
626 text += "<br><b><img src=\"addressbook/webpagehome\"> " + QObject::tr("Home Web Page: ") + "</b>" 656 text += "<br><b><img src=\"addressbook/webpagehome\"> " + QObject::tr("Home Web Page: ") + "</b>"
627 + Qtopia::escapeString(str); 657 + Qtopia::escapeString(str);
628 marker = true; 658 marker = true;
629 } 659 }
630 str = homePhone(); 660 str = homePhone();
631 if ( !str.isEmpty() ){ 661 if ( !str.isEmpty() ){
632 text += "<br><b><img src=\"addressbook/phonehome\"> " + QObject::tr("Home Phone: ") + "</b>" 662 text += "<br><b><img src=\"addressbook/phonehome\"> " + QObject::tr("Home Phone: ") + "</b>"
633 + Qtopia::escapeString(str); 663 + Qtopia::escapeString(str);
634 marker = true; 664 marker = true;
635 } 665 }
636 str = homeFax(); 666 str = homeFax();
637 if ( !str.isEmpty() ){ 667 if ( !str.isEmpty() ){
638 text += "<br><b><img src=\"addressbook/faxhome\"> " + QObject::tr("Home Fax: ") + "</b>" 668 text += "<br><b><img src=\"addressbook/faxhome\"> " + QObject::tr("Home Fax: ") + "</b>"
639 + Qtopia::escapeString(str); 669 + Qtopia::escapeString(str);
640 marker = true; 670 marker = true;
641 } 671 }
642 str = homeMobile(); 672 str = homeMobile();
643 if ( !str.isEmpty() ){ 673 if ( !str.isEmpty() ){
644 text += "<br><b><img src=\"addressbook/mobilehome\"> " + QObject::tr("Home Mobile: ") + "</b>" 674 text += "<br><b><img src=\"addressbook/mobilehome\"> " + QObject::tr("Home Mobile: ") + "</b>"
645 + Qtopia::escapeString(str); 675 + Qtopia::escapeString(str);
646 marker = true; 676 marker = true;
647 } 677 }
648 678
649 if ( marker ) 679 if ( marker )
650 text += "<br><hr>"; 680 text += "<br><hr>";
651 681
652 // the rest... 682 // the rest...
653 str = emails(); 683 str = emails();
654 if ( !str.isEmpty() && ( str != defEmail ) ) 684 if ( !str.isEmpty() && ( str != defEmail ) )
655 text += "<br><b>" + QObject::tr("All Emails: ") + "</b>" 685 text += "<br><b>" + QObject::tr("All Emails: ") + "</b>"
656 + Qtopia::escapeString(str); 686 + Qtopia::escapeString(str);
657 str = profession(); 687 str = profession();
658 if ( !str.isEmpty() ) 688 if ( !str.isEmpty() )
659 text += "<br><b>" + QObject::tr("Profession: ") + "</b>" 689 text += "<br><b>" + QObject::tr("Profession: ") + "</b>"
660 + Qtopia::escapeString(str); 690 + Qtopia::escapeString(str);
661 str = assistant(); 691 str = assistant();
662 if ( !str.isEmpty() ) 692 if ( !str.isEmpty() )
663 text += "<br><b>" + QObject::tr("Assistant: ") + "</b>" 693 text += "<br><b>" + QObject::tr("Assistant: ") + "</b>"
664 + Qtopia::escapeString(str); 694 + Qtopia::escapeString(str);
665 str = manager(); 695 str = manager();
666 if ( !str.isEmpty() ) 696 if ( !str.isEmpty() )
667 text += "<br><b>" + QObject::tr("Manager: ") + "</b>" 697 text += "<br><b>" + QObject::tr("Manager: ") + "</b>"
668 + Qtopia::escapeString(str); 698 + Qtopia::escapeString(str);
669 str = gender(); 699 str = gender();
670 if ( !str.isEmpty() && str.toInt() != 0 ) { 700 if ( !str.isEmpty() && str.toInt() != 0 ) {
671 text += "<br>"; 701 text += "<br>";
672 if ( str.toInt() == 1 ) 702 if ( str.toInt() == 1 )
673 str = QObject::tr( "Male" ); 703 str = QObject::tr( "Male" );
674 else if ( str.toInt() == 2 ) 704 else if ( str.toInt() == 2 )
675 str = QObject::tr( "Female" ); 705 str = QObject::tr( "Female" );
676 text += "<b>" + QObject::tr("Gender: ") + "</b>" + str; 706 text += "<b>" + QObject::tr("Gender: ") + "</b>" + str;
677 } 707 }
678 str = spouse(); 708 str = spouse();
679 if ( !str.isEmpty() ) 709 if ( !str.isEmpty() )
680 text += "<br><b>" + QObject::tr("Spouse: ") + "</b>" 710 text += "<br><b>" + QObject::tr("Spouse: ") + "</b>"
681 + Qtopia::escapeString(str); 711 + Qtopia::escapeString(str);
682 if ( birthday().isValid() ){ 712 if ( birthday().isValid() ){
683 str = TimeString::numberDateString( birthday() ); 713 str = TimeString::numberDateString( birthday() );
684 text += "<br><b>" + QObject::tr("Birthday: ") + "</b>" 714 text += "<br><b>" + QObject::tr("Birthday: ") + "</b>"
685 + Qtopia::escapeString(str); 715 + Qtopia::escapeString(str);
686 } 716 }
687 if ( anniversary().isValid() ){ 717 if ( anniversary().isValid() ){
688 str = TimeString::numberDateString( anniversary() ); 718 str = TimeString::numberDateString( anniversary() );
689 text += "<br><b>" + QObject::tr("Anniversary: ") + "</b>" 719 text += "<br><b>" + QObject::tr("Anniversary: ") + "</b>"
690 + Qtopia::escapeString(str); 720 + Qtopia::escapeString(str);
691 } 721 }
692 str = children(); 722 str = children();
693 if ( !str.isEmpty() ) 723 if ( !str.isEmpty() )
694 text += "<br><b>" + QObject::tr("Children: ") + "</b>" 724 text += "<br><b>" + QObject::tr("Children: ") + "</b>"
695 + Qtopia::escapeString(str); 725 + Qtopia::escapeString(str);
696 726
697 str = nickname(); 727 str = nickname();
698 if ( !str.isEmpty() ) 728 if ( !str.isEmpty() )
699 text += "<br><b>" + QObject::tr("Nickname: ") + "</b>" 729 text += "<br><b>" + QObject::tr("Nickname: ") + "</b>"
700 + Qtopia::escapeString(str); 730 + Qtopia::escapeString(str);
701 731
702 // categories 732 // categories
703 if ( categoryNames("Contacts").count() ){ 733 if ( categoryNames("Contacts").count() ){
704 text += "<br><b>" + QObject::tr( "Category:") + "</b> "; 734 text += "<br><b>" + QObject::tr( "Category:") + "</b> ";
705 text += categoryNames("Contacts").join(", "); 735 text += categoryNames("Contacts").join(", ");
706 } 736 }
707 737
708 // notes last 738 // notes last
709 if ( !(value = notes()).isEmpty() ) { 739 if ( !(value = notes()).isEmpty() ) {
710 text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> "; 740 text += "<br><hr><b>" + QObject::tr( "Notes:") + "</b> ";
711 QRegExp reg("\n"); 741 QRegExp reg("\n");
712 742
713 //QString tmp = Qtopia::escapeString(value); 743 //QString tmp = Qtopia::escapeString(value);
714 QString tmp = QStyleSheet::convertFromPlainText(value); 744 QString tmp = QStyleSheet::convertFromPlainText(value);
715 //tmp.replace( reg, "<br>" ); 745 //tmp.replace( reg, "<br>" );
716 text += "<br>" + tmp + "<br>"; 746 text += "<br>" + tmp + "<br>";
717 } 747 }
718 return text; 748 return text;
719} 749}
720 750
721/*! 751/*!
722 \internal 752 \internal
723*/ 753*/
724void OContact::insert( int key, const QString &v ) 754void OContact::insert( int key, const QString &v )
725{ 755{
726 QString value = v.stripWhiteSpace(); 756 QString value = v.stripWhiteSpace();
727 if ( value.isEmpty() ) 757 if ( value.isEmpty() )
728 mMap.remove( key ); 758 mMap.remove( key );
729 else 759 else
730 mMap.insert( key, value ); 760 mMap.insert( key, value );
731} 761}
732 762
733/*! 763/*!
734 \internal 764 \internal
735*/ 765*/
736void OContact::replace( int key, const QString & v ) 766void OContact::replace( int key, const QString & v )
737{ 767{
738 QString value = v.stripWhiteSpace(); 768 QString value = v.stripWhiteSpace();
739 if ( value.isEmpty() ) 769 if ( value.isEmpty() )
740 mMap.remove( key ); 770 mMap.remove( key );
741 else 771 else
742 mMap.replace( key, value ); 772 mMap.replace( key, value );
743} 773}
744 774
745/*! 775/*!
746 \internal 776 \internal
747*/ 777*/
748QString OContact::find( int key ) const 778QString OContact::find( int key ) const
749{ 779{
750 return mMap[key]; 780 return mMap[key];
751} 781}
752 782
753/*! 783/*!
754 \internal 784 \internal
755*/ 785*/
756QString OContact::displayAddress( const QString &street, 786QString OContact::displayAddress( const QString &street,
757 const QString &city, 787 const QString &city,
758 const QString &state, 788 const QString &state,
759 const QString &zip, 789 const QString &zip,
760 const QString &country ) const 790 const QString &country ) const
761{ 791{
762 QString s = street; 792 QString s = street;
763 if ( !street.isEmpty() ) 793 if ( !street.isEmpty() )
764 s+= "\n"; 794 s+= "\n";
765 s += city; 795 s += city;
766 if ( !city.isEmpty() && !state.isEmpty() ) 796 if ( !city.isEmpty() && !state.isEmpty() )
767 s += ", "; 797 s += ", ";
768 s += state; 798 s += state;
769 if ( !state.isEmpty() && !zip.isEmpty() ) 799 if ( !state.isEmpty() && !zip.isEmpty() )
770 s += " "; 800 s += " ";
771 s += zip; 801 s += zip;
772 if ( !country.isEmpty() && !s.isEmpty() ) 802 if ( !country.isEmpty() && !s.isEmpty() )
773 s += "\n"; 803 s += "\n";
774 s += country; 804 s += country;
775 return s; 805 return s;
776} 806}
777 807
778/*! 808/*!
779 \internal 809 \internal
780*/ 810*/
781QString OContact::displayBusinessAddress() const 811QString OContact::displayBusinessAddress() const
782{ 812{
783 return displayAddress( businessStreet(), businessCity(), 813 return displayAddress( businessStreet(), businessCity(),
784 businessState(), businessZip(), 814 businessState(), businessZip(),
785 businessCountry() ); 815 businessCountry() );
786} 816}
787 817
788/*! 818/*!
789 \internal 819 \internal
790*/ 820*/
791QString OContact::displayHomeAddress() const 821QString OContact::displayHomeAddress() const
792{ 822{
793 return displayAddress( homeStreet(), homeCity(), 823 return displayAddress( homeStreet(), homeCity(),
794 homeState(), homeZip(), 824 homeState(), homeZip(),
795 homeCountry() ); 825 homeCountry() );
796} 826}
797 827
798/*! 828/*!
799 Returns the full name of the contact 829 Returns the full name of the contact
800*/ 830*/
801QString OContact::fullName() const 831QString OContact::fullName() const
802{ 832{
803 QString title = find( Qtopia::Title ); 833 QString title = find( Qtopia::Title );
804 QString firstName = find( Qtopia::FirstName ); 834 QString firstName = find( Qtopia::FirstName );
805 QString middleName = find( Qtopia::MiddleName ); 835 QString middleName = find( Qtopia::MiddleName );
806 QString lastName = find( Qtopia::LastName ); 836 QString lastName = find( Qtopia::LastName );
807 QString suffix = find( Qtopia::Suffix ); 837 QString suffix = find( Qtopia::Suffix );
808 838
809 QString name = title; 839 QString name = title;
810 if ( !firstName.isEmpty() ) { 840 if ( !firstName.isEmpty() ) {
811 if ( !name.isEmpty() ) 841 if ( !name.isEmpty() )
812 name += " "; 842 name += " ";
813 name += firstName; 843 name += firstName;
814 } 844 }
815 if ( !middleName.isEmpty() ) { 845 if ( !middleName.isEmpty() ) {
816 if ( !name.isEmpty() ) 846 if ( !name.isEmpty() )
817 name += " "; 847 name += " ";
818 name += middleName; 848 name += middleName;
819 } 849 }
820 if ( !lastName.isEmpty() ) { 850 if ( !lastName.isEmpty() ) {
821 if ( !name.isEmpty() ) 851 if ( !name.isEmpty() )
822 name += " "; 852 name += " ";
823 name += lastName; 853 name += lastName;
824 } 854 }
825 if ( !suffix.isEmpty() ) { 855 if ( !suffix.isEmpty() ) {
826 if ( !name.isEmpty() ) 856 if ( !name.isEmpty() )
827 name += " "; 857 name += " ";
828 name += suffix; 858 name += suffix;
829 } 859 }
830 return name.simplifyWhiteSpace(); 860 return name.simplifyWhiteSpace();
831} 861}
832 862
833/*! 863/*!
834 Returns a list of the names of the children of the contact. 864 Returns a list of the names of the children of the contact.
835*/ 865*/
836QStringList OContact::childrenList() const 866QStringList OContact::childrenList() const
837{ 867{
838 return QStringList::split( " ", find( Qtopia::Children ) ); 868 return QStringList::split( " ", find( Qtopia::Children ) );
839} 869}
840 870
841/*! \fn void OContact::insertEmail( const QString &email ) 871/*! \fn void OContact::insertEmail( const QString &email )
842 872
843 Insert \a email into the email list. Ensures \a email can only be added 873 Insert \a email into the email list. Ensures \a email can only be added
844 once. If there is no default email address set, it sets it to the \a email. 874 once. If there is no default email address set, it sets it to the \a email.
845*/ 875*/
846 876
847/*! \fn void OContact::removeEmail( const QString &email ) 877/*! \fn void OContact::removeEmail( const QString &email )
848 878
849 Removes the \a email from the email list. If the default email was \a email, 879 Removes the \a email from the email list. If the default email was \a email,
850 then the default email address is assigned to the first email in the 880 then the default email address is assigned to the first email in the
851 email list 881 email list
852*/ 882*/
853 883
854/*! \fn void OContact::clearEmails() 884/*! \fn void OContact::clearEmails()
855 885
856 Clears the email list. 886 Clears the email list.
857 */ 887 */
858 888
859/*! \fn void OContact::insertEmails( const QStringList &emailList ) 889/*! \fn void OContact::insertEmails( const QStringList &emailList )
860 890
861 Appends the \a emailList to the exiting email list 891 Appends the \a emailList to the exiting email list
862 */ 892 */
863 893
864/*! 894/*!
865 Returns a list of email addresses belonging to the contact, including 895 Returns a list of email addresses belonging to the contact, including
866 the default email address. 896 the default email address.
867*/ 897*/
868QStringList OContact::emailList() const 898QStringList OContact::emailList() const
869{ 899{
870 QString emailStr = emails(); 900 QString emailStr = emails();
871 901
872 QStringList r; 902 QStringList r;
873 if ( !emailStr.isEmpty() ) { 903 if ( !emailStr.isEmpty() ) {
874 qDebug(" emailstr "); 904 qDebug(" emailstr ");
875 QStringList l = QStringList::split( emailSeparator(), emailStr ); 905 QStringList l = QStringList::split( emailSeparator(), emailStr );
876 for ( QStringList::ConstIterator it = l.begin();it != l.end();++it ) 906 for ( QStringList::ConstIterator it = l.begin();it != l.end();++it )
877 r += (*it).simplifyWhiteSpace(); 907 r += (*it).simplifyWhiteSpace();
878 } 908 }
879 909
880 return r; 910 return r;
881} 911}
882 912
883/*! 913/*!
884 \overload 914 \overload
885 915
886 Generates the string for the contact to be filed as from the first, 916 Generates the string for the contact to be filed as from the first,
887 middle and last name of the contact. 917 middle and last name of the contact.
888*/ 918*/
889void OContact::setFileAs() 919void OContact::setFileAs()
890{ 920{
891 QString lastName, firstName, middleName, fileas; 921 QString lastName, firstName, middleName, fileas;
892 922
893 lastName = find( Qtopia::LastName ); 923 lastName = find( Qtopia::LastName );
894 firstName = find( Qtopia::FirstName ); 924 firstName = find( Qtopia::FirstName );
895 middleName = find( Qtopia::MiddleName ); 925 middleName = find( Qtopia::MiddleName );
896 if ( !lastName.isEmpty() && !firstName.isEmpty() 926 if ( !lastName.isEmpty() && !firstName.isEmpty()
897 && !middleName.isEmpty() ) 927 && !middleName.isEmpty() )
898 fileas = lastName + ", " + firstName + " " + middleName; 928 fileas = lastName + ", " + firstName + " " + middleName;
899 else if ( !lastName.isEmpty() && !firstName.isEmpty() ) 929 else if ( !lastName.isEmpty() && !firstName.isEmpty() )
900 fileas = lastName + ", " + firstName; 930 fileas = lastName + ", " + firstName;
901 else if ( !lastName.isEmpty() || !firstName.isEmpty() || 931 else if ( !lastName.isEmpty() || !firstName.isEmpty() ||
902 !middleName.isEmpty() ) 932 !middleName.isEmpty() )
903 fileas = firstName + ( firstName.isEmpty() ? "" : " " ) 933 fileas = firstName + ( firstName.isEmpty() ? "" : " " )
904 + middleName + ( middleName.isEmpty() ? "" : " " ) 934 + middleName + ( middleName.isEmpty() ? "" : " " )
905 + lastName; 935 + lastName;
906 936
907 replace( Qtopia::FileAs, fileas ); 937 replace( Qtopia::FileAs, fileas );
908} 938}
909 939
910/*! 940/*!
911 \internal 941 \internal
912 Appends the contact information to \a buf. 942 Appends the contact information to \a buf.
913*/ 943*/
914void OContact::save( QString &buf ) const 944void OContact::save( QString &buf ) const
915{ 945{
916 static const QStringList SLFIELDS = fields(); 946 static const QStringList SLFIELDS = fields();
917 // I'm expecting "<Contact " in front of this... 947 // I'm expecting "<Contact " in front of this...
918 for ( QMap<int, QString>::ConstIterator it = mMap.begin(); 948 for ( QMap<int, QString>::ConstIterator it = mMap.begin();
919 it != mMap.end(); ++it ) { 949 it != mMap.end(); ++it ) {
920 const QString &value = it.data(); 950 const QString &value = it.data();
921 int key = it.key(); 951 int key = it.key();
922 if ( !value.isEmpty() ) { 952 if ( !value.isEmpty() ) {
923 if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) 953 if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid)
924 continue; 954 continue;
925 955
926 key -= Qtopia::AddressCategory+1; 956 key -= Qtopia::AddressCategory+1;
927 buf += SLFIELDS[key]; 957 buf += SLFIELDS[key];
928 buf += "=\"" + Qtopia::escapeString(value) + "\" "; 958 buf += "=\"" + Qtopia::escapeString(value) + "\" ";
929 } 959 }
930 } 960 }
931 buf += customToXml(); 961 buf += customToXml();
932 if ( categories().count() > 0 ) 962 if ( categories().count() > 0 )
933 buf += "Categories=\"" + idsToString( categories() ) + "\" "; 963 buf += "Categories=\"" + idsToString( categories() ) + "\" ";
934 buf += "Uid=\"" + QString::number( uid() ) + "\" "; 964 buf += "Uid=\"" + QString::number( uid() ) + "\" ";
935 // You need to close this yourself 965 // You need to close this yourself
936} 966}
937 967
938 968
939/*! 969/*!
940 \internal 970 \internal
941 Returns the list of fields belonging to a contact 971 Returns the list of fields belonging to a contact
942 Never change order of this list ! It has to be regarding 972 Never change order of this list ! It has to be regarding
943 enum AddressBookFields !! 973 enum AddressBookFields !!
944*/ 974*/
945QStringList OContact::fields() 975QStringList OContact::fields()
946{ 976{
947 QStringList list; 977 QStringList list;
948 978
949 list.append( "Title" ); // Not Used! 979 list.append( "Title" ); // Not Used!
950 list.append( "FirstName" ); 980 list.append( "FirstName" );
951 list.append( "MiddleName" ); 981 list.append( "MiddleName" );
952 list.append( "LastName" ); 982 list.append( "LastName" );
953 list.append( "Suffix" ); 983 list.append( "Suffix" );
954 list.append( "FileAs" ); 984 list.append( "FileAs" );
955 985
956 list.append( "JobTitle" ); 986 list.append( "JobTitle" );
957 list.append( "Department" ); 987 list.append( "Department" );
958 list.append( "Company" ); 988 list.append( "Company" );
959 list.append( "BusinessPhone" ); 989 list.append( "BusinessPhone" );
960 list.append( "BusinessFax" ); 990 list.append( "BusinessFax" );
961 list.append( "BusinessMobile" ); 991 list.append( "BusinessMobile" );
962 992
963 list.append( "DefaultEmail" ); 993 list.append( "DefaultEmail" );
964 list.append( "Emails" ); 994 list.append( "Emails" );
965 995
966 list.append( "HomePhone" ); 996 list.append( "HomePhone" );
967 list.append( "HomeFax" ); 997 list.append( "HomeFax" );
968 list.append( "HomeMobile" ); 998 list.append( "HomeMobile" );
969 999
970 list.append( "BusinessStreet" ); 1000 list.append( "BusinessStreet" );
971 list.append( "BusinessCity" ); 1001 list.append( "BusinessCity" );
972 list.append( "BusinessState" ); 1002 list.append( "BusinessState" );
973 list.append( "BusinessZip" ); 1003 list.append( "BusinessZip" );
974 list.append( "BusinessCountry" ); 1004 list.append( "BusinessCountry" );
975 list.append( "BusinessPager" ); 1005 list.append( "BusinessPager" );
976 list.append( "BusinessWebPage" ); 1006 list.append( "BusinessWebPage" );
977 1007
978 list.append( "Office" ); 1008 list.append( "Office" );
979 list.append( "Profession" ); 1009 list.append( "Profession" );
980 list.append( "Assistant" ); 1010 list.append( "Assistant" );
981 list.append( "Manager" ); 1011 list.append( "Manager" );
982 1012
983 list.append( "HomeStreet" ); 1013 list.append( "HomeStreet" );
984 list.append( "HomeCity" ); 1014 list.append( "HomeCity" );
985 list.append( "HomeState" ); 1015 list.append( "HomeState" );
986 list.append( "HomeZip" ); 1016 list.append( "HomeZip" );
987 list.append( "HomeCountry" ); 1017 list.append( "HomeCountry" );
988 list.append( "HomeWebPage" ); 1018 list.append( "HomeWebPage" );
989 1019
990 list.append( "Spouse" ); 1020 list.append( "Spouse" );
991 list.append( "Gender" ); 1021 list.append( "Gender" );
992 list.append( "Birthday" ); 1022 list.append( "Birthday" );
993 list.append( "Anniversary" ); 1023 list.append( "Anniversary" );
994 list.append( "Nickname" ); 1024 list.append( "Nickname" );
995 list.append( "Children" ); 1025 list.append( "Children" );
996 1026
997 list.append( "Notes" ); 1027 list.append( "Notes" );
998 list.append( "Groups" ); 1028 list.append( "Groups" );
999 1029
1000 return list; 1030 return list;
1001} 1031}
1002 1032
1003 1033
1004/*! 1034/*!
1005 Sets the list of email address for contact to those contained in \a str. 1035 Sets the list of email address for contact to those contained in \a str.
1006 Email address should be separated by ';'s. 1036 Email address should be separated by ';'s.
1007*/ 1037*/
1008void OContact::setEmails( const QString &str ) 1038void OContact::setEmails( const QString &str )
1009{ 1039{
1010 replace( Qtopia::Emails, str ); 1040 replace( Qtopia::Emails, str );
1011 if ( str.isEmpty() ) 1041 if ( str.isEmpty() )
1012 setDefaultEmail( QString::null ); 1042 setDefaultEmail( QString::null );
1013} 1043}
1014 1044
1015/*! 1045/*!
1016 Sets the list of children for the contact to those contained in \a str. 1046 Sets the list of children for the contact to those contained in \a str.
1017*/ 1047*/
1018void OContact::setChildren( const QString &str ) 1048void OContact::setChildren( const QString &str )
1019{ 1049{
1020 replace( Qtopia::Children, str ); 1050 replace( Qtopia::Children, str );
1021} 1051}
1022 1052
1023/*! 1053/*!
1024 \overload 1054 \overload
1025 Returns TRUE if the contact matches the regular expression \a regexp. 1055 Returns TRUE if the contact matches the regular expression \a regexp.
1026 Otherwise returns FALSE. 1056 Otherwise returns FALSE.
1027*/ 1057*/
1028bool OContact::match( const QRegExp &r ) const 1058bool OContact::match( const QRegExp &r ) const
1029{ 1059{
1030 setLastHitField( -1 ); 1060 setLastHitField( -1 );
1031 bool match; 1061 bool match;
1032 match = false; 1062 match = false;
1033 QMap<int, QString>::ConstIterator it; 1063 QMap<int, QString>::ConstIterator it;
1034 for ( it = mMap.begin(); it != mMap.end(); ++it ) { 1064 for ( it = mMap.begin(); it != mMap.end(); ++it ) {
1035 if ( (*it).find( r ) > -1 ) { 1065 if ( (*it).find( r ) > -1 ) {
1036 setLastHitField( it.key() ); 1066 setLastHitField( it.key() );
1037 match = true; 1067 match = true;
1038 break; 1068 break;
1039 } 1069 }
1040 } 1070 }
1041 return match; 1071 return match;
1042} 1072}
1043 1073
1044 1074
1045QString OContact::toShortText() const 1075QString OContact::toShortText() const
1046{ 1076{
1047 return ( fullName() ); 1077 return ( fullName() );
1048} 1078}
1049QString OContact::type() const 1079QString OContact::type() const
1050{ 1080{
1051 return QString::fromLatin1( "OContact" ); 1081 return QString::fromLatin1( "OContact" );
1052} 1082}
1053 1083
1054 1084
1055 1085
1056class QString OContact::recordField( int pos ) const 1086class QString OContact::recordField( int pos ) const
1057{ 1087{
1058 QStringList SLFIELDS = fields(); // ?? why this ? (se) 1088 QStringList SLFIELDS = fields(); // ?? why this ? (se)
1059 return SLFIELDS[pos]; 1089 return SLFIELDS[pos];
1060} 1090}
1061 1091
1062// In future releases, we should store birthday and anniversary 1092// In future releases, we should store birthday and anniversary
1063// internally as QDate instead of QString ! 1093// internally as QDate instead of QString !
1064// QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se) 1094// QString is always too complicate to interprete (DD.MM.YY, DD/MM/YY, MM/DD/YY, etc..)(se)
1065 1095
1066/*! \fn void OContact::setBirthday( const QDate& date ) 1096/*! \fn void OContact::setBirthday( const QDate& date )
1067 Sets the birthday for the contact to \a date. If date is null 1097 Sets the birthday for the contact to \a date. If date is null
1068 the current stored date will be removed. 1098 the current stored date will be removed.
1069*/ 1099*/
1070void OContact::setBirthday( const QDate &v ) 1100void OContact::setBirthday( const QDate &v )
1071{ 1101{
1072 if ( v.isNull() ){ 1102 if ( v.isNull() ){
1073 qWarning( "Remove Birthday"); 1103 qWarning( "Remove Birthday");
1074 replace( Qtopia::Birthday, QString::null ); 1104 replace( Qtopia::Birthday, QString::null );
1075 return; 1105 return;
1076 } 1106 }
1077 1107
1078 if ( v.isValid() ) 1108 if ( v.isValid() )
1079 replace( Qtopia::Birthday, OConversion::dateToString( v ) ); 1109 replace( Qtopia::Birthday, OConversion::dateToString( v ) );
1080 1110
1081} 1111}
1082 1112
1083 1113
1084/*! \fn void OContact::setAnniversary( const QDate &date ) 1114/*! \fn void OContact::setAnniversary( const QDate &date )
1085 Sets the anniversary of the contact to \a date. If date is 1115 Sets the anniversary of the contact to \a date. If date is
1086 null, the current stored date will be removed. 1116 null, the current stored date will be removed.
1087*/ 1117*/
1088void OContact::setAnniversary( const QDate &v ) 1118void OContact::setAnniversary( const QDate &v )
1089{ 1119{
1090 if ( v.isNull() ){ 1120 if ( v.isNull() ){
1091 qWarning( "Remove Anniversary"); 1121 qWarning( "Remove Anniversary");
1092 replace( Qtopia::Anniversary, QString::null ); 1122 replace( Qtopia::Anniversary, QString::null );
1093 return; 1123 return;
1094 } 1124 }
1095 1125
1096 if ( v.isValid() ) 1126 if ( v.isValid() )
1097 replace( Qtopia::Anniversary, OConversion::dateToString( v ) ); 1127 replace( Qtopia::Anniversary, OConversion::dateToString( v ) );
1098} 1128}
1099 1129
1100/*! \fn QDate OContact::birthday() const 1130/*! \fn QDate OContact::birthday() const
1101 Returns the birthday of the contact. 1131 Returns the birthday of the contact.
1102*/ 1132*/
1103QDate OContact::birthday() const 1133QDate OContact::birthday() const
1104{ 1134{
1105 QString str = find( Qtopia::Birthday ); 1135 QString str = find( Qtopia::Birthday );
1106 // qWarning ("Birthday %s", str.latin1() ); 1136 // qWarning ("Birthday %s", str.latin1() );
1107 if ( !str.isEmpty() ) 1137 if ( !str.isEmpty() )
1108 return OConversion::dateFromString ( str ); 1138 return OConversion::dateFromString ( str );
1109 else 1139 else
1110 return QDate(); 1140 return QDate();
1111} 1141}
1112 1142
1113 1143
1114/*! \fn QDate OContact::anniversary() const 1144/*! \fn QDate OContact::anniversary() const
1115 Returns the anniversary of the contact. 1145 Returns the anniversary of the contact.
1116*/ 1146*/
1117QDate OContact::anniversary() const 1147QDate OContact::anniversary() const
1118{ 1148{
1119 QDate empty; 1149 QDate empty;
1120 QString str = find( Qtopia::Anniversary ); 1150 QString str = find( Qtopia::Anniversary );
1121 // qWarning ("Anniversary %s", str.latin1() ); 1151 // qWarning ("Anniversary %s", str.latin1() );
1122 if ( !str.isEmpty() ) 1152 if ( !str.isEmpty() )
1123 return OConversion::dateFromString ( str ); 1153 return OConversion::dateFromString ( str );
1124 else 1154 else
1125 return empty; 1155 return empty;
1126} 1156}
1127 1157
1128 1158
1129void OContact::insertEmail( const QString &v ) 1159void OContact::insertEmail( const QString &v )
1130{ 1160{
1131 //qDebug("insertEmail %s", v.latin1()); 1161 //qDebug("insertEmail %s", v.latin1());
1132 QString e = v.simplifyWhiteSpace(); 1162 QString e = v.simplifyWhiteSpace();
1133 QString def = defaultEmail(); 1163 QString def = defaultEmail();
1134 1164
1135 // if no default, set it as the default email and don't insert 1165 // if no default, set it as the default email and don't insert
1136 if ( def.isEmpty() ) { 1166 if ( def.isEmpty() ) {
1137 setDefaultEmail( e ); // will insert into the list for us 1167 setDefaultEmail( e ); // will insert into the list for us
1138 return; 1168 return;
1139 } 1169 }
1140 1170
1141 // otherwise, insert assuming doesn't already exist 1171 // otherwise, insert assuming doesn't already exist
1142 QString emailsStr = find( Qtopia::Emails ); 1172 QString emailsStr = find( Qtopia::Emails );
1143 if ( emailsStr.contains( e )) 1173 if ( emailsStr.contains( e ))
1144 return; 1174 return;
1145 if ( !emailsStr.isEmpty() ) 1175 if ( !emailsStr.isEmpty() )
1146 emailsStr += emailSeparator(); 1176 emailsStr += emailSeparator();
1147 emailsStr += e; 1177 emailsStr += e;
1148 replace( Qtopia::Emails, emailsStr ); 1178 replace( Qtopia::Emails, emailsStr );
1149} 1179}
1150 1180
1151void OContact::removeEmail( const QString &v ) 1181void OContact::removeEmail( const QString &v )
1152{ 1182{
1153 QString e = v.simplifyWhiteSpace(); 1183 QString e = v.simplifyWhiteSpace();
1154 QString def = defaultEmail(); 1184 QString def = defaultEmail();
1155 QString emailsStr = find( Qtopia::Emails ); 1185 QString emailsStr = find( Qtopia::Emails );
1156 QStringList emails = emailList(); 1186 QStringList emails = emailList();
1157 1187
1158 // otherwise, must first contain it 1188 // otherwise, must first contain it
1159 if ( !emailsStr.contains( e ) ) 1189 if ( !emailsStr.contains( e ) )
1160 return; 1190 return;
1161 1191
1162 // remove it 1192 // remove it
1163 //qDebug(" removing email from list %s", e.latin1()); 1193 //qDebug(" removing email from list %s", e.latin1());
1164 emails.remove( e ); 1194 emails.remove( e );
1165 // reset the string 1195 // reset the string
1166 emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator 1196 emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator
1167 replace( Qtopia::Emails, emailsStr ); 1197 replace( Qtopia::Emails, emailsStr );
1168 1198
1169 // if default, then replace the default email with the first one 1199 // if default, then replace the default email with the first one
1170 if ( def == e ) { 1200 if ( def == e ) {
1171 //qDebug("removeEmail is default; setting new default"); 1201 //qDebug("removeEmail is default; setting new default");
1172 if ( !emails.count() ) 1202 if ( !emails.count() )
1173 clearEmails(); 1203 clearEmails();
1174 else // setDefaultEmail will remove e from the list 1204 else // setDefaultEmail will remove e from the list
1175 setDefaultEmail( emails.first() ); 1205 setDefaultEmail( emails.first() );
1176 } 1206 }
1177} 1207}
1178void OContact::clearEmails() 1208void OContact::clearEmails()
1179{ 1209{
1180 mMap.remove( Qtopia::DefaultEmail ); 1210 mMap.remove( Qtopia::DefaultEmail );
1181 mMap.remove( Qtopia::Emails ); 1211 mMap.remove( Qtopia::Emails );
1182} 1212}
1183void OContact::setDefaultEmail( const QString &v ) 1213void OContact::setDefaultEmail( const QString &v )
1184{ 1214{
1185 QString e = v.simplifyWhiteSpace(); 1215 QString e = v.simplifyWhiteSpace();
1186 1216
1187 //qDebug("OContact::setDefaultEmail %s", e.latin1()); 1217 //qDebug("OContact::setDefaultEmail %s", e.latin1());
1188 replace( Qtopia::DefaultEmail, e ); 1218 replace( Qtopia::DefaultEmail, e );
1189 1219
1190 if ( !e.isEmpty() ) 1220 if ( !e.isEmpty() )
1191 insertEmail( e ); 1221 insertEmail( e );
1192 1222
1193} 1223}
1194 1224
1195void OContact::insertEmails( const QStringList &v ) 1225void OContact::insertEmails( const QStringList &v )
1196{ 1226{
1197 for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) 1227 for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it )
1198 insertEmail( *it ); 1228 insertEmail( *it );
1199} 1229}
1200int OContact::rtti() { 1230int OContact::rtti() {
1201 return OPimResolver::AddressBook; 1231 return OPimResolver::AddressBook;
1202} 1232}
1203void OContact::setUid( int i ) 1233void OContact::setUid( int i )
1204{ 1234{
1205 OPimRecord::setUid(i); 1235 OPimRecord::setUid(i);
1206 replace( Qtopia::AddressUid , QString::number(i)); 1236 replace( Qtopia::AddressUid , QString::number(i));
1207} 1237}
1238}
diff --git a/libopie2/opiepim/ocontact.h b/libopie2/opiepim/ocontact.h
index 1d46b81..34888dc 100644
--- a/libopie2/opiepim/ocontact.h
+++ b/libopie2/opiepim/ocontact.h
@@ -1,240 +1,251 @@
1/********************************************************************** 1/*
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2 This file is part of the Opie Project
3** Copyright (C) 2002-2003 by Stefan Eilers (eilers.stefan@epost.de) 3 Copyright (C) The Main Author <main-author@whereever.org>
4** 4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5** This file may be distributed and/or modified under the terms of the 5 .=l.
6** GNU General Public License version 2 as published by the Free Software 6 .>+-=
7** Foundation and appearing in the file LICENSE.GPL included in the 7 _;:, .> :=|. This program is free software; you can
8** packaging of this file. 8.> <`_, > . <= redistribute it and/or modify it under
9** 9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 10.="- .-=="i, .._ License as published by the Free Software
11** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 11 - . .-<_> .<> Foundation; either version 2 of the License,
12** 12 ._= =} : or (at your option) any later version.
13** See http://www.trolltech.com/gpl/ for GPL licensing information. 13 .%`+i> _;_.
14** 14 .i_,=:_. -<s. This program is distributed in the hope that
15** Contact info@trolltech.com if any conditions of this licensing are 15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16** not clear to you. 16 : .. .:, . . . without even the implied warranty of
17** 17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18**********************************************************************/ 18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19 19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
20#ifndef __OCONTACT_H__ 29#ifndef __OCONTACT_H__
21#define __OCONTACT_H__ 30#define __OCONTACT_H__
22 31
23#include <opie/opimrecord.h> 32#include <opie2/opimrecord.h>
24#include <qpe/recordfields.h> 33#include <qpe/recordfields.h>
25 34
26#include <qdatetime.h> 35#include <qdatetime.h>
27#include <qstringlist.h> 36#include <qstringlist.h>
28 37
29#if defined(QPC_TEMPLATEDLL) 38#if defined(QPC_TEMPLATEDLL)
30// MOC_SKIP_BEGIN 39// MOC_SKIP_BEGIN
31QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>; 40QPC_TEMPLATEEXTERN template class QPC_EXPORT QMap<int, QString>;
32// MOC_SKIP_END 41// MOC_SKIP_END
33#endif 42#endif
34 43
44namespace Opie {
35class OContactPrivate; 45class OContactPrivate;
36 46
37/** 47/**
38 * OContact class represents a specialised PIM Record for contacts. 48 * OContact class represents a specialised PIM Record for contacts.
39 * It does store all kind of persopn related information. 49 * It does store all kind of persopn related information.
40 * 50 *
41 * @short Contact Container 51 * @short Contact Container
42 * @author TT, Stefan Eiler, Holger Freyther 52 * @author TT, Stefan Eiler, Holger Freyther
43 */ 53 */
44class QPC_EXPORT OContact : public OPimRecord 54class QPC_EXPORT OContact : public OPimRecord
45{ 55{
46 friend class DataSet; 56 friend class DataSet;
47public: 57public:
48 OContact(); 58 OContact();
49 OContact( const QMap<int, QString> &fromMap ); 59 OContact( const QMap<int, QString> &fromMap );
50 virtual ~OContact(); 60 virtual ~OContact();
51 61
52 enum DateFormat{ 62 enum DateFormat{
53 Zip_City_State = 0, 63 Zip_City_State = 0,
54 City_State_Zip 64 City_State_Zip
55 }; 65 };
56 66
57 /* 67 /*
58 * do we need to inline them 68 * do we need to inline them
59 * if yes do we need to inline them this way? 69 * if yes do we need to inline them this way?
60 * -zecke 70 * -zecke
61 */ 71 */
62 void setTitle( const QString &v ) { replace( Qtopia::Title, v ); } 72 void setTitle( const QString &v ) { replace( Qtopia::Title, v ); }
63 void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); } 73 void setFirstName( const QString &v ) { replace( Qtopia::FirstName, v ); }
64 void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); } 74 void setMiddleName( const QString &v ) { replace( Qtopia::MiddleName, v ); }
65 void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); } 75 void setLastName( const QString &v ) { replace( Qtopia::LastName, v ); }
66 void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); } 76 void setSuffix( const QString &v ) { replace( Qtopia::Suffix, v ); }
67 void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); } 77 void setFileAs( const QString &v ) { replace( Qtopia::FileAs, v ); }
68 void setFileAs(); 78 void setFileAs();
69 79
70 // default email address 80 // default email address
71 void setDefaultEmail( const QString &v ); 81 void setDefaultEmail( const QString &v );
72 // inserts email to list and ensure's doesn't already exist 82 // inserts email to list and ensure's doesn't already exist
73 void insertEmail( const QString &v ); 83 void insertEmail( const QString &v );
74 void removeEmail( const QString &v ); 84 void removeEmail( const QString &v );
75 void clearEmails(); 85 void clearEmails();
76 void insertEmails( const QStringList &v ); 86 void insertEmails( const QStringList &v );
77 87
78 // home 88 // home
79 void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); } 89 void setHomeStreet( const QString &v ) { replace( Qtopia::HomeStreet, v ); }
80 void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); } 90 void setHomeCity( const QString &v ) { replace( Qtopia::HomeCity, v ); }
81 void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); } 91 void setHomeState( const QString &v ) { replace( Qtopia::HomeState, v ); }
82 void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); } 92 void setHomeZip( const QString &v ) { replace( Qtopia::HomeZip, v ); }
83 void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); } 93 void setHomeCountry( const QString &v ) { replace( Qtopia::HomeCountry, v ); }
84 void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); } 94 void setHomePhone( const QString &v ) { replace( Qtopia::HomePhone, v ); }
85 void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); } 95 void setHomeFax( const QString &v ) { replace( Qtopia::HomeFax, v ); }
86 void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); } 96 void setHomeMobile( const QString &v ) { replace( Qtopia::HomeMobile, v ); }
87 void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); } 97 void setHomeWebpage( const QString &v ) { replace( Qtopia::HomeWebPage, v ); }
88 98
89 // business 99 // business
90 void setCompany( const QString &v ) { replace( Qtopia::Company, v ); } 100 void setCompany( const QString &v ) { replace( Qtopia::Company, v ); }
91 void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); } 101 void setBusinessStreet( const QString &v ) { replace( Qtopia::BusinessStreet, v ); }
92 void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); } 102 void setBusinessCity( const QString &v ) { replace( Qtopia::BusinessCity, v ); }
93 void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); } 103 void setBusinessState( const QString &v ) { replace( Qtopia::BusinessState, v ); }
94 void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); } 104 void setBusinessZip( const QString &v ) { replace( Qtopia::BusinessZip, v ); }
95 void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); } 105 void setBusinessCountry( const QString &v ) { replace( Qtopia::BusinessCountry, v ); }
96 void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); } 106 void setBusinessWebpage( const QString &v ) { replace( Qtopia::BusinessWebPage, v ); }
97 void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); } 107 void setJobTitle( const QString &v ) { replace( Qtopia::JobTitle, v ); }
98 void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); } 108 void setDepartment( const QString &v ) { replace( Qtopia::Department, v ); }
99 void setOffice( const QString &v ) { replace( Qtopia::Office, v ); } 109 void setOffice( const QString &v ) { replace( Qtopia::Office, v ); }
100 void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); } 110 void setBusinessPhone( const QString &v ) { replace( Qtopia::BusinessPhone, v ); }
101 void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); } 111 void setBusinessFax( const QString &v ) { replace( Qtopia::BusinessFax, v ); }
102 void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); } 112 void setBusinessMobile( const QString &v ) { replace( Qtopia::BusinessMobile, v ); }
103 void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); } 113 void setBusinessPager( const QString &v ) { replace( Qtopia::BusinessPager, v ); }
104 void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); } 114 void setProfession( const QString &v ) { replace( Qtopia::Profession, v ); }
105 void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); } 115 void setAssistant( const QString &v ) { replace( Qtopia::Assistant, v ); }
106 void setManager( const QString &v ) { replace( Qtopia::Manager, v ); } 116 void setManager( const QString &v ) { replace( Qtopia::Manager, v ); }
107 117
108 // personal 118 // personal
109 void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); } 119 void setSpouse( const QString &v ) { replace( Qtopia::Spouse, v ); }
110 void setGender( const QString &v ) { replace( Qtopia::Gender, v ); } 120 void setGender( const QString &v ) { replace( Qtopia::Gender, v ); }
111 void setBirthday( const QDate &v ); 121 void setBirthday( const QDate &v );
112 void setAnniversary( const QDate &v ); 122 void setAnniversary( const QDate &v );
113 void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); } 123 void setNickname( const QString &v ) { replace( Qtopia::Nickname, v ); }
114 void setChildren( const QString &v ); 124 void setChildren( const QString &v );
115 125
116 // other 126 // other
117 void setNotes( const QString &v ) { replace( Qtopia::Notes, v); } 127 void setNotes( const QString &v ) { replace( Qtopia::Notes, v); }
118 128
119 virtual bool match( const QRegExp &regexp ) const; 129 virtual bool match( const QRegExp &regexp ) const;
120 130
121// // custom 131// // custom
122// void setCustomField( const QString &key, const QString &v ) 132// void setCustomField( const QString &key, const QString &v )
123// { replace(Custom- + key, v ); } 133// { replace(Custom- + key, v ); }
124 134
125 // name 135 // name
126 QString fullName() const; 136 QString fullName() const;
127 QString title() const { return find( Qtopia::Title ); } 137 QString title() const { return find( Qtopia::Title ); }
128 QString firstName() const { return find( Qtopia::FirstName ); } 138 QString firstName() const { return find( Qtopia::FirstName ); }
129 QString middleName() const { return find( Qtopia::MiddleName ); } 139 QString middleName() const { return find( Qtopia::MiddleName ); }
130 QString lastName() const { return find( Qtopia::LastName ); } 140 QString lastName() const { return find( Qtopia::LastName ); }
131 QString suffix() const { return find( Qtopia::Suffix ); } 141 QString suffix() const { return find( Qtopia::Suffix ); }
132 QString fileAs() const { return find( Qtopia::FileAs ); } 142 QString fileAs() const { return find( Qtopia::FileAs ); }
133 143
134 // email 144 // email
135 QString defaultEmail() const { return find( Qtopia::DefaultEmail ); } 145 QString defaultEmail() const { return find( Qtopia::DefaultEmail ); }
136 QStringList emailList() const; 146 QStringList emailList() const;
137 147
138 // home 148 // home
139 /* 149 /*
140 * OPimAddress address(enum Location)const; 150 * OPimAddress address(enum Location)const;
141 * would be some how nicer... 151 * would be some how nicer...
142 * -zecke 152 * -zecke
143 */ 153 */
144 QString homeStreet() const { return find( Qtopia::HomeStreet ); } 154 QString homeStreet() const { return find( Qtopia::HomeStreet ); }
145 QString homeCity() const { return find( Qtopia::HomeCity ); } 155 QString homeCity() const { return find( Qtopia::HomeCity ); }
146 QString homeState() const { return find( Qtopia::HomeState ); } 156 QString homeState() const { return find( Qtopia::HomeState ); }
147 QString homeZip() const { return find( Qtopia::HomeZip ); } 157 QString homeZip() const { return find( Qtopia::HomeZip ); }
148 QString homeCountry() const { return find( Qtopia::HomeCountry ); } 158 QString homeCountry() const { return find( Qtopia::HomeCountry ); }
149 QString homePhone() const { return find( Qtopia::HomePhone ); } 159 QString homePhone() const { return find( Qtopia::HomePhone ); }
150 QString homeFax() const { return find( Qtopia::HomeFax ); } 160 QString homeFax() const { return find( Qtopia::HomeFax ); }
151 QString homeMobile() const { return find( Qtopia::HomeMobile ); } 161 QString homeMobile() const { return find( Qtopia::HomeMobile ); }
152 QString homeWebpage() const { return find( Qtopia::HomeWebPage ); } 162 QString homeWebpage() const { return find( Qtopia::HomeWebPage ); }
153 /** Multi line string containing all non-empty address info in the form 163 /** Multi line string containing all non-empty address info in the form
154 * Street 164 * Street
155 * City, State Zip 165 * City, State Zip
156 * Country 166 * Country
157 */ 167 */
158 QString displayHomeAddress() const; 168 QString displayHomeAddress() const;
159 169
160 // business 170 // business
161 QString company() const { return find( Qtopia::Company ); } 171 QString company() const { return find( Qtopia::Company ); }
162 QString businessStreet() const { return find( Qtopia::BusinessStreet ); } 172 QString businessStreet() const { return find( Qtopia::BusinessStreet ); }
163 QString businessCity() const { return find( Qtopia::BusinessCity ); } 173 QString businessCity() const { return find( Qtopia::BusinessCity ); }
164 QString businessState() const { return find( Qtopia::BusinessState ); } 174 QString businessState() const { return find( Qtopia::BusinessState ); }
165 QString businessZip() const { return find( Qtopia::BusinessZip ); } 175 QString businessZip() const { return find( Qtopia::BusinessZip ); }
166 QString businessCountry() const { return find( Qtopia::BusinessCountry ); } 176 QString businessCountry() const { return find( Qtopia::BusinessCountry ); }
167 QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); } 177 QString businessWebpage() const { return find( Qtopia::BusinessWebPage ); }
168 QString jobTitle() const { return find( Qtopia::JobTitle ); } 178 QString jobTitle() const { return find( Qtopia::JobTitle ); }
169 QString department() const { return find( Qtopia::Department ); } 179 QString department() const { return find( Qtopia::Department ); }
170 QString office() const { return find( Qtopia::Office ); } 180 QString office() const { return find( Qtopia::Office ); }
171 QString businessPhone() const { return find( Qtopia::BusinessPhone ); } 181 QString businessPhone() const { return find( Qtopia::BusinessPhone ); }
172 QString businessFax() const { return find( Qtopia::BusinessFax ); } 182 QString businessFax() const { return find( Qtopia::BusinessFax ); }
173 QString businessMobile() const { return find( Qtopia::BusinessMobile ); } 183 QString businessMobile() const { return find( Qtopia::BusinessMobile ); }
174 QString businessPager() const { return find( Qtopia::BusinessPager ); } 184 QString businessPager() const { return find( Qtopia::BusinessPager ); }
175 QString profession() const { return find( Qtopia::Profession ); } 185 QString profession() const { return find( Qtopia::Profession ); }
176 QString assistant() const { return find( Qtopia::Assistant ); } 186 QString assistant() const { return find( Qtopia::Assistant ); }
177 QString manager() const { return find( Qtopia::Manager ); } 187 QString manager() const { return find( Qtopia::Manager ); }
178 /** Multi line string containing all non-empty address info in the form 188 /** Multi line string containing all non-empty address info in the form
179 * Street 189 * Street
180 * City, State Zip 190 * City, State Zip
181 * Country 191 * Country
182 */ 192 */
183 QString displayBusinessAddress() const; 193 QString displayBusinessAddress() const;
184 194
185 //personal 195 //personal
186 QString spouse() const { return find( Qtopia::Spouse ); } 196 QString spouse() const { return find( Qtopia::Spouse ); }
187 QString gender() const { return find( Qtopia::Gender ); } 197 QString gender() const { return find( Qtopia::Gender ); }
188 QDate birthday() const; 198 QDate birthday() const;
189 QDate anniversary() const; 199 QDate anniversary() const;
190 QString nickname() const { return find( Qtopia::Nickname ); } 200 QString nickname() const { return find( Qtopia::Nickname ); }
191 QString children() const { return find( Qtopia::Children ); } 201 QString children() const { return find( Qtopia::Children ); }
192 QStringList childrenList() const; 202 QStringList childrenList() const;
193 203
194 // other 204 // other
195 QString notes() const { return find( Qtopia::Notes ); } 205 QString notes() const { return find( Qtopia::Notes ); }
196 QString groups() const { return find( Qtopia::Groups ); } 206 QString groups() const { return find( Qtopia::Groups ); }
197 QStringList groupList() const; 207 QStringList groupList() const;
198 208
199 QString toRichText() const; 209 QString toRichText() const;
200 QMap<int, QString> toMap() const; 210 QMap<int, QString> toMap() const;
201 QString field( int key ) const { return find( key ); } 211 QString field( int key ) const { return find( key ); }
202 212
203 213
204 void setUid( int i ); 214 void setUid( int i );
205 215
206 QString toShortText()const; 216 QString toShortText()const;
207 QString type()const; 217 QString type()const;
208 class QString recordField(int) const; 218 class QString recordField(int) const;
209 219
210 // Why private ? (eilers,se) 220 // Why private ? (eilers,se)
211 QString emailSeparator() const { return " "; } 221 QString emailSeparator() const { return " "; }
212 222
213 // the emails should be seperated by a comma 223 // the emails should be seperated by a comma
214 void setEmails( const QString &v ); 224 void setEmails( const QString &v );
215 QString emails() const { return find( Qtopia::Emails ); } 225 QString emails() const { return find( Qtopia::Emails ); }
216 static int rtti(); 226 static int rtti();
217 227
218private: 228private:
219 // The XML Backend needs some access to the private functions 229 // The XML Backend needs some access to the private functions
220 friend class OContactAccessBackend_XML; 230 friend class OContactAccessBackend_XML;
221 231
222 void insert( int key, const QString &value ); 232 void insert( int key, const QString &value );
223 void replace( int key, const QString &value ); 233 void replace( int key, const QString &value );
224 QString find( int key ) const; 234 QString find( int key ) const;
225 static QStringList fields(); 235 static QStringList fields();
226 236
227 void save( QString &buf ) const; 237 void save( QString &buf ) const;
228 238
229 QString displayAddress( const QString &street, 239 QString displayAddress( const QString &street,
230 const QString &city, 240 const QString &city,
231 const QString &state, 241 const QString &state,
232 const QString &zip, 242 const QString &zip,
233 const QString &country ) const; 243 const QString &country ) const;
234 244
235 QMap<int, QString> mMap; 245 QMap<int, QString> mMap;
236 OContactPrivate *d; 246 OContactPrivate *d;
237}; 247};
238 248
249}
239 250
240#endif 251#endif
diff --git a/libopie2/opiepim/ocontactfields.cpp b/libopie2/opiepim/ocontactfields.cpp
index 0f08a5a..deaa1e5 100644
--- a/libopie2/opiepim/ocontactfields.cpp
+++ b/libopie2/opiepim/ocontactfields.cpp
@@ -1,477 +1,508 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1 29
2#include "ocontactfields.h" 30#include <opie2/ocontactfields.h>
3 31
4#include <qstringlist.h> 32#include <qstringlist.h>
5#include <qobject.h> 33#include <qobject.h>
6 34
7// We should use our own enum in the future .. 35// We should use our own enum in the future ..
8#include <qpe/recordfields.h> 36#include <qpe/recordfields.h>
9#include <qpe/config.h> 37#include <qpe/config.h>
10#include <opie/ocontact.h> 38#include <opie2/ocontact.h>
11 39
40namespace Opie {
12/*! 41/*!
13 \internal 42 \internal
14 Returns a list of personal field names for a contact. 43 Returns a list of personal field names for a contact.
15*/ 44*/
16QStringList OContactFields::personalfields( bool sorted, bool translated ) 45QStringList OContactFields::personalfields( bool sorted, bool translated )
17{ 46{
18 QStringList list; 47 QStringList list;
19 QMap<int, QString> mapIdToStr; 48 QMap<int, QString> mapIdToStr;
20 if ( translated ) 49 if ( translated )
21 mapIdToStr = idToTrFields(); 50 mapIdToStr = idToTrFields();
22 else 51 else
23 mapIdToStr = idToUntrFields(); 52 mapIdToStr = idToUntrFields();
24 53
25 list.append( mapIdToStr[ Qtopia::AddressUid ] ); 54 list.append( mapIdToStr[ Qtopia::AddressUid ] );
26 list.append( mapIdToStr[ Qtopia::AddressCategory ] ); 55 list.append( mapIdToStr[ Qtopia::AddressCategory ] );
27 56
28 list.append( mapIdToStr[ Qtopia::Title ] ); 57 list.append( mapIdToStr[ Qtopia::Title ] );
29 list.append( mapIdToStr[ Qtopia::FirstName ] ); 58 list.append( mapIdToStr[ Qtopia::FirstName ] );
30 list.append( mapIdToStr[ Qtopia::MiddleName ] ); 59 list.append( mapIdToStr[ Qtopia::MiddleName ] );
31 list.append( mapIdToStr[ Qtopia::LastName ] ); 60 list.append( mapIdToStr[ Qtopia::LastName ] );
32 list.append( mapIdToStr[ Qtopia::Suffix ] ); 61 list.append( mapIdToStr[ Qtopia::Suffix ] );
33 list.append( mapIdToStr[ Qtopia::FileAs ] ); 62 list.append( mapIdToStr[ Qtopia::FileAs ] );
34 63
35 list.append( mapIdToStr[ Qtopia::JobTitle ] ); 64 list.append( mapIdToStr[ Qtopia::JobTitle ] );
36 list.append( mapIdToStr[ Qtopia::Department ] ); 65 list.append( mapIdToStr[ Qtopia::Department ] );
37 list.append( mapIdToStr[ Qtopia::Company ] ); 66 list.append( mapIdToStr[ Qtopia::Company ] );
38 67
39 list.append( mapIdToStr[ Qtopia::Notes ] ); 68 list.append( mapIdToStr[ Qtopia::Notes ] );
40 list.append( mapIdToStr[ Qtopia::Groups ] ); 69 list.append( mapIdToStr[ Qtopia::Groups ] );
41 70
42 if (sorted) list.sort(); 71 if (sorted) list.sort();
43 return list; 72 return list;
44} 73}
45 74
46/*! 75/*!
47 \internal 76 \internal
48 Returns a list of details field names for a contact. 77 Returns a list of details field names for a contact.
49*/ 78*/
50QStringList OContactFields::detailsfields( bool sorted, bool translated ) 79QStringList OContactFields::detailsfields( bool sorted, bool translated )
51{ 80{
52 QStringList list; 81 QStringList list;
53 QMap<int, QString> mapIdToStr; 82 QMap<int, QString> mapIdToStr;
54 if ( translated ) 83 if ( translated )
55 mapIdToStr = idToTrFields(); 84 mapIdToStr = idToTrFields();
56 else 85 else
57 mapIdToStr = idToUntrFields(); 86 mapIdToStr = idToUntrFields();
58 87
59 list.append( mapIdToStr[ Qtopia::Office ] ); 88 list.append( mapIdToStr[ Qtopia::Office ] );
60 list.append( mapIdToStr[ Qtopia::Profession ] ); 89 list.append( mapIdToStr[ Qtopia::Profession ] );
61 list.append( mapIdToStr[ Qtopia::Assistant ] ); 90 list.append( mapIdToStr[ Qtopia::Assistant ] );
62 list.append( mapIdToStr[ Qtopia::Manager ] ); 91 list.append( mapIdToStr[ Qtopia::Manager ] );
63 92
64 list.append( mapIdToStr[ Qtopia::Spouse ] ); 93 list.append( mapIdToStr[ Qtopia::Spouse ] );
65 list.append( mapIdToStr[ Qtopia::Gender ] ); 94 list.append( mapIdToStr[ Qtopia::Gender ] );
66 list.append( mapIdToStr[ Qtopia::Birthday ] ); 95 list.append( mapIdToStr[ Qtopia::Birthday ] );
67 list.append( mapIdToStr[ Qtopia::Anniversary ] ); 96 list.append( mapIdToStr[ Qtopia::Anniversary ] );
68 list.append( mapIdToStr[ Qtopia::Nickname ] ); 97 list.append( mapIdToStr[ Qtopia::Nickname ] );
69 list.append( mapIdToStr[ Qtopia::Children ] ); 98 list.append( mapIdToStr[ Qtopia::Children ] );
70 99
71 if (sorted) list.sort(); 100 if (sorted) list.sort();
72 return list; 101 return list;
73} 102}
74 103
75/*! 104/*!
76 \internal 105 \internal
77 Returns a list of phone field names for a contact. 106 Returns a list of phone field names for a contact.
78*/ 107*/
79QStringList OContactFields::phonefields( bool sorted, bool translated ) 108QStringList OContactFields::phonefields( bool sorted, bool translated )
80{ 109{
81 QStringList list; 110 QStringList list;
82 QMap<int, QString> mapIdToStr; 111 QMap<int, QString> mapIdToStr;
83 if ( translated ) 112 if ( translated )
84 mapIdToStr = idToTrFields(); 113 mapIdToStr = idToTrFields();
85 else 114 else
86 mapIdToStr = idToUntrFields(); 115 mapIdToStr = idToUntrFields();
87 116
88 list.append( mapIdToStr[Qtopia::BusinessPhone] ); 117 list.append( mapIdToStr[Qtopia::BusinessPhone] );
89 list.append( mapIdToStr[Qtopia::BusinessFax] ); 118 list.append( mapIdToStr[Qtopia::BusinessFax] );
90 list.append( mapIdToStr[Qtopia::BusinessMobile] ); 119 list.append( mapIdToStr[Qtopia::BusinessMobile] );
91 list.append( mapIdToStr[Qtopia::BusinessPager] ); 120 list.append( mapIdToStr[Qtopia::BusinessPager] );
92 list.append( mapIdToStr[Qtopia::BusinessWebPage] ); 121 list.append( mapIdToStr[Qtopia::BusinessWebPage] );
93 122
94 list.append( mapIdToStr[Qtopia::DefaultEmail] ); 123 list.append( mapIdToStr[Qtopia::DefaultEmail] );
95 list.append( mapIdToStr[Qtopia::Emails] ); 124 list.append( mapIdToStr[Qtopia::Emails] );
96 125
97 list.append( mapIdToStr[Qtopia::HomePhone] ); 126 list.append( mapIdToStr[Qtopia::HomePhone] );
98 list.append( mapIdToStr[Qtopia::HomeFax] ); 127 list.append( mapIdToStr[Qtopia::HomeFax] );
99 list.append( mapIdToStr[Qtopia::HomeMobile] ); 128 list.append( mapIdToStr[Qtopia::HomeMobile] );
100 // list.append( mapIdToStr[Qtopia::HomePager] ); 129 // list.append( mapIdToStr[Qtopia::HomePager] );
101 list.append( mapIdToStr[Qtopia::HomeWebPage] ); 130 list.append( mapIdToStr[Qtopia::HomeWebPage] );
102 131
103 if (sorted) list.sort(); 132 if (sorted) list.sort();
104 133
105 return list; 134 return list;
106} 135}
107 136
108/*! 137/*!
109 \internal 138 \internal
110 Returns a list of field names for a contact. 139 Returns a list of field names for a contact.
111*/ 140*/
112QStringList OContactFields::fields( bool sorted, bool translated ) 141QStringList OContactFields::fields( bool sorted, bool translated )
113{ 142{
114 QStringList list; 143 QStringList list;
115 QMap<int, QString> mapIdToStr; 144 QMap<int, QString> mapIdToStr;
116 if ( translated ) 145 if ( translated )
117 mapIdToStr = idToTrFields(); 146 mapIdToStr = idToTrFields();
118 else 147 else
119 mapIdToStr = idToUntrFields(); 148 mapIdToStr = idToUntrFields();
120 149
121 list += personalfields( sorted, translated ); 150 list += personalfields( sorted, translated );
122 151
123 list += phonefields( sorted, translated ); 152 list += phonefields( sorted, translated );
124 153
125 list.append( mapIdToStr[Qtopia::BusinessStreet] ); 154 list.append( mapIdToStr[Qtopia::BusinessStreet] );
126 list.append( mapIdToStr[Qtopia::BusinessCity] ); 155 list.append( mapIdToStr[Qtopia::BusinessCity] );
127 list.append( mapIdToStr[Qtopia::BusinessState] ); 156 list.append( mapIdToStr[Qtopia::BusinessState] );
128 list.append( mapIdToStr[Qtopia::BusinessZip] ); 157 list.append( mapIdToStr[Qtopia::BusinessZip] );
129 list.append( mapIdToStr[Qtopia::BusinessCountry] ); 158 list.append( mapIdToStr[Qtopia::BusinessCountry] );
130 159
131 list.append( mapIdToStr[Qtopia::HomeStreet] ); 160 list.append( mapIdToStr[Qtopia::HomeStreet] );
132 list.append( mapIdToStr[Qtopia::HomeCity] ); 161 list.append( mapIdToStr[Qtopia::HomeCity] );
133 list.append( mapIdToStr[Qtopia::HomeState] ); 162 list.append( mapIdToStr[Qtopia::HomeState] );
134 list.append( mapIdToStr[Qtopia::HomeZip] ); 163 list.append( mapIdToStr[Qtopia::HomeZip] );
135 list.append( mapIdToStr[Qtopia::HomeCountry] ); 164 list.append( mapIdToStr[Qtopia::HomeCountry] );
136 165
137 list += detailsfields( sorted, translated ); 166 list += detailsfields( sorted, translated );
138 167
139 if (sorted) list.sort(); 168 if (sorted) list.sort();
140 169
141 return list; 170 return list;
142} 171}
143 172
144 173
145/*! 174/*!
146 \internal 175 \internal
147 Returns an untranslated list of personal field names for a contact. 176 Returns an untranslated list of personal field names for a contact.
148*/ 177*/
149QStringList OContactFields::untrpersonalfields( bool sorted ) 178QStringList OContactFields::untrpersonalfields( bool sorted )
150{ 179{
151 return personalfields( sorted, false ); 180 return personalfields( sorted, false );
152} 181}
153 182
154 183
155/*! 184/*!
156 \internal 185 \internal
157 Returns a translated list of personal field names for a contact. 186 Returns a translated list of personal field names for a contact.
158*/ 187*/
159QStringList OContactFields::trpersonalfields( bool sorted ) 188QStringList OContactFields::trpersonalfields( bool sorted )
160{ 189{
161 return personalfields( sorted, true ); 190 return personalfields( sorted, true );
162} 191}
163 192
164 193
165/*! 194/*!
166 \internal 195 \internal
167 Returns an untranslated list of details field names for a contact. 196 Returns an untranslated list of details field names for a contact.
168*/ 197*/
169QStringList OContactFields::untrdetailsfields( bool sorted ) 198QStringList OContactFields::untrdetailsfields( bool sorted )
170{ 199{
171 return detailsfields( sorted, false ); 200 return detailsfields( sorted, false );
172} 201}
173 202
174 203
175/*! 204/*!
176 \internal 205 \internal
177 Returns a translated list of details field names for a contact. 206 Returns a translated list of details field names for a contact.
178*/ 207*/
179QStringList OContactFields::trdetailsfields( bool sorted ) 208QStringList OContactFields::trdetailsfields( bool sorted )
180{ 209{
181 return detailsfields( sorted, true ); 210 return detailsfields( sorted, true );
182} 211}
183 212
184 213
185/*! 214/*!
186 \internal 215 \internal
187 Returns a translated list of phone field names for a contact. 216 Returns a translated list of phone field names for a contact.
188*/ 217*/
189QStringList OContactFields::trphonefields( bool sorted ) 218QStringList OContactFields::trphonefields( bool sorted )
190{ 219{
191 return phonefields( sorted, true ); 220 return phonefields( sorted, true );
192} 221}
193 222
194/*! 223/*!
195 \internal 224 \internal
196 Returns an untranslated list of phone field names for a contact. 225 Returns an untranslated list of phone field names for a contact.
197*/ 226*/
198QStringList OContactFields::untrphonefields( bool sorted ) 227QStringList OContactFields::untrphonefields( bool sorted )
199{ 228{
200 return phonefields( sorted, false ); 229 return phonefields( sorted, false );
201} 230}
202 231
203 232
204/*! 233/*!
205 \internal 234 \internal
206 Returns a translated list of field names for a contact. 235 Returns a translated list of field names for a contact.
207*/ 236*/
208QStringList OContactFields::trfields( bool sorted ) 237QStringList OContactFields::trfields( bool sorted )
209{ 238{
210 return fields( sorted, true ); 239 return fields( sorted, true );
211} 240}
212 241
213/*! 242/*!
214 \internal 243 \internal
215 Returns an untranslated list of field names for a contact. 244 Returns an untranslated list of field names for a contact.
216*/ 245*/
217QStringList OContactFields::untrfields( bool sorted ) 246QStringList OContactFields::untrfields( bool sorted )
218{ 247{
219 return fields( sorted, false ); 248 return fields( sorted, false );
220} 249}
221 250
222QMap<int, QString> OContactFields::idToTrFields() 251QMap<int, QString> OContactFields::idToTrFields()
223{ 252{
224 QMap<int, QString> ret_map; 253 QMap<int, QString> ret_map;
225 254
226 ret_map.insert( Qtopia::AddressUid, QObject::tr( "User Id" ) ); 255 ret_map.insert( Qtopia::AddressUid, QObject::tr( "User Id" ) );
227 ret_map.insert( Qtopia::AddressCategory, QObject::tr( "Categories" ) ); 256 ret_map.insert( Qtopia::AddressCategory, QObject::tr( "Categories" ) );
228 257
229 ret_map.insert( Qtopia::Title, QObject::tr( "Name Title") ); 258 ret_map.insert( Qtopia::Title, QObject::tr( "Name Title") );
230 ret_map.insert( Qtopia::FirstName, QObject::tr( "First Name" ) ); 259 ret_map.insert( Qtopia::FirstName, QObject::tr( "First Name" ) );
231 ret_map.insert( Qtopia::MiddleName, QObject::tr( "Middle Name" ) ); 260 ret_map.insert( Qtopia::MiddleName, QObject::tr( "Middle Name" ) );
232 ret_map.insert( Qtopia::LastName, QObject::tr( "Last Name" ) ); 261 ret_map.insert( Qtopia::LastName, QObject::tr( "Last Name" ) );
233 ret_map.insert( Qtopia::Suffix, QObject::tr( "Suffix" )); 262 ret_map.insert( Qtopia::Suffix, QObject::tr( "Suffix" ));
234 ret_map.insert( Qtopia::FileAs, QObject::tr( "File As" ) ); 263 ret_map.insert( Qtopia::FileAs, QObject::tr( "File As" ) );
235 264
236 ret_map.insert( Qtopia::JobTitle, QObject::tr( "Job Title" ) ); 265 ret_map.insert( Qtopia::JobTitle, QObject::tr( "Job Title" ) );
237 ret_map.insert( Qtopia::Department, QObject::tr( "Department" ) ); 266 ret_map.insert( Qtopia::Department, QObject::tr( "Department" ) );
238 ret_map.insert( Qtopia::Company, QObject::tr( "Company" ) ); 267 ret_map.insert( Qtopia::Company, QObject::tr( "Company" ) );
239 ret_map.insert( Qtopia::BusinessPhone, QObject::tr( "Business Phone" ) ); 268 ret_map.insert( Qtopia::BusinessPhone, QObject::tr( "Business Phone" ) );
240 ret_map.insert( Qtopia::BusinessFax, QObject::tr( "Business Fax" ) ); 269 ret_map.insert( Qtopia::BusinessFax, QObject::tr( "Business Fax" ) );
241 ret_map.insert( Qtopia::BusinessMobile, QObject::tr( "Business Mobile" )); 270 ret_map.insert( Qtopia::BusinessMobile, QObject::tr( "Business Mobile" ));
242 271
243 // email 272 // email
244 ret_map.insert( Qtopia::DefaultEmail, QObject::tr( "Default Email" ) ); 273 ret_map.insert( Qtopia::DefaultEmail, QObject::tr( "Default Email" ) );
245 ret_map.insert( Qtopia::Emails, QObject::tr( "Emails" ) ); 274 ret_map.insert( Qtopia::Emails, QObject::tr( "Emails" ) );
246 275
247 ret_map.insert( Qtopia::HomePhone, QObject::tr( "Home Phone" ) ); 276 ret_map.insert( Qtopia::HomePhone, QObject::tr( "Home Phone" ) );
248 ret_map.insert( Qtopia::HomeFax, QObject::tr( "Home Fax" ) ); 277 ret_map.insert( Qtopia::HomeFax, QObject::tr( "Home Fax" ) );
249 ret_map.insert( Qtopia::HomeMobile, QObject::tr( "Home Mobile" ) ); 278 ret_map.insert( Qtopia::HomeMobile, QObject::tr( "Home Mobile" ) );
250 279
251 // business 280 // business
252 ret_map.insert( Qtopia::BusinessStreet, QObject::tr( "Business Street" ) ); 281 ret_map.insert( Qtopia::BusinessStreet, QObject::tr( "Business Street" ) );
253 ret_map.insert( Qtopia::BusinessCity, QObject::tr( "Business City" ) ); 282 ret_map.insert( Qtopia::BusinessCity, QObject::tr( "Business City" ) );
254 ret_map.insert( Qtopia::BusinessState, QObject::tr( "Business State" ) ); 283 ret_map.insert( Qtopia::BusinessState, QObject::tr( "Business State" ) );
255 ret_map.insert( Qtopia::BusinessZip, QObject::tr( "Business Zip" ) ); 284 ret_map.insert( Qtopia::BusinessZip, QObject::tr( "Business Zip" ) );
256 ret_map.insert( Qtopia::BusinessCountry, QObject::tr( "Business Country" ) ); 285 ret_map.insert( Qtopia::BusinessCountry, QObject::tr( "Business Country" ) );
257 ret_map.insert( Qtopia::BusinessPager, QObject::tr( "Business Pager" ) ); 286 ret_map.insert( Qtopia::BusinessPager, QObject::tr( "Business Pager" ) );
258 ret_map.insert( Qtopia::BusinessWebPage, QObject::tr( "Business WebPage" ) ); 287 ret_map.insert( Qtopia::BusinessWebPage, QObject::tr( "Business WebPage" ) );
259 288
260 ret_map.insert( Qtopia::Office, QObject::tr( "Office" ) ); 289 ret_map.insert( Qtopia::Office, QObject::tr( "Office" ) );
261 ret_map.insert( Qtopia::Profession, QObject::tr( "Profession" ) ); 290 ret_map.insert( Qtopia::Profession, QObject::tr( "Profession" ) );
262 ret_map.insert( Qtopia::Assistant, QObject::tr( "Assistant" ) ); 291 ret_map.insert( Qtopia::Assistant, QObject::tr( "Assistant" ) );
263 ret_map.insert( Qtopia::Manager, QObject::tr( "Manager" ) ); 292 ret_map.insert( Qtopia::Manager, QObject::tr( "Manager" ) );
264 293
265 // home 294 // home
266 ret_map.insert( Qtopia::HomeStreet, QObject::tr( "Home Street" ) ); 295 ret_map.insert( Qtopia::HomeStreet, QObject::tr( "Home Street" ) );
267 ret_map.insert( Qtopia::HomeCity, QObject::tr( "Home City" ) ); 296 ret_map.insert( Qtopia::HomeCity, QObject::tr( "Home City" ) );
268 ret_map.insert( Qtopia::HomeState, QObject::tr( "Home State" ) ); 297 ret_map.insert( Qtopia::HomeState, QObject::tr( "Home State" ) );
269 ret_map.insert( Qtopia::HomeZip, QObject::tr( "Home Zip" ) ); 298 ret_map.insert( Qtopia::HomeZip, QObject::tr( "Home Zip" ) );
270 ret_map.insert( Qtopia::HomeCountry, QObject::tr( "Home Country" ) ); 299 ret_map.insert( Qtopia::HomeCountry, QObject::tr( "Home Country" ) );
271 ret_map.insert( Qtopia::HomeWebPage, QObject::tr( "Home Web Page" ) ); 300 ret_map.insert( Qtopia::HomeWebPage, QObject::tr( "Home Web Page" ) );
272 301
273 //personal 302 //personal
274 ret_map.insert( Qtopia::Spouse, QObject::tr( "Spouse" ) ); 303 ret_map.insert( Qtopia::Spouse, QObject::tr( "Spouse" ) );
275 ret_map.insert( Qtopia::Gender, QObject::tr( "Gender" ) ); 304 ret_map.insert( Qtopia::Gender, QObject::tr( "Gender" ) );
276 ret_map.insert( Qtopia::Birthday, QObject::tr( "Birthday" ) ); 305 ret_map.insert( Qtopia::Birthday, QObject::tr( "Birthday" ) );
277 ret_map.insert( Qtopia::Anniversary, QObject::tr( "Anniversary" ) ); 306 ret_map.insert( Qtopia::Anniversary, QObject::tr( "Anniversary" ) );
278 ret_map.insert( Qtopia::Nickname, QObject::tr( "Nickname" ) ); 307 ret_map.insert( Qtopia::Nickname, QObject::tr( "Nickname" ) );
279 ret_map.insert( Qtopia::Children, QObject::tr( "Children" ) ); 308 ret_map.insert( Qtopia::Children, QObject::tr( "Children" ) );
280 309
281 // other 310 // other
282 ret_map.insert( Qtopia::Notes, QObject::tr( "Notes" ) ); 311 ret_map.insert( Qtopia::Notes, QObject::tr( "Notes" ) );
283 312
284 313
285 return ret_map; 314 return ret_map;
286} 315}
287 316
288QMap<int, QString> OContactFields::idToUntrFields() 317QMap<int, QString> OContactFields::idToUntrFields()
289{ 318{
290 QMap<int, QString> ret_map; 319 QMap<int, QString> ret_map;
291 320
292 ret_map.insert( Qtopia::AddressUid, "User Id" ); 321 ret_map.insert( Qtopia::AddressUid, "User Id" );
293 ret_map.insert( Qtopia::AddressCategory, "Categories" ); 322 ret_map.insert( Qtopia::AddressCategory, "Categories" );
294 323
295 ret_map.insert( Qtopia::Title, "Name Title" ); 324 ret_map.insert( Qtopia::Title, "Name Title" );
296 ret_map.insert( Qtopia::FirstName, "First Name" ); 325 ret_map.insert( Qtopia::FirstName, "First Name" );
297 ret_map.insert( Qtopia::MiddleName, "Middle Name" ); 326 ret_map.insert( Qtopia::MiddleName, "Middle Name" );
298 ret_map.insert( Qtopia::LastName, "Last Name" ); 327 ret_map.insert( Qtopia::LastName, "Last Name" );
299 ret_map.insert( Qtopia::Suffix, "Suffix" ); 328 ret_map.insert( Qtopia::Suffix, "Suffix" );
300 ret_map.insert( Qtopia::FileAs, "File As" ); 329 ret_map.insert( Qtopia::FileAs, "File As" );
301 330
302 ret_map.insert( Qtopia::JobTitle, "Job Title" ); 331 ret_map.insert( Qtopia::JobTitle, "Job Title" );
303 ret_map.insert( Qtopia::Department, "Department" ); 332 ret_map.insert( Qtopia::Department, "Department" );
304 ret_map.insert( Qtopia::Company, "Company" ); 333 ret_map.insert( Qtopia::Company, "Company" );
305 ret_map.insert( Qtopia::BusinessPhone, "Business Phone" ); 334 ret_map.insert( Qtopia::BusinessPhone, "Business Phone" );
306 ret_map.insert( Qtopia::BusinessFax, "Business Fax" ); 335 ret_map.insert( Qtopia::BusinessFax, "Business Fax" );
307 ret_map.insert( Qtopia::BusinessMobile, "Business Mobile" ); 336 ret_map.insert( Qtopia::BusinessMobile, "Business Mobile" );
308 337
309 // email 338 // email
310 ret_map.insert( Qtopia::DefaultEmail, "Default Email" ); 339 ret_map.insert( Qtopia::DefaultEmail, "Default Email" );
311 ret_map.insert( Qtopia::Emails, "Emails" ); 340 ret_map.insert( Qtopia::Emails, "Emails" );
312 341
313 ret_map.insert( Qtopia::HomePhone, "Home Phone" ); 342 ret_map.insert( Qtopia::HomePhone, "Home Phone" );
314 ret_map.insert( Qtopia::HomeFax, "Home Fax" ); 343 ret_map.insert( Qtopia::HomeFax, "Home Fax" );
315 ret_map.insert( Qtopia::HomeMobile, "Home Mobile" ); 344 ret_map.insert( Qtopia::HomeMobile, "Home Mobile" );
316 345
317 // business 346 // business
318 ret_map.insert( Qtopia::BusinessStreet, "Business Street" ); 347 ret_map.insert( Qtopia::BusinessStreet, "Business Street" );
319 ret_map.insert( Qtopia::BusinessCity, "Business City" ); 348 ret_map.insert( Qtopia::BusinessCity, "Business City" );
320 ret_map.insert( Qtopia::BusinessState, "Business State" ); 349 ret_map.insert( Qtopia::BusinessState, "Business State" );
321 ret_map.insert( Qtopia::BusinessZip, "Business Zip" ); 350 ret_map.insert( Qtopia::BusinessZip, "Business Zip" );
322 ret_map.insert( Qtopia::BusinessCountry, "Business Country" ); 351 ret_map.insert( Qtopia::BusinessCountry, "Business Country" );
323 ret_map.insert( Qtopia::BusinessPager, "Business Pager" ); 352 ret_map.insert( Qtopia::BusinessPager, "Business Pager" );
324 ret_map.insert( Qtopia::BusinessWebPage, "Business WebPage" ); 353 ret_map.insert( Qtopia::BusinessWebPage, "Business WebPage" );
325 354
326 ret_map.insert( Qtopia::Office, "Office" ); 355 ret_map.insert( Qtopia::Office, "Office" );
327 ret_map.insert( Qtopia::Profession, "Profession" ); 356 ret_map.insert( Qtopia::Profession, "Profession" );
328 ret_map.insert( Qtopia::Assistant, "Assistant" ); 357 ret_map.insert( Qtopia::Assistant, "Assistant" );
329 ret_map.insert( Qtopia::Manager, "Manager" ); 358 ret_map.insert( Qtopia::Manager, "Manager" );
330 359
331 // home 360 // home
332 ret_map.insert( Qtopia::HomeStreet, "Home Street" ); 361 ret_map.insert( Qtopia::HomeStreet, "Home Street" );
333 ret_map.insert( Qtopia::HomeCity, "Home City" ); 362 ret_map.insert( Qtopia::HomeCity, "Home City" );
334 ret_map.insert( Qtopia::HomeState, "Home State" ); 363 ret_map.insert( Qtopia::HomeState, "Home State" );
335 ret_map.insert( Qtopia::HomeZip, "Home Zip" ); 364 ret_map.insert( Qtopia::HomeZip, "Home Zip" );
336 ret_map.insert( Qtopia::HomeCountry, "Home Country" ); 365 ret_map.insert( Qtopia::HomeCountry, "Home Country" );
337 ret_map.insert( Qtopia::HomeWebPage, "Home Web Page" ); 366 ret_map.insert( Qtopia::HomeWebPage, "Home Web Page" );
338 367
339 //personal 368 //personal
340 ret_map.insert( Qtopia::Spouse, "Spouse" ); 369 ret_map.insert( Qtopia::Spouse, "Spouse" );
341 ret_map.insert( Qtopia::Gender, "Gender" ); 370 ret_map.insert( Qtopia::Gender, "Gender" );
342 ret_map.insert( Qtopia::Birthday, "Birthday" ); 371 ret_map.insert( Qtopia::Birthday, "Birthday" );
343 ret_map.insert( Qtopia::Anniversary, "Anniversary" ); 372 ret_map.insert( Qtopia::Anniversary, "Anniversary" );
344 ret_map.insert( Qtopia::Nickname, "Nickname" ); 373 ret_map.insert( Qtopia::Nickname, "Nickname" );
345 ret_map.insert( Qtopia::Children, "Children" ); 374 ret_map.insert( Qtopia::Children, "Children" );
346 375
347 // other 376 // other
348 ret_map.insert( Qtopia::Notes, "Notes" ); 377 ret_map.insert( Qtopia::Notes, "Notes" );
349 ret_map.insert( Qtopia::Groups, "Groups" ); 378 ret_map.insert( Qtopia::Groups, "Groups" );
350 379
351 380
352 return ret_map; 381 return ret_map;
353} 382}
354 383
355QMap<QString, int> OContactFields::trFieldsToId() 384QMap<QString, int> OContactFields::trFieldsToId()
356{ 385{
357 QMap<int, QString> idtostr = idToTrFields(); 386 QMap<int, QString> idtostr = idToTrFields();
358 QMap<QString, int> ret_map; 387 QMap<QString, int> ret_map;
359 388
360 389
361 QMap<int, QString>::Iterator it; 390 QMap<int, QString>::Iterator it;
362 for( it = idtostr.begin(); it != idtostr.end(); ++it ) 391 for( it = idtostr.begin(); it != idtostr.end(); ++it )
363 ret_map.insert( *it, it.key() ); 392 ret_map.insert( *it, it.key() );
364 393
365 394
366 return ret_map; 395 return ret_map;
367} 396}
368 397
369/* ======================================================================= */ 398/* ======================================================================= */
370 399
371QMap<QString, int> OContactFields::untrFieldsToId() 400QMap<QString, int> OContactFields::untrFieldsToId()
372{ 401{
373 QMap<int, QString> idtostr = idToUntrFields(); 402 QMap<int, QString> idtostr = idToUntrFields();
374 QMap<QString, int> ret_map; 403 QMap<QString, int> ret_map;
375 404
376 405
377 QMap<int, QString>::Iterator it; 406 QMap<int, QString>::Iterator it;
378 for( it = idtostr.begin(); it != idtostr.end(); ++it ) 407 for( it = idtostr.begin(); it != idtostr.end(); ++it )
379 ret_map.insert( *it, it.key() ); 408 ret_map.insert( *it, it.key() );
380 409
381 410
382 return ret_map; 411 return ret_map;
383} 412}
384 413
385 414
386OContactFields::OContactFields(): 415OContactFields::OContactFields():
387 fieldOrder( DEFAULT_FIELD_ORDER ), 416 fieldOrder( DEFAULT_FIELD_ORDER ),
388 changedFieldOrder( false ) 417 changedFieldOrder( false )
389{ 418{
390 // Get the global field order from the config file and 419 // Get the global field order from the config file and
391 // use it as a start pattern 420 // use it as a start pattern
392 Config cfg ( "AddressBook" ); 421 Config cfg ( "AddressBook" );
393 cfg.setGroup( "ContactFieldOrder" ); 422 cfg.setGroup( "ContactFieldOrder" );
394 globalFieldOrder = cfg.readEntry( "General", DEFAULT_FIELD_ORDER ); 423 globalFieldOrder = cfg.readEntry( "General", DEFAULT_FIELD_ORDER );
395} 424}
396 425
397OContactFields::~OContactFields(){ 426OContactFields::~OContactFields(){
398 427
399 // We will store the fieldorder into the config file 428 // We will store the fieldorder into the config file
400 // to reuse it for the future.. 429 // to reuse it for the future..
401 if ( changedFieldOrder ){ 430 if ( changedFieldOrder ){
402 Config cfg ( "AddressBook" ); 431 Config cfg ( "AddressBook" );
403 cfg.setGroup( "ContactFieldOrder" ); 432 cfg.setGroup( "ContactFieldOrder" );
404 cfg.writeEntry( "General", globalFieldOrder ); 433 cfg.writeEntry( "General", globalFieldOrder );
405 } 434 }
406} 435}
407 436
408 437
409 438
410void OContactFields::saveToRecord( OContact &cnt ){ 439void OContactFields::saveToRecord( OContact &cnt ){
411 440
412 qDebug("ocontactfields saveToRecord: >%s<",fieldOrder.latin1()); 441 qDebug("ocontactfields saveToRecord: >%s<",fieldOrder.latin1());
413 442
414 // Store fieldorder into this contact. 443 // Store fieldorder into this contact.
415 cnt.setCustomField( CONTACT_FIELD_ORDER_NAME, fieldOrder ); 444 cnt.setCustomField( CONTACT_FIELD_ORDER_NAME, fieldOrder );
416 445
417 globalFieldOrder = fieldOrder; 446 globalFieldOrder = fieldOrder;
418 changedFieldOrder = true; 447 changedFieldOrder = true;
419 448
420} 449}
421 450
422void OContactFields::loadFromRecord( const OContact &cnt ){ 451void OContactFields::loadFromRecord( const OContact &cnt ){
423 qDebug("ocontactfields loadFromRecord"); 452 qDebug("ocontactfields loadFromRecord");
424 qDebug("loading >%s<",cnt.fullName().latin1()); 453 qDebug("loading >%s<",cnt.fullName().latin1());
425 454
426 // Get fieldorder for this contact. If none is defined, 455 // Get fieldorder for this contact. If none is defined,
427 // we will use the global one from the config file.. 456 // we will use the global one from the config file..
428 457
429 fieldOrder = cnt.customField( CONTACT_FIELD_ORDER_NAME ); 458 fieldOrder = cnt.customField( CONTACT_FIELD_ORDER_NAME );
430 459
431 qDebug("fieldOrder from contact>%s<",fieldOrder.latin1()); 460 qDebug("fieldOrder from contact>%s<",fieldOrder.latin1());
432 461
433 if (fieldOrder.isEmpty()){ 462 if (fieldOrder.isEmpty()){
434 fieldOrder = globalFieldOrder; 463 fieldOrder = globalFieldOrder;
435 } 464 }
436 465
437 466
438 qDebug("effective fieldOrder in loadFromRecord >%s<",fieldOrder.latin1()); 467 qDebug("effective fieldOrder in loadFromRecord >%s<",fieldOrder.latin1());
439} 468}
440 469
441void OContactFields::setFieldOrder( int num, int index ){ 470void OContactFields::setFieldOrder( int num, int index ){
442 qDebug("qcontactfields setfieldorder pos %i -> %i",num,index); 471 qDebug("qcontactfields setfieldorder pos %i -> %i",num,index);
443 472
444 fieldOrder[num] = QString::number( index, 16 )[0]; 473 fieldOrder[num] = QString::number( index, 16 )[0];
445 474
446 // We will store this new fieldorder globally to 475 // We will store this new fieldorder globally to
447 // remember it for contacts which have none 476 // remember it for contacts which have none
448 globalFieldOrder = fieldOrder; 477 globalFieldOrder = fieldOrder;
449 changedFieldOrder = true; 478 changedFieldOrder = true;
450 479
451 qDebug("fieldOrder >%s<",fieldOrder.latin1()); 480 qDebug("fieldOrder >%s<",fieldOrder.latin1());
452} 481}
453 482
454int OContactFields::getFieldOrder( int num, int defIndex ){ 483int OContactFields::getFieldOrder( int num, int defIndex ){
455 qDebug("ocontactfields getFieldOrder"); 484 qDebug("ocontactfields getFieldOrder");
456 qDebug("fieldOrder >%s<",fieldOrder.latin1()); 485 qDebug("fieldOrder >%s<",fieldOrder.latin1());
457 486
458 // Get index of combo as char.. 487 // Get index of combo as char..
459 QChar poschar = fieldOrder[num]; 488 QChar poschar = fieldOrder[num];
460 489
461 bool ok; 490 bool ok;
462 int ret = 0; 491 int ret = 0;
463 // Convert char to number.. 492 // Convert char to number..
464 if ( !( poschar == QChar::null ) ) 493 if ( !( poschar == QChar::null ) )
465 ret = QString( poschar ).toInt(&ok, 16); 494 ret = QString( poschar ).toInt(&ok, 16);
466 else 495 else
467 ok = false; 496 ok = false;
468 497
469 // Return default value if index for 498 // Return default value if index for
470 // num was not set or if anything else happened.. 499 // num was not set or if anything else happened..
471 if ( !ok ) ret = defIndex; 500 if ( !ok ) ret = defIndex;
472 501
473 qDebug("returning >%i<",ret); 502 qDebug("returning >%i<",ret);
474 503
475 return ret; 504 return ret;
476 505
477} 506}
507
508}
diff --git a/libopie2/opiepim/ocontactfields.h b/libopie2/opiepim/ocontactfields.h
index f105de7..993ce3b 100644
--- a/libopie2/opiepim/ocontactfields.h
+++ b/libopie2/opiepim/ocontactfields.h
@@ -1,67 +1,96 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_CONTACTS_FIELDS 29#ifndef OPIE_CONTACTS_FIELDS
2#define OPIE_CONTACTS_FIELDS 30#define OPIE_CONTACTS_FIELDS
3 31
4class QStringList; 32class QStringList;
5 33
6#include <qmap.h> 34#include <qmap.h>
7#include <qstring.h> 35#include <qstring.h>
8#include <opie/ocontact.h> 36#include <opie2/ocontact.h>
9 37
10#define CONTACT_FIELD_ORDER_NAME "opie-contactfield-order" 38#define CONTACT_FIELD_ORDER_NAME "opie-contactfield-order"
11#define DEFAULT_FIELD_ORDER "__________" 39#define DEFAULT_FIELD_ORDER "__________"
12 40
41namespace Opie {
13class OContactFields{ 42class OContactFields{
14 43
15 public: 44 public:
16 OContactFields(); 45 OContactFields();
17 ~OContactFields(); 46 ~OContactFields();
18 /** Set the index for combo boxes. 47 /** Set the index for combo boxes.
19 * Sets the <b>index</b> of combo <b>num</b>. 48 * Sets the <b>index</b> of combo <b>num</b>.
20 * @param num selects the number of the combo 49 * @param num selects the number of the combo
21 * @param index sets the index in the combo 50 * @param index sets the index in the combo
22 */ 51 */
23 void setFieldOrder( int num, int index ); 52 void setFieldOrder( int num, int index );
24 53
25 /** Get the index for combo boxes. 54 /** Get the index for combo boxes.
26 * Returns the index of combo <b>num</b> or defindex 55 * Returns the index of combo <b>num</b> or defindex
27 * if none was defined.. 56 * if none was defined..
28 * @param num Selects the number of the combo 57 * @param num Selects the number of the combo
29 * @param defIndex will be returned if none was defined (either 58 * @param defIndex will be returned if none was defined (either
30 * globally in the config file, nor by the contact which was used 59 * globally in the config file, nor by the contact which was used
31 * by loadFromRecord() ) 60 * by loadFromRecord() )
32 */ 61 */
33 int getFieldOrder( int num, int defIndex); 62 int getFieldOrder( int num, int defIndex);
34 63
35 /** Store fieldorder to contact. */ 64 /** Store fieldorder to contact. */
36 void saveToRecord( OContact& ); 65 void saveToRecord( OContact& );
37 /** Get Fieldorder from contact. */ 66 /** Get Fieldorder from contact. */
38 void loadFromRecord( const OContact& ); 67 void loadFromRecord( const OContact& );
39 68
40 private: 69 private:
41 QString fieldOrder; 70 QString fieldOrder;
42 QString globalFieldOrder; 71 QString globalFieldOrder;
43 bool changedFieldOrder; 72 bool changedFieldOrder;
44 73
45 public: 74 public:
46 static QStringList personalfields( bool sorted = true, bool translated = false ); 75 static QStringList personalfields( bool sorted = true, bool translated = false );
47 static QStringList phonefields( bool sorted = true, bool translated = false ); 76 static QStringList phonefields( bool sorted = true, bool translated = false );
48 static QStringList detailsfields( bool sorted = true, bool translated = false ); 77 static QStringList detailsfields( bool sorted = true, bool translated = false );
49 static QStringList fields( bool sorted = true, bool translated = false ); 78 static QStringList fields( bool sorted = true, bool translated = false );
50 79
51 static QStringList trpersonalfields( bool sorted = true ); 80 static QStringList trpersonalfields( bool sorted = true );
52 static QStringList untrpersonalfields( bool sorted = true ); 81 static QStringList untrpersonalfields( bool sorted = true );
53 static QStringList trphonefields( bool sorted = true ); 82 static QStringList trphonefields( bool sorted = true );
54 static QStringList untrphonefields( bool sorted = true ); 83 static QStringList untrphonefields( bool sorted = true );
55 static QStringList trdetailsfields( bool sorted = true ); 84 static QStringList trdetailsfields( bool sorted = true );
56 static QStringList untrdetailsfields( bool sorted = true ); 85 static QStringList untrdetailsfields( bool sorted = true );
57 static QStringList trfields( bool sorted = true ); 86 static QStringList trfields( bool sorted = true );
58 static QStringList untrfields( bool sorted = true ); 87 static QStringList untrfields( bool sorted = true );
59 88
60 static QMap<int, QString> idToTrFields(); 89 static QMap<int, QString> idToTrFields();
61 static QMap<QString, int> trFieldsToId(); 90 static QMap<QString, int> trFieldsToId();
62 static QMap<int, QString> idToUntrFields(); 91 static QMap<int, QString> idToUntrFields();
63 static QMap<QString, int> untrFieldsToId(); 92 static QMap<QString, int> untrFieldsToId();
64 93
65}; 94};
66 95}
67#endif 96#endif
diff --git a/libopie2/opiepim/oevent.cpp b/libopie2/opiepim/oevent.cpp
index 9b31957..de5e30b 100644
--- a/libopie2/opiepim/oevent.cpp
+++ b/libopie2/opiepim/oevent.cpp
@@ -1,717 +1,749 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qshared.h> 29#include <qshared.h>
2#include <qarray.h> 30#include <qarray.h>
3 31
4#include <qpe/palmtopuidgen.h> 32#include <qpe/palmtopuidgen.h>
5#include <qpe/categories.h> 33#include <qpe/categories.h>
6#include <qpe/stringutil.h> 34#include <qpe/stringutil.h>
7 35
8#include "orecur.h" 36#include <opie2/orecur.h>
9#include "opimresolver.h" 37#include <opie2/opimresolver.h>
10#include "opimnotifymanager.h" 38#include <opie2/opimnotifymanager.h>
11 39
12#include "oevent.h" 40#include <opie2/oevent.h>
41
42namespace Opie {
13 43
14int OCalendarHelper::week( const QDate& date) { 44int OCalendarHelper::week( const QDate& date) {
15 // Calculates the week this date is in within that 45 // Calculates the week this date is in within that
16 // month. Equals the "row" is is in in the month view 46 // month. Equals the "row" is is in in the month view
17 int week = 1; 47 int week = 1;
18 QDate tmp( date.year(), date.month(), 1 ); 48 QDate tmp( date.year(), date.month(), 1 );
19 if ( date.dayOfWeek() < tmp.dayOfWeek() ) 49 if ( date.dayOfWeek() < tmp.dayOfWeek() )
20 ++week; 50 ++week;
21 51
22 week += ( date.day() - 1 ) / 7; 52 week += ( date.day() - 1 ) / 7;
23 53
24 return week; 54 return week;
25} 55}
26int OCalendarHelper::ocurrence( const QDate& date) { 56int OCalendarHelper::ocurrence( const QDate& date) {
27 // calculates the number of occurrances of this day of the 57 // calculates the number of occurrances of this day of the
28 // week till the given date (e.g 3rd Wednesday of the month) 58 // week till the given date (e.g 3rd Wednesday of the month)
29 return ( date.day() - 1 ) / 7 + 1; 59 return ( date.day() - 1 ) / 7 + 1;
30} 60}
31int OCalendarHelper::dayOfWeek( char day ) { 61int OCalendarHelper::dayOfWeek( char day ) {
32 int dayOfWeek = 1; 62 int dayOfWeek = 1;
33 char i = ORecur::MON; 63 char i = ORecur::MON;
34 while ( !( i & day ) && i <= ORecur::SUN ) { 64 while ( !( i & day ) && i <= ORecur::SUN ) {
35 i <<= 1; 65 i <<= 1;
36 ++dayOfWeek; 66 ++dayOfWeek;
37 } 67 }
38 return dayOfWeek; 68 return dayOfWeek;
39} 69}
40int OCalendarHelper::monthDiff( const QDate& first, const QDate& second ) { 70int OCalendarHelper::monthDiff( const QDate& first, const QDate& second ) {
41 return ( second.year() - first.year() ) * 12 + 71 return ( second.year() - first.year() ) * 12 +
42 second.month() - first.month(); 72 second.month() - first.month();
43} 73}
44 74
45struct OEvent::Data : public QShared { 75struct OEvent::Data : public QShared {
46 Data() : QShared() { 76 Data() : QShared() {
47 child = 0; 77 child = 0;
48 recur = 0; 78 recur = 0;
49 manager = 0; 79 manager = 0;
50 isAllDay = false; 80 isAllDay = false;
51 parent = 0; 81 parent = 0;
52 } 82 }
53 ~Data() { 83 ~Data() {
54 delete manager; 84 delete manager;
55 delete recur; 85 delete recur;
56 } 86 }
57 QString description; 87 QString description;
58 QString location; 88 QString location;
59 OPimNotifyManager* manager; 89 OPimNotifyManager* manager;
60 ORecur* recur; 90 ORecur* recur;
61 QString note; 91 QString note;
62 QDateTime created; 92 QDateTime created;
63 QDateTime start; 93 QDateTime start;
64 QDateTime end; 94 QDateTime end;
65 bool isAllDay : 1; 95 bool isAllDay : 1;
66 QString timezone; 96 QString timezone;
67 QArray<int>* child; 97 QArray<int>* child;
68 int parent; 98 int parent;
69}; 99};
70 100
71OEvent::OEvent( int uid ) 101OEvent::OEvent( int uid )
72 : OPimRecord( uid ) { 102 : OPimRecord( uid ) {
73 data = new Data; 103 data = new Data;
74} 104}
75OEvent::OEvent( const OEvent& ev) 105OEvent::OEvent( const OEvent& ev)
76 : OPimRecord( ev ), data( ev.data ) 106 : OPimRecord( ev ), data( ev.data )
77{ 107{
78 data->ref(); 108 data->ref();
79} 109}
80 110
81OEvent::OEvent( const QMap<int, QString> map ) 111OEvent::OEvent( const QMap<int, QString> map )
82 : OPimRecord( 0 ) 112 : OPimRecord( 0 )
83{ 113{
84 data = new Data; 114 data = new Data;
85 115
86 fromMap( map ); 116 fromMap( map );
87} 117}
88 118
89OEvent::~OEvent() { 119OEvent::~OEvent() {
90 if ( data->deref() ) { 120 if ( data->deref() ) {
91 delete data; 121 delete data;
92 data = 0; 122 data = 0;
93 } 123 }
94} 124}
95OEvent& OEvent::operator=( const OEvent& ev) { 125OEvent& OEvent::operator=( const OEvent& ev) {
96 if ( this == &ev ) return *this; 126 if ( this == &ev ) return *this;
97 127
98 OPimRecord::operator=( ev ); 128 OPimRecord::operator=( ev );
99 ev.data->ref(); 129 ev.data->ref();
100 deref(); 130 deref();
101 data = ev.data; 131 data = ev.data;
102 132
103 133
104 return *this; 134 return *this;
105} 135}
106QString OEvent::description()const { 136QString OEvent::description()const {
107 return data->description; 137 return data->description;
108} 138}
109void OEvent::setDescription( const QString& description ) { 139void OEvent::setDescription( const QString& description ) {
110 changeOrModify(); 140 changeOrModify();
111 data->description = description; 141 data->description = description;
112} 142}
113void OEvent::setLocation( const QString& loc ) { 143void OEvent::setLocation( const QString& loc ) {
114 changeOrModify(); 144 changeOrModify();
115 data->location = loc; 145 data->location = loc;
116} 146}
117QString OEvent::location()const { 147QString OEvent::location()const {
118 return data->location; 148 return data->location;
119} 149}
120OPimNotifyManager &OEvent::notifiers()const { 150OPimNotifyManager &OEvent::notifiers()const {
121 // I hope we can skip the changeOrModify here 151 // I hope we can skip the changeOrModify here
122 // the notifier should take care of it 152 // the notifier should take care of it
123 // and OPimNotify is shared too 153 // and OPimNotify is shared too
124 if (!data->manager ) 154 if (!data->manager )
125 data->manager = new OPimNotifyManager; 155 data->manager = new OPimNotifyManager;
126 156
127 return *data->manager; 157 return *data->manager;
128} 158}
129bool OEvent::hasNotifiers()const { 159bool OEvent::hasNotifiers()const {
130 if (!data->manager ) 160 if (!data->manager )
131 return false; 161 return false;
132 if (data->manager->reminders().isEmpty() && 162 if (data->manager->reminders().isEmpty() &&
133 data->manager->alarms().isEmpty() ) 163 data->manager->alarms().isEmpty() )
134 return false; 164 return false;
135 165
136 return true; 166 return true;
137} 167}
138ORecur OEvent::recurrence()const { 168ORecur OEvent::recurrence()const {
139 if (!data->recur) 169 if (!data->recur)
140 data->recur = new ORecur; 170 data->recur = new ORecur;
141 171
142 return *data->recur; 172 return *data->recur;
143} 173}
144void OEvent::setRecurrence( const ORecur& rec) { 174void OEvent::setRecurrence( const ORecur& rec) {
145 changeOrModify(); 175 changeOrModify();
146 if (data->recur ) 176 if (data->recur )
147 (*data->recur) = rec; 177 (*data->recur) = rec;
148 else 178 else
149 data->recur = new ORecur( rec ); 179 data->recur = new ORecur( rec );
150} 180}
151bool OEvent::hasRecurrence()const { 181bool OEvent::hasRecurrence()const {
152 if (!data->recur ) return false; 182 if (!data->recur ) return false;
153 return data->recur->doesRecur(); 183 return data->recur->doesRecur();
154} 184}
155QString OEvent::note()const { 185QString OEvent::note()const {
156 return data->note; 186 return data->note;
157} 187}
158void OEvent::setNote( const QString& note ) { 188void OEvent::setNote( const QString& note ) {
159 changeOrModify(); 189 changeOrModify();
160 data->note = note; 190 data->note = note;
161} 191}
162QDateTime OEvent::createdDateTime()const { 192QDateTime OEvent::createdDateTime()const {
163 return data->created; 193 return data->created;
164} 194}
165void OEvent::setCreatedDateTime( const QDateTime& time ) { 195void OEvent::setCreatedDateTime( const QDateTime& time ) {
166 changeOrModify(); 196 changeOrModify();
167 data->created = time; 197 data->created = time;
168} 198}
169QDateTime OEvent::startDateTime()const { 199QDateTime OEvent::startDateTime()const {
170 if ( data->isAllDay ) 200 if ( data->isAllDay )
171 return QDateTime( data->start.date(), QTime(0, 0, 0 ) ); 201 return QDateTime( data->start.date(), QTime(0, 0, 0 ) );
172 return data->start; 202 return data->start;
173} 203}
174QDateTime OEvent::startDateTimeInZone()const { 204QDateTime OEvent::startDateTimeInZone()const {
175 /* if no timezone, or all day event or if the current and this timeZone match... */ 205 /* if no timezone, or all day event or if the current and this timeZone match... */
176 if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime(); 206 if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return startDateTime();
177 207
178 OTimeZone zone(data->timezone ); 208 OTimeZone zone(data->timezone );
179 return zone.toDateTime( data->start, OTimeZone::current() ); 209 return zone.toDateTime( data->start, OTimeZone::current() );
180} 210}
181void OEvent::setStartDateTime( const QDateTime& dt ) { 211void OEvent::setStartDateTime( const QDateTime& dt ) {
182 changeOrModify(); 212 changeOrModify();
183 data->start = dt; 213 data->start = dt;
184} 214}
185QDateTime OEvent::endDateTime()const { 215QDateTime OEvent::endDateTime()const {
186 /* 216 /*
187 * if all Day event the end time needs 217 * if all Day event the end time needs
188 * to be on the same day as the start 218 * to be on the same day as the start
189 */ 219 */
190 if ( data->isAllDay ) 220 if ( data->isAllDay )
191 return QDateTime( data->start.date(), QTime(23, 59, 59 ) ); 221 return QDateTime( data->start.date(), QTime(23, 59, 59 ) );
192 return data->end; 222 return data->end;
193} 223}
194QDateTime OEvent::endDateTimeInZone()const { 224QDateTime OEvent::endDateTimeInZone()const {
195 /* if no timezone, or all day event or if the current and this timeZone match... */ 225 /* if no timezone, or all day event or if the current and this timeZone match... */
196 if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime(); 226 if (data->timezone.isEmpty() || data->isAllDay || data->timezone == OTimeZone::current().timeZone() ) return endDateTime();
197 227
198 OTimeZone zone(data->timezone ); 228 OTimeZone zone(data->timezone );
199 return zone.toDateTime( data->end, OTimeZone::current() ); 229 return zone.toDateTime( data->end, OTimeZone::current() );
200} 230}
201void OEvent::setEndDateTime( const QDateTime& dt ) { 231void OEvent::setEndDateTime( const QDateTime& dt ) {
202 changeOrModify(); 232 changeOrModify();
203 data->end = dt; 233 data->end = dt;
204} 234}
205bool OEvent::isMultipleDay()const { 235bool OEvent::isMultipleDay()const {
206 return data->end.date().day() - data->start.date().day(); 236 return data->end.date().day() - data->start.date().day();
207} 237}
208bool OEvent::isAllDay()const { 238bool OEvent::isAllDay()const {
209 return data->isAllDay; 239 return data->isAllDay;
210} 240}
211void OEvent::setAllDay( bool allDay ) { 241void OEvent::setAllDay( bool allDay ) {
212 changeOrModify(); 242 changeOrModify();
213 data->isAllDay = allDay; 243 data->isAllDay = allDay;
214 if (allDay ) data->timezone = "UTC"; 244 if (allDay ) data->timezone = "UTC";
215} 245}
216void OEvent::setTimeZone( const QString& tz ) { 246void OEvent::setTimeZone( const QString& tz ) {
217 changeOrModify(); 247 changeOrModify();
218 data->timezone = tz; 248 data->timezone = tz;
219} 249}
220QString OEvent::timeZone()const { 250QString OEvent::timeZone()const {
221 if (data->isAllDay ) return QString::fromLatin1("UTC"); 251 if (data->isAllDay ) return QString::fromLatin1("UTC");
222 return data->timezone; 252 return data->timezone;
223} 253}
224bool OEvent::match( const QRegExp& re )const { 254bool OEvent::match( const QRegExp& re )const {
225 if ( re.match( data->description ) != -1 ){ 255 if ( re.match( data->description ) != -1 ){
226 setLastHitField( Qtopia::DatebookDescription ); 256 setLastHitField( Qtopia::DatebookDescription );
227 return true; 257 return true;
228 } 258 }
229 if ( re.match( data->note ) != -1 ){ 259 if ( re.match( data->note ) != -1 ){
230 setLastHitField( Qtopia::Note ); 260 setLastHitField( Qtopia::Note );
231 return true; 261 return true;
232 } 262 }
233 if ( re.match( data->location ) != -1 ){ 263 if ( re.match( data->location ) != -1 ){
234 setLastHitField( Qtopia::Location ); 264 setLastHitField( Qtopia::Location );
235 return true; 265 return true;
236 } 266 }
237 if ( re.match( data->start.toString() ) != -1 ){ 267 if ( re.match( data->start.toString() ) != -1 ){
238 setLastHitField( Qtopia::StartDateTime ); 268 setLastHitField( Qtopia::StartDateTime );
239 return true; 269 return true;
240 } 270 }
241 if ( re.match( data->end.toString() ) != -1 ){ 271 if ( re.match( data->end.toString() ) != -1 ){
242 setLastHitField( Qtopia::EndDateTime ); 272 setLastHitField( Qtopia::EndDateTime );
243 return true; 273 return true;
244 } 274 }
245 return false; 275 return false;
246} 276}
247QString OEvent::toRichText()const { 277QString OEvent::toRichText()const {
248 QString text, value; 278 QString text, value;
249 279
250 // description 280 // description
251 text += "<b><h3><img src=\"datebook/DateBook\">"; 281 text += "<b><h3><img src=\"datebook/DateBook\">";
252 if ( !description().isEmpty() ) { 282 if ( !description().isEmpty() ) {
253 text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "" ); 283 text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "" );
254 } 284 }
255 text += "</h3></b><br><hr><br>"; 285 text += "</h3></b><br><hr><br>";
256 286
257 // location 287 // location
258 if ( !(value = location()).isEmpty() ) { 288 if ( !(value = location()).isEmpty() ) {
259 text += "<b>" + QObject::tr( "Location:" ) + "</b> "; 289 text += "<b>" + QObject::tr( "Location:" ) + "</b> ";
260 text += Qtopia::escapeString(value) + "<br>"; 290 text += Qtopia::escapeString(value) + "<br>";
261 } 291 }
262 292
263 // all day event 293 // all day event
264 if ( isAllDay() ) { 294 if ( isAllDay() ) {
265 text += "<b><i>" + QObject::tr( "This is an all day event" ) + "</i></b><br>"; 295 text += "<b><i>" + QObject::tr( "This is an all day event" ) + "</i></b><br>";
266 } 296 }
267 // multiple day event 297 // multiple day event
268 else if ( isMultipleDay () ) { 298 else if ( isMultipleDay () ) {
269 text += "<b><i>" + QObject::tr( "This is a multiple day event" ) + "</i></b><br>"; 299 text += "<b><i>" + QObject::tr( "This is a multiple day event" ) + "</i></b><br>";
270 } 300 }
271 // start & end times 301 // start & end times
272 else { 302 else {
273 // start time 303 // start time
274 if ( startDateTime().isValid() ) { 304 if ( startDateTime().isValid() ) {
275 text += "<b>" + QObject::tr( "Start:") + "</b> "; 305 text += "<b>" + QObject::tr( "Start:") + "</b> ";
276 text += Qtopia::escapeString(startDateTime().toString() ). 306 text += Qtopia::escapeString(startDateTime().toString() ).
277 replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; 307 replace(QRegExp( "[\n]"), "<br>" ) + "<br>";
278 } 308 }
279 309
280 // end time 310 // end time
281 if ( endDateTime().isValid() ) { 311 if ( endDateTime().isValid() ) {
282 text += "<b>" + QObject::tr( "End:") + "</b> "; 312 text += "<b>" + QObject::tr( "End:") + "</b> ";
283 text += Qtopia::escapeString(endDateTime().toString() ). 313 text += Qtopia::escapeString(endDateTime().toString() ).
284 replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; 314 replace(QRegExp( "[\n]"), "<br>" ) + "<br>";
285 } 315 }
286 } 316 }
287 317
288 // categories 318 // categories
289 if ( categoryNames("Calendar").count() ){ 319 if ( categoryNames("Calendar").count() ){
290 text += "<b>" + QObject::tr( "Category:") + "</b> "; 320 text += "<b>" + QObject::tr( "Category:") + "</b> ";
291 text += categoryNames("Calendar").join(", "); 321 text += categoryNames("Calendar").join(", ");
292 text += "<br>"; 322 text += "<br>";
293 } 323 }
294 324
295 //notes 325 //notes
296 if ( !note().isEmpty() ) { 326 if ( !note().isEmpty() ) {
297 text += "<b>" + QObject::tr( "Note:") + "</b><br>"; 327 text += "<b>" + QObject::tr( "Note:") + "</b><br>";
298 text += note(); 328 text += note();
299// text += Qtopia::escapeString(note() ). 329// text += Qtopia::escapeString(note() ).
300// replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; 330// replace(QRegExp( "[\n]"), "<br>" ) + "<br>";
301 } 331 }
302 return text; 332 return text;
303} 333}
304QString OEvent::toShortText()const { 334QString OEvent::toShortText()const {
305 QString text; 335 QString text;
306 text += QString::number( startDateTime().date().day() ); 336 text += QString::number( startDateTime().date().day() );
307 text += "."; 337 text += ".";
308 text += QString::number( startDateTime().date().month() ); 338 text += QString::number( startDateTime().date().month() );
309 text += "."; 339 text += ".";
310 text += QString::number( startDateTime().date().year() ); 340 text += QString::number( startDateTime().date().year() );
311 text += " "; 341 text += " ";
312 text += QString::number( startDateTime().time().hour() ); 342 text += QString::number( startDateTime().time().hour() );
313 text += ":"; 343 text += ":";
314 text += QString::number( startDateTime().time().minute() ); 344 text += QString::number( startDateTime().time().minute() );
315 text += " - "; 345 text += " - ";
316 text += description(); 346 text += description();
317 return text; 347 return text;
318} 348}
319QString OEvent::type()const { 349QString OEvent::type()const {
320 return QString::fromLatin1("OEvent"); 350 return QString::fromLatin1("OEvent");
321} 351}
322QString OEvent::recordField( int /*id */ )const { 352QString OEvent::recordField( int /*id */ )const {
323 return QString::null; 353 return QString::null;
324} 354}
325int OEvent::rtti() { 355int OEvent::rtti() {
326 return OPimResolver::DateBook; 356 return OPimResolver::DateBook;
327} 357}
328bool OEvent::loadFromStream( QDataStream& ) { 358bool OEvent::loadFromStream( QDataStream& ) {
329 return true; 359 return true;
330} 360}
331bool OEvent::saveToStream( QDataStream& )const { 361bool OEvent::saveToStream( QDataStream& )const {
332 return true; 362 return true;
333} 363}
334void OEvent::changeOrModify() { 364void OEvent::changeOrModify() {
335 if ( data->count != 1 ) { 365 if ( data->count != 1 ) {
336 data->deref(); 366 data->deref();
337 Data* d2 = new Data; 367 Data* d2 = new Data;
338 d2->description = data->description; 368 d2->description = data->description;
339 d2->location = data->location; 369 d2->location = data->location;
340 370
341 if (data->manager ) 371 if (data->manager )
342 d2->manager = new OPimNotifyManager( *data->manager ); 372 d2->manager = new OPimNotifyManager( *data->manager );
343 373
344 if ( data->recur ) 374 if ( data->recur )
345 d2->recur = new ORecur( *data->recur ); 375 d2->recur = new ORecur( *data->recur );
346 376
347 d2->note = data->note; 377 d2->note = data->note;
348 d2->created = data->created; 378 d2->created = data->created;
349 d2->start = data->start; 379 d2->start = data->start;
350 d2->end = data->end; 380 d2->end = data->end;
351 d2->isAllDay = data->isAllDay; 381 d2->isAllDay = data->isAllDay;
352 d2->timezone = data->timezone; 382 d2->timezone = data->timezone;
353 d2->parent = data->parent; 383 d2->parent = data->parent;
354 384
355 if ( data->child ) { 385 if ( data->child ) {
356 d2->child = new QArray<int>( *data->child ); 386 d2->child = new QArray<int>( *data->child );
357 d2->child->detach(); 387 d2->child->detach();
358 } 388 }
359 389
360 data = d2; 390 data = d2;
361 } 391 }
362} 392}
363void OEvent::deref() { 393void OEvent::deref() {
364 if ( data->deref() ) { 394 if ( data->deref() ) {
365 delete data; 395 delete data;
366 data = 0; 396 data = 0;
367 } 397 }
368} 398}
369// Exporting Event data to map. Using the same 399// Exporting Event data to map. Using the same
370// encoding as ODateBookAccessBackend_xml does.. 400// encoding as ODateBookAccessBackend_xml does..
371// Thus, we could remove the stuff there and use this 401// Thus, we could remove the stuff there and use this
372// for it and for all other places.. 402// for it and for all other places..
373// Encoding should happen at one place, only ! (eilers) 403// Encoding should happen at one place, only ! (eilers)
374QMap<int, QString> OEvent::toMap()const { 404QMap<int, QString> OEvent::toMap()const {
375 QMap<int, QString> retMap; 405 QMap<int, QString> retMap;
376 406
377 retMap.insert( OEvent::FUid, QString::number( uid() ) ); 407 retMap.insert( OEvent::FUid, QString::number( uid() ) );
378 retMap.insert( OEvent::FCategories, Qtopia::escapeString( Qtopia::Record::idsToString( categories() ) )); 408 retMap.insert( OEvent::FCategories, Qtopia::escapeString( Qtopia::Record::idsToString( categories() ) ));
379 retMap.insert( OEvent::FDescription, Qtopia::escapeString( description() ) ); 409 retMap.insert( OEvent::FDescription, Qtopia::escapeString( description() ) );
380 retMap.insert( OEvent::FLocation, Qtopia::escapeString( location() ) ); 410 retMap.insert( OEvent::FLocation, Qtopia::escapeString( location() ) );
381 retMap.insert( OEvent::FType, isAllDay() ? "AllDay" : "" ); 411 retMap.insert( OEvent::FType, isAllDay() ? "AllDay" : "" );
382 OPimAlarm alarm = notifiers().alarms()[0]; 412 OPimAlarm alarm = notifiers().alarms()[0];
383 retMap.insert( OEvent::FAlarm, QString::number( alarm.dateTime().secsTo( startDateTime() ) / 60 ) ); 413 retMap.insert( OEvent::FAlarm, QString::number( alarm.dateTime().secsTo( startDateTime() ) / 60 ) );
384 retMap.insert( OEvent::FSound, (alarm.sound() == OPimAlarm::Loud) ? "loud" : "silent" ); 414 retMap.insert( OEvent::FSound, (alarm.sound() == OPimAlarm::Loud) ? "loud" : "silent" );
385 415
386 OTimeZone zone( timeZone().isEmpty() ? OTimeZone::current() : timeZone() ); 416 OTimeZone zone( timeZone().isEmpty() ? OTimeZone::current() : timeZone() );
387 retMap.insert( OEvent::FStart, QString::number( zone.fromUTCDateTime( zone.toDateTime( startDateTime(), OTimeZone::utc() ) ) ) ); 417 retMap.insert( OEvent::FStart, QString::number( zone.fromUTCDateTime( zone.toDateTime( startDateTime(), OTimeZone::utc() ) ) ) );
388 retMap.insert( OEvent::FEnd, QString::number( zone.fromUTCDateTime( zone.toDateTime( endDateTime(), OTimeZone::utc() ) ) ) ); 418 retMap.insert( OEvent::FEnd, QString::number( zone.fromUTCDateTime( zone.toDateTime( endDateTime(), OTimeZone::utc() ) ) ) );
389 retMap.insert( OEvent::FNote, Qtopia::escapeString( note() ) ); 419 retMap.insert( OEvent::FNote, Qtopia::escapeString( note() ) );
390 retMap.insert( OEvent::FTimeZone, timeZone().isEmpty() ? QString( "None" ) : timeZone() ); 420 retMap.insert( OEvent::FTimeZone, timeZone().isEmpty() ? QString( "None" ) : timeZone() );
391 if( parent() ) 421 if( parent() )
392 retMap.insert( OEvent::FRecParent, QString::number( parent() ) ); 422 retMap.insert( OEvent::FRecParent, QString::number( parent() ) );
393 if( children().count() ){ 423 if( children().count() ){
394 QArray<int> childr = children(); 424 QArray<int> childr = children();
395 QString buf; 425 QString buf;
396 for ( uint i = 0; i < childr.count(); i++ ) { 426 for ( uint i = 0; i < childr.count(); i++ ) {
397 if ( i != 0 ) buf += " "; 427 if ( i != 0 ) buf += " ";
398 buf += QString::number( childr[i] ); 428 buf += QString::number( childr[i] );
399 } 429 }
400 retMap.insert( OEvent::FRecChildren, buf ); 430 retMap.insert( OEvent::FRecChildren, buf );
401 } 431 }
402 432
403 // Add recurrence stuff 433 // Add recurrence stuff
404 if( hasRecurrence() ){ 434 if( hasRecurrence() ){
405 ORecur recur = recurrence(); 435 ORecur recur = recurrence();
406 QMap<int, QString> recFields = recur.toMap(); 436 QMap<int, QString> recFields = recur.toMap();
407 retMap.insert( OEvent::FRType, recFields[ORecur::RType] ); 437 retMap.insert( OEvent::FRType, recFields[ORecur::RType] );
408 retMap.insert( OEvent::FRWeekdays, recFields[ORecur::RWeekdays] ); 438 retMap.insert( OEvent::FRWeekdays, recFields[ORecur::RWeekdays] );
409 retMap.insert( OEvent::FRPosition, recFields[ORecur::RPosition] ); 439 retMap.insert( OEvent::FRPosition, recFields[ORecur::RPosition] );
410 retMap.insert( OEvent::FRFreq, recFields[ORecur::RFreq] ); 440 retMap.insert( OEvent::FRFreq, recFields[ORecur::RFreq] );
411 retMap.insert( OEvent::FRHasEndDate, recFields[ORecur::RHasEndDate] ); 441 retMap.insert( OEvent::FRHasEndDate, recFields[ORecur::RHasEndDate] );
412 retMap.insert( OEvent::FREndDate, recFields[ORecur::EndDate] ); 442 retMap.insert( OEvent::FREndDate, recFields[ORecur::EndDate] );
413 retMap.insert( OEvent::FRCreated, recFields[ORecur::Created] ); 443 retMap.insert( OEvent::FRCreated, recFields[ORecur::Created] );
414 retMap.insert( OEvent::FRExceptions, recFields[ORecur::Exceptions] ); 444 retMap.insert( OEvent::FRExceptions, recFields[ORecur::Exceptions] );
415 } else { 445 } else {
416 ORecur recur = recurrence(); 446 ORecur recur = recurrence();
417 QMap<int, QString> recFields = recur.toMap(); 447 QMap<int, QString> recFields = recur.toMap();
418 retMap.insert( OEvent::FRType, recFields[ORecur::RType] ); 448 retMap.insert( OEvent::FRType, recFields[ORecur::RType] );
419 } 449 }
420 450
421 return retMap; 451 return retMap;
422} 452}
423 453
424void OEvent::fromMap( const QMap<int, QString>& map ) 454void OEvent::fromMap( const QMap<int, QString>& map )
425{ 455{
426 456
427 // We just want to set the UID if it is really stored. 457 // We just want to set the UID if it is really stored.
428 if ( !map[OEvent::FUid].isEmpty() ) 458 if ( !map[OEvent::FUid].isEmpty() )
429 setUid( map[OEvent::FUid].toInt() ); 459 setUid( map[OEvent::FUid].toInt() );
430 460
431 setCategories( idsFromString( map[OEvent::FCategories] ) ); 461 setCategories( idsFromString( map[OEvent::FCategories] ) );
432 setDescription( map[OEvent::FDescription] ); 462 setDescription( map[OEvent::FDescription] );
433 setLocation( map[OEvent::FLocation] ); 463 setLocation( map[OEvent::FLocation] );
434 464
435 if ( map[OEvent::FType] == "AllDay" ) 465 if ( map[OEvent::FType] == "AllDay" )
436 setAllDay( true ); 466 setAllDay( true );
437 else 467 else
438 setAllDay( false ); 468 setAllDay( false );
439 469
440 int alarmTime = -1; 470 int alarmTime = -1;
441 if( !map[OEvent::FAlarm].isEmpty() ) 471 if( !map[OEvent::FAlarm].isEmpty() )
442 alarmTime = map[OEvent::FAlarm].toInt(); 472 alarmTime = map[OEvent::FAlarm].toInt();
443 473
444 int sound = ( ( map[OEvent::FSound] == "loud" ) ? OPimAlarm::Loud : OPimAlarm::Silent ); 474 int sound = ( ( map[OEvent::FSound] == "loud" ) ? OPimAlarm::Loud : OPimAlarm::Silent );
445 if ( ( alarmTime != -1 ) ){ 475 if ( ( alarmTime != -1 ) ){
446 QDateTime dt = startDateTime().addSecs( -1*alarmTime*60 ); 476 QDateTime dt = startDateTime().addSecs( -1*alarmTime*60 );
447 OPimAlarm al( sound , dt ); 477 OPimAlarm al( sound , dt );
448 notifiers().add( al ); 478 notifiers().add( al );
449 } 479 }
450 if ( !map[OEvent::FTimeZone].isEmpty() && ( map[OEvent::FTimeZone] != "None" ) ){ 480 if ( !map[OEvent::FTimeZone].isEmpty() && ( map[OEvent::FTimeZone] != "None" ) ){
451 setTimeZone( map[OEvent::FTimeZone] ); 481 setTimeZone( map[OEvent::FTimeZone] );
452 } 482 }
453 483
454 time_t start = (time_t) map[OEvent::FStart].toLong(); 484 time_t start = (time_t) map[OEvent::FStart].toLong();
455 time_t end = (time_t) map[OEvent::FEnd].toLong(); 485 time_t end = (time_t) map[OEvent::FEnd].toLong();
456 486
457 /* AllDay is always in UTC */ 487 /* AllDay is always in UTC */
458 if ( isAllDay() ) { 488 if ( isAllDay() ) {
459 OTimeZone utc = OTimeZone::utc(); 489 OTimeZone utc = OTimeZone::utc();
460 setStartDateTime( utc.fromUTCDateTime( start ) ); 490 setStartDateTime( utc.fromUTCDateTime( start ) );
461 setEndDateTime ( utc.fromUTCDateTime( end ) ); 491 setEndDateTime ( utc.fromUTCDateTime( end ) );
462 setTimeZone( "UTC"); // make sure it is really utc 492 setTimeZone( "UTC"); // make sure it is really utc
463 }else { 493 }else {
464 /* to current date time */ 494 /* to current date time */
465 // qWarning(" Start is %d", start ); 495 // qWarning(" Start is %d", start );
466 OTimeZone zone( timeZone().isEmpty() ? OTimeZone::current() : timeZone() ); 496 OTimeZone zone( timeZone().isEmpty() ? OTimeZone::current() : timeZone() );
467 QDateTime date = zone.toDateTime( start ); 497 QDateTime date = zone.toDateTime( start );
468 qWarning(" Start is %s", date.toString().latin1() ); 498 qWarning(" Start is %s", date.toString().latin1() );
469 setStartDateTime( zone.toDateTime( date, OTimeZone::current() ) ); 499 setStartDateTime( zone.toDateTime( date, OTimeZone::current() ) );
470 500
471 date = zone.toDateTime( end ); 501 date = zone.toDateTime( end );
472 setEndDateTime ( zone.toDateTime( date, OTimeZone::current() ) ); 502 setEndDateTime ( zone.toDateTime( date, OTimeZone::current() ) );
473 } 503 }
474 504
475 if ( !map[OEvent::FRecParent].isEmpty() ) 505 if ( !map[OEvent::FRecParent].isEmpty() )
476 setParent( map[OEvent::FRecParent].toInt() ); 506 setParent( map[OEvent::FRecParent].toInt() );
477 507
478 if ( !map[OEvent::FRecChildren].isEmpty() ){ 508 if ( !map[OEvent::FRecChildren].isEmpty() ){
479 QStringList list = QStringList::split(' ', map[OEvent::FRecChildren] ); 509 QStringList list = QStringList::split(' ', map[OEvent::FRecChildren] );
480 for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { 510 for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) {
481 addChild( (*it).toInt() ); 511 addChild( (*it).toInt() );
482 } 512 }
483 } 513 }
484 514
485 // Fill recurrence stuff and put it directly into the ORecur-Object using fromMap.. 515 // Fill recurrence stuff and put it directly into the ORecur-Object using fromMap..
486 if( !map[OEvent::FRType].isEmpty() ){ 516 if( !map[OEvent::FRType].isEmpty() ){
487 QMap<int, QString> recFields; 517 QMap<int, QString> recFields;
488 recFields.insert( ORecur::RType, map[OEvent::FRType] ); 518 recFields.insert( ORecur::RType, map[OEvent::FRType] );
489 recFields.insert( ORecur::RWeekdays, map[OEvent::FRWeekdays] ); 519 recFields.insert( ORecur::RWeekdays, map[OEvent::FRWeekdays] );
490 recFields.insert( ORecur::RPosition, map[OEvent::FRPosition] ); 520 recFields.insert( ORecur::RPosition, map[OEvent::FRPosition] );
491 recFields.insert( ORecur::RFreq, map[OEvent::FRFreq] ); 521 recFields.insert( ORecur::RFreq, map[OEvent::FRFreq] );
492 recFields.insert( ORecur::RHasEndDate, map[OEvent::FRHasEndDate] ); 522 recFields.insert( ORecur::RHasEndDate, map[OEvent::FRHasEndDate] );
493 recFields.insert( ORecur::EndDate, map[OEvent::FREndDate] ); 523 recFields.insert( ORecur::EndDate, map[OEvent::FREndDate] );
494 recFields.insert( ORecur::Created, map[OEvent::FRCreated] ); 524 recFields.insert( ORecur::Created, map[OEvent::FRCreated] );
495 recFields.insert( ORecur::Exceptions, map[OEvent::FRExceptions] ); 525 recFields.insert( ORecur::Exceptions, map[OEvent::FRExceptions] );
496 ORecur recur( recFields ); 526 ORecur recur( recFields );
497 setRecurrence( recur ); 527 setRecurrence( recur );
498 } 528 }
499 529
500} 530}
501 531
502 532
503int OEvent::parent()const { 533int OEvent::parent()const {
504 return data->parent; 534 return data->parent;
505} 535}
506void OEvent::setParent( int uid ) { 536void OEvent::setParent( int uid ) {
507 changeOrModify(); 537 changeOrModify();
508 data->parent = uid; 538 data->parent = uid;
509} 539}
510QArray<int> OEvent::children() const{ 540QArray<int> OEvent::children() const{
511 if (!data->child) return QArray<int>(); 541 if (!data->child) return QArray<int>();
512 else 542 else
513 return data->child->copy(); 543 return data->child->copy();
514} 544}
515void OEvent::setChildren( const QArray<int>& arr ) { 545void OEvent::setChildren( const QArray<int>& arr ) {
516 changeOrModify(); 546 changeOrModify();
517 if (data->child) delete data->child; 547 if (data->child) delete data->child;
518 548
519 data->child = new QArray<int>( arr ); 549 data->child = new QArray<int>( arr );
520 data->child->detach(); 550 data->child->detach();
521} 551}
522void OEvent::addChild( int uid ) { 552void OEvent::addChild( int uid ) {
523 changeOrModify(); 553 changeOrModify();
524 if (!data->child ) { 554 if (!data->child ) {
525 data->child = new QArray<int>(1); 555 data->child = new QArray<int>(1);
526 (*data->child)[0] = uid; 556 (*data->child)[0] = uid;
527 }else{ 557 }else{
528 int count = data->child->count(); 558 int count = data->child->count();
529 data->child->resize( count + 1 ); 559 data->child->resize( count + 1 );
530 (*data->child)[count] = uid; 560 (*data->child)[count] = uid;
531 } 561 }
532} 562}
533void OEvent::removeChild( int uid ) { 563void OEvent::removeChild( int uid ) {
534 if (!data->child || !data->child->contains( uid ) ) return; 564 if (!data->child || !data->child->contains( uid ) ) return;
535 changeOrModify(); 565 changeOrModify();
536 QArray<int> newAr( data->child->count() - 1 ); 566 QArray<int> newAr( data->child->count() - 1 );
537 int j = 0; 567 int j = 0;
538 uint count = data->child->count(); 568 uint count = data->child->count();
539 for ( uint i = 0; i < count; i++ ) { 569 for ( uint i = 0; i < count; i++ ) {
540 if ( (*data->child)[i] != uid ) { 570 if ( (*data->child)[i] != uid ) {
541 newAr[j] = (*data->child)[i]; 571 newAr[j] = (*data->child)[i];
542 j++; 572 j++;
543 } 573 }
544 } 574 }
545 (*data->child) = newAr; 575 (*data->child) = newAr;
546} 576}
547struct OEffectiveEvent::Data : public QShared { 577struct OEffectiveEvent::Data : public QShared {
548 Data() : QShared() { 578 Data() : QShared() {
549 } 579 }
550 OEvent event; 580 OEvent event;
551 QDate date; 581 QDate date;
552 QTime start, end; 582 QTime start, end;
553 QDate startDate, endDate; 583 QDate startDate, endDate;
554 bool dates : 1; 584 bool dates : 1;
555}; 585};
556 586
557OEffectiveEvent::OEffectiveEvent() { 587OEffectiveEvent::OEffectiveEvent() {
558 data = new Data; 588 data = new Data;
559 data->date = QDate::currentDate(); 589 data->date = QDate::currentDate();
560 data->start = data->end = QTime::currentTime(); 590 data->start = data->end = QTime::currentTime();
561 data->dates = false; 591 data->dates = false;
562} 592}
563OEffectiveEvent::OEffectiveEvent( const OEvent& ev, const QDate& startDate, 593OEffectiveEvent::OEffectiveEvent( const OEvent& ev, const QDate& startDate,
564 Position pos ) { 594 Position pos ) {
565 data = new Data; 595 data = new Data;
566 data->event = ev; 596 data->event = ev;
567 data->date = startDate; 597 data->date = startDate;
568 if ( pos & Start ) 598 if ( pos & Start )
569 data->start = ev.startDateTime().time(); 599 data->start = ev.startDateTime().time();
570 else 600 else
571 data->start = QTime( 0, 0, 0 ); 601 data->start = QTime( 0, 0, 0 );
572 602
573 if ( pos & End ) 603 if ( pos & End )
574 data->end = ev.endDateTime().time(); 604 data->end = ev.endDateTime().time();
575 else 605 else
576 data->end = QTime( 23, 59, 59 ); 606 data->end = QTime( 23, 59, 59 );
577 607
578 data->dates = false; 608 data->dates = false;
579} 609}
580OEffectiveEvent::OEffectiveEvent( const OEffectiveEvent& ev) { 610OEffectiveEvent::OEffectiveEvent( const OEffectiveEvent& ev) {
581 data = ev.data; 611 data = ev.data;
582 data->ref(); 612 data->ref();
583} 613}
584OEffectiveEvent::~OEffectiveEvent() { 614OEffectiveEvent::~OEffectiveEvent() {
585 if ( data->deref() ) { 615 if ( data->deref() ) {
586 delete data; 616 delete data;
587 data = 0; 617 data = 0;
588 } 618 }
589} 619}
590OEffectiveEvent& OEffectiveEvent::operator=( const OEffectiveEvent& ev ) { 620OEffectiveEvent& OEffectiveEvent::operator=( const OEffectiveEvent& ev ) {
591 if ( *this == ev ) return *this; 621 if ( *this == ev ) return *this;
592 622
593 ev.data->ref(); 623 ev.data->ref();
594 deref(); 624 deref();
595 data = ev.data; 625 data = ev.data;
596 626
597 return *this; 627 return *this;
598} 628}
599 629
600void OEffectiveEvent::setStartTime( const QTime& ti) { 630void OEffectiveEvent::setStartTime( const QTime& ti) {
601 changeOrModify(); 631 changeOrModify();
602 data->start = ti; 632 data->start = ti;
603} 633}
604void OEffectiveEvent::setEndTime( const QTime& en) { 634void OEffectiveEvent::setEndTime( const QTime& en) {
605 changeOrModify(); 635 changeOrModify();
606 data->end = en; 636 data->end = en;
607} 637}
608void OEffectiveEvent::setEvent( const OEvent& ev) { 638void OEffectiveEvent::setEvent( const OEvent& ev) {
609 changeOrModify(); 639 changeOrModify();
610 data->event = ev; 640 data->event = ev;
611} 641}
612void OEffectiveEvent::setDate( const QDate& da) { 642void OEffectiveEvent::setDate( const QDate& da) {
613 changeOrModify(); 643 changeOrModify();
614 data->date = da; 644 data->date = da;
615} 645}
616void OEffectiveEvent::setEffectiveDates( const QDate& from, 646void OEffectiveEvent::setEffectiveDates( const QDate& from,
617 const QDate& to ) { 647 const QDate& to ) {
618 if (!from.isValid() ) { 648 if (!from.isValid() ) {
619 data->dates = false; 649 data->dates = false;
620 return; 650 return;
621 } 651 }
622 652
623 data->startDate = from; 653 data->startDate = from;
624 data->endDate = to; 654 data->endDate = to;
625} 655}
626QString OEffectiveEvent::description()const { 656QString OEffectiveEvent::description()const {
627 return data->event.description(); 657 return data->event.description();
628} 658}
629QString OEffectiveEvent::location()const { 659QString OEffectiveEvent::location()const {
630 return data->event.location(); 660 return data->event.location();
631} 661}
632QString OEffectiveEvent::note()const { 662QString OEffectiveEvent::note()const {
633 return data->event.note(); 663 return data->event.note();
634} 664}
635OEvent OEffectiveEvent::event()const { 665OEvent OEffectiveEvent::event()const {
636 return data->event; 666 return data->event;
637} 667}
638QTime OEffectiveEvent::startTime()const { 668QTime OEffectiveEvent::startTime()const {
639 return data->start; 669 return data->start;
640} 670}
641QTime OEffectiveEvent::endTime()const { 671QTime OEffectiveEvent::endTime()const {
642 return data->end; 672 return data->end;
643} 673}
644QDate OEffectiveEvent::date()const { 674QDate OEffectiveEvent::date()const {
645 return data->date; 675 return data->date;
646} 676}
647int OEffectiveEvent::length()const { 677int OEffectiveEvent::length()const {
648 return (data->end.hour() * 60 - data->start.hour() * 60) 678 return (data->end.hour() * 60 - data->start.hour() * 60)
649 + QABS(data->start.minute() - data->end.minute() ); 679 + QABS(data->start.minute() - data->end.minute() );
650} 680}
651int OEffectiveEvent::size()const { 681int OEffectiveEvent::size()const {
652 return ( data->end.hour() - data->start.hour() ) * 3600 682 return ( data->end.hour() - data->start.hour() ) * 3600
653 + (data->end.minute() - data->start.minute() * 60 683 + (data->end.minute() - data->start.minute() * 60
654 + data->end.second() - data->start.second() ); 684 + data->end.second() - data->start.second() );
655} 685}
656QDate OEffectiveEvent::startDate()const { 686QDate OEffectiveEvent::startDate()const {
657 if ( data->dates ) 687 if ( data->dates )
658 return data->startDate; 688 return data->startDate;
659 else if ( data->event.hasRecurrence() ) // single day, since multi-day should have a d pointer 689 else if ( data->event.hasRecurrence() ) // single day, since multi-day should have a d pointer
660 return data->date; 690 return data->date;
661 else 691 else
662 return data->event.startDateTime().date(); 692 return data->event.startDateTime().date();
663} 693}
664QDate OEffectiveEvent::endDate()const { 694QDate OEffectiveEvent::endDate()const {
665 if ( data->dates ) 695 if ( data->dates )
666 return data->endDate; 696 return data->endDate;
667 else if ( data->event.hasRecurrence() ) 697 else if ( data->event.hasRecurrence() )
668 return data->date; 698 return data->date;
669 else 699 else
670 return data->event.endDateTime().date(); 700 return data->event.endDateTime().date();
671} 701}
672void OEffectiveEvent::deref() { 702void OEffectiveEvent::deref() {
673 if ( data->deref() ) { 703 if ( data->deref() ) {
674 delete data; 704 delete data;
675 data = 0; 705 data = 0;
676 } 706 }
677} 707}
678void OEffectiveEvent::changeOrModify() { 708void OEffectiveEvent::changeOrModify() {
679 if ( data->count != 1 ) { 709 if ( data->count != 1 ) {
680 data->deref(); 710 data->deref();
681 Data* d2 = new Data; 711 Data* d2 = new Data;
682 d2->event = data->event; 712 d2->event = data->event;
683 d2->date = data->date; 713 d2->date = data->date;
684 d2->start = data->start; 714 d2->start = data->start;
685 d2->end = data->end; 715 d2->end = data->end;
686 d2->startDate = data->startDate; 716 d2->startDate = data->startDate;
687 d2->endDate = data->endDate; 717 d2->endDate = data->endDate;
688 d2->dates = data->dates; 718 d2->dates = data->dates;
689 data = d2; 719 data = d2;
690 } 720 }
691} 721}
692bool OEffectiveEvent::operator<( const OEffectiveEvent &e ) const{ 722bool OEffectiveEvent::operator<( const OEffectiveEvent &e ) const{
693 if ( data->date < e.date() ) 723 if ( data->date < e.date() )
694 return TRUE; 724 return TRUE;
695 if ( data->date == e.date() ) 725 if ( data->date == e.date() )
696 return ( startTime() < e.startTime() ); 726 return ( startTime() < e.startTime() );
697 else 727 else
698 return FALSE; 728 return FALSE;
699} 729}
700bool OEffectiveEvent::operator<=( const OEffectiveEvent &e ) const{ 730bool OEffectiveEvent::operator<=( const OEffectiveEvent &e ) const{
701 return (data->date <= e.date() ); 731 return (data->date <= e.date() );
702} 732}
703bool OEffectiveEvent::operator==( const OEffectiveEvent &e ) const { 733bool OEffectiveEvent::operator==( const OEffectiveEvent &e ) const {
704 return ( date() == e.date() 734 return ( date() == e.date()
705 && startTime() == e.startTime() 735 && startTime() == e.startTime()
706 && endTime()== e.endTime() 736 && endTime()== e.endTime()
707 && event() == e.event() ); 737 && event() == e.event() );
708} 738}
709bool OEffectiveEvent::operator!=( const OEffectiveEvent &e ) const { 739bool OEffectiveEvent::operator!=( const OEffectiveEvent &e ) const {
710 return !(*this == e ); 740 return !(*this == e );
711} 741}
712bool OEffectiveEvent::operator>( const OEffectiveEvent &e ) const { 742bool OEffectiveEvent::operator>( const OEffectiveEvent &e ) const {
713 return !(*this <= e ); 743 return !(*this <= e );
714} 744}
715bool OEffectiveEvent::operator>= ( const OEffectiveEvent &e ) const { 745bool OEffectiveEvent::operator>= ( const OEffectiveEvent &e ) const {
716 return !(*this < e); 746 return !(*this < e);
717} 747}
748
749}
diff --git a/libopie2/opiepim/oevent.h b/libopie2/opiepim/oevent.h
index 9eb948f..9502efa 100644
--- a/libopie2/opiepim/oevent.h
+++ b/libopie2/opiepim/oevent.h
@@ -1,236 +1,268 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1// CONTAINS GPLed code of TT 29// CONTAINS GPLed code of TT
2 30
3#ifndef OPIE_PIM_EVENT_H 31#ifndef OPIE_PIM_EVENT_H
4#define OPIE_PIM_EVENT_H 32#define OPIE_PIM_EVENT_H
5 33
6#include <qstring.h> 34#include <qstring.h>
7#include <qdatetime.h> 35#include <qdatetime.h>
8#include <qvaluelist.h> 36#include <qvaluelist.h>
9 37
10#include <qpe/recordfields.h> 38#include <qpe/recordfields.h>
11#include <qpe/palmtopuidgen.h> 39#include <qpe/palmtopuidgen.h>
12 40
13#include "otimezone.h" 41#include <opie2/otimezone.h>
14#include "opimrecord.h" 42#include <opie2/opimrecord.h>
15 43
44namespace Opie {
16struct OCalendarHelper { 45struct OCalendarHelper {
17 /** calculate the week number of the date */ 46 /** calculate the week number of the date */
18 static int week( const QDate& ); 47 static int week( const QDate& );
19 /** calculate the occurence of week days since the start of the month */ 48 /** calculate the occurence of week days since the start of the month */
20 static int ocurrence( const QDate& ); 49 static int ocurrence( const QDate& );
21 50
22 // returns the dayOfWeek for the *first* day it finds (ignores 51 // returns the dayOfWeek for the *first* day it finds (ignores
23 // any further days!). Returns 1 (Monday) if there isn't any day found 52 // any further days!). Returns 1 (Monday) if there isn't any day found
24 static int dayOfWeek( char day ); 53 static int dayOfWeek( char day );
25 54
26 /** returns the diff of month */ 55 /** returns the diff of month */
27 static int monthDiff( const QDate& first, const QDate& second ); 56 static int monthDiff( const QDate& first, const QDate& second );
28 57
29}; 58};
30 59
31class OPimNotifyManager; 60class OPimNotifyManager;
32class ORecur; 61class ORecur;
33 62
34/** 63/**
35 * This is the container for all Events. It encapsules all 64 * This is the container for all Events. It encapsules all
36 * available information for a single Event 65 * available information for a single Event
37 * @short container for events. 66 * @short container for events.
38 */ 67 */
39class OEvent : public OPimRecord { 68class OEvent : public OPimRecord {
40public: 69public:
41 typedef QValueList<OEvent> ValueList; 70 typedef QValueList<OEvent> ValueList;
42 /** 71 /**
43 * RecordFields contain possible attributes 72 * RecordFields contain possible attributes
44 * used in the Results of toMap().. 73 * used in the Results of toMap()..
45 */ 74 */
46 enum RecordFields { 75 enum RecordFields {
47 FUid = Qtopia::UID_ID, 76 FUid = Qtopia::UID_ID,
48 FCategories = Qtopia::CATEGORY_ID, 77 FCategories = Qtopia::CATEGORY_ID,
49 FDescription = 0, 78 FDescription = 0,
50 FLocation, 79 FLocation,
51 FType, 80 FType,
52 FAlarm, 81 FAlarm,
53 FSound, 82 FSound,
54 FRType, 83 FRType,
55 FRWeekdays, 84 FRWeekdays,
56 FRPosition, 85 FRPosition,
57 FRFreq, 86 FRFreq,
58 FRHasEndDate, 87 FRHasEndDate,
59 FREndDate, 88 FREndDate,
60 FRCreated, 89 FRCreated,
61 FRExceptions, 90 FRExceptions,
62 FStart, 91 FStart,
63 FEnd, 92 FEnd,
64 FNote, 93 FNote,
65 FTimeZone, 94 FTimeZone,
66 FRecParent, 95 FRecParent,
67 FRecChildren, 96 FRecChildren,
68 }; 97 };
69 98
70 /** 99 /**
71 * Start with an Empty OEvent. UID == 0 means that it is empty 100 * Start with an Empty OEvent. UID == 0 means that it is empty
72 */ 101 */
73 OEvent(int uid = 0); 102 OEvent(int uid = 0);
74 103
75 /** 104 /**
76 * copy c'tor 105 * copy c'tor
77 */ 106 */
78 OEvent( const OEvent& ); 107 OEvent( const OEvent& );
79 108
80 /** 109 /**
81 * Create OEvent, initialized by map 110 * Create OEvent, initialized by map
82 * @see enum RecordFields 111 * @see enum RecordFields
83 */ 112 */
84 OEvent( const QMap<int, QString> map ); 113 OEvent( const QMap<int, QString> map );
85 ~OEvent(); 114 ~OEvent();
86 OEvent &operator=( const OEvent& ); 115 OEvent &operator=( const OEvent& );
87 116
88 QString description()const; 117 QString description()const;
89 void setDescription( const QString& description ); 118 void setDescription( const QString& description );
90 119
91 QString location()const; 120 QString location()const;
92 void setLocation( const QString& loc ); 121 void setLocation( const QString& loc );
93 122
94 bool hasNotifiers()const; 123 bool hasNotifiers()const;
95 OPimNotifyManager &notifiers()const; 124 OPimNotifyManager &notifiers()const;
96 125
97 ORecur recurrence()const; 126 ORecur recurrence()const;
98 void setRecurrence( const ORecur& ); 127 void setRecurrence( const ORecur& );
99 bool hasRecurrence()const; 128 bool hasRecurrence()const;
100 129
101 QString note()const; 130 QString note()const;
102 void setNote( const QString& note ); 131 void setNote( const QString& note );
103 132
104 133
105 QDateTime createdDateTime()const; 134 QDateTime createdDateTime()const;
106 void setCreatedDateTime( const QDateTime& dt); 135 void setCreatedDateTime( const QDateTime& dt);
107 136
108 /** set the date to dt. dt is the QDateTime in localtime */ 137 /** set the date to dt. dt is the QDateTime in localtime */
109 void setStartDateTime( const QDateTime& ); 138 void setStartDateTime( const QDateTime& );
110 /** returns the datetime in the local timeZone */ 139 /** returns the datetime in the local timeZone */
111 QDateTime startDateTime()const; 140 QDateTime startDateTime()const;
112 141
113 /** returns the start datetime in the current zone */ 142 /** returns the start datetime in the current zone */
114 QDateTime startDateTimeInZone()const; 143 QDateTime startDateTimeInZone()const;
115 144
116 /** in current timezone */ 145 /** in current timezone */
117 void setEndDateTime( const QDateTime& ); 146 void setEndDateTime( const QDateTime& );
118 /** in current timezone */ 147 /** in current timezone */
119 QDateTime endDateTime()const; 148 QDateTime endDateTime()const;
120 QDateTime endDateTimeInZone()const; 149 QDateTime endDateTimeInZone()const;
121 150
122 bool isMultipleDay()const; 151 bool isMultipleDay()const;
123 bool isAllDay()const; 152 bool isAllDay()const;
124 void setAllDay( bool isAllDay ); 153 void setAllDay( bool isAllDay );
125 154
126 /* pin this event to a timezone! FIXME */ 155 /* pin this event to a timezone! FIXME */
127 void setTimeZone( const QString& timeZone ); 156 void setTimeZone( const QString& timeZone );
128 QString timeZone()const; 157 QString timeZone()const;
129 158
130 159
131 virtual bool match( const QRegExp& )const; 160 virtual bool match( const QRegExp& )const;
132 161
133 /** For exception to recurrence here is a list of children... */ 162 /** For exception to recurrence here is a list of children... */
134 QArray<int> children()const; 163 QArray<int> children()const;
135 void setChildren( const QArray<int>& ); 164 void setChildren( const QArray<int>& );
136 void addChild( int uid ); 165 void addChild( int uid );
137 void removeChild( int uid ); 166 void removeChild( int uid );
138 167
139 /** return the parent OEvent */ 168 /** return the parent OEvent */
140 int parent()const; 169 int parent()const;
141 void setParent( int uid ); 170 void setParent( int uid );
142 171
143 172
144 /* needed reimp */ 173 /* needed reimp */
145 QString toRichText()const; 174 QString toRichText()const;
146 QString toShortText()const; 175 QString toShortText()const;
147 QString type()const; 176 QString type()const;
148 177
149 QMap<int, QString> toMap()const; 178 QMap<int, QString> toMap()const;
150 void fromMap( const QMap<int, QString>& map ); 179 void fromMap( const QMap<int, QString>& map );
151 QString recordField(int )const; 180 QString recordField(int )const;
152 181
153 static int rtti(); 182 static int rtti();
154 183
155 bool loadFromStream( QDataStream& ); 184 bool loadFromStream( QDataStream& );
156 bool saveToStream( QDataStream& )const; 185 bool saveToStream( QDataStream& )const;
157 186
158/* bool operator==( const OEvent& ); 187/* bool operator==( const OEvent& );
159 bool operator!=( const OEvent& ); 188 bool operator!=( const OEvent& );
160 bool operator<( const OEvent& ); 189 bool operator<( const OEvent& );
161 bool operator<=( const OEvent& ); 190 bool operator<=( const OEvent& );
162 bool operator>( const OEvent& ); 191 bool operator>( const OEvent& );
163 bool operator>=(const OEvent& ); 192 bool operator>=(const OEvent& );
164*/ 193*/
165private: 194private:
166 inline void changeOrModify(); 195 inline void changeOrModify();
167 void deref(); 196 void deref();
168 struct Data; 197 struct Data;
169 Data* data; 198 Data* data;
170 class Private; 199 class Private;
171 Private* priv; 200 Private* priv;
172 201
173}; 202};
174 203
175/** 204/**
176 * AN Event can span through multiple days. We split up a multiday eve 205 * AN Event can span through multiple days. We split up a multiday eve
177 */ 206 */
178class OEffectiveEvent { 207class OEffectiveEvent {
179public: 208public:
180 typedef QValueList<OEffectiveEvent> ValueList; 209 typedef QValueList<OEffectiveEvent> ValueList;
181 enum Position { MidWay, Start, End, StartEnd }; 210 enum Position { MidWay, Start, End, StartEnd };
182 // If we calculate the effective event of a multi-day event 211 // If we calculate the effective event of a multi-day event
183 // we have to figure out whether we are at the first day, 212 // we have to figure out whether we are at the first day,
184 // at the end, or anywhere else ("middle"). This is important 213 // at the end, or anywhere else ("middle"). This is important
185 // for the start/end times (00:00/23:59) 214 // for the start/end times (00:00/23:59)
186 // MidWay: 00:00 -> 23:59, as we are "in the middle" of a multi- 215 // MidWay: 00:00 -> 23:59, as we are "in the middle" of a multi-
187 // day event 216 // day event
188 // Start: start time -> 23:59 217 // Start: start time -> 23:59
189 // End: 00:00 -> end time 218 // End: 00:00 -> end time
190 // Start | End == StartEnd: for single-day events (default) 219 // Start | End == StartEnd: for single-day events (default)
191 // here we draw start time -> end time 220 // here we draw start time -> end time
192 OEffectiveEvent(); 221 OEffectiveEvent();
193 OEffectiveEvent( const OEvent& event, const QDate& startDate, Position pos = StartEnd ); 222 OEffectiveEvent( const OEvent& event, const QDate& startDate, Position pos = StartEnd );
194 OEffectiveEvent( const OEffectiveEvent& ); 223 OEffectiveEvent( const OEffectiveEvent& );
195 OEffectiveEvent &operator=(const OEffectiveEvent& ); 224 OEffectiveEvent &operator=(const OEffectiveEvent& );
196 ~OEffectiveEvent(); 225 ~OEffectiveEvent();
197 226
198 void setStartTime( const QTime& ); 227 void setStartTime( const QTime& );
199 void setEndTime( const QTime& ); 228 void setEndTime( const QTime& );
200 void setEvent( const OEvent& ); 229 void setEvent( const OEvent& );
201 void setDate( const QDate& ); 230 void setDate( const QDate& );
202 231
203 void setEffectiveDates( const QDate& from, const QDate& to ); 232 void setEffectiveDates( const QDate& from, const QDate& to );
204 233
205 QString description()const; 234 QString description()const;
206 QString location()const; 235 QString location()const;
207 QString note()const; 236 QString note()const;
208 OEvent event()const; 237 OEvent event()const;
209 QTime startTime()const; 238 QTime startTime()const;
210 QTime endTime()const; 239 QTime endTime()const;
211 QDate date()const; 240 QDate date()const;
212 241
213 /* return the length in hours */ 242 /* return the length in hours */
214 int length()const; 243 int length()const;
215 int size()const; 244 int size()const;
216 245
217 QDate startDate()const; 246 QDate startDate()const;
218 QDate endDate()const; 247 QDate endDate()const;
219 248
220 bool operator<( const OEffectiveEvent &e ) const; 249 bool operator<( const OEffectiveEvent &e ) const;
221 bool operator<=( const OEffectiveEvent &e ) const; 250 bool operator<=( const OEffectiveEvent &e ) const;
222 bool operator==( const OEffectiveEvent &e ) const; 251 bool operator==( const OEffectiveEvent &e ) const;
223 bool operator!=( const OEffectiveEvent &e ) const; 252 bool operator!=( const OEffectiveEvent &e ) const;
224 bool operator>( const OEffectiveEvent &e ) const; 253 bool operator>( const OEffectiveEvent &e ) const;
225 bool operator>= ( const OEffectiveEvent &e ) const; 254 bool operator>= ( const OEffectiveEvent &e ) const;
226 255
227private: 256private:
228 void deref(); 257 void deref();
229 inline void changeOrModify(); 258 inline void changeOrModify();
230 class Private; 259 class Private;
231 Private* priv; 260 Private* priv;
232 struct Data; 261 struct Data;
233 Data* data; 262 Data* data;
234 263
235}; 264};
265
266}
267
236#endif 268#endif
diff --git a/libopie2/opiepim/opiepim.pro b/libopie2/opiepim/opiepim.pro
index 3972c3f..82737f4 100644
--- a/libopie2/opiepim/opiepim.pro
+++ b/libopie2/opiepim/opiepim.pro
@@ -1,24 +1,30 @@
1TEMPLATE = lib 1TEMPLATE = lib
2CONFIG += qt warn_on debug 2CONFIG += qt warn_on debug
3DESTDIR = $(OPIEDIR)/lib 3DESTDIR = $(OPIEDIR)/lib
4HEADERS = 4HEADERS = ocontact.h ocontactfields.h opimrecord.h otodo.h opimnotify.h opimnotifymanager.h oevent.h
5 5
6SOURCES = 6SOURCES = ocontact.cpp ocontactfields.cpp opimrecord.cpp otodo.cpp opimnotify.cpp \
7 opimnotifymanager.cpp oevent.cpp
7INTERFACES = 8INTERFACES =
8TARGET = opiepim2 9TARGET = opiepim2
9VERSION = 1.8.2 10VERSION = 1.8.2
10INCLUDEPATH += $(OPIEDIR)/include 11INCLUDEPATH += $(OPIEDIR)/include
11DEPENDPATH += $(OPIEDIR)/include 12DEPENDPATH += $(OPIEDIR)/include
12 13
14include ( core/core.pro )
15include ( core/backends/backends.pro )
16include ( ui/ui.pro )
17
13MOC_DIR = moc 18MOC_DIR = moc
14OBJECTS_DIR = obj 19OBJECTS_DIR = obj
15 20
16 21
17!contains( platform, x11 ) { 22!contains( platform, x11 ) {
18 include ( $(OPIEDIR)/include.pro ) 23 include ( $(OPIEDIR)/include.pro )
19} 24}
20 25
21contains( platform, x11 ) { 26contains( platform, x11 ) {
22 LIBS = -L$(OPIEDIR)/lib -Wl,-rpath,$(OPIEDIR)/lib 27 LIBS = -L$(OPIEDIR)/lib -Wl,-rpath,$(OPIEDIR)/lib
23} 28}
24 29
30LIBS += -lopiecore2
diff --git a/libopie2/opiepim/orecordlist.h b/libopie2/opiepim/orecordlist.h
index 5211f57..8f0011b 100644
--- a/libopie2/opiepim/orecordlist.h
+++ b/libopie2/opiepim/orecordlist.h
@@ -1,306 +1,336 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1 29
2#ifndef OPIE_RECORD_LIST_H 30#ifndef OPIE_RECORD_LIST_H
3#define OPIE_RECORD_LIST_H 31#define OPIE_RECORD_LIST_H
4 32
5#include <qarray.h> 33#include <qarray.h>
6 34
7#include "otemplatebase.h" 35#include <opie2/otemplatebase.h>
8#include "opimrecord.h" 36#include <opie2/opimrecord.h>
37
38namespace Opie {
9 39
10class ORecordListIteratorPrivate; 40class ORecordListIteratorPrivate;
11/** 41/**
12 * Our List Iterator 42 * Our List Iterator
13 * it behaves like STL or Qt 43 * it behaves like STL or Qt
14 * 44 *
15 * for(it = list.begin(); it != list.end(); ++it ) 45 * for(it = list.begin(); it != list.end(); ++it )
16 * doSomeCoolStuff( (*it) ); 46 * doSomeCoolStuff( (*it) );
17 */ 47 */
18template <class T> class ORecordList; 48template <class T> class ORecordList;
19template <class T = OPimRecord> 49template <class T = OPimRecord>
20class ORecordListIterator { 50class ORecordListIterator {
21 friend class ORecordList<T>; 51 friend class ORecordList<T>;
22public: 52public:
23 typedef OTemplateBase<T> Base; 53 typedef OTemplateBase<T> Base;
24 54
25 /** 55 /**
26 * The c'tor used internally from 56 * The c'tor used internally from
27 * ORecordList 57 * ORecordList
28 */ 58 */
29 ORecordListIterator( const QArray<int>, const Base* ); 59 ORecordListIterator( const QArray<int>, const Base* );
30 60
31 /** 61 /**
32 * The standard c'tor 62 * The standard c'tor
33 */ 63 */
34 ORecordListIterator(); 64 ORecordListIterator();
35 ~ORecordListIterator(); 65 ~ORecordListIterator();
36 66
37 ORecordListIterator( const ORecordListIterator& ); 67 ORecordListIterator( const ORecordListIterator& );
38 ORecordListIterator &operator=(const ORecordListIterator& ); 68 ORecordListIterator &operator=(const ORecordListIterator& );
39 69
40 /** 70 /**
41 * a * operator ;) 71 * a * operator ;)
42 * use it like this T = (*it); 72 * use it like this T = (*it);
43 */ 73 */
44 T operator*(); 74 T operator*();
45 ORecordListIterator &operator++(); 75 ORecordListIterator &operator++();
46 ORecordListIterator &operator--(); 76 ORecordListIterator &operator--();
47 77
48 bool operator==( const ORecordListIterator& it ); 78 bool operator==( const ORecordListIterator& it );
49 bool operator!=( const ORecordListIterator& it ); 79 bool operator!=( const ORecordListIterator& it );
50 80
51 /** 81 /**
52 * the current item 82 * the current item
53 */ 83 */
54 uint current()const; 84 uint current()const;
55 85
56 /** 86 /**
57 * the number of items 87 * the number of items
58 */ 88 */
59 uint count()const; 89 uint count()const;
60 90
61 /** 91 /**
62 * sets the current item 92 * sets the current item
63 */ 93 */
64 void setCurrent( uint cur ); 94 void setCurrent( uint cur );
65 95
66private: 96private:
67 QArray<int> m_uids; 97 QArray<int> m_uids;
68 uint m_current; 98 uint m_current;
69 const Base* m_temp; 99 const Base* m_temp;
70 bool m_end : 1; 100 bool m_end : 1;
71 T m_record; 101 T m_record;
72 bool m_direction :1; 102 bool m_direction :1;
73 103
74 /* d pointer for future versions */ 104 /* d pointer for future versions */
75 ORecordListIteratorPrivate *d; 105 ORecordListIteratorPrivate *d;
76}; 106};
77 107
78class ORecordListPrivate; 108class ORecordListPrivate;
79/** 109/**
80 * The recordlist used as a return type 110 * The recordlist used as a return type
81 * from OPimAccessTemplate 111 * from OPimAccessTemplate
82 */ 112 */
83template <class T = OPimRecord > 113template <class T = OPimRecord >
84class ORecordList { 114class ORecordList {
85public: 115public:
86 typedef OTemplateBase<T> Base; 116 typedef OTemplateBase<T> Base;
87 typedef ORecordListIterator<T> Iterator; 117 typedef ORecordListIterator<T> Iterator;
88 118
89 /** 119 /**
90 * c'tor 120 * c'tor
91 */ 121 */
92 ORecordList () { 122 ORecordList () {
93 } 123 }
94ORecordList( const QArray<int>& ids, 124ORecordList( const QArray<int>& ids,
95 const Base* ); 125 const Base* );
96 ~ORecordList(); 126 ~ORecordList();
97 127
98 /** 128 /**
99 * the first iterator 129 * the first iterator
100 */ 130 */
101 Iterator begin(); 131 Iterator begin();
102 132
103 /** 133 /**
104 * the end 134 * the end
105 */ 135 */
106 Iterator end(); 136 Iterator end();
107 137
108 /** 138 /**
109 * the number of items in the list 139 * the number of items in the list
110 */ 140 */
111 uint count()const; 141 uint count()const;
112 142
113 T operator[]( uint i ); 143 T operator[]( uint i );
114 int uidAt(uint i ); 144 int uidAt(uint i );
115 145
116 /** 146 /**
117 * Remove the contact with given uid 147 * Remove the contact with given uid
118 */ 148 */
119 bool remove( int uid ); 149 bool remove( int uid );
120 150
121 /* 151 /*
122 ConstIterator begin()const; 152 ConstIterator begin()const;
123 ConstIterator end()const; 153 ConstIterator end()const;
124 */ 154 */
125private: 155private:
126 QArray<int> m_ids; 156 QArray<int> m_ids;
127 const Base* m_acc; 157 const Base* m_acc;
128 ORecordListPrivate *d; 158 ORecordListPrivate *d;
129}; 159};
130 160
131/* ok now implement it */ 161/* ok now implement it */
132template <class T> 162template <class T>
133ORecordListIterator<T>::ORecordListIterator() { 163ORecordListIterator<T>::ORecordListIterator() {
134 m_current = 0; 164 m_current = 0;
135 m_temp = 0l; 165 m_temp = 0l;
136 m_end = true; 166 m_end = true;
137 m_record = T(); 167 m_record = T();
138 /* forward */ 168 /* forward */
139 m_direction = TRUE; 169 m_direction = TRUE;
140} 170}
141template <class T> 171template <class T>
142ORecordListIterator<T>::~ORecordListIterator() { 172ORecordListIterator<T>::~ORecordListIterator() {
143/* nothing to delete */ 173/* nothing to delete */
144} 174}
145 175
146template <class T> 176template <class T>
147ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) { 177ORecordListIterator<T>::ORecordListIterator( const ORecordListIterator<T>& it) {
148// qWarning("ORecordListIterator copy c'tor"); 178// qWarning("ORecordListIterator copy c'tor");
149 m_uids = it.m_uids; 179 m_uids = it.m_uids;
150 m_current = it.m_current; 180 m_current = it.m_current;
151 m_temp = it.m_temp; 181 m_temp = it.m_temp;
152 m_end = it.m_end; 182 m_end = it.m_end;
153 m_record = it.m_record; 183 m_record = it.m_record;
154 m_direction = it.m_direction; 184 m_direction = it.m_direction;
155} 185}
156 186
157template <class T> 187template <class T>
158ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) { 188ORecordListIterator<T> &ORecordListIterator<T>::operator=( const ORecordListIterator<T>& it) {
159 m_uids = it.m_uids; 189 m_uids = it.m_uids;
160 m_current = it.m_current; 190 m_current = it.m_current;
161 m_temp = it.m_temp; 191 m_temp = it.m_temp;
162 m_end = it.m_end; 192 m_end = it.m_end;
163 m_record = it.m_record; 193 m_record = it.m_record;
164 194
165 return *this; 195 return *this;
166} 196}
167 197
168template <class T> 198template <class T>
169T ORecordListIterator<T>::operator*() { 199T ORecordListIterator<T>::operator*() {
170 //qWarning("operator* %d %d", m_current, m_uids[m_current] ); 200 //qWarning("operator* %d %d", m_current, m_uids[m_current] );
171 if (!m_end ) 201 if (!m_end )
172 m_record = m_temp->find( m_uids[m_current], m_uids, m_current, 202 m_record = m_temp->find( m_uids[m_current], m_uids, m_current,
173 m_direction ? Base::Forward : 203 m_direction ? Base::Forward :
174 Base::Reverse ); 204 Base::Reverse );
175 else 205 else
176 m_record = T(); 206 m_record = T();
177 207
178 return m_record; 208 return m_record;
179} 209}
180 210
181template <class T> 211template <class T>
182ORecordListIterator<T> &ORecordListIterator<T>::operator++() { 212ORecordListIterator<T> &ORecordListIterator<T>::operator++() {
183 m_direction = true; 213 m_direction = true;
184 if (m_current < m_uids.count() ) { 214 if (m_current < m_uids.count() ) {
185 m_end = false; 215 m_end = false;
186 ++m_current; 216 ++m_current;
187 }else 217 }else
188 m_end = true; 218 m_end = true;
189 219
190 return *this; 220 return *this;
191} 221}
192template <class T> 222template <class T>
193ORecordListIterator<T> &ORecordListIterator<T>::operator--() { 223ORecordListIterator<T> &ORecordListIterator<T>::operator--() {
194 m_direction = false; 224 m_direction = false;
195 if ( m_current > 0 ) { 225 if ( m_current > 0 ) {
196 --m_current; 226 --m_current;
197 m_end = false; 227 m_end = false;
198 } else 228 } else
199 m_end = true; 229 m_end = true;
200 230
201 return *this; 231 return *this;
202} 232}
203 233
204template <class T> 234template <class T>
205bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) { 235bool ORecordListIterator<T>::operator==( const ORecordListIterator<T>& it ) {
206 236
207 /* if both are at we're the same.... */ 237 /* if both are at we're the same.... */
208 if ( m_end == it.m_end ) return true; 238 if ( m_end == it.m_end ) return true;
209 239
210 if ( m_uids != it.m_uids ) return false; 240 if ( m_uids != it.m_uids ) return false;
211 if ( m_current != it.m_current ) return false; 241 if ( m_current != it.m_current ) return false;
212 if ( m_temp != it.m_temp ) return false; 242 if ( m_temp != it.m_temp ) return false;
213 243
214 return true; 244 return true;
215} 245}
216template <class T> 246template <class T>
217bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) { 247bool ORecordListIterator<T>::operator!=( const ORecordListIterator<T>& it ) {
218 return !(*this == it ); 248 return !(*this == it );
219} 249}
220template <class T> 250template <class T>
221ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids, 251ORecordListIterator<T>::ORecordListIterator( const QArray<int> uids,
222 const Base* t ) 252 const Base* t )
223 : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ), 253 : m_uids( uids ), m_current( 0 ), m_temp( t ), m_end( false ),
224 m_direction( false ) 254 m_direction( false )
225{ 255{
226 /* if the list is empty we're already at the end of the list */ 256 /* if the list is empty we're already at the end of the list */
227 if (uids.count() == 0 ) 257 if (uids.count() == 0 )
228 m_end = true; 258 m_end = true;
229} 259}
230template <class T> 260template <class T>
231uint ORecordListIterator<T>::current()const { 261uint ORecordListIterator<T>::current()const {
232 return m_current; 262 return m_current;
233} 263}
234template <class T> 264template <class T>
235void ORecordListIterator<T>::setCurrent( uint cur ) { 265void ORecordListIterator<T>::setCurrent( uint cur ) {
236 if( cur < m_uids.count() ) { 266 if( cur < m_uids.count() ) {
237 m_end = false; 267 m_end = false;
238 m_current= cur; 268 m_current= cur;
239 } 269 }
240} 270}
241template <class T> 271template <class T>
242uint ORecordListIterator<T>::count()const { 272uint ORecordListIterator<T>::count()const {
243 return m_uids.count(); 273 return m_uids.count();
244} 274}
245template <class T> 275template <class T>
246ORecordList<T>::ORecordList( const QArray<int>& ids, 276ORecordList<T>::ORecordList( const QArray<int>& ids,
247 const Base* acc ) 277 const Base* acc )
248 : m_ids( ids ), m_acc( acc ) 278 : m_ids( ids ), m_acc( acc )
249{ 279{
250} 280}
251template <class T> 281template <class T>
252ORecordList<T>::~ORecordList() { 282ORecordList<T>::~ORecordList() {
253/* nothing to do here */ 283/* nothing to do here */
254} 284}
255template <class T> 285template <class T>
256typename ORecordList<T>::Iterator ORecordList<T>::begin() { 286typename ORecordList<T>::Iterator ORecordList<T>::begin() {
257 Iterator it( m_ids, m_acc ); 287 Iterator it( m_ids, m_acc );
258 return it; 288 return it;
259} 289}
260template <class T> 290template <class T>
261typename ORecordList<T>::Iterator ORecordList<T>::end() { 291typename ORecordList<T>::Iterator ORecordList<T>::end() {
262 Iterator it( m_ids, m_acc ); 292 Iterator it( m_ids, m_acc );
263 it.m_end = true; 293 it.m_end = true;
264 it.m_current = m_ids.count(); 294 it.m_current = m_ids.count();
265 295
266 return it; 296 return it;
267} 297}
268template <class T> 298template <class T>
269uint ORecordList<T>::count()const { 299uint ORecordList<T>::count()const {
270return m_ids.count(); 300return m_ids.count();
271} 301}
272template <class T> 302template <class T>
273T ORecordList<T>::operator[]( uint i ) { 303T ORecordList<T>::operator[]( uint i ) {
274 if ( i >= m_ids.count() ) 304 if ( i >= m_ids.count() )
275 return T(); 305 return T();
276 /* forward */ 306 /* forward */
277 return m_acc->find( m_ids[i], m_ids, i ); 307 return m_acc->find( m_ids[i], m_ids, i );
278} 308}
279template <class T> 309template <class T>
280int ORecordList<T>::uidAt( uint i ) { 310int ORecordList<T>::uidAt( uint i ) {
281 return m_ids[i]; 311 return m_ids[i];
282} 312}
283 313
284template <class T> 314template <class T>
285bool ORecordList<T>::remove( int uid ) { 315bool ORecordList<T>::remove( int uid ) {
286 QArray<int> copy( m_ids.count() ); 316 QArray<int> copy( m_ids.count() );
287 int counter = 0; 317 int counter = 0;
288 bool ret_val = false; 318 bool ret_val = false;
289 319
290 for (uint i = 0; i < m_ids.count(); i++){ 320 for (uint i = 0; i < m_ids.count(); i++){
291 if ( m_ids[i] != uid ){ 321 if ( m_ids[i] != uid ){
292 copy[counter++] = m_ids[i]; 322 copy[counter++] = m_ids[i];
293 323
294 }else 324 }else
295 ret_val = true; 325 ret_val = true;
296 } 326 }
297 327
298 copy.resize( counter ); 328 copy.resize( counter );
299 m_ids = copy; 329 m_ids = copy;
300 330
301 331
302 return ret_val; 332 return ret_val;
303} 333}
304 334
305 335}
306#endif 336#endif
diff --git a/libopie2/opiepim/otodo.cpp b/libopie2/opiepim/otodo.cpp
index 189bf94..3eb0026 100644
--- a/libopie2/opiepim/otodo.cpp
+++ b/libopie2/opiepim/otodo.cpp
@@ -1,520 +1,550 @@
1 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
2#include <qobject.h> 29#include <qobject.h>
3#include <qshared.h> 30#include <qshared.h>
4 31
5 32
6 33
7#include <qpe/palmtopuidgen.h> 34#include <qpe/palmtopuidgen.h>
8#include <qpe/stringutil.h> 35#include <qpe/stringutil.h>
9#include <qpe/palmtoprecord.h> 36#include <qpe/palmtoprecord.h>
10#include <qpe/stringutil.h> 37#include <qpe/stringutil.h>
11#include <qpe/categories.h> 38#include <qpe/categories.h>
12#include <qpe/categoryselect.h> 39#include <qpe/categoryselect.h>
13 40
14 41
15#include "opimstate.h" 42#include <opie2/opimstate.h>
16#include "orecur.h" 43#include <opie2/orecur.h>
17#include "opimmaintainer.h" 44#include <opie2/opimmaintainer.h>
18#include "opimnotifymanager.h" 45#include <opie2/opimnotifymanager.h>
19#include "opimresolver.h" 46#include <opie2/opimresolver.h>
20 47
21#include "otodo.h" 48#include <opie2/otodo.h>
22 49
50namespace Opie {
23 51
24struct OTodo::OTodoData : public QShared { 52struct OTodo::OTodoData : public QShared {
25 OTodoData() : QShared() { 53 OTodoData() : QShared() {
26 recur = 0; 54 recur = 0;
27 state = 0; 55 state = 0;
28 maintainer = 0; 56 maintainer = 0;
29 notifiers = 0; 57 notifiers = 0;
30 }; 58 };
31 ~OTodoData() { 59 ~OTodoData() {
32 delete recur; 60 delete recur;
33 delete maintainer; 61 delete maintainer;
34 delete notifiers; 62 delete notifiers;
35 } 63 }
36 64
37 QDate date; 65 QDate date;
38 bool isCompleted:1; 66 bool isCompleted:1;
39 bool hasDate:1; 67 bool hasDate:1;
40 int priority; 68 int priority;
41 QString desc; 69 QString desc;
42 QString sum; 70 QString sum;
43 QMap<QString, QString> extra; 71 QMap<QString, QString> extra;
44 ushort prog; 72 ushort prog;
45 OPimState *state; 73 OPimState *state;
46 ORecur *recur; 74 ORecur *recur;
47 OPimMaintainer *maintainer; 75 OPimMaintainer *maintainer;
48 QDate start; 76 QDate start;
49 QDate completed; 77 QDate completed;
50 OPimNotifyManager *notifiers; 78 OPimNotifyManager *notifiers;
51}; 79};
52 80
53OTodo::OTodo(const OTodo &event ) 81OTodo::OTodo(const OTodo &event )
54 : OPimRecord( event ), data( event.data ) 82 : OPimRecord( event ), data( event.data )
55{ 83{
56 data->ref(); 84 data->ref();
57// qWarning("ref up"); 85// qWarning("ref up");
58} 86}
59OTodo::~OTodo() { 87OTodo::~OTodo() {
60 88
61// qWarning("~OTodo " ); 89// qWarning("~OTodo " );
62 if ( data->deref() ) { 90 if ( data->deref() ) {
63// qWarning("OTodo::dereffing"); 91// qWarning("OTodo::dereffing");
64 delete data; 92 delete data;
65 data = 0l; 93 data = 0l;
66 } 94 }
67} 95}
68OTodo::OTodo(bool completed, int priority, 96OTodo::OTodo(bool completed, int priority,
69 const QArray<int> &category, 97 const QArray<int> &category,
70 const QString& summary, 98 const QString& summary,
71 const QString &description, 99 const QString &description,
72 ushort progress, 100 ushort progress,
73 bool hasDate, QDate date, int uid ) 101 bool hasDate, QDate date, int uid )
74 : OPimRecord( uid ) 102 : OPimRecord( uid )
75{ 103{
76// qWarning("OTodoData " + summary); 104// qWarning("OTodoData " + summary);
77 setCategories( category ); 105 setCategories( category );
78 106
79 data = new OTodoData; 107 data = new OTodoData;
80 108
81 data->date = date; 109 data->date = date;
82 data->isCompleted = completed; 110 data->isCompleted = completed;
83 data->hasDate = hasDate; 111 data->hasDate = hasDate;
84 data->priority = priority; 112 data->priority = priority;
85 data->sum = summary; 113 data->sum = summary;
86 data->prog = progress; 114 data->prog = progress;
87 data->desc = Qtopia::simplifyMultiLineSpace(description ); 115 data->desc = Qtopia::simplifyMultiLineSpace(description );
88} 116}
89OTodo::OTodo(bool completed, int priority, 117OTodo::OTodo(bool completed, int priority,
90 const QStringList &category, 118 const QStringList &category,
91 const QString& summary, 119 const QString& summary,
92 const QString &description, 120 const QString &description,
93 ushort progress, 121 ushort progress,
94 bool hasDate, QDate date, int uid ) 122 bool hasDate, QDate date, int uid )
95 : OPimRecord( uid ) 123 : OPimRecord( uid )
96{ 124{
97// qWarning("OTodoData" + summary); 125// qWarning("OTodoData" + summary);
98 setCategories( idsFromString( category.join(";") ) ); 126 setCategories( idsFromString( category.join(";") ) );
99 127
100 data = new OTodoData; 128 data = new OTodoData;
101 129
102 data->date = date; 130 data->date = date;
103 data->isCompleted = completed; 131 data->isCompleted = completed;
104 data->hasDate = hasDate; 132 data->hasDate = hasDate;
105 data->priority = priority; 133 data->priority = priority;
106 data->sum = summary; 134 data->sum = summary;
107 data->prog = progress; 135 data->prog = progress;
108 data->desc = Qtopia::simplifyMultiLineSpace(description ); 136 data->desc = Qtopia::simplifyMultiLineSpace(description );
109} 137}
110bool OTodo::match( const QRegExp &regExp )const 138bool OTodo::match( const QRegExp &regExp )const
111{ 139{
112 if( QString::number( data->priority ).find( regExp ) != -1 ){ 140 if( QString::number( data->priority ).find( regExp ) != -1 ){
113 setLastHitField( Priority ); 141 setLastHitField( Priority );
114 return true; 142 return true;
115 }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){ 143 }else if( data->hasDate && data->date.toString().find( regExp) != -1 ){
116 setLastHitField( HasDate ); 144 setLastHitField( HasDate );
117 return true; 145 return true;
118 }else if(data->desc.find( regExp ) != -1 ){ 146 }else if(data->desc.find( regExp ) != -1 ){
119 setLastHitField( Description ); 147 setLastHitField( Description );
120 return true; 148 return true;
121 }else if(data->sum.find( regExp ) != -1 ) { 149 }else if(data->sum.find( regExp ) != -1 ) {
122 setLastHitField( Summary ); 150 setLastHitField( Summary );
123 return true; 151 return true;
124 } 152 }
125 return false; 153 return false;
126} 154}
127bool OTodo::isCompleted() const 155bool OTodo::isCompleted() const
128{ 156{
129 return data->isCompleted; 157 return data->isCompleted;
130} 158}
131bool OTodo::hasDueDate() const 159bool OTodo::hasDueDate() const
132{ 160{
133 return data->hasDate; 161 return data->hasDate;
134} 162}
135bool OTodo::hasStartDate()const { 163bool OTodo::hasStartDate()const {
136 return data->start.isValid(); 164 return data->start.isValid();
137} 165}
138bool OTodo::hasCompletedDate()const { 166bool OTodo::hasCompletedDate()const {
139 return data->completed.isValid(); 167 return data->completed.isValid();
140} 168}
141int OTodo::priority()const 169int OTodo::priority()const
142{ 170{
143 return data->priority; 171 return data->priority;
144} 172}
145QString OTodo::summary() const 173QString OTodo::summary() const
146{ 174{
147 return data->sum; 175 return data->sum;
148} 176}
149ushort OTodo::progress() const 177ushort OTodo::progress() const
150{ 178{
151 return data->prog; 179 return data->prog;
152} 180}
153QDate OTodo::dueDate()const 181QDate OTodo::dueDate()const
154{ 182{
155 return data->date; 183 return data->date;
156} 184}
157QDate OTodo::startDate()const { 185QDate OTodo::startDate()const {
158 return data->start; 186 return data->start;
159} 187}
160QDate OTodo::completedDate()const { 188QDate OTodo::completedDate()const {
161 return data->completed; 189 return data->completed;
162} 190}
163QString OTodo::description()const 191QString OTodo::description()const
164{ 192{
165 return data->desc; 193 return data->desc;
166} 194}
167bool OTodo::hasState() const{ 195bool OTodo::hasState() const{
168 if (!data->state ) return false; 196 if (!data->state ) return false;
169 return ( data->state->state() != OPimState::Undefined ); 197 return ( data->state->state() != OPimState::Undefined );
170} 198}
171OPimState OTodo::state()const { 199OPimState OTodo::state()const {
172 if (!data->state ) { 200 if (!data->state ) {
173 OPimState state; 201 OPimState state;
174 return state; 202 return state;
175 } 203 }
176 204
177 return (*data->state); 205 return (*data->state);
178} 206}
179bool OTodo::hasRecurrence()const { 207bool OTodo::hasRecurrence()const {
180 if (!data->recur) return false; 208 if (!data->recur) return false;
181 return data->recur->doesRecur(); 209 return data->recur->doesRecur();
182} 210}
183ORecur OTodo::recurrence()const { 211ORecur OTodo::recurrence()const {
184 if (!data->recur) return ORecur(); 212 if (!data->recur) return ORecur();
185 213
186 return (*data->recur); 214 return (*data->recur);
187} 215}
188bool OTodo::hasMaintainer()const { 216bool OTodo::hasMaintainer()const {
189 if (!data->maintainer) return false; 217 if (!data->maintainer) return false;
190 218
191 return (data->maintainer->mode() != OPimMaintainer::Undefined ); 219 return (data->maintainer->mode() != OPimMaintainer::Undefined );
192} 220}
193OPimMaintainer OTodo::maintainer()const { 221OPimMaintainer OTodo::maintainer()const {
194 if (!data->maintainer) return OPimMaintainer(); 222 if (!data->maintainer) return OPimMaintainer();
195 223
196 return (*data->maintainer); 224 return (*data->maintainer);
197} 225}
198void OTodo::setCompleted( bool completed ) 226void OTodo::setCompleted( bool completed )
199{ 227{
200 changeOrModify(); 228 changeOrModify();
201 data->isCompleted = completed; 229 data->isCompleted = completed;
202} 230}
203void OTodo::setHasDueDate( bool hasDate ) 231void OTodo::setHasDueDate( bool hasDate )
204{ 232{
205 changeOrModify(); 233 changeOrModify();
206 data->hasDate = hasDate; 234 data->hasDate = hasDate;
207} 235}
208void OTodo::setDescription(const QString &desc ) 236void OTodo::setDescription(const QString &desc )
209{ 237{
210// qWarning( "desc " + desc ); 238// qWarning( "desc " + desc );
211 changeOrModify(); 239 changeOrModify();
212 data->desc = Qtopia::simplifyMultiLineSpace(desc ); 240 data->desc = Qtopia::simplifyMultiLineSpace(desc );
213} 241}
214void OTodo::setSummary( const QString& sum ) 242void OTodo::setSummary( const QString& sum )
215{ 243{
216 changeOrModify(); 244 changeOrModify();
217 data->sum = sum; 245 data->sum = sum;
218} 246}
219void OTodo::setPriority(int prio ) 247void OTodo::setPriority(int prio )
220{ 248{
221 changeOrModify(); 249 changeOrModify();
222 data->priority = prio; 250 data->priority = prio;
223} 251}
224void OTodo::setDueDate( const QDate& date ) 252void OTodo::setDueDate( const QDate& date )
225{ 253{
226 changeOrModify(); 254 changeOrModify();
227 data->date = date; 255 data->date = date;
228} 256}
229void OTodo::setStartDate( const QDate& date ) { 257void OTodo::setStartDate( const QDate& date ) {
230 changeOrModify(); 258 changeOrModify();
231 data->start = date; 259 data->start = date;
232} 260}
233void OTodo::setCompletedDate( const QDate& date ) { 261void OTodo::setCompletedDate( const QDate& date ) {
234 changeOrModify(); 262 changeOrModify();
235 data->completed = date; 263 data->completed = date;
236} 264}
237void OTodo::setState( const OPimState& state ) { 265void OTodo::setState( const OPimState& state ) {
238 changeOrModify(); 266 changeOrModify();
239 if (data->state ) 267 if (data->state )
240 (*data->state) = state; 268 (*data->state) = state;
241 else 269 else
242 data->state = new OPimState( state ); 270 data->state = new OPimState( state );
243} 271}
244void OTodo::setRecurrence( const ORecur& rec) { 272void OTodo::setRecurrence( const ORecur& rec) {
245 changeOrModify(); 273 changeOrModify();
246 if (data->recur ) 274 if (data->recur )
247 (*data->recur) = rec; 275 (*data->recur) = rec;
248 else 276 else
249 data->recur = new ORecur( rec ); 277 data->recur = new ORecur( rec );
250} 278}
251void OTodo::setMaintainer( const OPimMaintainer& pim ) { 279void OTodo::setMaintainer( const OPimMaintainer& pim ) {
252 changeOrModify(); 280 changeOrModify();
253 281
254 if (data->maintainer ) 282 if (data->maintainer )
255 (*data->maintainer) = pim; 283 (*data->maintainer) = pim;
256 else 284 else
257 data->maintainer = new OPimMaintainer( pim ); 285 data->maintainer = new OPimMaintainer( pim );
258} 286}
259bool OTodo::isOverdue( ) 287bool OTodo::isOverdue( )
260{ 288{
261 if( data->hasDate && !data->isCompleted) 289 if( data->hasDate && !data->isCompleted)
262 return QDate::currentDate() > data->date; 290 return QDate::currentDate() > data->date;
263 return false; 291 return false;
264} 292}
265void OTodo::setProgress(ushort progress ) 293void OTodo::setProgress(ushort progress )
266{ 294{
267 changeOrModify(); 295 changeOrModify();
268 data->prog = progress; 296 data->prog = progress;
269} 297}
270QString OTodo::toShortText() const { 298QString OTodo::toShortText() const {
271 return summary(); 299 return summary();
272} 300}
273/*! 301/*!
274 Returns a richt text string 302 Returns a richt text string
275*/ 303*/
276QString OTodo::toRichText() const 304QString OTodo::toRichText() const
277{ 305{
278 QString text; 306 QString text;
279 QStringList catlist; 307 QStringList catlist;
280 308
281 // summary 309 // summary
282 text += "<b><h3><img src=\"todo/TodoList\"> "; 310 text += "<b><h3><img src=\"todo/TodoList\"> ";
283 if ( !summary().isEmpty() ) { 311 if ( !summary().isEmpty() ) {
284 text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "" ); 312 text += Qtopia::escapeString(summary() ).replace(QRegExp( "[\n]"), "" );
285 } 313 }
286 text += "</h3></b><br><hr><br>"; 314 text += "</h3></b><br><hr><br>";
287 315
288 // description 316 // description
289 if( !description().isEmpty() ){ 317 if( !description().isEmpty() ){
290 text += "<b>" + QObject::tr( "Description:" ) + "</b><br>"; 318 text += "<b>" + QObject::tr( "Description:" ) + "</b><br>";
291 text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>"; 319 text += Qtopia::escapeString(description() ).replace(QRegExp( "[\n]"), "<br>" ) + "<br>";
292 } 320 }
293 321
294 // priority 322 // priority
295 int priorityval = priority(); 323 int priorityval = priority();
296 text += "<b>" + QObject::tr( "Priority:") +" </b><img src=\"todo/priority" + 324 text += "<b>" + QObject::tr( "Priority:") +" </b><img src=\"todo/priority" +
297 QString::number( priorityval ) + "\"> "; 325 QString::number( priorityval ) + "\"> ";
298 326
299 switch ( priorityval ) 327 switch ( priorityval )
300 { 328 {
301 case 1 : text += QObject::tr( "Very high" ); 329 case 1 : text += QObject::tr( "Very high" );
302 break; 330 break;
303 case 2 : text += QObject::tr( "High" ); 331 case 2 : text += QObject::tr( "High" );
304 break; 332 break;
305 case 3 : text += QObject::tr( "Normal" ); 333 case 3 : text += QObject::tr( "Normal" );
306 break; 334 break;
307 case 4 : text += QObject::tr( "Low" ); 335 case 4 : text += QObject::tr( "Low" );
308 break; 336 break;
309 case 5 : text += QObject::tr( "Very low" ); 337 case 5 : text += QObject::tr( "Very low" );
310 break; 338 break;
311 }; 339 };
312 text += "<br>"; 340 text += "<br>";
313 341
314 // progress 342 // progress
315 text += "<b>" + QObject::tr( "Progress:") + " </b>" 343 text += "<b>" + QObject::tr( "Progress:") + " </b>"
316 + QString::number( progress() ) + " %<br>"; 344 + QString::number( progress() ) + " %<br>";
317 345
318 // due date 346 // due date
319 if (hasDueDate() ){ 347 if (hasDueDate() ){
320 QDate dd = dueDate(); 348 QDate dd = dueDate();
321 int off = QDate::currentDate().daysTo( dd ); 349 int off = QDate::currentDate().daysTo( dd );
322 350
323 text += "<b>" + QObject::tr( "Deadline:" ) + " </b><font color=\""; 351 text += "<b>" + QObject::tr( "Deadline:" ) + " </b><font color=\"";
324 if ( off < 0 ) 352 if ( off < 0 )
325 text += "#FF0000"; 353 text += "#FF0000";
326 else if ( off == 0 ) 354 else if ( off == 0 )
327 text += "#FFFF00"; 355 text += "#FFFF00";
328 else if ( off > 0 ) 356 else if ( off > 0 )
329 text += "#00FF00"; 357 text += "#00FF00";
330 358
331 text += "\">" + dd.toString() + "</font><br>"; 359 text += "\">" + dd.toString() + "</font><br>";
332 } 360 }
333 361
334 // categories 362 // categories
335 text += "<b>" + QObject::tr( "Category:") + "</b> "; 363 text += "<b>" + QObject::tr( "Category:") + "</b> ";
336 text += categoryNames( "Todo List" ).join(", "); 364 text += categoryNames( "Todo List" ).join(", ");
337 text += "<br>"; 365 text += "<br>";
338 366
339 return text; 367 return text;
340} 368}
341bool OTodo::hasNotifiers()const { 369bool OTodo::hasNotifiers()const {
342 if (!data->notifiers) return false; 370 if (!data->notifiers) return false;
343 return !data->notifiers->isEmpty(); 371 return !data->notifiers->isEmpty();
344} 372}
345OPimNotifyManager& OTodo::notifiers() { 373OPimNotifyManager& OTodo::notifiers() {
346 if (!data->notifiers ) 374 if (!data->notifiers )
347 data->notifiers = new OPimNotifyManager; 375 data->notifiers = new OPimNotifyManager;
348 return (*data->notifiers); 376 return (*data->notifiers);
349} 377}
350const OPimNotifyManager& OTodo::notifiers()const{ 378const OPimNotifyManager& OTodo::notifiers()const{
351 if (!data->notifiers ) 379 if (!data->notifiers )
352 data->notifiers = new OPimNotifyManager; 380 data->notifiers = new OPimNotifyManager;
353 381
354 return (*data->notifiers); 382 return (*data->notifiers);
355} 383}
356 384
357bool OTodo::operator<( const OTodo &toDoEvent )const{ 385bool OTodo::operator<( const OTodo &toDoEvent )const{
358 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; 386 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true;
359 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; 387 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false;
360 if( hasDueDate() && toDoEvent.hasDueDate() ){ 388 if( hasDueDate() && toDoEvent.hasDueDate() ){
361 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide 389 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide
362 return priority() < toDoEvent.priority(); 390 return priority() < toDoEvent.priority();
363 }else{ 391 }else{
364 return dueDate() < toDoEvent.dueDate(); 392 return dueDate() < toDoEvent.dueDate();
365 } 393 }
366 } 394 }
367 return false; 395 return false;
368} 396}
369bool OTodo::operator<=(const OTodo &toDoEvent )const 397bool OTodo::operator<=(const OTodo &toDoEvent )const
370{ 398{
371 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; 399 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true;
372 if( !hasDueDate() && toDoEvent.hasDueDate() ) return true; 400 if( !hasDueDate() && toDoEvent.hasDueDate() ) return true;
373 if( hasDueDate() && toDoEvent.hasDueDate() ){ 401 if( hasDueDate() && toDoEvent.hasDueDate() ){
374 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide 402 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide
375 return priority() <= toDoEvent.priority(); 403 return priority() <= toDoEvent.priority();
376 }else{ 404 }else{
377 return dueDate() <= toDoEvent.dueDate(); 405 return dueDate() <= toDoEvent.dueDate();
378 } 406 }
379 } 407 }
380 return true; 408 return true;
381} 409}
382bool OTodo::operator>(const OTodo &toDoEvent )const 410bool OTodo::operator>(const OTodo &toDoEvent )const
383{ 411{
384 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false; 412 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return false;
385 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; 413 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false;
386 if( hasDueDate() && toDoEvent.hasDueDate() ){ 414 if( hasDueDate() && toDoEvent.hasDueDate() ){
387 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide 415 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide
388 return priority() > toDoEvent.priority(); 416 return priority() > toDoEvent.priority();
389 }else{ 417 }else{
390 return dueDate() > toDoEvent.dueDate(); 418 return dueDate() > toDoEvent.dueDate();
391 } 419 }
392 } 420 }
393 return false; 421 return false;
394} 422}
395bool OTodo::operator>=(const OTodo &toDoEvent )const 423bool OTodo::operator>=(const OTodo &toDoEvent )const
396{ 424{
397 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true; 425 if( !hasDueDate() && !toDoEvent.hasDueDate() ) return true;
398 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false; 426 if( !hasDueDate() && toDoEvent.hasDueDate() ) return false;
399 if( hasDueDate() && toDoEvent.hasDueDate() ){ 427 if( hasDueDate() && toDoEvent.hasDueDate() ){
400 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide 428 if( dueDate() == toDoEvent.dueDate() ){ // let's the priority decide
401 return priority() > toDoEvent.priority(); 429 return priority() > toDoEvent.priority();
402 }else{ 430 }else{
403 return dueDate() > toDoEvent.dueDate(); 431 return dueDate() > toDoEvent.dueDate();
404 } 432 }
405 } 433 }
406 return true; 434 return true;
407} 435}
408bool OTodo::operator==(const OTodo &toDoEvent )const 436bool OTodo::operator==(const OTodo &toDoEvent )const
409{ 437{
410 if ( data->priority != toDoEvent.data->priority ) return false; 438 if ( data->priority != toDoEvent.data->priority ) return false;
411 if ( data->priority != toDoEvent.data->prog ) return false; 439 if ( data->priority != toDoEvent.data->prog ) return false;
412 if ( data->isCompleted != toDoEvent.data->isCompleted ) return false; 440 if ( data->isCompleted != toDoEvent.data->isCompleted ) return false;
413 if ( data->hasDate != toDoEvent.data->hasDate ) return false; 441 if ( data->hasDate != toDoEvent.data->hasDate ) return false;
414 if ( data->date != toDoEvent.data->date ) return false; 442 if ( data->date != toDoEvent.data->date ) return false;
415 if ( data->sum != toDoEvent.data->sum ) return false; 443 if ( data->sum != toDoEvent.data->sum ) return false;
416 if ( data->desc != toDoEvent.data->desc ) return false; 444 if ( data->desc != toDoEvent.data->desc ) return false;
417 if ( data->maintainer != toDoEvent.data->maintainer ) 445 if ( data->maintainer != toDoEvent.data->maintainer )
418 return false; 446 return false;
419 447
420 return OPimRecord::operator==( toDoEvent ); 448 return OPimRecord::operator==( toDoEvent );
421} 449}
422void OTodo::deref() { 450void OTodo::deref() {
423 451
424// qWarning("deref in ToDoEvent"); 452// qWarning("deref in ToDoEvent");
425 if ( data->deref() ) { 453 if ( data->deref() ) {
426// qWarning("deleting"); 454// qWarning("deleting");
427 delete data; 455 delete data;
428 data= 0; 456 data= 0;
429 } 457 }
430} 458}
431OTodo &OTodo::operator=(const OTodo &item ) 459OTodo &OTodo::operator=(const OTodo &item )
432{ 460{
433 if ( this == &item ) return *this; 461 if ( this == &item ) return *this;
434 462
435 OPimRecord::operator=( item ); 463 OPimRecord::operator=( item );
436 //qWarning("operator= ref "); 464 //qWarning("operator= ref ");
437 item.data->ref(); 465 item.data->ref();
438 deref(); 466 deref();
439 data = item.data; 467 data = item.data;
440 468
441 return *this; 469 return *this;
442} 470}
443 471
444QMap<int, QString> OTodo::toMap() const { 472QMap<int, QString> OTodo::toMap() const {
445 QMap<int, QString> map; 473 QMap<int, QString> map;
446 474
447 map.insert( Uid, QString::number( uid() ) ); 475 map.insert( Uid, QString::number( uid() ) );
448 map.insert( Category, idsToString( categories() ) ); 476 map.insert( Category, idsToString( categories() ) );
449 map.insert( HasDate, QString::number( data->hasDate ) ); 477 map.insert( HasDate, QString::number( data->hasDate ) );
450 map.insert( Completed, QString::number( data->isCompleted ) ); 478 map.insert( Completed, QString::number( data->isCompleted ) );
451 map.insert( Description, data->desc ); 479 map.insert( Description, data->desc );
452 map.insert( Summary, data->sum ); 480 map.insert( Summary, data->sum );
453 map.insert( Priority, QString::number( data->priority ) ); 481 map.insert( Priority, QString::number( data->priority ) );
454 map.insert( DateDay, QString::number( data->date.day() ) ); 482 map.insert( DateDay, QString::number( data->date.day() ) );
455 map.insert( DateMonth, QString::number( data->date.month() ) ); 483 map.insert( DateMonth, QString::number( data->date.month() ) );
456 map.insert( DateYear, QString::number( data->date.year() ) ); 484 map.insert( DateYear, QString::number( data->date.year() ) );
457 map.insert( Progress, QString::number( data->prog ) ); 485 map.insert( Progress, QString::number( data->prog ) );
458// map.insert( CrossReference, crossToString() ); 486// map.insert( CrossReference, crossToString() );
459 /* FIXME!!! map.insert( State, ); 487 /* FIXME!!! map.insert( State, );
460 map.insert( Recurrence, ); 488 map.insert( Recurrence, );
461 map.insert( Reminders, ); 489 map.insert( Reminders, );
462 map. 490 map.
463 */ 491 */
464 return map; 492 return map;
465} 493}
466 494
467/** 495/**
468 * change or modify looks at the ref count and either 496 * change or modify looks at the ref count and either
469 * creates a new QShared Object or it can modify it 497 * creates a new QShared Object or it can modify it
470 * right in place 498 * right in place
471 */ 499 */
472void OTodo::changeOrModify() { 500void OTodo::changeOrModify() {
473 if ( data->count != 1 ) { 501 if ( data->count != 1 ) {
474 qWarning("changeOrModify"); 502 qWarning("changeOrModify");
475 data->deref(); 503 data->deref();
476 OTodoData* d2 = new OTodoData(); 504 OTodoData* d2 = new OTodoData();
477 copy(data, d2 ); 505 copy(data, d2 );
478 data = d2; 506 data = d2;
479 } 507 }
480} 508}
481// WATCHOUT 509// WATCHOUT
482/* 510/*
483 * if you add something to the Data struct 511 * if you add something to the Data struct
484 * be sure to copy it here 512 * be sure to copy it here
485 */ 513 */
486void OTodo::copy( OTodoData* src, OTodoData* dest ) { 514void OTodo::copy( OTodoData* src, OTodoData* dest ) {
487 dest->date = src->date; 515 dest->date = src->date;
488 dest->isCompleted = src->isCompleted; 516 dest->isCompleted = src->isCompleted;
489 dest->hasDate = src->hasDate; 517 dest->hasDate = src->hasDate;
490 dest->priority = src->priority; 518 dest->priority = src->priority;
491 dest->desc = src->desc; 519 dest->desc = src->desc;
492 dest->sum = src->sum; 520 dest->sum = src->sum;
493 dest->extra = src->extra; 521 dest->extra = src->extra;
494 dest->prog = src->prog; 522 dest->prog = src->prog;
495 523
496 if (src->state ) 524 if (src->state )
497 dest->state = new OPimState( *src->state ); 525 dest->state = new OPimState( *src->state );
498 526
499 if (src->recur ) 527 if (src->recur )
500 dest->recur = new ORecur( *src->recur ); 528 dest->recur = new ORecur( *src->recur );
501 529
502 if (src->maintainer ) 530 if (src->maintainer )
503 dest->maintainer = new OPimMaintainer( *src->maintainer ) 531 dest->maintainer = new OPimMaintainer( *src->maintainer )
504 ; 532 ;
505 dest->start = src->start; 533 dest->start = src->start;
506 dest->completed = src->completed; 534 dest->completed = src->completed;
507 535
508 if (src->notifiers ) 536 if (src->notifiers )
509 dest->notifiers = new OPimNotifyManager( *src->notifiers ); 537 dest->notifiers = new OPimNotifyManager( *src->notifiers );
510} 538}
511QString OTodo::type() const { 539QString OTodo::type() const {
512 return QString::fromLatin1("OTodo"); 540 return QString::fromLatin1("OTodo");
513} 541}
514QString OTodo::recordField(int /*id*/ )const { 542QString OTodo::recordField(int /*id*/ )const {
515 return QString::null; 543 return QString::null;
516} 544}
517 545
518int OTodo::rtti(){ 546int OTodo::rtti(){
519 return OPimResolver::TodoList; 547 return OPimResolver::TodoList;
520} 548}
549
550}
diff --git a/libopie2/opiepim/otodo.h b/libopie2/opiepim/otodo.h
index 6df98b9..61add04 100644
--- a/libopie2/opiepim/otodo.h
+++ b/libopie2/opiepim/otodo.h
@@ -1,285 +1,315 @@
1 1/*
2 This file is part of the Opie Project
3 Copyright (C) The Main Author <main-author@whereever.org>
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
2#ifndef OPIE_TODO_EVENT_H 29#ifndef OPIE_TODO_EVENT_H
3#define OPIE_TODO_EVENT_H 30#define OPIE_TODO_EVENT_H
4 31
5 32
6#include <qarray.h> 33#include <qarray.h>
7#include <qmap.h> 34#include <qmap.h>
8#include <qregexp.h> 35#include <qregexp.h>
9#include <qstringlist.h> 36#include <qstringlist.h>
10#include <qdatetime.h> 37#include <qdatetime.h>
11#include <qvaluelist.h> 38#include <qvaluelist.h>
12 39
13#include <qpe/recordfields.h> 40#include <qpe/recordfields.h>
14#include <qpe/palmtopuidgen.h> 41#include <qpe/palmtopuidgen.h>
15 42
16#include <opie/opimrecord.h> 43#include <opie2/opimrecord.h>
44
17 45
46namespace Opie {
18 47
19class OPimState; 48class OPimState;
20class ORecur; 49class ORecur;
21class OPimMaintainer; 50class OPimMaintainer;
22class OPimNotifyManager; 51class OPimNotifyManager;
23class OTodo : public OPimRecord { 52class OTodo : public OPimRecord {
24public: 53public:
25 typedef QValueList<OTodo> ValueList; 54 typedef QValueList<OTodo> ValueList;
26 enum RecordFields { 55 enum RecordFields {
27 Uid = Qtopia::UID_ID, 56 Uid = Qtopia::UID_ID,
28 Category = Qtopia::CATEGORY_ID, 57 Category = Qtopia::CATEGORY_ID,
29 HasDate, 58 HasDate,
30 Completed, 59 Completed,
31 Description, 60 Description,
32 Summary, 61 Summary,
33 Priority, 62 Priority,
34 DateDay, 63 DateDay,
35 DateMonth, 64 DateMonth,
36 DateYear, 65 DateYear,
37 Progress, 66 Progress,
38 CrossReference, 67 CrossReference,
39 State, 68 State,
40 Recurrence, 69 Recurrence,
41 Alarms, 70 Alarms,
42 Reminders, 71 Reminders,
43 Notifiers, 72 Notifiers,
44 Maintainer, 73 Maintainer,
45 StartDate, 74 StartDate,
46 CompletedDate 75 CompletedDate
47 }; 76 };
48 public: 77 public:
49 // priorities from Very low to very high 78 // priorities from Very low to very high
50 enum TaskPriority { VeryHigh=1, High, Normal, Low, VeryLow }; 79 enum TaskPriority { VeryHigh=1, High, Normal, Low, VeryLow };
51 80
52 /* Constructs a new ToDoEvent 81 /* Constructs a new ToDoEvent
53 @param completed Is the TodoEvent completed 82 @param completed Is the TodoEvent completed
54 @param priority What is the priority of this ToDoEvent 83 @param priority What is the priority of this ToDoEvent
55 @param category Which category does it belong( uid ) 84 @param category Which category does it belong( uid )
56 @param summary A small summary of the todo 85 @param summary A small summary of the todo
57 @param description What is this ToDoEvent about 86 @param description What is this ToDoEvent about
58 @param hasDate Does this Event got a deadline 87 @param hasDate Does this Event got a deadline
59 @param date what is the deadline? 88 @param date what is the deadline?
60 @param uid what is the UUID of this Event 89 @param uid what is the UUID of this Event
61 **/ 90 **/
62 OTodo( bool completed = false, int priority = Normal, 91 OTodo( bool completed = false, int priority = Normal,
63 const QStringList &category = QStringList(), 92 const QStringList &category = QStringList(),
64 const QString &summary = QString::null , 93 const QString &summary = QString::null ,
65 const QString &description = QString::null, 94 const QString &description = QString::null,
66 ushort progress = 0, 95 ushort progress = 0,
67 bool hasDate = false, QDate date = QDate::currentDate(), 96 bool hasDate = false, QDate date = QDate::currentDate(),
68 int uid = 0 /*empty*/ ); 97 int uid = 0 /*empty*/ );
69 98
70 OTodo( bool completed, int priority, 99 OTodo( bool completed, int priority,
71 const QArray<int>& category, 100 const QArray<int>& category,
72 const QString& summary = QString::null, 101 const QString& summary = QString::null,
73 const QString& description = QString::null, 102 const QString& description = QString::null,
74 ushort progress = 0, 103 ushort progress = 0,
75 bool hasDate = false, QDate date = QDate::currentDate(), 104 bool hasDate = false, QDate date = QDate::currentDate(),
76 int uid = 0 /* empty */ ); 105 int uid = 0 /* empty */ );
77 106
78 /** Copy c'tor 107 /** Copy c'tor
79 * 108 *
80 */ 109 */
81 OTodo(const OTodo & ); 110 OTodo(const OTodo & );
82 111
83 /** 112 /**
84 *destructor 113 *destructor
85 */ 114 */
86 ~OTodo(); 115 ~OTodo();
87 116
88 /** 117 /**
89 * Is this event completed? 118 * Is this event completed?
90 */ 119 */
91 bool isCompleted() const; 120 bool isCompleted() const;
92 121
93 /** 122 /**
94 * Does this Event have a deadline 123 * Does this Event have a deadline
95 */ 124 */
96 bool hasDueDate() const; 125 bool hasDueDate() const;
97 bool hasStartDate()const; 126 bool hasStartDate()const;
98 bool hasCompletedDate()const; 127 bool hasCompletedDate()const;
99 128
100 /** 129 /**
101 * What is the priority? 130 * What is the priority?
102 */ 131 */
103 int priority()const ; 132 int priority()const ;
104 133
105 /** 134 /**
106 * progress as ushort 0, 20, 40, 60, 80 or 100% 135 * progress as ushort 0, 20, 40, 60, 80 or 100%
107 */ 136 */
108 ushort progress() const; 137 ushort progress() const;
109 138
110 /** 139 /**
111 * The due Date 140 * The due Date
112 */ 141 */
113 QDate dueDate()const; 142 QDate dueDate()const;
114 143
115 /** 144 /**
116 * When did it start? 145 * When did it start?
117 */ 146 */
118 QDate startDate()const; 147 QDate startDate()const;
119 148
120 /** 149 /**
121 * When was it completed? 150 * When was it completed?
122 */ 151 */
123 QDate completedDate()const; 152 QDate completedDate()const;
124 153
125 /** 154 /**
126 * does it have a state? 155 * does it have a state?
127 */ 156 */
128 bool hasState()const; 157 bool hasState()const;
129 158
130 /** 159 /**
131 * What is the state of this OTodo? 160 * What is the state of this OTodo?
132 */ 161 */
133 OPimState state()const; 162 OPimState state()const;
134 163
135 /** 164 /**
136 * has recurrence? 165 * has recurrence?
137 */ 166 */
138 bool hasRecurrence()const; 167 bool hasRecurrence()const;
139 168
140 /** 169 /**
141 * the recurrance of this 170 * the recurrance of this
142 */ 171 */
143 ORecur recurrence()const; 172 ORecur recurrence()const;
144 173
145 /** 174 /**
146 * does this OTodo have a maintainer? 175 * does this OTodo have a maintainer?
147 */ 176 */
148 bool hasMaintainer()const; 177 bool hasMaintainer()const;
149 178
150 /** 179 /**
151 * the Maintainer of this OTodo 180 * the Maintainer of this OTodo
152 */ 181 */
153 OPimMaintainer maintainer()const; 182 OPimMaintainer maintainer()const;
154 183
155 /** 184 /**
156 * The description of the todo 185 * The description of the todo
157 */ 186 */
158 QString description()const; 187 QString description()const;
159 188
160 /** 189 /**
161 * A small summary of the todo 190 * A small summary of the todo
162 */ 191 */
163 QString summary() const; 192 QString summary() const;
164 193
165 /** 194 /**
166 * @reimplemented 195 * @reimplemented
167 * Return this todoevent in a RichText formatted QString 196 * Return this todoevent in a RichText formatted QString
168 */ 197 */
169 QString toRichText() const; 198 QString toRichText() const;
170 199
171 bool hasNotifiers()const; 200 bool hasNotifiers()const;
172 /* 201 /*
173 * FIXME check if the sharing is still fine!! -zecke 202 * FIXME check if the sharing is still fine!! -zecke
174 * ### CHECK If API is fine 203 * ### CHECK If API is fine
175 */ 204 */
176 /** 205 /**
177 * return a reference to our notifiers... 206 * return a reference to our notifiers...
178 */ 207 */
179 OPimNotifyManager &notifiers(); 208 OPimNotifyManager &notifiers();
180 209
181 /** 210 /**
182 * 211 *
183 */ 212 */
184 const OPimNotifyManager &notifiers()const; 213 const OPimNotifyManager &notifiers()const;
185 214
186 /** 215 /**
187 * reimplementations 216 * reimplementations
188 */ 217 */
189 QString type()const; 218 QString type()const;
190 QString toShortText()const; 219 QString toShortText()const;
191 QString recordField(int id )const; 220 QString recordField(int id )const;
192 221
193 /** 222 /**
194 * toMap puts all data into the map. int relates 223 * toMap puts all data into the map. int relates
195 * to ToDoEvent RecordFields enum 224 * to ToDoEvent RecordFields enum
196 */ 225 */
197 QMap<int, QString> toMap()const; 226 QMap<int, QString> toMap()const;
198 227
199 /** 228 /**
200 * Set if this Todo is completed 229 * Set if this Todo is completed
201 */ 230 */
202 void setCompleted(bool completed ); 231 void setCompleted(bool completed );
203 232
204 /** 233 /**
205 * set if this todo got an end data 234 * set if this todo got an end data
206 */ 235 */
207 void setHasDueDate( bool hasDate ); 236 void setHasDueDate( bool hasDate );
208 // FIXME we do not have these for start, completed 237 // FIXME we do not have these for start, completed
209 // cause we'll use the isNull() of QDate for figuring 238 // cause we'll use the isNull() of QDate for figuring
210 // out if it's has a date... 239 // out if it's has a date...
211 // decide what to do here? -zecke 240 // decide what to do here? -zecke
212 241
213 /** 242 /**
214 * Set the priority of the Todo 243 * Set the priority of the Todo
215 */ 244 */
216 void setPriority(int priority ); 245 void setPriority(int priority );
217 246
218 /** 247 /**
219 * Set the progress. 248 * Set the progress.
220 */ 249 */
221 void setProgress( ushort progress ); 250 void setProgress( ushort progress );
222 251
223 /** 252 /**
224 * set the end date 253 * set the end date
225 */ 254 */
226 void setDueDate( const QDate& date ); 255 void setDueDate( const QDate& date );
227 256
228 /** 257 /**
229 * set the start date 258 * set the start date
230 */ 259 */
231 void setStartDate( const QDate& date ); 260 void setStartDate( const QDate& date );
232 261
233 /** 262 /**
234 * set the completed date 263 * set the completed date
235 */ 264 */
236 void setCompletedDate( const QDate& date ); 265 void setCompletedDate( const QDate& date );
237 266
238 void setRecurrence( const ORecur& ); 267 void setRecurrence( const ORecur& );
239 268
240 void setDescription(const QString& ); 269 void setDescription(const QString& );
241 void setSummary(const QString& ); 270 void setSummary(const QString& );
242 271
243 /** 272 /**
244 * set the state of a Todo 273 * set the state of a Todo
245 * @param state State what the todo should take 274 * @param state State what the todo should take
246 */ 275 */
247 void setState( const OPimState& state); 276 void setState( const OPimState& state);
248 277
249 /** 278 /**
250 * set the Maintainer Mode 279 * set the Maintainer Mode
251 */ 280 */
252 void setMaintainer( const OPimMaintainer& ); 281 void setMaintainer( const OPimMaintainer& );
253 282
254 bool isOverdue(); 283 bool isOverdue();
255 284
256 285
257 virtual bool match( const QRegExp &r )const; 286 virtual bool match( const QRegExp &r )const;
258 287
259 bool operator<(const OTodo &toDoEvent )const; 288 bool operator<(const OTodo &toDoEvent )const;
260 bool operator<=(const OTodo &toDoEvent )const; 289 bool operator<=(const OTodo &toDoEvent )const;
261 bool operator!=(const OTodo &toDoEvent )const; 290 bool operator!=(const OTodo &toDoEvent )const;
262 bool operator>(const OTodo &toDoEvent )const; 291 bool operator>(const OTodo &toDoEvent )const;
263 bool operator>=(const OTodo &toDoEvent)const; 292 bool operator>=(const OTodo &toDoEvent)const;
264 bool operator==(const OTodo &toDoEvent )const; 293 bool operator==(const OTodo &toDoEvent )const;
265 OTodo &operator=(const OTodo &toDoEvent ); 294 OTodo &operator=(const OTodo &toDoEvent );
266 295
267 static int rtti(); 296 static int rtti();
268 297
269 private: 298 private:
270 class OTodoPrivate; 299 class OTodoPrivate;
271 struct OTodoData; 300 struct OTodoData;
272 301
273 void deref(); 302 void deref();
274 inline void changeOrModify(); 303 inline void changeOrModify();
275 void copy( OTodoData* src, OTodoData* dest ); 304 void copy( OTodoData* src, OTodoData* dest );
276 OTodoPrivate *d; 305 OTodoPrivate *d;
277 OTodoData *data; 306 OTodoData *data;
278 307
279}; 308};
280inline bool OTodo::operator!=(const OTodo &toDoEvent )const { 309inline bool OTodo::operator!=(const OTodo &toDoEvent )const {
281 return !(*this == toDoEvent); 310 return !(*this == toDoEvent);
282} 311}
283 312
313}
284 314
285#endif 315#endif
diff --git a/libopie2/opiepim/ui/opimmainwindow.cpp b/libopie2/opiepim/ui/opimmainwindow.cpp
index 2739e26..10ed743 100644
--- a/libopie2/opiepim/ui/opimmainwindow.cpp
+++ b/libopie2/opiepim/ui/opimmainwindow.cpp
@@ -1,150 +1,181 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#include <qapplication.h> 29#include <qapplication.h>
2#include <qdatetime.h> 30#include <qdatetime.h>
3#include <qcopchannel_qws.h> 31#include <qcopchannel_qws.h>
4 32
5#include <qpe/sound.h> 33#include <qpe/sound.h>
6#include <qpe/qcopenvelope_qws.h> 34#include <qpe/qcopenvelope_qws.h>
7#include <qpe/qpeapplication.h> 35#include <qpe/qpeapplication.h>
8 36
9#include "opimresolver.h" 37#include <opie2/opimresolver.h>
10#include "opimmainwindow.h" 38#include "opimmainwindow.h"
11 39
40namespace Opie {
12OPimMainWindow::OPimMainWindow( const QString& service, QWidget* parent, 41OPimMainWindow::OPimMainWindow( const QString& service, QWidget* parent,
13 const char* name, WFlags flag ) 42 const char* name, WFlags flag )
14 : QMainWindow( parent, name, flag ), m_rtti(-1), m_service( service ), m_fallBack(0l) { 43 : QMainWindow( parent, name, flag ), m_rtti(-1), m_service( service ), m_fallBack(0l) {
15 44
16 /* 45 /*
17 * let's generate our QCopChannel 46 * let's generate our QCopChannel
18 */ 47 */
19 m_str = QString("QPE/"+m_service).local8Bit(); 48 m_str = QString("QPE/"+m_service).local8Bit();
20 m_channel= new QCopChannel(m_str, this ); 49 m_channel= new QCopChannel(m_str, this );
21 connect(m_channel, SIGNAL(received(const QCString&, const QByteArray& ) ), 50 connect(m_channel, SIGNAL(received(const QCString&, const QByteArray& ) ),
22 this, SLOT( appMessage( const QCString&, const QByteArray& ) ) ); 51 this, SLOT( appMessage( const QCString&, const QByteArray& ) ) );
23 connect(qApp, SIGNAL(appMessage(const QCString&, const QByteArray& ) ), 52 connect(qApp, SIGNAL(appMessage(const QCString&, const QByteArray& ) ),
24 this, SLOT( appMessage( const QCString&, const QByteArray& ) ) ); 53 this, SLOT( appMessage( const QCString&, const QByteArray& ) ) );
25 54
26 /* connect flush and reload */ 55 /* connect flush and reload */
27 connect(qApp, SIGNAL(flush() ), 56 connect(qApp, SIGNAL(flush() ),
28 this, SLOT(flush() ) ); 57 this, SLOT(flush() ) );
29 connect(qApp, SIGNAL(reload() ), 58 connect(qApp, SIGNAL(reload() ),
30 this, SLOT(reload() ) ); 59 this, SLOT(reload() ) );
31} 60}
32OPimMainWindow::~OPimMainWindow() { 61OPimMainWindow::~OPimMainWindow() {
33 delete m_channel; 62 delete m_channel;
34} 63}
35QCopChannel* OPimMainWindow::channel() { 64QCopChannel* OPimMainWindow::channel() {
36 return m_channel; 65 return m_channel;
37} 66}
38void OPimMainWindow::doSetDocument( const QString& ) { 67void OPimMainWindow::doSetDocument( const QString& ) {
39 68
40} 69}
41void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) { 70void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) {
42 bool needShow = false; 71 bool needShow = false;
43 /* 72 /*
44 * create demands to create 73 * create demands to create
45 * a new record... 74 * a new record...
46 */ 75 */
47 QDataStream stream(array, IO_ReadOnly); 76 QDataStream stream(array, IO_ReadOnly);
48 if ( cmd == "create()" ) { 77 if ( cmd == "create()" ) {
49 raise(); 78 raise();
50 int uid = create(); 79 int uid = create();
51 QCopEnvelope e(m_str, "created(int)" ); 80 QCopEnvelope e(m_str, "created(int)" );
52 e << uid; 81 e << uid;
53 needShow = true; 82 needShow = true;
54 }else if ( cmd == "remove(int)" ) { 83 }else if ( cmd == "remove(int)" ) {
55 int uid; 84 int uid;
56 stream >> uid; 85 stream >> uid;
57 bool rem = remove( uid ); 86 bool rem = remove( uid );
58 QCopEnvelope e(m_str, "removed(bool)" ); 87 QCopEnvelope e(m_str, "removed(bool)" );
59 e << rem; 88 e << rem;
60 needShow = true; 89 needShow = true;
61 }else if ( cmd == "beam(int)" ) { 90 }else if ( cmd == "beam(int)" ) {
62 int uid; 91 int uid;
63 stream >> uid; 92 stream >> uid;
64 beam( uid); 93 beam( uid);
65 }else if ( cmd == "show(int)" ) { 94 }else if ( cmd == "show(int)" ) {
66 raise(); 95 raise();
67 int uid; 96 int uid;
68 stream >> uid; 97 stream >> uid;
69 show( uid ); 98 show( uid );
70 needShow = true; 99 needShow = true;
71 }else if ( cmd == "edit(int)" ) { 100 }else if ( cmd == "edit(int)" ) {
72 raise(); 101 raise();
73 int uid; 102 int uid;
74 stream >> uid; 103 stream >> uid;
75 edit( uid ); 104 edit( uid );
76 }else if ( cmd == "add(int,QByteArray)" ) { 105 }else if ( cmd == "add(int,QByteArray)" ) {
77 int rtti; 106 int rtti;
78 QByteArray array; 107 QByteArray array;
79 stream >> rtti; 108 stream >> rtti;
80 stream >> array; 109 stream >> array;
81 m_fallBack = record(rtti, array ); 110 m_fallBack = record(rtti, array );
82 if (!m_fallBack) return; 111 if (!m_fallBack) return;
83 add( *m_fallBack ); 112 add( *m_fallBack );
84 delete m_fallBack; 113 delete m_fallBack;
85 }else if ( cmd == "alarm(QDateTime,int)" ) { 114 }else if ( cmd == "alarm(QDateTime,int)" ) {
86 raise(); 115 raise();
87 QDateTime dt; int uid; 116 QDateTime dt; int uid;
88 stream >> dt; 117 stream >> dt;
89 stream >> uid; 118 stream >> uid;
90 qWarning(" Date: %s Uid: %d", dt.toString().latin1(), uid ); 119 qWarning(" Date: %s Uid: %d", dt.toString().latin1(), uid );
91 QDateTime current = QDateTime::currentDateTime(); 120 QDateTime current = QDateTime::currentDateTime();
92 if ( current.time().hour() != dt.time().hour() && current.time().minute() != dt.time().minute() ) 121 if ( current.time().hour() != dt.time().hour() && current.time().minute() != dt.time().minute() )
93 return; 122 return;
94 doAlarm( dt, uid ); 123 doAlarm( dt, uid );
95 needShow = true; 124 needShow = true;
96 } 125 }
97 126
98 if (needShow ) 127 if (needShow )
99 QPEApplication::setKeepRunning(); 128 QPEApplication::setKeepRunning();
100} 129}
101/* implement the url scripting here */ 130/* implement the url scripting here */
102void OPimMainWindow::setDocument( const QString& str) { 131void OPimMainWindow::setDocument( const QString& str) {
103 doSetDocument( str ); 132 doSetDocument( str );
104} 133}
105/* 134/*
106 * we now try to get the array demarshalled 135 * we now try to get the array demarshalled
107 * check if the rtti matches this one 136 * check if the rtti matches this one
108 */ 137 */
109OPimRecord* OPimMainWindow::record( int rtti, const QByteArray& array ) { 138OPimRecord* OPimMainWindow::record( int rtti, const QByteArray& array ) {
110 if ( service() != rtti ) 139 if ( service() != rtti )
111 return 0l; 140 return 0l;
112 141
113 OPimRecord* record = OPimResolver::self()->record( rtti ); 142 OPimRecord* record = OPimResolver::self()->record( rtti );
114 QDataStream str(array, IO_ReadOnly ); 143 QDataStream str(array, IO_ReadOnly );
115 if ( !record || !record->loadFromStream(str) ) { 144 if ( !record || !record->loadFromStream(str) ) {
116 delete record; 145 delete record;
117 record = 0l; 146 record = 0l;
118 } 147 }
119 148
120 return record; 149 return record;
121} 150}
122/* 151/*
123 * get the rtti for the service 152 * get the rtti for the service
124 */ 153 */
125int OPimMainWindow::service() { 154int OPimMainWindow::service() {
126 if ( m_rtti == -1 ) 155 if ( m_rtti == -1 )
127 m_rtti = OPimResolver::self()->serviceId( m_service ); 156 m_rtti = OPimResolver::self()->serviceId( m_service );
128 157
129 return m_rtti; 158 return m_rtti;
130} 159}
131void OPimMainWindow::doAlarm( const QDateTime&, int ) { 160void OPimMainWindow::doAlarm( const QDateTime&, int ) {
132 161
133} 162}
134void OPimMainWindow::startAlarm(int count ) { 163void OPimMainWindow::startAlarm(int count ) {
135 m_alarmCount = count; 164 m_alarmCount = count;
136 m_playedCount = 0; 165 m_playedCount = 0;
137 Sound::soundAlarm(); 166 Sound::soundAlarm();
138 m_timerId = startTimer( 5000 ); 167 m_timerId = startTimer( 5000 );
139} 168}
140void OPimMainWindow::killAlarm() { 169void OPimMainWindow::killAlarm() {
141 killTimer( m_timerId ); 170 killTimer( m_timerId );
142} 171}
143void OPimMainWindow::timerEvent( QTimerEvent* e) { 172void OPimMainWindow::timerEvent( QTimerEvent* e) {
144 if ( m_playedCount <m_alarmCount ) { 173 if ( m_playedCount <m_alarmCount ) {
145 m_playedCount++; 174 m_playedCount++;
146 Sound::soundAlarm(); 175 Sound::soundAlarm();
147 }else { 176 }else {
148 killTimer( e->timerId() ); 177 killTimer( e->timerId() );
149 } 178 }
150} 179}
180
181}
diff --git a/libopie2/opiepim/ui/opimmainwindow.h b/libopie2/opiepim/ui/opimmainwindow.h
index 855d364..abad630 100644
--- a/libopie2/opiepim/ui/opimmainwindow.h
+++ b/libopie2/opiepim/ui/opimmainwindow.h
@@ -1,99 +1,129 @@
1/*
2 This file is part of the Opie Project
3 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de)
4 =. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5 .=l.
6 .>+-=
7 _;:, .> :=|. This program is free software; you can
8.> <`_, > . <= redistribute it and/or modify it under
9:`=1 )Y*s>-.-- : the terms of the GNU Library General Public
10.="- .-=="i, .._ License as published by the Free Software
11 - . .-<_> .<> Foundation; either version 2 of the License,
12 ._= =} : or (at your option) any later version.
13 .%`+i> _;_.
14 .i_,=:_. -<s. This program is distributed in the hope that
15 + . -:. = it will be useful, but WITHOUT ANY WARRANTY;
16 : .. .:, . . . without even the implied warranty of
17 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A
18 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.= = ; Library General Public License for more
20++= -. .` .: details.
21 : = ...= . :.=-
22 -. .:....=;==+<; You should have received a copy of the GNU
23 -_. . . )=. = Library General Public License along with
24 -- :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA.
28*/
1#ifndef OPIE_PIM_MAINWINDOW_H 29#ifndef OPIE_PIM_MAINWINDOW_H
2#define OPIE_PIM_MAINWINDOW_H 30#define OPIE_PIM_MAINWINDOW_H
3 31
4#include <qmainwindow.h> 32#include <qmainwindow.h>
5 33
6#include <opie/opimrecord.h> 34#include <opie2/opimrecord.h>
35class QCopChannel;
36class QDateTime;
7 37
38namespace Opie {
8/** 39/**
9 * This is a common Opie PIM MainWindow 40 * This is a common Opie PIM MainWindow
10 * it takes care of the QCOP internals 41 * it takes care of the QCOP internals
11 * and implements some functions 42 * and implements some functions
12 * for the URL scripting schema 43 * for the URL scripting schema
13 */ 44 */
14/* 45/*
15 * due Qt and Templates with signal and slots 46 * due Qt and Templates with signal and slots
16 * do not work that good :( 47 * do not work that good :(
17 * (Ok how to moc a template ;) ) 48 * (Ok how to moc a template ;) )
18 * We will have the mainwindow which calls a struct which 49 * We will have the mainwindow which calls a struct which
19 * is normally reimplemented as a template ;) 50 * is normally reimplemented as a template ;)
20 */ 51 */
21 52
22class QCopChannel;
23class QDateTime;
24class OPimMainWindow : public QMainWindow { 53class OPimMainWindow : public QMainWindow {
25 Q_OBJECT 54 Q_OBJECT
26public: 55public:
27 enum TransPort { BlueTooth=0, 56 enum TransPort { BlueTooth=0,
28 IrDa }; 57 IrDa };
29 58
30 OPimMainWindow( const QString& service, QWidget *parent = 0, const char* name = 0, 59 OPimMainWindow( const QString& service, QWidget *parent = 0, const char* name = 0,
31 WFlags f = WType_TopLevel); 60 WFlags f = WType_TopLevel);
32 virtual ~OPimMainWindow(); 61 virtual ~OPimMainWindow();
33 62
34 63
35protected slots: 64protected slots:
36 /* 65 /*
37 * called when a setDocument 66 * called when a setDocument
38 * couldn't be handled by this window 67 * couldn't be handled by this window
39 */ 68 */
40 virtual void doSetDocument( const QString& ); 69 virtual void doSetDocument( const QString& );
41 /* for syncing */ 70 /* for syncing */
42 virtual void flush() = 0; 71 virtual void flush() = 0;
43 virtual void reload() = 0; 72 virtual void reload() = 0;
44 73
45 /** create a new Records and return the uid */ 74 /** create a new Records and return the uid */
46 virtual int create() = 0; 75 virtual int create() = 0;
47 /** remove a record with UID == uid */ 76 /** remove a record with UID == uid */
48 virtual bool remove( int uid ) = 0; 77 virtual bool remove( int uid ) = 0;
49 /** beam the record with UID = uid */ 78 /** beam the record with UID = uid */
50 virtual void beam( int uid ) = 0; 79 virtual void beam( int uid ) = 0;
51 80
52 /** show the record with UID == uid */ 81 /** show the record with UID == uid */
53 virtual void show( int uid ) = 0; 82 virtual void show( int uid ) = 0;
54 /** edit the record */ 83 /** edit the record */
55 virtual void edit( int uid ) = 0; 84 virtual void edit( int uid ) = 0;
56 85
57 /** make a copy of it! */ 86 /** make a copy of it! */
58 virtual void add( const OPimRecord& ) = 0; 87 virtual void add( const OPimRecord& ) = 0;
59 88
60 virtual void doAlarm( const QDateTime&, int uid ); 89 virtual void doAlarm( const QDateTime&, int uid );
61 90
62 QCopChannel* channel(); 91 QCopChannel* channel();
63 92
64protected: 93protected:
65 /** 94 /**
66 * start to play soundAlarm() 95 * start to play soundAlarm()
67 * @param count How many times the alarm is played 96 * @param count How many times the alarm is played
68 */ 97 */
69 void startAlarm(int count = 10); 98 void startAlarm(int count = 10);
70 void killAlarm(); 99 void killAlarm();
71 void timerEvent( QTimerEvent* ); 100 void timerEvent( QTimerEvent* );
72 101
73private slots: 102private slots:
74 void appMessage( const QCString&, const QByteArray& ); 103 void appMessage( const QCString&, const QByteArray& );
75 void setDocument( const QString& ); 104 void setDocument( const QString& );
76 105
77 106
78private: 107private:
79 class Private; 108 class Private;
80 Private* d; 109 Private* d;
81 110
82 int m_rtti; 111 int m_rtti;
83 QCopChannel* m_channel; 112 QCopChannel* m_channel;
84 QString m_service; 113 QString m_service;
85 QCString m_str; 114 QCString m_str;
86 OPimRecord* m_fallBack; 115 OPimRecord* m_fallBack;
87 int m_alarmCount; 116 int m_alarmCount;
88 int m_playedCount; 117 int m_playedCount;
89 int m_timerId; 118 int m_timerId;
90 /* I would love to do this as a template 119 /* I would love to do this as a template
91 * but can't think of a right way 120 * but can't think of a right way
92 * because I need signal and slots -zecke 121 * because I need signal and slots -zecke
93 */ 122 */
94 virtual OPimRecord* record( int rtti, const QByteArray& ) ; 123 virtual OPimRecord* record( int rtti, const QByteArray& ) ;
95 int service(); 124 int service();
96}; 125};
97 126
127}
98 128
99#endif 129#endif
diff --git a/libopie2/opiepim/ui/ui.pro b/libopie2/opiepim/ui/ui.pro
new file mode 100644
index 0000000..db19bca
--- a/dev/null
+++ b/libopie2/opiepim/ui/ui.pro
@@ -0,0 +1,3 @@
1HEADERS += ui/opimmainwindow.h
2
3SOURCES += ui/opimmainwindow.cpp