-rw-r--r-- | libopie/pim/ocontact.cpp | 1 | ||||
-rw-r--r-- | libopie/pim/ocontact.h | 4 | ||||
-rw-r--r-- | libopie/pim/opimrecord.cpp | 8 | ||||
-rw-r--r-- | libopie/pim/opimrecord.h | 15 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.cpp | 8 | ||||
-rw-r--r-- | libopie2/opiepim/core/opimrecord.h | 15 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.cpp | 1 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.h | 4 |
8 files changed, 44 insertions, 12 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index aeb69ee..a7ca975 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -924,64 +924,65 @@ QStringList OContact::fields() | |||
924 | list.append( "Groups" ); | 924 | list.append( "Groups" ); |
925 | 925 | ||
926 | return list; | 926 | return list; |
927 | } | 927 | } |
928 | 928 | ||
929 | 929 | ||
930 | /*! | 930 | /*! |
931 | Sets the list of email address for contact to those contained in \a str. | 931 | Sets the list of email address for contact to those contained in \a str. |
932 | Email address should be separated by ';'s. | 932 | Email address should be separated by ';'s. |
933 | */ | 933 | */ |
934 | void OContact::setEmails( const QString &str ) | 934 | void OContact::setEmails( const QString &str ) |
935 | { | 935 | { |
936 | replace( Qtopia::Emails, str ); | 936 | replace( Qtopia::Emails, str ); |
937 | if ( str.isEmpty() ) | 937 | if ( str.isEmpty() ) |
938 | setDefaultEmail( QString::null ); | 938 | setDefaultEmail( QString::null ); |
939 | } | 939 | } |
940 | 940 | ||
941 | /*! | 941 | /*! |
942 | Sets the list of children for the contact to those contained in \a str. | 942 | Sets the list of children for the contact to those contained in \a str. |
943 | */ | 943 | */ |
944 | void OContact::setChildren( const QString &str ) | 944 | void OContact::setChildren( const QString &str ) |
945 | { | 945 | { |
946 | replace( Qtopia::Children, str ); | 946 | replace( Qtopia::Children, str ); |
947 | } | 947 | } |
948 | 948 | ||
949 | /*! | 949 | /*! |
950 | \overload | 950 | \overload |
951 | Returns TRUE if the contact matches the regular expression \a regexp. | 951 | Returns TRUE if the contact matches the regular expression \a regexp. |
952 | Otherwise returns FALSE. | 952 | Otherwise returns FALSE. |
953 | */ | 953 | */ |
954 | bool OContact::match( const QRegExp &r ) const | 954 | bool OContact::match( const QRegExp &r ) const |
955 | { | 955 | { |
956 | setLastHitField( -1 ); | ||
956 | bool match; | 957 | bool match; |
957 | match = false; | 958 | match = false; |
958 | QMap<int, QString>::ConstIterator it; | 959 | QMap<int, QString>::ConstIterator it; |
959 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { | 960 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { |
960 | if ( (*it).find( r ) > -1 ) { | 961 | if ( (*it).find( r ) > -1 ) { |
961 | setLastHitField( it.key() ); | 962 | setLastHitField( it.key() ); |
962 | match = true; | 963 | match = true; |
963 | break; | 964 | break; |
964 | } | 965 | } |
965 | } | 966 | } |
966 | return match; | 967 | return match; |
967 | } | 968 | } |
968 | 969 | ||
969 | 970 | ||
970 | QString OContact::toShortText() const | 971 | QString OContact::toShortText() const |
971 | { | 972 | { |
972 | return ( fullName() ); | 973 | return ( fullName() ); |
973 | } | 974 | } |
974 | QString OContact::type() const | 975 | QString OContact::type() const |
975 | { | 976 | { |
976 | return QString::fromLatin1( "OContact" ); | 977 | return QString::fromLatin1( "OContact" ); |
977 | } | 978 | } |
978 | 979 | ||
979 | // Definition is missing ! (se) | 980 | // Definition is missing ! (se) |
980 | QMap<QString,QString> OContact::toExtraMap() const | 981 | QMap<QString,QString> OContact::toExtraMap() const |
981 | { | 982 | { |
982 | qWarning ("Function not implemented: OContact::toExtraMap()"); | 983 | qWarning ("Function not implemented: OContact::toExtraMap()"); |
983 | QMap <QString,QString> useless; | 984 | QMap <QString,QString> useless; |
984 | return useless; | 985 | return useless; |
985 | } | 986 | } |
986 | 987 | ||
987 | class QString OContact::recordField( int pos ) const | 988 | class QString OContact::recordField( int pos ) const |
diff --git a/libopie/pim/ocontact.h b/libopie/pim/ocontact.h index f79f0f3..dd2de17 100644 --- a/libopie/pim/ocontact.h +++ b/libopie/pim/ocontact.h | |||
@@ -185,60 +185,56 @@ public: | |||
185 | QString nickname() const { return find( Qtopia::Nickname ); } | 185 | QString nickname() const { return find( Qtopia::Nickname ); } |
186 | QString children() const { return find( Qtopia::Children ); } | 186 | QString children() const { return find( Qtopia::Children ); } |
187 | QStringList childrenList() const; | 187 | QStringList childrenList() const; |
188 | 188 | ||
189 | // other | 189 | // other |
190 | QString notes() const { return find( Qtopia::Notes ); } | 190 | QString notes() const { return find( Qtopia::Notes ); } |
191 | QString groups() const { return find( Qtopia::Groups ); } | 191 | QString groups() const { return find( Qtopia::Groups ); } |
192 | QStringList groupList() const; | 192 | QStringList groupList() const; |
193 | 193 | ||
194 | // // custom | 194 | // // custom |
195 | // const QString &customField( const QString &key ) | 195 | // const QString &customField( const QString &key ) |
196 | // { return find( Custom- + key ); } | 196 | // { return find( Custom- + key ); } |
197 | 197 | ||
198 | 198 | ||
199 | QString toRichText() const; | 199 | QString toRichText() const; |
200 | QMap<int, QString> toMap() const; | 200 | QMap<int, QString> toMap() const; |
201 | QString field( int key ) const { return find( key ); } | 201 | QString field( int key ) const { return find( key ); } |
202 | 202 | ||
203 | 203 | ||
204 | void setUid( int i ); | 204 | void setUid( int i ); |
205 | 205 | ||
206 | QString toShortText()const; | 206 | QString toShortText()const; |
207 | QString OContact::type()const; | 207 | QString OContact::type()const; |
208 | QMap<QString,QString> OContact::toExtraMap() const; | 208 | QMap<QString,QString> OContact::toExtraMap() const; |
209 | class QString OContact::recordField(int) const; | 209 | class QString OContact::recordField(int) const; |
210 | 210 | ||
211 | // Why private ? (eilers,se) | 211 | // Why private ? (eilers,se) |
212 | QString emailSeparator() const { return " "; } | 212 | QString emailSeparator() const { return " "; } |
213 | // the emails should be seperated by a comma | 213 | // the emails should be seperated by a comma |
214 | void setEmails( const QString &v ); | 214 | void setEmails( const QString &v ); |
215 | QString emails() const { return find( Qtopia::Emails ); } | 215 | QString emails() const { return find( Qtopia::Emails ); } |
216 | static int rtti(); | 216 | static int rtti(); |
217 | int lastHitField() const {return m_lastHitField;}; | ||
218 | protected: | ||
219 | mutable int m_lastHitField; | ||
220 | void setLastHitField(int i) const { m_lastHitField = i; }; | ||
221 | 217 | ||
222 | private: | 218 | private: |
223 | // The XML-Backend needs some access to the private functions | 219 | // The XML-Backend needs some access to the private functions |
224 | friend class OContactAccessBackend_XML; | 220 | friend class OContactAccessBackend_XML; |
225 | 221 | ||
226 | void insert( int key, const QString &value ); | 222 | void insert( int key, const QString &value ); |
227 | void replace( int key, const QString &value ); | 223 | void replace( int key, const QString &value ); |
228 | QString find( int key ) const; | 224 | QString find( int key ) const; |
229 | static QStringList fields(); | 225 | static QStringList fields(); |
230 | 226 | ||
231 | void save( QString &buf ) const; | 227 | void save( QString &buf ) const; |
232 | 228 | ||
233 | QString displayAddress( const QString &street, | 229 | QString displayAddress( const QString &street, |
234 | const QString &city, | 230 | const QString &city, |
235 | const QString &state, | 231 | const QString &state, |
236 | const QString &zip, | 232 | const QString &zip, |
237 | const QString &country ) const; | 233 | const QString &country ) const; |
238 | 234 | ||
239 | QMap<int, QString> mMap; | 235 | QMap<int, QString> mMap; |
240 | ContactPrivate *d; | 236 | ContactPrivate *d; |
241 | }; | 237 | }; |
242 | 238 | ||
243 | 239 | ||
244 | #endif | 240 | #endif |
diff --git a/libopie/pim/opimrecord.cpp b/libopie/pim/opimrecord.cpp index d45417a..9510357 100644 --- a/libopie/pim/opimrecord.cpp +++ b/libopie/pim/opimrecord.cpp | |||
@@ -1,58 +1,60 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | m_lastHit = -1; | ||
14 | setUid( uid ); | 15 | setUid( uid ); |
15 | } | 16 | } |
16 | OPimRecord::~OPimRecord() { | 17 | OPimRecord::~OPimRecord() { |
17 | } | 18 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 19 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 20 | : Qtopia::Record( rec ) |
20 | { | 21 | { |
21 | (*this) = rec; | 22 | (*this) = rec; |
22 | } | 23 | } |
23 | 24 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 25 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 26 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 27 | m_xrefman = rec.m_xrefman; |
28 | m_lastHit = rec.m_lastHit; | ||
27 | 29 | ||
28 | return *this; | 30 | return *this; |
29 | } | 31 | } |
30 | /* | 32 | /* |
31 | * category names | 33 | * category names |
32 | */ | 34 | */ |
33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { | 35 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 36 | QStringList list; |
35 | QArray<int> cats = categories(); | 37 | QArray<int> cats = categories(); |
36 | Categories catDB; | 38 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 39 | catDB.load( categoryFileName() ); |
38 | 40 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 41 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label( appname, cats[i] ); | 42 | list << catDB.label( appname, cats[i] ); |
41 | } | 43 | } |
42 | 44 | ||
43 | return list; | 45 | return list; |
44 | } | 46 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 47 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 48 | ||
47 | } | 49 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 50 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 51 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 52 | catDB.load( categoryFileName() ); |
51 | 53 | ||
52 | 54 | ||
53 | } | 55 | } |
54 | bool OPimRecord::isEmpty()const { | 56 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 57 | return ( uid() == 0 ); |
56 | } | 58 | } |
57 | /*QString OPimRecord::crossToString()const { | 59 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 60 | QString str; |
@@ -135,32 +137,38 @@ bool OPimRecord::saveToStream( QDataStream& stream )const { | |||
135 | * first the XRef count | 137 | * first the XRef count |
136 | * then the xrefs | 138 | * then the xrefs |
137 | */ | 139 | */ |
138 | stream << m_xrefman.list().count(); | 140 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 141 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 142 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 143 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 144 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 145 | } |
144 | return true; | 146 | return true; |
145 | } | 147 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 148 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 149 | str << par.service(); |
148 | str << par.uid(); | 150 | str << par.uid(); |
149 | str << par.field(); | 151 | str << par.field(); |
150 | } | 152 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 153 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 154 | OPimXRefPartner par; |
153 | QString str; | 155 | QString str; |
154 | int i; | 156 | int i; |
155 | 157 | ||
156 | stream >> str; | 158 | stream >> str; |
157 | par.setService( str ); | 159 | par.setService( str ); |
158 | 160 | ||
159 | stream >> i; | 161 | stream >> i; |
160 | par.setUid( i ); | 162 | par.setUid( i ); |
161 | 163 | ||
162 | stream >> i ; | 164 | stream >> i ; |
163 | par.setField( i ); | 165 | par.setField( i ); |
164 | 166 | ||
165 | return par; | 167 | return par; |
166 | } | 168 | } |
169 | void OPimRecord::setLastHitField( int lastHit )const { | ||
170 | m_lastHit = lastHit; | ||
171 | } | ||
172 | int OPimRecord::lastHitField()const{ | ||
173 | return m_lastHit; | ||
174 | } | ||
diff --git a/libopie/pim/opimrecord.h b/libopie/pim/opimrecord.h index 6e7c0da..494c78e 100644 --- a/libopie/pim/opimrecord.h +++ b/libopie/pim/opimrecord.h | |||
@@ -46,95 +46,106 @@ public: | |||
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * matches the Records the regular expression? | 76 | * matches the Records the regular expression? |
77 | */ | 77 | */ |
78 | virtual bool match( const QString ®exp ) const | 78 | virtual bool match( const QString ®exp ) const |
79 | {return Qtopia::Record::match(QRegExp(regexp));}; | 79 | {setLastHitField( -1 ); |
80 | return Qtopia::Record::match(QRegExp(regexp));}; | ||
81 | |||
82 | /** | ||
83 | * if implemented this function returns which item has been | ||
84 | * last hit by the match() function. | ||
85 | * or -1 if not implemented or no hit has occured | ||
86 | */ | ||
87 | int lastHitField()const; | ||
80 | 88 | ||
81 | /** | 89 | /** |
82 | * converts the internal structure to a map | 90 | * converts the internal structure to a map |
83 | */ | 91 | */ |
84 | virtual QMap<int, QString> toMap()const = 0; | 92 | virtual QMap<int, QString> toMap()const = 0; |
85 | 93 | ||
86 | /** | 94 | /** |
87 | * key value representation of extra items | 95 | * key value representation of extra items |
88 | */ | 96 | */ |
89 | virtual QMap<QString, QString> toExtraMap()const = 0; | 97 | virtual QMap<QString, QString> toExtraMap()const = 0; |
90 | 98 | ||
91 | /** | 99 | /** |
92 | * the name for a recordField | 100 | * the name for a recordField |
93 | */ | 101 | */ |
94 | virtual QString recordField(int)const = 0; | 102 | virtual QString recordField(int)const = 0; |
95 | 103 | ||
96 | /** | 104 | /** |
97 | * returns a reference of the | 105 | * returns a reference of the |
98 | * Cross Reference Manager | 106 | * Cross Reference Manager |
99 | * Partner 'One' is THIS PIM RECORD! | 107 | * Partner 'One' is THIS PIM RECORD! |
100 | * 'Two' is the Partner where we link to | 108 | * 'Two' is the Partner where we link to |
101 | */ | 109 | */ |
102 | OPimXRefManager& xrefmanager(); | 110 | OPimXRefManager& xrefmanager(); |
103 | 111 | ||
104 | /** | 112 | /** |
105 | * set the uid | 113 | * set the uid |
106 | */ | 114 | */ |
107 | virtual void setUid( int uid ); | 115 | virtual void setUid( int uid ); |
108 | 116 | ||
109 | /* | 117 | /* |
110 | * used inside the Templates for casting | 118 | * used inside the Templates for casting |
111 | * REIMPLEMENT in your .... | 119 | * REIMPLEMENT in your .... |
112 | */ | 120 | */ |
113 | static int rtti(); | 121 | static int rtti(); |
114 | 122 | ||
115 | /** | 123 | /** |
116 | * some marshalling and de marshalling code | 124 | * some marshalling and de marshalling code |
117 | * saves the OPimRecord | 125 | * saves the OPimRecord |
118 | * to and from a DataStream | 126 | * to and from a DataStream |
119 | */ | 127 | */ |
120 | virtual bool loadFromStream(QDataStream& ); | 128 | virtual bool loadFromStream(QDataStream& ); |
121 | virtual bool saveToStream( QDataStream& stream )const; | 129 | virtual bool saveToStream( QDataStream& stream )const; |
122 | 130 | ||
123 | protected: | 131 | protected: |
132 | // need to be const cause it is called from const methods | ||
133 | mutable int m_lastHit; | ||
134 | void setLastHitField( int lastHit )const; | ||
124 | Qtopia::UidGen &uidGen(); | 135 | Qtopia::UidGen &uidGen(); |
125 | // QString crossToString()const; | 136 | // QString crossToString()const; |
126 | 137 | ||
127 | private: | 138 | private: |
128 | class OPimRecordPrivate; | 139 | class OPimRecordPrivate; |
129 | OPimRecordPrivate *d; | 140 | OPimRecordPrivate *d; |
130 | OPimXRefManager m_xrefman; | 141 | OPimXRefManager m_xrefman; |
131 | static Qtopia::UidGen m_uidGen; | 142 | static Qtopia::UidGen m_uidGen; |
132 | 143 | ||
133 | private: | 144 | private: |
134 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 145 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
135 | OPimXRefPartner partner( QDataStream& ); | 146 | OPimXRefPartner partner( QDataStream& ); |
136 | }; | 147 | }; |
137 | 148 | ||
138 | 149 | ||
139 | 150 | ||
140 | #endif | 151 | #endif |
diff --git a/libopie2/opiepim/core/opimrecord.cpp b/libopie2/opiepim/core/opimrecord.cpp index d45417a..9510357 100644 --- a/libopie2/opiepim/core/opimrecord.cpp +++ b/libopie2/opiepim/core/opimrecord.cpp | |||
@@ -1,58 +1,60 @@ | |||
1 | #include <qarray.h> | 1 | #include <qarray.h> |
2 | 2 | ||
3 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
4 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
9 | 9 | ||
10 | 10 | ||
11 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
12 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
13 | 13 | ||
14 | m_lastHit = -1; | ||
14 | setUid( uid ); | 15 | setUid( uid ); |
15 | } | 16 | } |
16 | OPimRecord::~OPimRecord() { | 17 | OPimRecord::~OPimRecord() { |
17 | } | 18 | } |
18 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 19 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
19 | : Qtopia::Record( rec ) | 20 | : Qtopia::Record( rec ) |
20 | { | 21 | { |
21 | (*this) = rec; | 22 | (*this) = rec; |
22 | } | 23 | } |
23 | 24 | ||
24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 25 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
25 | Qtopia::Record::operator=( rec ); | 26 | Qtopia::Record::operator=( rec ); |
26 | m_xrefman = rec.m_xrefman; | 27 | m_xrefman = rec.m_xrefman; |
28 | m_lastHit = rec.m_lastHit; | ||
27 | 29 | ||
28 | return *this; | 30 | return *this; |
29 | } | 31 | } |
30 | /* | 32 | /* |
31 | * category names | 33 | * category names |
32 | */ | 34 | */ |
33 | QStringList OPimRecord::categoryNames( const QString& appname ) const { | 35 | QStringList OPimRecord::categoryNames( const QString& appname ) const { |
34 | QStringList list; | 36 | QStringList list; |
35 | QArray<int> cats = categories(); | 37 | QArray<int> cats = categories(); |
36 | Categories catDB; | 38 | Categories catDB; |
37 | catDB.load( categoryFileName() ); | 39 | catDB.load( categoryFileName() ); |
38 | 40 | ||
39 | for (uint i = 0; i < cats.count(); i++ ) { | 41 | for (uint i = 0; i < cats.count(); i++ ) { |
40 | list << catDB.label( appname, cats[i] ); | 42 | list << catDB.label( appname, cats[i] ); |
41 | } | 43 | } |
42 | 44 | ||
43 | return list; | 45 | return list; |
44 | } | 46 | } |
45 | void OPimRecord::setCategoryNames( const QStringList& ) { | 47 | void OPimRecord::setCategoryNames( const QStringList& ) { |
46 | 48 | ||
47 | } | 49 | } |
48 | void OPimRecord::addCategoryName( const QString& ) { | 50 | void OPimRecord::addCategoryName( const QString& ) { |
49 | Categories catDB; | 51 | Categories catDB; |
50 | catDB.load( categoryFileName() ); | 52 | catDB.load( categoryFileName() ); |
51 | 53 | ||
52 | 54 | ||
53 | } | 55 | } |
54 | bool OPimRecord::isEmpty()const { | 56 | bool OPimRecord::isEmpty()const { |
55 | return ( uid() == 0 ); | 57 | return ( uid() == 0 ); |
56 | } | 58 | } |
57 | /*QString OPimRecord::crossToString()const { | 59 | /*QString OPimRecord::crossToString()const { |
58 | QString str; | 60 | QString str; |
@@ -135,32 +137,38 @@ bool OPimRecord::saveToStream( QDataStream& stream )const { | |||
135 | * first the XRef count | 137 | * first the XRef count |
136 | * then the xrefs | 138 | * then the xrefs |
137 | */ | 139 | */ |
138 | stream << m_xrefman.list().count(); | 140 | stream << m_xrefman.list().count(); |
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | 141 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); |
140 | it != m_xrefman.list().end(); ++it ) { | 142 | it != m_xrefman.list().end(); ++it ) { |
141 | flush( (*it).partner( OPimXRef::One), stream ); | 143 | flush( (*it).partner( OPimXRef::One), stream ); |
142 | flush( (*it).partner( OPimXRef::Two), stream ); | 144 | flush( (*it).partner( OPimXRef::Two), stream ); |
143 | } | 145 | } |
144 | return true; | 146 | return true; |
145 | } | 147 | } |
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | 148 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ |
147 | str << par.service(); | 149 | str << par.service(); |
148 | str << par.uid(); | 150 | str << par.uid(); |
149 | str << par.field(); | 151 | str << par.field(); |
150 | } | 152 | } |
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | 153 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { |
152 | OPimXRefPartner par; | 154 | OPimXRefPartner par; |
153 | QString str; | 155 | QString str; |
154 | int i; | 156 | int i; |
155 | 157 | ||
156 | stream >> str; | 158 | stream >> str; |
157 | par.setService( str ); | 159 | par.setService( str ); |
158 | 160 | ||
159 | stream >> i; | 161 | stream >> i; |
160 | par.setUid( i ); | 162 | par.setUid( i ); |
161 | 163 | ||
162 | stream >> i ; | 164 | stream >> i ; |
163 | par.setField( i ); | 165 | par.setField( i ); |
164 | 166 | ||
165 | return par; | 167 | return par; |
166 | } | 168 | } |
169 | void OPimRecord::setLastHitField( int lastHit )const { | ||
170 | m_lastHit = lastHit; | ||
171 | } | ||
172 | int OPimRecord::lastHitField()const{ | ||
173 | return m_lastHit; | ||
174 | } | ||
diff --git a/libopie2/opiepim/core/opimrecord.h b/libopie2/opiepim/core/opimrecord.h index 6e7c0da..494c78e 100644 --- a/libopie2/opiepim/core/opimrecord.h +++ b/libopie2/opiepim/core/opimrecord.h | |||
@@ -46,95 +46,106 @@ public: | |||
46 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
50 | * to the internal category list | 50 | * to the internal category list |
51 | */ | 51 | */ |
52 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
53 | 53 | ||
54 | /** | 54 | /** |
55 | * if a Record isEmpty | 55 | * if a Record isEmpty |
56 | * it's empty if it's 0 | 56 | * it's empty if it's 0 |
57 | */ | 57 | */ |
58 | virtual bool isEmpty()const; | 58 | virtual bool isEmpty()const; |
59 | 59 | ||
60 | /** | 60 | /** |
61 | * toRichText summary | 61 | * toRichText summary |
62 | */ | 62 | */ |
63 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * a small one line summary | 66 | * a small one line summary |
67 | */ | 67 | */ |
68 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * the name of the Record | 71 | * the name of the Record |
72 | */ | 72 | */ |
73 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * matches the Records the regular expression? | 76 | * matches the Records the regular expression? |
77 | */ | 77 | */ |
78 | virtual bool match( const QString ®exp ) const | 78 | virtual bool match( const QString ®exp ) const |
79 | {return Qtopia::Record::match(QRegExp(regexp));}; | 79 | {setLastHitField( -1 ); |
80 | return Qtopia::Record::match(QRegExp(regexp));}; | ||
81 | |||
82 | /** | ||
83 | * if implemented this function returns which item has been | ||
84 | * last hit by the match() function. | ||
85 | * or -1 if not implemented or no hit has occured | ||
86 | */ | ||
87 | int lastHitField()const; | ||
80 | 88 | ||
81 | /** | 89 | /** |
82 | * converts the internal structure to a map | 90 | * converts the internal structure to a map |
83 | */ | 91 | */ |
84 | virtual QMap<int, QString> toMap()const = 0; | 92 | virtual QMap<int, QString> toMap()const = 0; |
85 | 93 | ||
86 | /** | 94 | /** |
87 | * key value representation of extra items | 95 | * key value representation of extra items |
88 | */ | 96 | */ |
89 | virtual QMap<QString, QString> toExtraMap()const = 0; | 97 | virtual QMap<QString, QString> toExtraMap()const = 0; |
90 | 98 | ||
91 | /** | 99 | /** |
92 | * the name for a recordField | 100 | * the name for a recordField |
93 | */ | 101 | */ |
94 | virtual QString recordField(int)const = 0; | 102 | virtual QString recordField(int)const = 0; |
95 | 103 | ||
96 | /** | 104 | /** |
97 | * returns a reference of the | 105 | * returns a reference of the |
98 | * Cross Reference Manager | 106 | * Cross Reference Manager |
99 | * Partner 'One' is THIS PIM RECORD! | 107 | * Partner 'One' is THIS PIM RECORD! |
100 | * 'Two' is the Partner where we link to | 108 | * 'Two' is the Partner where we link to |
101 | */ | 109 | */ |
102 | OPimXRefManager& xrefmanager(); | 110 | OPimXRefManager& xrefmanager(); |
103 | 111 | ||
104 | /** | 112 | /** |
105 | * set the uid | 113 | * set the uid |
106 | */ | 114 | */ |
107 | virtual void setUid( int uid ); | 115 | virtual void setUid( int uid ); |
108 | 116 | ||
109 | /* | 117 | /* |
110 | * used inside the Templates for casting | 118 | * used inside the Templates for casting |
111 | * REIMPLEMENT in your .... | 119 | * REIMPLEMENT in your .... |
112 | */ | 120 | */ |
113 | static int rtti(); | 121 | static int rtti(); |
114 | 122 | ||
115 | /** | 123 | /** |
116 | * some marshalling and de marshalling code | 124 | * some marshalling and de marshalling code |
117 | * saves the OPimRecord | 125 | * saves the OPimRecord |
118 | * to and from a DataStream | 126 | * to and from a DataStream |
119 | */ | 127 | */ |
120 | virtual bool loadFromStream(QDataStream& ); | 128 | virtual bool loadFromStream(QDataStream& ); |
121 | virtual bool saveToStream( QDataStream& stream )const; | 129 | virtual bool saveToStream( QDataStream& stream )const; |
122 | 130 | ||
123 | protected: | 131 | protected: |
132 | // need to be const cause it is called from const methods | ||
133 | mutable int m_lastHit; | ||
134 | void setLastHitField( int lastHit )const; | ||
124 | Qtopia::UidGen &uidGen(); | 135 | Qtopia::UidGen &uidGen(); |
125 | // QString crossToString()const; | 136 | // QString crossToString()const; |
126 | 137 | ||
127 | private: | 138 | private: |
128 | class OPimRecordPrivate; | 139 | class OPimRecordPrivate; |
129 | OPimRecordPrivate *d; | 140 | OPimRecordPrivate *d; |
130 | OPimXRefManager m_xrefman; | 141 | OPimXRefManager m_xrefman; |
131 | static Qtopia::UidGen m_uidGen; | 142 | static Qtopia::UidGen m_uidGen; |
132 | 143 | ||
133 | private: | 144 | private: |
134 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | 145 | void flush( const OPimXRefPartner&, QDataStream& stream )const; |
135 | OPimXRefPartner partner( QDataStream& ); | 146 | OPimXRefPartner partner( QDataStream& ); |
136 | }; | 147 | }; |
137 | 148 | ||
138 | 149 | ||
139 | 150 | ||
140 | #endif | 151 | #endif |
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp index aeb69ee..a7ca975 100644 --- a/libopie2/opiepim/ocontact.cpp +++ b/libopie2/opiepim/ocontact.cpp | |||
@@ -924,64 +924,65 @@ QStringList OContact::fields() | |||
924 | list.append( "Groups" ); | 924 | list.append( "Groups" ); |
925 | 925 | ||
926 | return list; | 926 | return list; |
927 | } | 927 | } |
928 | 928 | ||
929 | 929 | ||
930 | /*! | 930 | /*! |
931 | Sets the list of email address for contact to those contained in \a str. | 931 | Sets the list of email address for contact to those contained in \a str. |
932 | Email address should be separated by ';'s. | 932 | Email address should be separated by ';'s. |
933 | */ | 933 | */ |
934 | void OContact::setEmails( const QString &str ) | 934 | void OContact::setEmails( const QString &str ) |
935 | { | 935 | { |
936 | replace( Qtopia::Emails, str ); | 936 | replace( Qtopia::Emails, str ); |
937 | if ( str.isEmpty() ) | 937 | if ( str.isEmpty() ) |
938 | setDefaultEmail( QString::null ); | 938 | setDefaultEmail( QString::null ); |
939 | } | 939 | } |
940 | 940 | ||
941 | /*! | 941 | /*! |
942 | Sets the list of children for the contact to those contained in \a str. | 942 | Sets the list of children for the contact to those contained in \a str. |
943 | */ | 943 | */ |
944 | void OContact::setChildren( const QString &str ) | 944 | void OContact::setChildren( const QString &str ) |
945 | { | 945 | { |
946 | replace( Qtopia::Children, str ); | 946 | replace( Qtopia::Children, str ); |
947 | } | 947 | } |
948 | 948 | ||
949 | /*! | 949 | /*! |
950 | \overload | 950 | \overload |
951 | Returns TRUE if the contact matches the regular expression \a regexp. | 951 | Returns TRUE if the contact matches the regular expression \a regexp. |
952 | Otherwise returns FALSE. | 952 | Otherwise returns FALSE. |
953 | */ | 953 | */ |
954 | bool OContact::match( const QRegExp &r ) const | 954 | bool OContact::match( const QRegExp &r ) const |
955 | { | 955 | { |
956 | setLastHitField( -1 ); | ||
956 | bool match; | 957 | bool match; |
957 | match = false; | 958 | match = false; |
958 | QMap<int, QString>::ConstIterator it; | 959 | QMap<int, QString>::ConstIterator it; |
959 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { | 960 | for ( it = mMap.begin(); it != mMap.end(); ++it ) { |
960 | if ( (*it).find( r ) > -1 ) { | 961 | if ( (*it).find( r ) > -1 ) { |
961 | setLastHitField( it.key() ); | 962 | setLastHitField( it.key() ); |
962 | match = true; | 963 | match = true; |
963 | break; | 964 | break; |
964 | } | 965 | } |
965 | } | 966 | } |
966 | return match; | 967 | return match; |
967 | } | 968 | } |
968 | 969 | ||
969 | 970 | ||
970 | QString OContact::toShortText() const | 971 | QString OContact::toShortText() const |
971 | { | 972 | { |
972 | return ( fullName() ); | 973 | return ( fullName() ); |
973 | } | 974 | } |
974 | QString OContact::type() const | 975 | QString OContact::type() const |
975 | { | 976 | { |
976 | return QString::fromLatin1( "OContact" ); | 977 | return QString::fromLatin1( "OContact" ); |
977 | } | 978 | } |
978 | 979 | ||
979 | // Definition is missing ! (se) | 980 | // Definition is missing ! (se) |
980 | QMap<QString,QString> OContact::toExtraMap() const | 981 | QMap<QString,QString> OContact::toExtraMap() const |
981 | { | 982 | { |
982 | qWarning ("Function not implemented: OContact::toExtraMap()"); | 983 | qWarning ("Function not implemented: OContact::toExtraMap()"); |
983 | QMap <QString,QString> useless; | 984 | QMap <QString,QString> useless; |
984 | return useless; | 985 | return useless; |
985 | } | 986 | } |
986 | 987 | ||
987 | class QString OContact::recordField( int pos ) const | 988 | class QString OContact::recordField( int pos ) const |
diff --git a/libopie2/opiepim/ocontact.h b/libopie2/opiepim/ocontact.h index f79f0f3..dd2de17 100644 --- a/libopie2/opiepim/ocontact.h +++ b/libopie2/opiepim/ocontact.h | |||
@@ -185,60 +185,56 @@ public: | |||
185 | QString nickname() const { return find( Qtopia::Nickname ); } | 185 | QString nickname() const { return find( Qtopia::Nickname ); } |
186 | QString children() const { return find( Qtopia::Children ); } | 186 | QString children() const { return find( Qtopia::Children ); } |
187 | QStringList childrenList() const; | 187 | QStringList childrenList() const; |
188 | 188 | ||
189 | // other | 189 | // other |
190 | QString notes() const { return find( Qtopia::Notes ); } | 190 | QString notes() const { return find( Qtopia::Notes ); } |
191 | QString groups() const { return find( Qtopia::Groups ); } | 191 | QString groups() const { return find( Qtopia::Groups ); } |
192 | QStringList groupList() const; | 192 | QStringList groupList() const; |
193 | 193 | ||
194 | // // custom | 194 | // // custom |
195 | // const QString &customField( const QString &key ) | 195 | // const QString &customField( const QString &key ) |
196 | // { return find( Custom- + key ); } | 196 | // { return find( Custom- + key ); } |
197 | 197 | ||
198 | 198 | ||
199 | QString toRichText() const; | 199 | QString toRichText() const; |
200 | QMap<int, QString> toMap() const; | 200 | QMap<int, QString> toMap() const; |
201 | QString field( int key ) const { return find( key ); } | 201 | QString field( int key ) const { return find( key ); } |
202 | 202 | ||
203 | 203 | ||
204 | void setUid( int i ); | 204 | void setUid( int i ); |
205 | 205 | ||
206 | QString toShortText()const; | 206 | QString toShortText()const; |
207 | QString OContact::type()const; | 207 | QString OContact::type()const; |
208 | QMap<QString,QString> OContact::toExtraMap() const; | 208 | QMap<QString,QString> OContact::toExtraMap() const; |
209 | class QString OContact::recordField(int) const; | 209 | class QString OContact::recordField(int) const; |
210 | 210 | ||
211 | // Why private ? (eilers,se) | 211 | // Why private ? (eilers,se) |
212 | QString emailSeparator() const { return " "; } | 212 | QString emailSeparator() const { return " "; } |
213 | // the emails should be seperated by a comma | 213 | // the emails should be seperated by a comma |
214 | void setEmails( const QString &v ); | 214 | void setEmails( const QString &v ); |
215 | QString emails() const { return find( Qtopia::Emails ); } | 215 | QString emails() const { return find( Qtopia::Emails ); } |
216 | static int rtti(); | 216 | static int rtti(); |
217 | int lastHitField() const {return m_lastHitField;}; | ||
218 | protected: | ||
219 | mutable int m_lastHitField; | ||
220 | void setLastHitField(int i) const { m_lastHitField = i; }; | ||
221 | 217 | ||
222 | private: | 218 | private: |
223 | // The XML-Backend needs some access to the private functions | 219 | // The XML-Backend needs some access to the private functions |
224 | friend class OContactAccessBackend_XML; | 220 | friend class OContactAccessBackend_XML; |
225 | 221 | ||
226 | void insert( int key, const QString &value ); | 222 | void insert( int key, const QString &value ); |
227 | void replace( int key, const QString &value ); | 223 | void replace( int key, const QString &value ); |
228 | QString find( int key ) const; | 224 | QString find( int key ) const; |
229 | static QStringList fields(); | 225 | static QStringList fields(); |
230 | 226 | ||
231 | void save( QString &buf ) const; | 227 | void save( QString &buf ) const; |
232 | 228 | ||
233 | QString displayAddress( const QString &street, | 229 | QString displayAddress( const QString &street, |
234 | const QString &city, | 230 | const QString &city, |
235 | const QString &state, | 231 | const QString &state, |
236 | const QString &zip, | 232 | const QString &zip, |
237 | const QString &country ) const; | 233 | const QString &country ) const; |
238 | 234 | ||
239 | QMap<int, QString> mMap; | 235 | QMap<int, QString> mMap; |
240 | ContactPrivate *d; | 236 | ContactPrivate *d; |
241 | }; | 237 | }; |
242 | 238 | ||
243 | 239 | ||
244 | #endif | 240 | #endif |