author | eilers <eilers> | 2004-12-28 12:14:44 (UTC) |
---|---|---|
committer | eilers <eilers> | 2004-12-28 12:14:44 (UTC) |
commit | 4f0a67218237c83bdd02d339835f62ad064dc248 (patch) (unidiff) | |
tree | 26680f7a55cb0b09f158e1bf18b4bad4117e0db0 | |
parent | 97a3d431ba9e33a3e256955755b23a55a9a9ea05 (diff) | |
download | opie-4f0a67218237c83bdd02d339835f62ad064dc248.zip opie-4f0a67218237c83bdd02d339835f62ad064dc248.tar.gz opie-4f0a67218237c83bdd02d339835f62ad064dc248.tar.bz2 |
* Make improved query by example accessable via frontend
* Some API improvement
-rw-r--r-- | libopie2/opiepim/ChangeLog | 3 | ||||
-rw-r--r-- | libopie2/opiepim/core/ocontactaccess.h | 2 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimaccesstemplate.h | 76 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimtemplatebase.h | 2 |
4 files changed, 74 insertions, 9 deletions
diff --git a/libopie2/opiepim/ChangeLog b/libopie2/opiepim/ChangeLog index dd57259..564e92a 100644 --- a/libopie2/opiepim/ChangeLog +++ b/libopie2/opiepim/ChangeLog | |||
@@ -1,18 +1,21 @@ | |||
1 | 2004-12-28 Stefan Eilers <stefan@eilers-online.net> | ||
2 | * Make improved query by example accessable via frontend | ||
3 | * Some API improvement | ||
1 | 2004-11-23 Stefan Eilers <stefan@eilers-online.net> | 4 | 2004-11-23 Stefan Eilers <stefan@eilers-online.net> |
2 | * Implement fast and full featured version of sorted() for addressbook | 5 | * Implement fast and full featured version of sorted() for addressbook |
3 | * Implement generic queryByExample for all Addressboook backends. It allows incremental search. | 6 | * Implement generic queryByExample for all Addressboook backends. It allows incremental search. |
4 | * Update of API Documentation | 7 | * Update of API Documentation |
5 | 2004-11-18 Holger Freyther <freyther@handhelds.org> | 8 | 2004-11-18 Holger Freyther <freyther@handhelds.org> |
6 | * Every Access can give a set of Occurrences for a period or a datetime | 9 | * Every Access can give a set of Occurrences for a period or a datetime |
7 | * QueryByExample, Find, Sort can be generically accessed by OPimBase | 10 | * QueryByExample, Find, Sort can be generically accessed by OPimBase |
8 | pointer interface | 11 | pointer interface |
9 | * OPimBackendOccurrence gets split up to OPimOccurrences by | 12 | * OPimBackendOccurrence gets split up to OPimOccurrences by |
10 | OPimTemplateBase | 13 | OPimTemplateBase |
11 | * Add safeCast to various OPimRecords | 14 | * Add safeCast to various OPimRecords |
12 | * Kill memleak in OPimTodo | 15 | * Kill memleak in OPimTodo |
13 | * Add SortVector implementations for OPimTodo and OPimContact | 16 | * Add SortVector implementations for OPimTodo and OPimContact |
14 | 17 | ||
15 | 2004-??-??The Opie Team <opie@handhelds.org> | 18 | 2004-??-??The Opie Team <opie@handhelds.org> |
16 | * Implemented some important modifications to allow to use OPimRecords as it is, without | 19 | * Implemented some important modifications to allow to use OPimRecords as it is, without |
17 | have to cast them. This makes it possible to write applications which handling pim | 20 | have to cast them. This makes it possible to write applications which handling pim |
18 | data in a generic manner (see opimconvertion tool) (eilers) \ No newline at end of file | 21 | data in a generic manner (see opimconvertion tool) (eilers) \ No newline at end of file |
diff --git a/libopie2/opiepim/core/ocontactaccess.h b/libopie2/opiepim/core/ocontactaccess.h index bd85b4e..5051321 100644 --- a/libopie2/opiepim/core/ocontactaccess.h +++ b/libopie2/opiepim/core/ocontactaccess.h | |||
@@ -1,177 +1,177 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) The Main Author <main-author@whereever.org> | 3 | Copyright (C) The Main Author <main-author@whereever.org> |
4 | =. Copyright (C) The Opie Team <opie-devel@handhelds.org> | 4 | =. Copyright (C) The Opie Team <opie-devel@handhelds.org> |
5 | .=l. | 5 | .=l. |
6 | .>+-= | 6 | .>+-= |
7 | _;:, .> :=|. This program is free software; you can | 7 | _;:, .> :=|. This program is free software; you can |
8 | .> <`_, > . <= redistribute it and/or modify it under | 8 | .> <`_, > . <= redistribute it and/or modify it under |
9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
10 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
11 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
12 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
13 | .%`+i> _;_. | 13 | .%`+i> _;_. |
14 | .i_,=:_. -<s. This program is distributed in the hope that | 14 | .i_,=:_. -<s. This program is distributed in the hope that |
15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
16 | : .. .:, . . . without even the implied warranty of | 16 | : .. .:, . . . without even the implied warranty of |
17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
19 | ..}^=.= = ; Library General Public License for more | 19 | ..}^=.= = ; Library General Public License for more |
20 | ++= -. .` .: details. | 20 | ++= -. .` .: details. |
21 | : = ...= . :.=- | 21 | : = ...= . :.=- |
22 | -. .:....=;==+<; You should have received a copy of the GNU | 22 | -. .:....=;==+<; You should have received a copy of the GNU |
23 | -_. . . )=. = Library General Public License along with | 23 | -_. . . )=. = Library General Public License along with |
24 | -- :-=` this library; see the file COPYING.LIB. | 24 | -- :-=` this library; see the file COPYING.LIB. |
25 | If not, write to the Free Software Foundation, | 25 | If not, write to the Free Software Foundation, |
26 | Inc., 59 Temple Place - Suite 330, | 26 | Inc., 59 Temple Place - Suite 330, |
27 | Boston, MA 02111-1307, USA. | 27 | Boston, MA 02111-1307, USA. |
28 | */ | 28 | */ |
29 | /* | 29 | /* |
30 | * ===================================================================== | 30 | * ===================================================================== |
31 | * ToDo: Define enum for query settings | 31 | * ToDo: Define enum for query settings |
32 | * ===================================================================== | 32 | * ===================================================================== |
33 | */ | 33 | */ |
34 | #ifndef _OCONTACTACCESS_H | 34 | #ifndef _OCONTACTACCESS_H |
35 | #define _OCONTACTACCESS_H | 35 | #define _OCONTACTACCESS_H |
36 | 36 | ||
37 | #include <qobject.h> | 37 | #include <qobject.h> |
38 | 38 | ||
39 | #include <qpe/qcopenvelope_qws.h> | 39 | #include <qpe/qcopenvelope_qws.h> |
40 | 40 | ||
41 | #include <qvaluelist.h> | 41 | #include <qvaluelist.h> |
42 | #include <qfileinfo.h> | 42 | #include <qfileinfo.h> |
43 | 43 | ||
44 | #include <opie2/opimcontact.h> | 44 | #include <opie2/opimcontact.h> |
45 | #include <opie2/ocontactaccessbackend.h> | 45 | #include <opie2/ocontactaccessbackend.h> |
46 | #include <opie2/opimaccesstemplate.h> | 46 | #include <opie2/opimaccesstemplate.h> |
47 | 47 | ||
48 | namespace Opie { | 48 | namespace Opie { |
49 | /** | 49 | /** |
50 | * Class to access the contacts database. | 50 | * Class to access the contacts database. |
51 | * 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 |
52 | * done by the backend. | 52 | * done by the backend. |
53 | * 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 |
54 | * class is backend independent. | 54 | * class is backend independent. |
55 | * @author Stefan Eilers, Holger Freyther | 55 | * @author Stefan Eilers, Holger Freyther |
56 | * @see OPimAccessTemplate | 56 | * @see OPimAccessTemplate |
57 | */ | 57 | */ |
58 | class OPimContactAccess: public QObject, public OPimAccessTemplate<OPimContact> | 58 | class OPimContactAccess: public QObject, public OPimAccessTemplate<OPimContact> |
59 | { | 59 | { |
60 | Q_OBJECT | 60 | Q_OBJECT |
61 | 61 | ||
62 | public: | 62 | public: |
63 | /** | 63 | /** |
64 | * Filter for sorted() | 64 | * Filter for sorted() |
65 | * @see SortFilterBase in OPimBase | 65 | * @see SortFilterBase in OPimBase |
66 | */ | 66 | */ |
67 | enum SortFilter { | 67 | enum SortFilter { |
68 | /** Don't return entries who don't have children */ | 68 | /** Don't return entries who don't have children */ |
69 | DoNotShowWithoutChildren = FilterCustom<<1, | 69 | DoNotShowWithoutChildren = FilterCustom<<1, |
70 | /** Don't return entries who don't have an anniversary */ | 70 | /** Don't return entries who don't have an anniversary */ |
71 | DoNotShowWithoutAnniversary = FilterCustom<<2, | 71 | DoNotShowWithoutAnniversary = FilterCustom<<2, |
72 | /** Don't return entries who don't have a birthday */ | 72 | /** Don't return entries who don't have a birthday */ |
73 | DoNotShowWithoutBirthday = FilterCustom<<3, | 73 | DoNotShowWithoutBirthday = FilterCustom<<3, |
74 | /** Don't return entries who don't have a home address */ | 74 | /** Don't return entries who don't have a home address */ |
75 | DoNotShowWithoutHomeAddress = FilterCustom<<4, | 75 | DoNotShowWithoutHomeAddress = FilterCustom<<4, |
76 | /** Don't return entries who don't have a business address */ | 76 | /** Don't return entries who don't have a business address */ |
77 | DoNotShowWithoutBusinessAddress = FilterCustom<<5, | 77 | DoNotShowWithoutBusinessAddress = FilterCustom<<5, |
78 | /** Don't return entries which hava any category */ | 78 | /** Don't return entries which hava any category */ |
79 | DoNotShowWithCategory = FilterCustom << 6 | 79 | DoNotShowWithCategory = FilterCustom << 6 |
80 | }; | 80 | }; |
81 | 81 | ||
82 | /** | 82 | /** |
83 | * Sort order for sorted() | 83 | * Sort order for sorted() |
84 | * @see SortOrderBase in OPimBase | 84 | * @see SortOrderBase in OPimBase |
85 | */ | 85 | */ |
86 | enum SortOrder { | 86 | enum SortOrder { |
87 | SortTitle = SortCustom, | 87 | SortTitle = SortCustom, |
88 | SortFirstName, | 88 | SortFirstName, |
89 | SortMiddleName, | 89 | SortMiddleName, |
90 | SortLastName, | 90 | SortLastName, |
91 | SortSuffix, | 91 | SortSuffix, |
92 | SortEmail, | 92 | SortEmail, |
93 | SortNickname, | 93 | SortNickname, |
94 | SortFileAsName, | 94 | SortFileAsName, |
95 | SortAnniversary, | 95 | SortAnniversary, |
96 | SortBirthday, | 96 | SortBirthday, |
97 | SortGender | 97 | SortGender |
98 | }; | 98 | }; |
99 | 99 | ||
100 | /** | 100 | /** |
101 | * Create Database with contacts (addressbook). | 101 | * Create Database with contacts (addressbook). |
102 | * @param appname Name of application which wants access to the database | 102 | * @param appname Name of application which wants access to the database |
103 | * (i.e. "todolist") | 103 | * (i.e. "todolist") |
104 | * @param filename The name of the database file. If not set, the default one | 104 | * @param filename The name of the database file. If not set, the default one |
105 | * is used. | 105 | * is used. |
106 | * @param backend Pointer to an alternative Backend. If not set, we will use | 106 | * @param backend Pointer to an alternative Backend. If not set, we will use |
107 | * the default backend. | 107 | * the default backend. |
108 | * @param handlesync If <b>true</b> the database stores the current state | 108 | * @param handlesync If <b>true</b> the database stores the current state |
109 | * automatically if it receives the signals <i>flush()</i> and <i>reload()</i> | 109 | * automatically if it receives the signals <i>flush()</i> and <i>reload()</i> |
110 | * which are used before and after synchronisation. If the application wants | 110 | * which are used before and after synchronisation. If the application wants |
111 | * to react itself, it should be disabled by setting it to <b>false</b> | 111 | * to react itself, it should be disabled by setting it to <b>false</b> |
112 | * @see OPimContactAccessBackend | 112 | * @see OPimContactAccessBackend |
113 | */ | 113 | */ |
114 | OPimContactAccess (const QString appname, const QString filename = 0l, | 114 | OPimContactAccess (const QString appname, const QString filename = 0l, |
115 | OPimContactAccessBackend* backend = 0l, bool handlesync = true); | 115 | OPimContactAccessBackend* backend = 0l, bool handlesync = true); |
116 | ~OPimContactAccess (); | 116 | ~OPimContactAccess (); |
117 | 117 | ||
118 | 118 | ||
119 | /** | 119 | /** |
120 | * Return all possible settings for queryByExample(). | 120 | * Return all possible settings for queryByExample(). |
121 | * @return All settings provided by the current backend | 121 | * @return All settings provided by the current backend |
122 | * (i.e.: WildCards & IgnoreCase) | 122 | * (i.e.: WildCards & IgnoreCase) |
123 | * @see QuerySettings in OPimBase for details of the parameter | 123 | * @see QuerySettings in OPimBase for details of the parameter, queryByExample() |
124 | */ | 124 | */ |
125 | const uint querySettings(); | 125 | const uint querySettings(); |
126 | 126 | ||
127 | /** | 127 | /** |
128 | * Check whether settings are correct for queryByExample(). | 128 | * Check whether settings are correct for queryByExample(). |
129 | * @return <i>true</i> if the given settings are correct and possible. | 129 | * @return <i>true</i> if the given settings are correct and possible. |
130 | * @see QuerySettings in OPimBase for details of the parameter | 130 | * @see QuerySettings in OPimBase for details of the parameter |
131 | */ | 131 | */ |
132 | bool hasQuerySettings ( int querySettings ) const; | 132 | bool hasQuerySettings ( int querySettings ) const; |
133 | 133 | ||
134 | /** | 134 | /** |
135 | * if the resource was changed externally. | 135 | * if the resource was changed externally. |
136 | * You should use the signal instead of polling possible changes ! | 136 | * You should use the signal instead of polling possible changes ! |
137 | */ | 137 | */ |
138 | bool wasChangedExternally()const; | 138 | bool wasChangedExternally()const; |
139 | 139 | ||
140 | 140 | ||
141 | /** Save contacts database. | 141 | /** Save contacts database. |
142 | * Save is more a "commit". After calling this function, all changes are public available. | 142 | * Save is more a "commit". After calling this function, all changes are public available. |
143 | * @return true if successful | 143 | * @return true if successful |
144 | */ | 144 | */ |
145 | bool save(); | 145 | bool save(); |
146 | 146 | ||
147 | /** | 147 | /** |
148 | * Return identification of used records | 148 | * Return identification of used records |
149 | */ | 149 | */ |
150 | int rtti() const; | 150 | int rtti() const; |
151 | 151 | ||
152 | signals: | 152 | signals: |
153 | /* Signal is emitted if the database was changed. Therefore | 153 | /* Signal is emitted if the database was changed. Therefore |
154 | * we may need to reload to stay consistent. | 154 | * we may need to reload to stay consistent. |
155 | * @param which Pointer to the database who created this event. This pointer | 155 | * @param which Pointer to the database who created this event. This pointer |
156 | * is useful if an application has to handle multiple databases at the same time. | 156 | * is useful if an application has to handle multiple databases at the same time. |
157 | * @see reload() | 157 | * @see reload() |
158 | */ | 158 | */ |
159 | void signalChanged ( const OPimContactAccess *which ); | 159 | void signalChanged ( const OPimContactAccess *which ); |
160 | 160 | ||
161 | 161 | ||
162 | private: | 162 | private: |
163 | OPimContactAccessBackend *m_backEnd; | 163 | OPimContactAccessBackend *m_backEnd; |
164 | bool m_loading:1; | 164 | bool m_loading:1; |
165 | 165 | ||
166 | private slots: | 166 | private slots: |
167 | void copMessage( const QCString &msg, const QByteArray &data ); | 167 | void copMessage( const QCString &msg, const QByteArray &data ); |
168 | 168 | ||
169 | private: | 169 | private: |
170 | class Private; | 170 | class Private; |
171 | Private *d; | 171 | Private *d; |
172 | 172 | ||
173 | }; | 173 | }; |
174 | 174 | ||
175 | } | 175 | } |
176 | 176 | ||
177 | #endif | 177 | #endif |
diff --git a/libopie2/opiepim/core/opimaccesstemplate.h b/libopie2/opiepim/core/opimaccesstemplate.h index 073d5f9..3875f09 100644 --- a/libopie2/opiepim/core/opimaccesstemplate.h +++ b/libopie2/opiepim/core/opimaccesstemplate.h | |||
@@ -1,413 +1,475 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) Holger Freyther <zecke@handhelds.org> | 3 | Copyright (C) Holger Freyther <zecke@handhelds.org> |
4 | Copyright (C) Stefan Eilers <eilers.stefan@epost.de> | 4 | Copyright (C) Stefan Eilers <eilers.stefan@epost.de> |
5 | =. Copyright (C) The Opie Team <opie-devel@handhelds.org> | 5 | =. Copyright (C) The Opie Team <opie-devel@handhelds.org> |
6 | .=l. | 6 | .=l. |
7 | .>+-= | 7 | .>+-= |
8 | _;:, .> :=|. This program is free software; you can | 8 | _;:, .> :=|. This program is free software; you can |
9 | .> <`_, > . <= redistribute it and/or modify it under | 9 | .> <`_, > . <= redistribute it and/or modify it under |
10 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 10 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
11 | .="- .-=="i, .._ License as published by the Free Software | 11 | .="- .-=="i, .._ License as published by the Free Software |
12 | - . .-<_> .<> Foundation; either version 2 of the License, | 12 | - . .-<_> .<> Foundation; either version 2 of the License, |
13 | ._= =} : or (at your option) any later version. | 13 | ._= =} : or (at your option) any later version. |
14 | .%`+i> _;_. | 14 | .%`+i> _;_. |
15 | .i_,=:_. -<s. This program is distributed in the hope that | 15 | .i_,=:_. -<s. This program is distributed in the hope that |
16 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 16 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
17 | : .. .:, . . . without even the implied warranty of | 17 | : .. .:, . . . without even the implied warranty of |
18 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 18 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
19 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 19 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
20 | ..}^=.= = ; Library General Public License for more | 20 | ..}^=.= = ; Library General Public License for more |
21 | ++= -. .` .: details. | 21 | ++= -. .` .: details. |
22 | : = ...= . :.=- | 22 | : = ...= . :.=- |
23 | -. .:....=;==+<; You should have received a copy of the GNU | 23 | -. .:....=;==+<; You should have received a copy of the GNU |
24 | -_. . . )=. = Library General Public License along with | 24 | -_. . . )=. = Library General Public License along with |
25 | -- :-=` this library; see the file COPYING.LIB. | 25 | -- :-=` this library; see the file COPYING.LIB. |
26 | If not, write to the Free Software Foundation, | 26 | If not, write to the Free Software Foundation, |
27 | Inc., 59 Temple Place - Suite 330, | 27 | Inc., 59 Temple Place - Suite 330, |
28 | Boston, MA 02111-1307, USA. | 28 | Boston, MA 02111-1307, USA. |
29 | */ | 29 | */ |
30 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H | 30 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H |
31 | #define OPIE_PIM_ACCESS_TEMPLATE_H | 31 | #define OPIE_PIM_ACCESS_TEMPLATE_H |
32 | 32 | ||
33 | /* OPIE */ | 33 | /* OPIE */ |
34 | #include <opie2/opimrecord.h> | 34 | #include <opie2/opimrecord.h> |
35 | #include <opie2/opimaccessbackend.h> | 35 | #include <opie2/opimaccessbackend.h> |
36 | #include <opie2/opimrecordlist.h> | 36 | #include <opie2/opimrecordlist.h> |
37 | 37 | ||
38 | #include <opie2/opimtemplatebase.h> | 38 | #include <opie2/opimtemplatebase.h> |
39 | #include <opie2/odebug.h> | 39 | #include <opie2/odebug.h> |
40 | 40 | ||
41 | /* QT */ | 41 | /* QT */ |
42 | #include <qarray.h> | 42 | #include <qarray.h> |
43 | #include <qdatetime.h> | 43 | #include <qdatetime.h> |
44 | 44 | ||
45 | namespace Opie { | 45 | namespace Opie { |
46 | 46 | ||
47 | class OPimAccessTemplatePrivate; | 47 | class OPimAccessTemplatePrivate; |
48 | /** | 48 | /** |
49 | * Thats the frontend to our OPIE PIM | 49 | * Thats the frontend to our OPIE PIM |
50 | * Library. Either you want to use it's | 50 | * Library. Either you want to use it's |
51 | * interface or you want to implement | 51 | * interface or you want to implement |
52 | * your own Access lib | 52 | * your own Access lib |
53 | * Just create a OPimRecord and inherit from | 53 | * Just create a OPimRecord and inherit from |
54 | * the templates | 54 | * the templates |
55 | */ | 55 | */ |
56 | 56 | ||
57 | template <class T = OPimRecord > | 57 | template <class T = OPimRecord > |
58 | class OPimAccessTemplate : public OTemplateBase<T> { | 58 | class OPimAccessTemplate : public OTemplateBase<T> { |
59 | public: | 59 | public: |
60 | /** | 60 | /** |
61 | * | 61 | * |
62 | */ | 62 | */ |
63 | enum Access { | 63 | enum Access { |
64 | Random = 0, | 64 | Random = 0, |
65 | SortedAccess | 65 | SortedAccess |
66 | }; | 66 | }; |
67 | typedef OPimRecordList<T> List; | 67 | typedef OPimRecordList<T> List; |
68 | typedef OPimAccessBackend<T> BackEnd; | 68 | typedef OPimAccessBackend<T> BackEnd; |
69 | typedef OPimCache<T> Cache; | 69 | typedef OPimCache<T> Cache; |
70 | 70 | ||
71 | //@{ | 71 | //@{ |
72 | OPimAccessTemplate( BackEnd* end); | 72 | OPimAccessTemplate( BackEnd* end); |
73 | virtual ~OPimAccessTemplate(); | 73 | virtual ~OPimAccessTemplate(); |
74 | //@} | 74 | //@} |
75 | 75 | ||
76 | //@{ | 76 | //@{ |
77 | bool load(); | 77 | bool load(); |
78 | virtual bool reload(); | 78 | virtual bool reload(); |
79 | bool save(); | 79 | bool save(); |
80 | void clear() ; | 80 | void clear() ; |
81 | //@} | 81 | //@} |
82 | 82 | ||
83 | 83 | ||
84 | bool wasChangedExternally()const; | 84 | bool wasChangedExternally()const; |
85 | 85 | ||
86 | //@{ | 86 | //@{ |
87 | virtual List allRecords()const; | 87 | virtual List allRecords()const; |
88 | virtual List matchRegexp( const QRegExp &r ) const; | 88 | virtual List matchRegexp( const QRegExp &r ) const; |
89 | virtual List queryByExample( const T& t, int querySettings, const QDateTime& d = QDateTime() ); | 89 | |
90 | /** | ||
91 | * Query by example search interface. | ||
92 | * "Query by Example" provides a very powerful search engine. Use the query object | ||
93 | * (this may be a contact, a todo or databook event) | ||
94 | * as a search mask which is converted into a query regarding the querySettings. If a time period is needed | ||
95 | * (as for OpimBase::DateDiff), you have to use the date/time in the query object and the endperiod (the last parameter). | ||
96 | * @see QuerySettings in class OPimBase | ||
97 | * @param query The object which contains the query set | ||
98 | * @param querySettings This parameter defines what should be searched and how the query should be interpreted | ||
99 | * @param endperiod Defines the end of a period for some special queries. | ||
100 | */ | ||
101 | virtual List queryByExample( const T& query, int querySettings, const QDateTime& endperiod = QDateTime() ); | ||
102 | |||
103 | /** | ||
104 | * Generic query by example search interface. This is a special version which handles generic OPimRecord types. They are converted | ||
105 | * automatically into the right datatype. | ||
106 | * "Query by Example" provides a very powerful search engine. Use the query object (this may be a contact, a todo or databook event) | ||
107 | * as a search mask which is converted into a query regarding the querySettings. If a time period is needed | ||
108 | * (as for OpimBase::DateDiff), you have to use the date/time in the query object and the endperiod (the last parameter). | ||
109 | * @see QuerySettings in class OPimBase | ||
110 | * @param query The object which contains the query set | ||
111 | * @param querySettings This parameter defines what should be searched and how the query should be interpreted | ||
112 | * @param endperiod Defines the end of a period for some special queries. | ||
113 | */ | ||
114 | virtual List queryByExample( const OPimRecord* query, int querySettings, const QDateTime& endperiod = QDateTime() ); | ||
115 | /** | ||
116 | * Incremental query by example search interface. Providing incremental search, this one provides the feature | ||
117 | * to search in a list of records which may be returned by an other search. | ||
118 | * "Query by Example" provides a very powerful search engine. Use the query object (this may be a contact, a todo or databook event) | ||
119 | * as a search mask which is converted into a query regarding the querySettings. If a time period is needed | ||
120 | * (as for OpimBase::DateDiff), you have to use the date/time in the query object and the endperiod (the last parameter). | ||
121 | * @see QuerySettings in class OPimBase | ||
122 | * @param uidlist List of uid's which should be incorporated into the next search | ||
123 | * @param query The object which contains the query set | ||
124 | * @param querySettings This parameter defines what should be searched and how the query should be interpreted | ||
125 | * @param endperiod Defines the end of a period for some special queries. | ||
126 | */ | ||
127 | virtual List queryByExample( const OPimAccessTemplate::List& uidlist, const T& query, int querySettings, | ||
128 | const QDateTime& endperiod = QDateTime() ); | ||
129 | |||
90 | virtual T find( UID uid )const; | 130 | virtual T find( UID uid )const; |
91 | virtual T find( UID uid, const QArray<int>&, | 131 | virtual T find( UID uid, const QArray<int>&, |
92 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; | 132 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; |
93 | //@} | 133 | //@} |
94 | 134 | ||
95 | /** | 135 | /** |
96 | * Get sorted lists.. | 136 | * Get sorted lists.. |
97 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: | 137 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: |
98 | * @param list of UID's received by allRecords() or others... | 138 | * @param list of UID's received by allRecords() or others... |
99 | * @param sortOrder Setting the sort order defined by enum SortOrder | 139 | * @param sortOrder Setting the sort order defined by enum SortOrder |
100 | * @param ascending Sort in ascending order if true, otherwise descending | 140 | * @param ascending Sort in ascending order if true, otherwise descending |
101 | * @param sortFilter Setting the sort filter defined by enum SortFilter | 141 | * @param sortFilter Setting the sort filter defined by enum SortFilter |
102 | * @param cat number of category. | 142 | * @param cat number of category. |
103 | */ | 143 | */ |
104 | virtual List sorted( const List& list, bool ascending, int sortOrder, | 144 | virtual List sorted( const List& list, bool ascending, int sortOrder, |
105 | int sortFilter, int cat )const; | 145 | int sortFilter, int cat )const; |
106 | 146 | ||
107 | /** | 147 | /** |
108 | * Get sorted lists.. | 148 | * Get sorted lists.. |
109 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: | 149 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: |
110 | * @param list of UID's received by allRecords() or others... | 150 | * @param list of UID's received by allRecords() or others... |
111 | * @param sortOrder Setting the sort order defined by enum SortOrder | 151 | * @param sortOrder Setting the sort order defined by enum SortOrder |
112 | * @param ascending Sort in ascending order if true, otherwise descending | 152 | * @param ascending Sort in ascending order if true, otherwise descending |
113 | * @param sortFilter Setting the sort filter defined by enum SortFilter | 153 | * @param sortFilter Setting the sort filter defined by enum SortFilter |
114 | * @param cats List of categories. | 154 | * @param cats List of categories. |
115 | */ | 155 | */ |
116 | virtual List sorted( const List& list, bool ascending, int sortOrder, | 156 | virtual List sorted( const List& list, bool ascending, int sortOrder, |
117 | int sortFilter, const QArray<UID>& cats )const; | 157 | int sortFilter, const QArray<UID>& cats )const; |
118 | 158 | ||
119 | /** | 159 | /** |
120 | * Get sorted lists.. | 160 | * Get sorted lists.. |
121 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: | 161 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: |
122 | * @param ascending Sort in ascending order if true, otherwise descending | 162 | * @param ascending Sort in ascending order if true, otherwise descending |
123 | * @param sortOrder Setting the sort order defined by enum SortOrder | 163 | * @param sortOrder Setting the sort order defined by enum SortOrder |
124 | * @param sortFilter Setting the sort filter defined by enum SortFilter | 164 | * @param sortFilter Setting the sort filter defined by enum SortFilter |
125 | * @param cat number of category. | 165 | * @param cat number of category. |
126 | */ | 166 | */ |
127 | virtual List sorted( bool ascending, int sortOrder, int sortFilter, int cat )const; | 167 | virtual List sorted( bool ascending, int sortOrder, int sortFilter, int cat )const; |
128 | 168 | ||
129 | /** | 169 | /** |
130 | * Get sorted lists.. | 170 | * Get sorted lists.. |
131 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: | 171 | * @see OPimContactAccess, OPimTodoAccess and ODateBookAccess regarding more info for the following params: |
132 | * @param ascending Sort in ascending order if true, otherwise descending | 172 | * @param ascending Sort in ascending order if true, otherwise descending |
133 | * @param sortOrder Setting the sort order defined by enum SortOrder | 173 | * @param sortOrder Setting the sort order defined by enum SortOrder |
134 | * @param sortFilter Setting the sort filter defined by enum SortFilter | 174 | * @param sortFilter Setting the sort filter defined by enum SortFilter |
135 | * @param cats List of categories. | 175 | * @param cats List of categories. |
136 | */ | 176 | */ |
137 | virtual List sorted( bool ascending, int sortOrder, int sortFilter, | 177 | virtual List sorted( bool ascending, int sortOrder, int sortFilter, |
138 | const QArray<UID>& cats )const; | 178 | const QArray<UID>& cats )const; |
139 | /** | 179 | /** |
140 | * (Re)Implementation | 180 | * (Re)Implementation |
141 | */ | 181 | */ |
142 | //@{ | 182 | //@{ |
143 | UIDArray matchRegexpSimple( const QRegExp& r )const; | 183 | UIDArray matchRegexpSimple( const QRegExp& r )const; |
144 | UIDArray queryByExampleSimple( const OPimRecord*, int, const QDateTime& )const; | 184 | UIDArray queryByExampleSimple( const OPimRecord*, int, const QDateTime& )const; |
145 | UIDArray sortedSimple( const UIDArray&, bool asc, int sortOrder, | 185 | UIDArray sortedSimple( const UIDArray&, bool asc, int sortOrder, |
146 | int sortFilter, int cat )const; | 186 | int sortFilter, int cat )const; |
147 | UIDArray sortedSimple( const UIDArray&, bool asc, int sortOrder, | 187 | UIDArray sortedSimple( const UIDArray&, bool asc, int sortOrder, |
148 | int sortFilter, const QArray<int>& )const; | 188 | int sortFilter, const QArray<int>& )const; |
149 | UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, | 189 | UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, |
150 | int cat )const; | 190 | int cat )const; |
151 | UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, | 191 | UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, |
152 | const QArray<int>& )const; | 192 | const QArray<int>& )const; |
153 | OPimOccurrence::List occurrences( const QDate& start, const QDate& end )const; | 193 | OPimOccurrence::List occurrences( const QDate& start, const QDate& end )const; |
154 | OPimOccurrence::List occurrences( const QDateTime& dt )const; | 194 | OPimOccurrence::List occurrences( const QDateTime& dt )const; |
155 | //@} | 195 | //@} |
156 | 196 | ||
157 | //@{ | 197 | //@{ |
158 | virtual bool add( const T& t ) ; | 198 | virtual bool add( const T& t ) ; |
159 | bool add( const OPimRecord& ); | 199 | bool add( const OPimRecord& ); |
160 | bool add( const OPimRecord* ); | 200 | bool add( const OPimRecord* ); |
161 | virtual bool remove( const T& t ); | 201 | virtual bool remove( const T& t ); |
162 | bool remove( UID uid ); | 202 | bool remove( UID uid ); |
163 | bool remove( const OPimRecord& ); | 203 | bool remove( const OPimRecord& ); |
164 | virtual bool replace( const T& t) ; | 204 | virtual bool replace( const T& t) ; |
165 | 205 | ||
166 | //@} | 206 | //@} |
167 | 207 | ||
168 | void setReadAhead( uint count ); | 208 | void setReadAhead( uint count ); |
169 | void cache( const T& )const; | 209 | void cache( const T& )const; |
170 | void setSaneCacheSize( int ); | 210 | void setSaneCacheSize( int ); |
171 | 211 | ||
172 | QArray<UID> records()const; | 212 | QArray<UID> records()const; |
173 | protected: | 213 | protected: |
174 | /** | 214 | /** |
175 | * invalidate the cache | 215 | * invalidate the cache |
176 | */ | 216 | */ |
177 | void invalidateCache(); | 217 | void invalidateCache(); |
178 | 218 | ||
179 | void setBackEnd( BackEnd* end ); | 219 | void setBackEnd( BackEnd* end ); |
180 | /** | 220 | /** |
181 | * returns the backend | 221 | * returns the backend |
182 | */ | 222 | */ |
183 | BackEnd* backEnd(); | 223 | BackEnd* backEnd(); |
184 | BackEnd* m_backEnd; | 224 | BackEnd* m_backEnd; |
185 | 225 | ||
186 | Cache m_cache; | 226 | Cache m_cache; |
187 | 227 | ||
188 | private: | 228 | private: |
189 | OPimAccessTemplatePrivate *d; | 229 | OPimAccessTemplatePrivate *d; |
190 | 230 | ||
191 | }; | 231 | }; |
192 | 232 | ||
193 | /** | 233 | /** |
194 | * c'tor BackEnd | 234 | * c'tor BackEnd |
195 | * enum Access a small hint on how to handle the backend | 235 | * enum Access a small hint on how to handle the backend |
196 | */ | 236 | */ |
197 | template <class T> | 237 | template <class T> |
198 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) | 238 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) |
199 | : OTemplateBase<T>(), m_backEnd( end ) | 239 | : OTemplateBase<T>(), m_backEnd( end ) |
200 | { | 240 | { |
201 | if (end ) | 241 | if (end ) |
202 | end->setFrontend( this ); | 242 | end->setFrontend( this ); |
203 | } | 243 | } |
204 | template <class T> | 244 | template <class T> |
205 | OPimAccessTemplate<T>::~OPimAccessTemplate() { | 245 | OPimAccessTemplate<T>::~OPimAccessTemplate() { |
206 | delete m_backEnd; | 246 | delete m_backEnd; |
207 | } | 247 | } |
208 | 248 | ||
209 | /** | 249 | /** |
210 | * load from the backend | 250 | * load from the backend |
211 | */ | 251 | */ |
212 | template <class T> | 252 | template <class T> |
213 | bool OPimAccessTemplate<T>::load() { | 253 | bool OPimAccessTemplate<T>::load() { |
214 | invalidateCache(); | 254 | invalidateCache(); |
215 | return m_backEnd->load(); | 255 | return m_backEnd->load(); |
216 | } | 256 | } |
217 | 257 | ||
218 | /** Reload database. | 258 | /** Reload database. |
219 | * You should execute this function if the external database | 259 | * You should execute this function if the external database |
220 | * was changed. | 260 | * was changed. |
221 | * This function will load the external database and afterwards | 261 | * This function will load the external database and afterwards |
222 | * rejoin the local changes. Therefore the local database will be set consistent. | 262 | * rejoin the local changes. Therefore the local database will be set consistent. |
223 | */ | 263 | */ |
224 | template <class T> | 264 | template <class T> |
225 | bool OPimAccessTemplate<T>::reload() { | 265 | bool OPimAccessTemplate<T>::reload() { |
226 | invalidateCache(); | 266 | invalidateCache(); |
227 | return m_backEnd->reload(); | 267 | return m_backEnd->reload(); |
228 | } | 268 | } |
229 | 269 | ||
230 | /** | 270 | /** |
231 | * Save contacts database. | 271 | * Save contacts database. |
232 | * Save is more a "commit". After calling this function, all changes are public available. | 272 | * Save is more a "commit". After calling this function, all changes are public available. |
233 | * @return true if successful | 273 | * @return true if successful |
234 | */ | 274 | */ |
235 | template <class T> | 275 | template <class T> |
236 | bool OPimAccessTemplate<T>::save() { | 276 | bool OPimAccessTemplate<T>::save() { |
237 | return m_backEnd->save(); | 277 | return m_backEnd->save(); |
238 | } | 278 | } |
239 | 279 | ||
240 | 280 | ||
241 | /** | 281 | /** |
242 | * return a List of records | 282 | * return a List of records |
243 | * you can iterate over them | 283 | * you can iterate over them |
244 | */ | 284 | */ |
245 | template <class T> | 285 | template <class T> |
246 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { | 286 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { |
247 | QArray<int> ints = m_backEnd->allRecords(); | 287 | QArray<int> ints = m_backEnd->allRecords(); |
248 | List lis(ints, this ); | 288 | List lis(ints, this ); |
249 | return lis; | 289 | return lis; |
250 | } | 290 | } |
251 | 291 | ||
252 | /** | 292 | /** |
253 | * return a List of records | 293 | * return a List of records |
254 | * that match the regex | 294 | * that match the regex |
255 | */ | 295 | */ |
256 | template <class T> | 296 | template <class T> |
257 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::matchRegexp( const QRegExp &r )const { | 297 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::matchRegexp( const QRegExp &r )const { |
258 | QArray<int> ints = m_backEnd->matchRegexp( r ); | 298 | QArray<int> ints = m_backEnd->matchRegexp( r ); |
259 | List lis(ints, this ); | 299 | List lis(ints, this ); |
260 | return lis; | 300 | return lis; |
261 | } | 301 | } |
262 | 302 | ||
263 | /** | 303 | /** |
264 | * find the OPimRecord uid | 304 | * find the OPimRecord uid |
265 | */ | 305 | */ |
266 | template <class T> | 306 | template <class T> |
267 | QArray<int> OPimAccessTemplate<T>::records()const { | 307 | QArray<int> OPimAccessTemplate<T>::records()const { |
268 | return m_backEnd->allRecords(); | 308 | return m_backEnd->allRecords(); |
269 | } | 309 | } |
270 | 310 | ||
271 | 311 | ||
272 | /** | ||
273 | * queryByExample. | ||
274 | * @see otodoaccess, ocontactaccess | ||
275 | */ | ||
276 | template <class T> | 312 | template <class T> |
277 | typename OPimAccessTemplate<T>::List | 313 | typename OPimAccessTemplate<T>::List |
278 | OPimAccessTemplate<T>::queryByExample( const T& t, int settings, const QDateTime& d ) { | 314 | OPimAccessTemplate<T>::queryByExample( const T& t, int settings, const QDateTime& d ) { |
279 | QArray<int> ints = m_backEnd->queryByExample( t, settings, d ); | 315 | QArray<int> ints = m_backEnd->queryByExample( t, settings, d ); |
280 | 316 | ||
281 | List lis(ints, this ); | 317 | List list(ints, this ); |
282 | return lis; | 318 | return list; |
283 | } | 319 | } |
284 | 320 | ||
285 | template <class T> | 321 | template <class T> |
322 | typename OPimAccessTemplate<T>::List | ||
323 | OPimAccessTemplate<T>::queryByExample( const OPimRecord* t, int settings, const QDateTime& d ) { | ||
324 | T tempInstance; | ||
325 | |||
326 | if ( t->rtti() == tempInstance.rtti() ) { | ||
327 | QArray<int> ints = m_backEnd->queryByExample( t, settings, d ); | ||
328 | List list( ints, this ); | ||
329 | return list; | ||
330 | } else { | ||
331 | owarn << "Query not possible: Objecttype mismatch" << oendl; | ||
332 | } | ||
333 | |||
334 | return List(); | ||
335 | } | ||
336 | |||
337 | template <class T> | ||
338 | typename OPimAccessTemplate<T>::List | ||
339 | OPimAccessTemplate<T>::queryByExample( const OPimAccessTemplate::List& uidlist, const T& t, int settings, const QDateTime& d ) { | ||
340 | QArray<int> ints = m_backEnd->queryByExample( uidlist.uids(), t, settings, d ); | ||
341 | |||
342 | List list( ints, this ); | ||
343 | return list; | ||
344 | } | ||
345 | |||
346 | |||
347 | template <class T> | ||
286 | T OPimAccessTemplate<T>::find( UID uid ) const{ | 348 | T OPimAccessTemplate<T>::find( UID uid ) const{ |
287 | // First search in cache.. | 349 | // First search in cache.. |
288 | if ( m_cache.contains( uid ) ) | 350 | if ( m_cache.contains( uid ) ) |
289 | return m_cache.find( uid ); | 351 | return m_cache.find( uid ); |
290 | 352 | ||
291 | T t = m_backEnd->find( uid ); | 353 | T t = m_backEnd->find( uid ); |
292 | cache( t ); | 354 | cache( t ); |
293 | 355 | ||
294 | return t; | 356 | return t; |
295 | } | 357 | } |
296 | 358 | ||
297 | 359 | ||
298 | /** | 360 | /** |
299 | * read ahead cache find method ;) | 361 | * read ahead cache find method ;) |
300 | */ | 362 | */ |
301 | template <class T> | 363 | template <class T> |
302 | T OPimAccessTemplate<T>::find( UID uid, const QArray<int>& ar, | 364 | T OPimAccessTemplate<T>::find( UID uid, const QArray<int>& ar, |
303 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { | 365 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { |
304 | /* | 366 | /* |
305 | * better do T.isEmpty() | 367 | * better do T.isEmpty() |
306 | * after a find this way we would | 368 | * after a find this way we would |
307 | * avoid two finds in QCache... | 369 | * avoid two finds in QCache... |
308 | */ | 370 | */ |
309 | if (m_cache.contains( uid ) ) | 371 | if (m_cache.contains( uid ) ) |
310 | return m_cache.find( uid ); | 372 | return m_cache.find( uid ); |
311 | 373 | ||
312 | 374 | ||
313 | T t = m_backEnd->find( uid, ar, current, dir ); | 375 | T t = m_backEnd->find( uid, ar, current, dir ); |
314 | cache( t ); | 376 | cache( t ); |
315 | return t; | 377 | return t; |
316 | } | 378 | } |
317 | 379 | ||
318 | /** | 380 | /** |
319 | * clears the backend and invalidates the backend | 381 | * clears the backend and invalidates the backend |
320 | */ | 382 | */ |
321 | template <class T> | 383 | template <class T> |
322 | void OPimAccessTemplate<T>::clear() { | 384 | void OPimAccessTemplate<T>::clear() { |
323 | invalidateCache(); | 385 | invalidateCache(); |
324 | m_backEnd->clear(); | 386 | m_backEnd->clear(); |
325 | } | 387 | } |
326 | 388 | ||
327 | 389 | ||
328 | /** | 390 | /** |
329 | * add T to the backend | 391 | * add T to the backend |
330 | * @param t The item to add. | 392 | * @param t The item to add. |
331 | * @return <i>true</i> if added successfully. | 393 | * @return <i>true</i> if added successfully. |
332 | */ | 394 | */ |
333 | template <class T> | 395 | template <class T> |
334 | bool OPimAccessTemplate<T>::add( const T& t ) { | 396 | bool OPimAccessTemplate<T>::add( const T& t ) { |
335 | cache( t ); | 397 | cache( t ); |
336 | return m_backEnd->add( t ); | 398 | return m_backEnd->add( t ); |
337 | } | 399 | } |
338 | 400 | ||
339 | template <class T> | 401 | template <class T> |
340 | bool OPimAccessTemplate<T>::add( const OPimRecord& rec ) { | 402 | bool OPimAccessTemplate<T>::add( const OPimRecord& rec ) { |
341 | /* same type */ | 403 | /* same type */ |
342 | T tempInstance; | 404 | T tempInstance; |
343 | if ( rec.rtti() == tempInstance.rtti() ) { | 405 | if ( rec.rtti() == tempInstance.rtti() ) { |
344 | const T& t = static_cast<const T&>(rec); | 406 | const T& t = static_cast<const T&>(rec); |
345 | return add(t); | 407 | return add(t); |
346 | } else { | 408 | } else { |
347 | owarn << "Adding not possible: Objecttype mismatch" << oendl; | 409 | owarn << "Adding not possible: Objecttype mismatch" << oendl; |
348 | } | 410 | } |
349 | return false; | 411 | return false; |
350 | } | 412 | } |
351 | 413 | ||
352 | /** | 414 | /** |
353 | * Add an Opie PimRecord. | 415 | * Add an Opie PimRecord. |
354 | * Info: Take this if you are working with OPimRecords and you need to add it into any database. | 416 | * Info: Take this if you are working with OPimRecords and you need to add it into any database. |
355 | * But take care that the accessing database is compatible to the real type of OPimRecord !! | 417 | * But take care that the accessing database is compatible to the real type of OPimRecord !! |
356 | * Otherwise this access will be rejected ! | 418 | * Otherwise this access will be rejected ! |
357 | */ | 419 | */ |
358 | template <class T> | 420 | template <class T> |
359 | bool OPimAccessTemplate<T>::add( const OPimRecord* rec) { | 421 | bool OPimAccessTemplate<T>::add( const OPimRecord* rec) { |
360 | /* same type, but pointer */ | 422 | /* same type, but pointer */ |
361 | T tempInstance; | 423 | T tempInstance; |
362 | if ( rec -> rtti() == tempInstance.rtti() ) { | 424 | if ( rec -> rtti() == tempInstance.rtti() ) { |
363 | const T* t = static_cast<const T*>(rec); | 425 | const T* t = static_cast<const T*>(rec); |
364 | return add( *t ); | 426 | return add( *t ); |
365 | } else { | 427 | } else { |
366 | owarn << "Adding not possible: Objecttype mismatch" << oendl; | 428 | owarn << "Adding not possible: Objecttype mismatch" << oendl; |
367 | } | 429 | } |
368 | return false; | 430 | return false; |
369 | } | 431 | } |
370 | 432 | ||
371 | /** | 433 | /** |
372 | * remove T from the backend | 434 | * remove T from the backend |
373 | * @param t The item to remove | 435 | * @param t The item to remove |
374 | * @return <i>true</i> if successful. | 436 | * @return <i>true</i> if successful. |
375 | */ | 437 | */ |
376 | template <class T> | 438 | template <class T> |
377 | bool OPimAccessTemplate<T>::remove( const T& t ) { | 439 | bool OPimAccessTemplate<T>::remove( const T& t ) { |
378 | return remove( t.uid() ); | 440 | return remove( t.uid() ); |
379 | } | 441 | } |
380 | 442 | ||
381 | /** | 443 | /** |
382 | * remove the OPimRecord with uid | 444 | * remove the OPimRecord with uid |
383 | * @param uid The ID of the item to remove | 445 | * @param uid The ID of the item to remove |
384 | * @return <i>true</i> if successful. | 446 | * @return <i>true</i> if successful. |
385 | */ | 447 | */ |
386 | template <class T> | 448 | template <class T> |
387 | bool OPimAccessTemplate<T>::remove( UID uid ) { | 449 | bool OPimAccessTemplate<T>::remove( UID uid ) { |
388 | m_cache.remove( uid ); | 450 | m_cache.remove( uid ); |
389 | return m_backEnd->remove( uid ); | 451 | return m_backEnd->remove( uid ); |
390 | } | 452 | } |
391 | template <class T> | 453 | template <class T> |
392 | bool OPimAccessTemplate<T>::remove( const OPimRecord& rec) { | 454 | bool OPimAccessTemplate<T>::remove( const OPimRecord& rec) { |
393 | return remove( rec.uid() ); | 455 | return remove( rec.uid() ); |
394 | } | 456 | } |
395 | 457 | ||
396 | /** | 458 | /** |
397 | * replace T from backend | 459 | * replace T from backend |
398 | * @param t The item to replace | 460 | * @param t The item to replace |
399 | * @return <i>true</i> if successful. | 461 | * @return <i>true</i> if successful. |
400 | */ | 462 | */ |
401 | template <class T> | 463 | template <class T> |
402 | bool OPimAccessTemplate<T>::replace( const T& t ) { | 464 | bool OPimAccessTemplate<T>::replace( const T& t ) { |
403 | m_cache.replace( t ); | 465 | m_cache.replace( t ); |
404 | return m_backEnd->replace( t ); | 466 | return m_backEnd->replace( t ); |
405 | } | 467 | } |
406 | 468 | ||
407 | /** | 469 | /** |
408 | * @internal | 470 | * @internal |
409 | */ | 471 | */ |
410 | template <class T> | 472 | template <class T> |
411 | void OPimAccessTemplate<T>::invalidateCache() { | 473 | void OPimAccessTemplate<T>::invalidateCache() { |
412 | m_cache.invalidate(); | 474 | m_cache.invalidate(); |
413 | } | 475 | } |
diff --git a/libopie2/opiepim/core/opimtemplatebase.h b/libopie2/opiepim/core/opimtemplatebase.h index c8abab4..075e573 100644 --- a/libopie2/opiepim/core/opimtemplatebase.h +++ b/libopie2/opiepim/core/opimtemplatebase.h | |||
@@ -9,234 +9,234 @@ | |||
9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 9 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
10 | .="- .-=="i, .._ License as published by the Free Software | 10 | .="- .-=="i, .._ License as published by the Free Software |
11 | - . .-<_> .<> Foundation; either version 2 of the License, | 11 | - . .-<_> .<> Foundation; either version 2 of the License, |
12 | ._= =} : or (at your option) any later version. | 12 | ._= =} : or (at your option) any later version. |
13 | .%`+i> _;_. | 13 | .%`+i> _;_. |
14 | .i_,=:_. -<s. This program is distributed in the hope that | 14 | .i_,=:_. -<s. This program is distributed in the hope that |
15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 15 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
16 | : .. .:, . . . without even the implied warranty of | 16 | : .. .:, . . . without even the implied warranty of |
17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 17 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 18 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
19 | ..}^=.= = ; Library General Public License for more | 19 | ..}^=.= = ; Library General Public License for more |
20 | ++= -. .` .: details. | 20 | ++= -. .` .: details. |
21 | : = ...= . :.=- | 21 | : = ...= . :.=- |
22 | -. .:....=;==+<; You should have received a copy of the GNU | 22 | -. .:....=;==+<; You should have received a copy of the GNU |
23 | -_. . . )=. = Library General Public License along with | 23 | -_. . . )=. = Library General Public License along with |
24 | -- :-=` this library; see the file COPYING.LIB. | 24 | -- :-=` this library; see the file COPYING.LIB. |
25 | If not, write to the Free Software Foundation, | 25 | If not, write to the Free Software Foundation, |
26 | Inc., 59 Temple Place - Suite 330, | 26 | Inc., 59 Temple Place - Suite 330, |
27 | Boston, MA 02111-1307, USA. | 27 | Boston, MA 02111-1307, USA. |
28 | */ | 28 | */ |
29 | #ifndef OTEMPLATEBASE_H | 29 | #ifndef OTEMPLATEBASE_H |
30 | #define OTEMPLATEBASE_H | 30 | #define OTEMPLATEBASE_H |
31 | 31 | ||
32 | /* OPIE */ | 32 | /* OPIE */ |
33 | #include <opie2/opimrecord.h> | 33 | #include <opie2/opimrecord.h> |
34 | #include <opie2/opimcache.h> | 34 | #include <opie2/opimcache.h> |
35 | #include <opie2/opimoccurrence.h> | 35 | #include <opie2/opimoccurrence.h> |
36 | #include <opie2/opimbackendoccurrence.h> | 36 | #include <opie2/opimbackendoccurrence.h> |
37 | 37 | ||
38 | /* QT */ | 38 | /* QT */ |
39 | #include <qarray.h> | 39 | #include <qarray.h> |
40 | #include <qdatetime.h> | 40 | #include <qdatetime.h> |
41 | 41 | ||
42 | namespace Opie { | 42 | namespace Opie { |
43 | 43 | ||
44 | class OPimBasePrivate; | 44 | class OPimBasePrivate; |
45 | 45 | ||
46 | /** | 46 | /** |
47 | * This is the base class for all our Interfaces to the | 47 | * This is the base class for all our Interfaces to the |
48 | * PIM Records. It is pointer based and can be used | 48 | * PIM Records. It is pointer based and can be used |
49 | * generically for all types of Records. | 49 | * generically for all types of Records. |
50 | * | 50 | * |
51 | */ | 51 | */ |
52 | struct OPimBase { | 52 | struct OPimBase { |
53 | //@{ | 53 | //@{ |
54 | OPimBase(); | 54 | OPimBase(); |
55 | virtual ~OPimBase(); | 55 | virtual ~OPimBase(); |
56 | //@} | 56 | //@} |
57 | 57 | ||
58 | //@{ | 58 | //@{ |
59 | /** | 59 | /** |
60 | * return the rtti | 60 | * return the rtti |
61 | */ | 61 | */ |
62 | virtual int rtti() const = 0; | 62 | virtual int rtti() const = 0; |
63 | virtual OPimRecord* record()const = 0; | 63 | virtual OPimRecord* record()const = 0; |
64 | virtual OPimRecord* record(int uid)const = 0; | 64 | virtual OPimRecord* record(int uid)const = 0; |
65 | //@} | 65 | //@} |
66 | 66 | ||
67 | //@{ | 67 | //@{ |
68 | virtual bool add( const OPimRecord& ) = 0; | 68 | virtual bool add( const OPimRecord& ) = 0; |
69 | virtual bool add( const OPimRecord* ) = 0; | 69 | virtual bool add( const OPimRecord* ) = 0; |
70 | 70 | ||
71 | virtual bool remove( int uid ) = 0; | 71 | virtual bool remove( int uid ) = 0; |
72 | virtual bool remove( const OPimRecord& ) = 0; | 72 | virtual bool remove( const OPimRecord& ) = 0; |
73 | //@} | 73 | //@} |
74 | 74 | ||
75 | //@{ | 75 | //@{ |
76 | virtual void clear() = 0; | 76 | virtual void clear() = 0; |
77 | virtual bool load() = 0; | 77 | virtual bool load() = 0; |
78 | virtual bool save() = 0; | 78 | virtual bool save() = 0; |
79 | //@} | 79 | //@} |
80 | 80 | ||
81 | //@{ | 81 | //@{ |
82 | virtual QArray<UID> records()const = 0; | 82 | virtual QArray<UID> records()const = 0; |
83 | //@} | 83 | //@} |
84 | 84 | ||
85 | /** Constants for query. | 85 | /** Constants for query. |
86 | * Use this constants to set the query parameters. | 86 | * Use this constants to set the query parameters. |
87 | * Note: <i>query_IgnoreCase</i> just make sense with one of the other attributes ! | 87 | * Note: <i>query_IgnoreCase</i> just make sense with one of the other attributes ! |
88 | * @see queryByExample() | 88 | * @see queryByExample() |
89 | */ | 89 | */ |
90 | enum QuerySettings { | 90 | enum QuerySettings { |
91 | /** Use Wildcards */ | 91 | /** Use Wildcards */ |
92 | WildCards = 0x0001, | 92 | WildCards = 0x0001, |
93 | /** Ignore the Case */ | 93 | /** Ignore the Case */ |
94 | IgnoreCase = 0x0002, | 94 | IgnoreCase = 0x0002, |
95 | /** Do a Regular Expression match */ | 95 | /** Do a Regular Expression match */ |
96 | RegExp = 0x0004, | 96 | RegExp = 0x0004, |
97 | /** It needs to exactly match */ | 97 | /** It needs to exactly match */ |
98 | ExactMatch = 0x0008, | 98 | ExactMatch = 0x0008, |
99 | /** Only one Entry must match */ | 99 | /** Only one Entry must match */ |
100 | MatchOne = 0x0010, | 100 | MatchOne = 0x0010, |
101 | /** Find all entries from today until given date */ | 101 | /** Find all entries from today until given date */ |
102 | DateDiff = 0x0020, | 102 | DateDiff = 0x0020, |
103 | /** The year matches */ | 103 | /** The year matches */ |
104 | DateYear = 0x0040, | 104 | DateYear = 0x0040, |
105 | /** The month matches */ | 105 | /** The month matches */ |
106 | DateMonth = 0x0080, | 106 | DateMonth = 0x0080, |
107 | /** The day matches */ | 107 | /** The day matches */ |
108 | DateDay = 0x0100, | 108 | DateDay = 0x0100, |
109 | /** The last possible name matches */ | 109 | /** The last possible name matches */ |
110 | LastItem = 0xffff | 110 | LastItem = 0xffff |
111 | }; | 111 | }; |
112 | 112 | ||
113 | /** | 113 | /** |
114 | * Common Attributes for the Sort Order | 114 | * Common Attributes for the Sort Order |
115 | */ | 115 | */ |
116 | enum SortOrderBase { | 116 | enum SortOrderBase { |
117 | /** Sort by a Summary of the records */ | 117 | /** Sort by a Summary of the records */ |
118 | SortSummary = 0, | 118 | SortSummary = 0, |
119 | /** Sort by Category */ | 119 | /** Sort by Category */ |
120 | SortByCategory = 1, | 120 | SortByCategory = 1, |
121 | /** Sort by Date */ | 121 | /** Sort by Date */ |
122 | SortByDate = 2, | 122 | SortByDate = 2, |
123 | /** The First available sort number for the OPimAccessTemplates */ | 123 | /** The First available sort number for the OPimAccessTemplates */ |
124 | SortCustom = 10, | 124 | SortCustom = 10, |
125 | /** make this enum 16bit large */ | 125 | /** make this enum 16bit large */ |
126 | LastSortOrderBase = 0xffff | 126 | LastSortOrderBase = 0xffff |
127 | }; | 127 | }; |
128 | 128 | ||
129 | /** | 129 | /** |
130 | * Sort a list of Items with the help of the sorted() function. | 130 | * Sort a list of Items with the help of the sorted() function. |
131 | * The Item you provide in SortOrder will be used | 131 | * The Item you provide in SortOrder will be used |
132 | * for sorting. | 132 | * for sorting. |
133 | * | 133 | * |
134 | * @see OPimAccessTemplate<>::sorted() | 134 | * @see OPimAccessTemplate<>::sorted() |
135 | */ | 135 | */ |
136 | enum SortFilterBase { | 136 | enum SortFilterBase { |
137 | /** Do not filter anything. */ | 137 | /** Do not filter anything. */ |
138 | FilterOff = 0, | 138 | FilterOff = 0, |
139 | /** Use given Categories for filter */ | 139 | /** Use given Categories for filter */ |
140 | FilterCategory = 1, | 140 | FilterCategory = 1, |
141 | /** The first available custom filter defined in the specialized frontends */ | 141 | /** The first available custom filter defined in the specialized frontends */ |
142 | FilterCustom = 1024, | 142 | FilterCustom = 1024, |
143 | LastSortFilterBase = 0xffffffff | 143 | LastSortFilterBase = 0xffffffff |
144 | }; | 144 | }; |
145 | 145 | ||
146 | virtual UIDArray matchRegexpSimple( const QRegExp& r )const = 0; | 146 | virtual UIDArray matchRegexpSimple( const QRegExp& r )const = 0; |
147 | virtual UIDArray queryByExampleSimple( const OPimRecord*, int settings, | 147 | virtual UIDArray queryByExampleSimple( const OPimRecord*, int settings, |
148 | const QDateTime& d = QDateTime() )const = 0; | 148 | const QDateTime& d = QDateTime() )const = 0; |
149 | virtual UIDArray sortedSimple( const UIDArray& uid, bool ascending, | 149 | virtual UIDArray sortedSimple( const UIDArray& uid, bool ascending, |
150 | int sortOrder, int sortFilter, int cat)const = 0; | 150 | int sortOrder, int sortFilter, int cat)const = 0; |
151 | virtual UIDArray sortedSimple( const UIDArray& uid, bool ascending, | 151 | virtual UIDArray sortedSimple( const UIDArray& uid, bool ascending, |
152 | int sortOrder, int sortFilter, const QArray<UID>& cats )const = 0; | 152 | int sortOrder, int sortFilter, const QArray<UID>& cats )const = 0; |
153 | virtual UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, int cat)const = 0; | 153 | virtual UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, int cat)const = 0; |
154 | virtual UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, const QArray<UID>& cats )const = 0; | 154 | virtual UIDArray sortedSimple( bool ascending, int sortOrder, int sortFilter, const QArray<UID>& cats )const = 0; |
155 | virtual OPimOccurrence::List occurrences( const QDate& start, const QDate& end )const = 0; | 155 | virtual OPimOccurrence::List occurrences( const QDate& start, const QDate& end )const = 0; |
156 | virtual OPimOccurrence::List occurrences( const QDateTime& dt )const = 0; | 156 | virtual OPimOccurrence::List occurrences( const QDateTime& dt )const = 0; |
157 | //@} | 157 | //@} |
158 | 158 | ||
159 | 159 | ||
160 | protected: | 160 | protected: |
161 | OPimOccurrence::List convertOccurrenceFromBackend( const OPimBackendOccurrence::List& )const; | 161 | OPimOccurrence::List convertOccurrenceFromBackend( const OPimBackendOccurrence::List& )const; |
162 | 162 | ||
163 | private: | 163 | private: |
164 | OPimBasePrivate* d; | 164 | OPimBasePrivate* d; |
165 | }; | 165 | }; |
166 | 166 | ||
167 | 167 | ||
168 | /** | 168 | /** |
169 | * internal template base | 169 | * internal template base |
170 | * Attention: T needs to implement the copy c'tor!!! | 170 | * Attention: T needs to implement the copy c'tor!!! |
171 | */ | 171 | */ |
172 | class OTemplateBasePrivate; | 172 | class OTemplateBasePrivate; |
173 | template <class T = OPimRecord> | 173 | template <class T = OPimRecord> |
174 | class OTemplateBase : public OPimBase { | 174 | class OTemplateBase : public OPimBase { |
175 | public: | 175 | public: |
176 | /** | 176 | /** |
177 | * The Direction for ReadAhead/ReadBehind which will | 177 | * The Direction for ReadAhead/ReadBehind which will |
178 | * be used by the backends to Cache Items in | 178 | * be used by the backends to Cache Items in |
179 | * advance. | 179 | * advance. |
180 | * For example if you know that you will access the | 180 | * For example if you know that you will access the |
181 | * next ten items you can give the backend a hint | 181 | * next ten items you can give the backend a hint |
182 | * to read ahead or read before. | 182 | * to read ahead or read before. |
183 | */ | 183 | */ |
184 | enum CacheDirection { | 184 | enum CacheDirection { |
185 | Forward=0, /** Go forward when caching (++ to the index) */ | 185 | Forward=0, /** Go forward when caching (++ to the index) */ |
186 | Reverse /** Go backward when caching (-- to the index) */ | 186 | Reverse /** Go backward when caching (-- to the index) */ |
187 | }; | 187 | }; |
188 | 188 | ||
189 | 189 | ||
190 | //@{ | 190 | //@{ |
191 | OTemplateBase() {}; | 191 | OTemplateBase() {}; |
192 | virtual ~OTemplateBase() {} | 192 | virtual ~OTemplateBase() {} |
193 | //@} | 193 | //@} |
194 | 194 | ||
195 | 195 | ||
196 | //@{ | 196 | //@{ |
197 | virtual T find( int uid )const = 0; | 197 | virtual T find( int uid )const = 0; |
198 | 198 | ||
199 | /** | 199 | /** |
200 | * read ahead find | 200 | * read ahead find |
201 | */ | 201 | */ |
202 | virtual T find( int uid, const QArray<int>& items, | 202 | virtual T find( int uid, const QArray<int>& items, |
203 | uint current, CacheDirection dir = Forward )const = 0; | 203 | uint current, CacheDirection dir = Forward )const = 0; |
204 | //@} | 204 | //@} |
205 | 205 | ||
206 | //@{ | 206 | //@{ |
207 | /** | 207 | /** |
208 | * Put element into Cache | 208 | * Put element into Cache |
209 | */ | 209 | */ |
210 | virtual void cache( const T& )const = 0; | 210 | virtual void cache( const T& )const = 0; |
211 | virtual void setSaneCacheSize( int ) = 0; | 211 | virtual void setSaneCacheSize( int ) = 0; |
212 | 212 | ||
213 | OPimRecord* record()const; | 213 | OPimRecord* record()const; |
214 | OPimRecord* record(int uid )const; | 214 | OPimRecord* record(int uid )const; |
215 | static T* rec(); | 215 | static T* rec(); |
216 | //@} | 216 | //@} |
217 | 217 | ||
218 | private: | 218 | private: |
219 | OTemplateBasePrivate *d; | 219 | OTemplateBasePrivate *d; |
220 | }; | 220 | }; |
221 | 221 | ||
222 | 222 | ||
223 | template <class T> | 223 | template <class T> |
224 | OPimRecord* OTemplateBase<T>::record()const { | 224 | OPimRecord* OTemplateBase<T>::record()const { |
225 | T* t = new T; | 225 | T* t = new T; |
226 | return t; | 226 | return t; |
227 | } | 227 | } |
228 | template <class T> | 228 | template <class T> |
229 | OPimRecord* OTemplateBase<T>::record(int uid )const { | 229 | OPimRecord* OTemplateBase<T>::record(int uid )const { |
230 | T t2 = find(uid ); | 230 | T t2 = find(uid ); |
231 | T* t1 = new T(t2); | 231 | T* t1 = new T(t2); |
232 | 232 | ||
233 | return t1; | 233 | return t1; |
234 | } | 234 | } |
235 | 235 | ||
236 | template <class T> | 236 | template <class T> |
237 | T* OTemplateBase<T>::rec() { | 237 | T* OTemplateBase<T>::rec() { |
238 | return new T; | 238 | return new T; |
239 | } | 239 | } |
240 | } | 240 | } |
241 | 241 | ||
242 | #endif | 242 | #endif |