-rw-r--r-- | libopie/pim/ocontact.cpp | 11 | ||||
-rw-r--r-- | libopie/pim/opimaccessbackend.h | 16 | ||||
-rw-r--r-- | libopie/pim/opimaccesstemplate.h | 25 | ||||
-rw-r--r-- | libopie/pim/opimcache.h | 6 | ||||
-rw-r--r-- | libopie/pim/opimmainwindow.cpp | 36 | ||||
-rw-r--r-- | libopie/pim/opimmainwindow.h | 26 | ||||
-rw-r--r-- | libopie/pim/opimrecord.cpp | 82 | ||||
-rw-r--r-- | libopie/pim/opimrecord.h | 12 | ||||
-rw-r--r-- | libopie/pim/opimresolver.cpp | 198 | ||||
-rw-r--r-- | libopie/pim/opimresolver.h | 52 | ||||
-rw-r--r-- | libopie/pim/otemplatebase.h | 63 | ||||
-rw-r--r-- | libopie/pim/otodo.cpp | 3 | ||||
-rw-r--r-- | libopie/pim/otodoaccess.cpp | 32 | ||||
-rw-r--r-- | libopie/pim/otodoaccess.h | 13 | ||||
-rw-r--r-- | libopie/pim/otodoaccessxml.cpp | 43 |
15 files changed, 536 insertions, 82 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index 6aec62e..38cba72 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -1,72 +1,73 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** Copyright (C) 2002 by Stefan Eilers (eilers.stefan@epost.de) | 3 | ** Copyright (C) 2002 by Stefan Eilers (eilers.stefan@epost.de) |
4 | ** | 4 | ** |
5 | ** This file is part of the Qtopia Environment. | 5 | ** This file is part of the Qtopia Environment. |
6 | ** | 6 | ** |
7 | ** This file may be distributed and/or modified under the terms of the | 7 | ** This file may be distributed and/or modified under the terms of the |
8 | ** GNU General Public License version 2 as published by the Free Software | 8 | ** GNU General Public License version 2 as published by the Free Software |
9 | ** Foundation and appearing in the file LICENSE.GPL included in the | 9 | ** Foundation and appearing in the file LICENSE.GPL included in the |
10 | ** packaging of this file. | 10 | ** packaging of this file. |
11 | ** | 11 | ** |
12 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 12 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
13 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 13 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
14 | ** | 14 | ** |
15 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 15 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
16 | ** | 16 | ** |
17 | ** Contact info@trolltech.com if any conditions of this licensing are | 17 | ** Contact info@trolltech.com if any conditions of this licensing are |
18 | ** not clear to you. | 18 | ** not clear to you. |
19 | ** | 19 | ** |
20 | **********************************************************************/ | 20 | **********************************************************************/ |
21 | 21 | ||
22 | #define QTOPIA_INTERNAL_CONTACT_MRE | 22 | #define QTOPIA_INTERNAL_CONTACT_MRE |
23 | 23 | ||
24 | #include "ocontact.h" | 24 | #include "ocontact.h" |
25 | #include "opimresolver.h" | ||
25 | 26 | ||
26 | #include <qpe/stringutil.h> | 27 | #include <qpe/stringutil.h> |
27 | #include <qpe/timeconversion.h> | 28 | #include <qpe/timeconversion.h> |
28 | #include <qpe/timestring.h> | 29 | #include <qpe/timestring.h> |
29 | 30 | ||
30 | #include <qobject.h> | 31 | #include <qobject.h> |
31 | #include <qregexp.h> | 32 | #include <qregexp.h> |
32 | #include <qstylesheet.h> | 33 | #include <qstylesheet.h> |
33 | #include <qfileinfo.h> | 34 | #include <qfileinfo.h> |
34 | #include <qmap.h> | 35 | #include <qmap.h> |
35 | 36 | ||
36 | #include <stdio.h> | 37 | #include <stdio.h> |
37 | 38 | ||
38 | /*! | 39 | /*! |
39 | \class Contact contact.h | 40 | \class Contact contact.h |
40 | \brief The Contact class holds the data of an address book entry. | 41 | \brief The Contact class holds the data of an address book entry. |
41 | 42 | ||
42 | This data includes information the name of the person, contact | 43 | This data includes information the name of the person, contact |
43 | information, and business information such as deparment and job title. | 44 | information, and business information such as deparment and job title. |
44 | 45 | ||
45 | \ingroup qtopiaemb | 46 | \ingroup qtopiaemb |
46 | \ingroup qtopiadesktop | 47 | \ingroup qtopiadesktop |
47 | */ | 48 | */ |
48 | 49 | ||
49 | 50 | ||
50 | /*! | 51 | /*! |
51 | Creates a new, empty contact. | 52 | Creates a new, empty contact. |
52 | */ | 53 | */ |
53 | OContact::OContact() | 54 | OContact::OContact() |
54 | : OPimRecord(), mMap(), d( 0 ) | 55 | : OPimRecord(), mMap(), d( 0 ) |
55 | { | 56 | { |
56 | } | 57 | } |
57 | 58 | ||
58 | /*! | 59 | /*! |
59 | \internal | 60 | \internal |
60 | Creates a new contact. The properties of the contact are | 61 | Creates a new contact. The properties of the contact are |
61 | set from \a fromMap. | 62 | set from \a fromMap. |
62 | */ | 63 | */ |
63 | OContact::OContact( const QMap<int, QString> &fromMap ) : | 64 | OContact::OContact( const QMap<int, QString> &fromMap ) : |
64 | OPimRecord(), mMap( fromMap ), d( 0 ) | 65 | OPimRecord(), mMap( fromMap ), d( 0 ) |
65 | { | 66 | { |
66 | QString cats = mMap[ Qtopia::AddressCategory ]; | 67 | QString cats = mMap[ Qtopia::AddressCategory ]; |
67 | if ( !cats.isEmpty() ) | 68 | if ( !cats.isEmpty() ) |
68 | setCategories( idsFromString( cats ) ); | 69 | setCategories( idsFromString( cats ) ); |
69 | 70 | ||
70 | QString uidStr = find( Qtopia::AddressUid ); | 71 | QString uidStr = find( Qtopia::AddressUid ); |
71 | 72 | ||
72 | if ( uidStr.isEmpty() || (uidStr.toInt() == 0) ){ | 73 | if ( uidStr.isEmpty() || (uidStr.toInt() == 0) ){ |
@@ -784,97 +785,97 @@ void OContact::setFileAs() | |||
784 | middleName = find( Qtopia::MiddleName ); | 785 | middleName = find( Qtopia::MiddleName ); |
785 | if ( !lastName.isEmpty() && !firstName.isEmpty() | 786 | if ( !lastName.isEmpty() && !firstName.isEmpty() |
786 | && !middleName.isEmpty() ) | 787 | && !middleName.isEmpty() ) |
787 | fileas = lastName + ", " + firstName + " " + middleName; | 788 | fileas = lastName + ", " + firstName + " " + middleName; |
788 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) | 789 | else if ( !lastName.isEmpty() && !firstName.isEmpty() ) |
789 | fileas = lastName + ", " + firstName; | 790 | fileas = lastName + ", " + firstName; |
790 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || | 791 | else if ( !lastName.isEmpty() || !firstName.isEmpty() || |
791 | !middleName.isEmpty() ) | 792 | !middleName.isEmpty() ) |
792 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) | 793 | fileas = firstName + ( firstName.isEmpty() ? "" : " " ) |
793 | + middleName + ( middleName.isEmpty() ? "" : " " ) | 794 | + middleName + ( middleName.isEmpty() ? "" : " " ) |
794 | + lastName; | 795 | + lastName; |
795 | 796 | ||
796 | replace( Qtopia::FileAs, fileas ); | 797 | replace( Qtopia::FileAs, fileas ); |
797 | } | 798 | } |
798 | 799 | ||
799 | /*! | 800 | /*! |
800 | \internal | 801 | \internal |
801 | Appends the contact information to \a buf. | 802 | Appends the contact information to \a buf. |
802 | */ | 803 | */ |
803 | void OContact::save( QString &buf ) const | 804 | void OContact::save( QString &buf ) const |
804 | { | 805 | { |
805 | static const QStringList SLFIELDS = fields(); | 806 | static const QStringList SLFIELDS = fields(); |
806 | // I'm expecting "<Contact " in front of this... | 807 | // I'm expecting "<Contact " in front of this... |
807 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); | 808 | for ( QMap<int, QString>::ConstIterator it = mMap.begin(); |
808 | it != mMap.end(); ++it ) { | 809 | it != mMap.end(); ++it ) { |
809 | const QString &value = it.data(); | 810 | const QString &value = it.data(); |
810 | int key = it.key(); | 811 | int key = it.key(); |
811 | if ( !value.isEmpty() ) { | 812 | if ( !value.isEmpty() ) { |
812 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) | 813 | if ( key == Qtopia::AddressCategory || key == Qtopia::AddressUid) |
813 | continue; | 814 | continue; |
814 | 815 | ||
815 | key -= Qtopia::AddressCategory+1; | 816 | key -= Qtopia::AddressCategory+1; |
816 | buf += SLFIELDS[key]; | 817 | buf += SLFIELDS[key]; |
817 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; | 818 | buf += "=\"" + Qtopia::escapeString(value) + "\" "; |
818 | } | 819 | } |
819 | } | 820 | } |
820 | buf += customToXml(); | 821 | buf += customToXml(); |
821 | if ( categories().count() > 0 ) | 822 | if ( categories().count() > 0 ) |
822 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; | 823 | buf += "Categories=\"" + idsToString( categories() ) + "\" "; |
823 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; | 824 | buf += "Uid=\"" + QString::number( uid() ) + "\" "; |
824 | // You need to close this yourself | 825 | // You need to close this yourself |
825 | } | 826 | } |
826 | 827 | ||
827 | 828 | ||
828 | /*! | 829 | /*! |
829 | \internal | 830 | \internal |
830 | Returns the list of fields belonging to a contact | 831 | Returns the list of fields belonging to a contact |
831 | Never change order of this list ! It has to be regarding | 832 | Never change order of this list ! It has to be regarding |
832 | enum AddressBookFields !! | 833 | enum AddressBookFields !! |
833 | */ | 834 | */ |
834 | QStringList OContact::fields() | 835 | QStringList OContact::fields() |
835 | { | 836 | { |
836 | QStringList list; | 837 | QStringList list; |
837 | 838 | ||
838 | list.append( "Title" ); // Not Used! | 839 | list.append( "Title" ); // Not Used! |
839 | list.append( "FirstName" ); | 840 | list.append( "FirstName" ); |
840 | list.append( "MiddleName" ); | 841 | list.append( "MiddleName" ); |
841 | list.append( "LastName" ); | 842 | list.append( "LastName" ); |
842 | list.append( "Suffix" ); | 843 | list.append( "Suffix" ); |
843 | list.append( "FileAs" ); | 844 | list.append( "FileAs" ); |
844 | 845 | ||
845 | list.append( "JobTitle" ); | 846 | list.append( "JobTitle" ); |
846 | list.append( "Department" ); | 847 | list.append( "Department" ); |
847 | list.append( "Company" ); | 848 | list.append( "Company" ); |
848 | list.append( "BusinessPhone" ); | 849 | list.append( "BusinessPhone" ); |
849 | list.append( "BusinessFax" ); | 850 | list.append( "BusinessFax" ); |
850 | list.append( "BusinessMobile" ); | 851 | list.append( "BusinessMobile" ); |
851 | 852 | ||
852 | list.append( "DefaultEmail" ); | 853 | list.append( "DefaultEmail" ); |
853 | list.append( "Emails" ); | 854 | list.append( "Emails" ); |
854 | 855 | ||
855 | list.append( "HomePhone" ); | 856 | list.append( "HomePhone" ); |
856 | list.append( "HomeFax" ); | 857 | list.append( "HomeFax" ); |
857 | list.append( "HomeMobile" ); | 858 | list.append( "HomeMobile" ); |
858 | 859 | ||
859 | list.append( "BusinessStreet" ); | 860 | list.append( "BusinessStreet" ); |
860 | list.append( "BusinessCity" ); | 861 | list.append( "BusinessCity" ); |
861 | list.append( "BusinessState" ); | 862 | list.append( "BusinessState" ); |
862 | list.append( "BusinessZip" ); | 863 | list.append( "BusinessZip" ); |
863 | list.append( "BusinessCountry" ); | 864 | list.append( "BusinessCountry" ); |
864 | list.append( "BusinessPager" ); | 865 | list.append( "BusinessPager" ); |
865 | list.append( "BusinessWebPage" ); | 866 | list.append( "BusinessWebPage" ); |
866 | 867 | ||
867 | list.append( "Office" ); | 868 | list.append( "Office" ); |
868 | list.append( "Profession" ); | 869 | list.append( "Profession" ); |
869 | list.append( "Assistant" ); | 870 | list.append( "Assistant" ); |
870 | list.append( "Manager" ); | 871 | list.append( "Manager" ); |
871 | 872 | ||
872 | list.append( "HomeStreet" ); | 873 | list.append( "HomeStreet" ); |
873 | list.append( "HomeCity" ); | 874 | list.append( "HomeCity" ); |
874 | list.append( "HomeState" ); | 875 | list.append( "HomeState" ); |
875 | list.append( "HomeZip" ); | 876 | list.append( "HomeZip" ); |
876 | list.append( "HomeCountry" ); | 877 | list.append( "HomeCountry" ); |
877 | list.append( "HomeWebPage" ); | 878 | list.append( "HomeWebPage" ); |
878 | 879 | ||
879 | list.append( "Spouse" ); | 880 | list.append( "Spouse" ); |
880 | list.append( "Gender" ); | 881 | list.append( "Gender" ); |
@@ -1055,55 +1056,55 @@ void OContact::removeEmail( const QString &v ) | |||
1055 | QString e = v.simplifyWhiteSpace(); | 1056 | QString e = v.simplifyWhiteSpace(); |
1056 | QString def = defaultEmail(); | 1057 | QString def = defaultEmail(); |
1057 | QString emailsStr = find( Qtopia::Emails ); | 1058 | QString emailsStr = find( Qtopia::Emails ); |
1058 | QStringList emails = emailList(); | 1059 | QStringList emails = emailList(); |
1059 | 1060 | ||
1060 | // otherwise, must first contain it | 1061 | // otherwise, must first contain it |
1061 | if ( !emailsStr.contains( e ) ) | 1062 | if ( !emailsStr.contains( e ) ) |
1062 | return; | 1063 | return; |
1063 | 1064 | ||
1064 | // remove it | 1065 | // remove it |
1065 | //qDebug(" removing email from list %s", e.latin1()); | 1066 | //qDebug(" removing email from list %s", e.latin1()); |
1066 | emails.remove( e ); | 1067 | emails.remove( e ); |
1067 | // reset the string | 1068 | // reset the string |
1068 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator | 1069 | emailsStr = emails.join(emailSeparator()); // Sharp's brain dead separator |
1069 | replace( Qtopia::Emails, emailsStr ); | 1070 | replace( Qtopia::Emails, emailsStr ); |
1070 | 1071 | ||
1071 | // if default, then replace the default email with the first one | 1072 | // if default, then replace the default email with the first one |
1072 | if ( def == e ) { | 1073 | if ( def == e ) { |
1073 | //qDebug("removeEmail is default; setting new default"); | 1074 | //qDebug("removeEmail is default; setting new default"); |
1074 | if ( !emails.count() ) | 1075 | if ( !emails.count() ) |
1075 | clearEmails(); | 1076 | clearEmails(); |
1076 | else // setDefaultEmail will remove e from the list | 1077 | else // setDefaultEmail will remove e from the list |
1077 | setDefaultEmail( emails.first() ); | 1078 | setDefaultEmail( emails.first() ); |
1078 | } | 1079 | } |
1079 | } | 1080 | } |
1080 | void OContact::clearEmails() | 1081 | void OContact::clearEmails() |
1081 | { | 1082 | { |
1082 | mMap.remove( Qtopia::DefaultEmail ); | 1083 | mMap.remove( Qtopia::DefaultEmail ); |
1083 | mMap.remove( Qtopia::Emails ); | 1084 | mMap.remove( Qtopia::Emails ); |
1084 | } | 1085 | } |
1085 | void OContact::setDefaultEmail( const QString &v ) | 1086 | void OContact::setDefaultEmail( const QString &v ) |
1086 | { | 1087 | { |
1087 | QString e = v.simplifyWhiteSpace(); | 1088 | QString e = v.simplifyWhiteSpace(); |
1088 | 1089 | ||
1089 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); | 1090 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); |
1090 | replace( Qtopia::DefaultEmail, e ); | 1091 | replace( Qtopia::DefaultEmail, e ); |
1091 | 1092 | ||
1092 | if ( !e.isEmpty() ) | 1093 | if ( !e.isEmpty() ) |
1093 | insertEmail( e ); | 1094 | insertEmail( e ); |
1094 | 1095 | ||
1095 | } | 1096 | } |
1096 | 1097 | ||
1097 | void OContact::insertEmails( const QStringList &v ) | 1098 | void OContact::insertEmails( const QStringList &v ) |
1098 | { | 1099 | { |
1099 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) | 1100 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) |
1100 | insertEmail( *it ); | 1101 | insertEmail( *it ); |
1101 | } | 1102 | } |
1102 | int OContact::rtti() { | 1103 | int OContact::rtti() { |
1103 | return 2; | 1104 | return OPimResolver::AddressBook; |
1104 | } | 1105 | } |
1105 | void OContact::setUid( int i ) | 1106 | void OContact::setUid( int i ) |
1106 | { | 1107 | { |
1107 | OPimRecord::setUid(i); | 1108 | OPimRecord::setUid(i); |
1108 | replace( Qtopia::AddressUid , QString::number(i)); | 1109 | replace( Qtopia::AddressUid , QString::number(i)); |
1109 | } | 1110 | } |
diff --git a/libopie/pim/opimaccessbackend.h b/libopie/pim/opimaccessbackend.h index 4f00bc9..e268f4f 100644 --- a/libopie/pim/opimaccessbackend.h +++ b/libopie/pim/opimaccessbackend.h | |||
@@ -1,141 +1,153 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_BACKEND | 1 | #ifndef OPIE_PIM_ACCESS_BACKEND |
2 | #define OPIE_PIM_ACCESS_BACKEND | 2 | #define OPIE_PIM_ACCESS_BACKEND |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/otemplatebase.h> | 6 | #include <opie/otemplatebase.h> |
7 | #include <opie/opimrecord.h> | 7 | #include <opie/opimrecord.h> |
8 | 8 | ||
9 | 9 | ||
10 | /** | 10 | /** |
11 | * OPimAccessBackend is the base class | 11 | * OPimAccessBackend is the base class |
12 | * for all private backends | 12 | * for all private backends |
13 | * it operates on OPimRecord as the base class | 13 | * it operates on OPimRecord as the base class |
14 | * and it's responsible for fast manipulating | 14 | * and it's responsible for fast manipulating |
15 | * the resource the implementation takes care | 15 | * the resource the implementation takes care |
16 | * of | 16 | * of |
17 | */ | 17 | */ |
18 | template <class T = OPimRecord> | 18 | template <class T = OPimRecord> |
19 | class OPimAccessBackend { | 19 | class OPimAccessBackend { |
20 | public: | 20 | public: |
21 | typedef OTemplateBase<T> Frontend; | 21 | typedef OTemplateBase<T> Frontend; |
22 | OPimAccessBackend(); | 22 | |
23 | /** The access hint from the frontend */ | ||
24 | OPimAccessBackend(int access = 0); | ||
23 | virtual ~OPimAccessBackend(); | 25 | virtual ~OPimAccessBackend(); |
24 | 26 | ||
25 | /** | 27 | /** |
26 | * load the resource | 28 | * load the resource |
27 | */ | 29 | */ |
28 | virtual bool load() = 0; | 30 | virtual bool load() = 0; |
29 | 31 | ||
30 | /** | 32 | /** |
31 | * reload the resource | 33 | * reload the resource |
32 | */ | 34 | */ |
33 | virtual bool reload() = 0; | 35 | virtual bool reload() = 0; |
34 | 36 | ||
35 | /** | 37 | /** |
36 | * save the resource and | 38 | * save the resource and |
37 | * all it's changes | 39 | * all it's changes |
38 | */ | 40 | */ |
39 | virtual bool save() = 0; | 41 | virtual bool save() = 0; |
40 | 42 | ||
41 | /** | 43 | /** |
42 | * return an array of | 44 | * return an array of |
43 | * all available uids | 45 | * all available uids |
44 | */ | 46 | */ |
45 | virtual QArray<int> allRecords()const = 0; | 47 | virtual QArray<int> allRecords()const = 0; |
46 | 48 | ||
47 | /** | 49 | /** |
48 | * queryByExample for T with the SortOrder | 50 | * queryByExample for T with the SortOrder |
49 | * sort | 51 | * sort |
50 | */ | 52 | */ |
51 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; | 53 | virtual QArray<int> queryByExample( const T& t, int sort ) = 0; |
52 | 54 | ||
53 | /** | 55 | /** |
54 | * find the OPimRecord with uid @param uid | 56 | * find the OPimRecord with uid @param uid |
55 | * returns T and T.isEmpty() if nothing was found | 57 | * returns T and T.isEmpty() if nothing was found |
56 | */ | 58 | */ |
57 | virtual T find(int uid )const = 0; | 59 | virtual T find(int uid )const = 0; |
58 | 60 | ||
59 | virtual T find(int uid, const QArray<int>& items, | 61 | virtual T find(int uid, const QArray<int>& items, |
60 | uint current, typename Frontend::CacheDirection )const ; | 62 | uint current, typename Frontend::CacheDirection )const ; |
61 | /** | 63 | /** |
62 | * clear the back end | 64 | * clear the back end |
63 | */ | 65 | */ |
64 | virtual void clear() = 0; | 66 | virtual void clear() = 0; |
65 | 67 | ||
66 | /** | 68 | /** |
67 | * add T | 69 | * add T |
68 | */ | 70 | */ |
69 | virtual bool add( const T& t ) = 0; | 71 | virtual bool add( const T& t ) = 0; |
70 | 72 | ||
71 | /** | 73 | /** |
72 | * remove | 74 | * remove |
73 | */ | 75 | */ |
74 | virtual bool remove( int uid ) = 0; | 76 | virtual bool remove( int uid ) = 0; |
75 | 77 | ||
76 | /** | 78 | /** |
77 | * replace a record with T.uid() | 79 | * replace a record with T.uid() |
78 | */ | 80 | */ |
79 | virtual bool replace( const T& t ) = 0; | 81 | virtual bool replace( const T& t ) = 0; |
80 | 82 | ||
81 | /* | 83 | /* |
82 | * setTheFrontEnd!!! | 84 | * setTheFrontEnd!!! |
83 | */ | 85 | */ |
84 | void setFrontend( Frontend* front ); | 86 | void setFrontend( Frontend* front ); |
85 | 87 | ||
86 | /** | 88 | /** |
87 | * set the read ahead count | 89 | * set the read ahead count |
88 | */ | 90 | */ |
89 | void setReadAhead( uint count ); | 91 | void setReadAhead( uint count ); |
90 | protected: | 92 | protected: |
93 | int access()const; | ||
91 | void cache( const T& t )const; | 94 | void cache( const T& t )const; |
92 | 95 | ||
93 | /** | 96 | /** |
94 | * use a prime number here! | 97 | * use a prime number here! |
95 | */ | 98 | */ |
96 | void setSaneCacheSize( int ); | 99 | void setSaneCacheSize( int ); |
97 | 100 | ||
98 | uint readAhead()const; | 101 | uint readAhead()const; |
99 | 102 | ||
100 | private: | 103 | private: |
104 | class Private; | ||
105 | Private* d; | ||
101 | Frontend* m_front; | 106 | Frontend* m_front; |
102 | uint m_read; | 107 | uint m_read; |
108 | int m_acc; | ||
103 | 109 | ||
104 | }; | 110 | }; |
105 | 111 | ||
106 | template <class T> | 112 | template <class T> |
107 | OPimAccessBackend<T>::OPimAccessBackend() { | 113 | OPimAccessBackend<T>::OPimAccessBackend(int acc) |
114 | : m_acc( acc ) | ||
115 | { | ||
108 | m_front = 0l; | 116 | m_front = 0l; |
109 | } | 117 | } |
110 | template <class T> | 118 | template <class T> |
111 | OPimAccessBackend<T>::~OPimAccessBackend() { | 119 | OPimAccessBackend<T>::~OPimAccessBackend() { |
112 | 120 | ||
113 | } | 121 | } |
114 | template <class T> | 122 | template <class T> |
115 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { | 123 | void OPimAccessBackend<T>::setFrontend( Frontend* fr ) { |
116 | m_front = fr; | 124 | m_front = fr; |
117 | } | 125 | } |
118 | template <class T> | 126 | template <class T> |
119 | void OPimAccessBackend<T>::cache( const T& t )const { | 127 | void OPimAccessBackend<T>::cache( const T& t )const { |
120 | if (m_front ) | 128 | if (m_front ) |
121 | m_front->cache( t ); | 129 | m_front->cache( t ); |
122 | } | 130 | } |
123 | template <class T> | 131 | template <class T> |
124 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { | 132 | void OPimAccessBackend<T>::setSaneCacheSize( int size) { |
125 | if (m_front ) | 133 | if (m_front ) |
126 | m_front->setSaneCacheSize( size ); | 134 | m_front->setSaneCacheSize( size ); |
127 | } | 135 | } |
128 | template <class T> | 136 | template <class T> |
129 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, | 137 | T OPimAccessBackend<T>::find( int uid, const QArray<int>&, |
130 | uint, typename Frontend::CacheDirection )const { | 138 | uint, typename Frontend::CacheDirection )const { |
131 | return find( uid ); | 139 | return find( uid ); |
132 | } | 140 | } |
133 | template <class T> | 141 | template <class T> |
134 | void OPimAccessBackend<T>::setReadAhead( uint count ) { | 142 | void OPimAccessBackend<T>::setReadAhead( uint count ) { |
135 | m_read = count; | 143 | m_read = count; |
136 | } | 144 | } |
137 | template <class T> | 145 | template <class T> |
138 | uint OPimAccessBackend<T>::readAhead()const { | 146 | uint OPimAccessBackend<T>::readAhead()const { |
139 | return m_read; | 147 | return m_read; |
140 | } | 148 | } |
149 | template <class T> | ||
150 | int OPimAccessBackend<T>::access()const { | ||
151 | return m_acc; | ||
152 | } | ||
141 | #endif | 153 | #endif |
diff --git a/libopie/pim/opimaccesstemplate.h b/libopie/pim/opimaccesstemplate.h index 8cf81c8..259e2c1 100644 --- a/libopie/pim/opimaccesstemplate.h +++ b/libopie/pim/opimaccesstemplate.h | |||
@@ -1,269 +1,286 @@ | |||
1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H | 1 | #ifndef OPIE_PIM_ACCESS_TEMPLATE_H |
2 | #define OPIE_PIM_ACCESS_TEMPLATE_H | 2 | #define OPIE_PIM_ACCESS_TEMPLATE_H |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include <opie/opimrecord.h> | 6 | #include <opie/opimrecord.h> |
7 | #include <opie/opimaccessbackend.h> | 7 | #include <opie/opimaccessbackend.h> |
8 | #include <opie/orecordlist.h> | 8 | #include <opie/orecordlist.h> |
9 | 9 | ||
10 | #include "opimcache.h" | 10 | #include "opimcache.h" |
11 | #include "otemplatebase.h" | 11 | #include "otemplatebase.h" |
12 | 12 | ||
13 | /** | 13 | /** |
14 | * Thats the frontend to our OPIE PIM | 14 | * Thats the frontend to our OPIE PIM |
15 | * Library. Either you want to use it's | 15 | * Library. Either you want to use it's |
16 | * interface or you want to implement | 16 | * interface or you want to implement |
17 | * your own Access lib | 17 | * your own Access lib |
18 | * Just create a OPimRecord and inherit from | 18 | * Just create a OPimRecord and inherit from |
19 | * the plugins | 19 | * the plugins |
20 | */ | 20 | */ |
21 | 21 | ||
22 | template <class T = OPimRecord > | 22 | template <class T = OPimRecord > |
23 | class OPimAccessTemplate : public OTemplateBase<T> { | 23 | class OPimAccessTemplate : public OTemplateBase<T> { |
24 | public: | 24 | public: |
25 | enum Access { | ||
26 | Random = 0, | ||
27 | SortedAccess | ||
28 | }; | ||
25 | typedef ORecordList<T> List; | 29 | typedef ORecordList<T> List; |
26 | typedef OPimAccessBackend<T> BackEnd; | 30 | typedef OPimAccessBackend<T> BackEnd; |
27 | typedef OPimCache<T> Cache; | 31 | typedef OPimCache<T> Cache; |
28 | 32 | ||
29 | /** | 33 | /** |
30 | * c'tor BackEnd | 34 | * c'tor BackEnd |
35 | * enum Access a small hint on how to handle the backend | ||
31 | */ | 36 | */ |
32 | OPimAccessTemplate( BackEnd* end); | 37 | OPimAccessTemplate( BackEnd* end); |
38 | |||
33 | virtual ~OPimAccessTemplate(); | 39 | virtual ~OPimAccessTemplate(); |
34 | 40 | ||
35 | /** | 41 | /** |
36 | * load from the backend | 42 | * load from the backend |
37 | */ | 43 | */ |
38 | virtual bool load(); | 44 | bool load(); |
39 | 45 | ||
40 | /** Reload database. | 46 | /** Reload database. |
41 | * You should execute this function if the external database | 47 | * You should execute this function if the external database |
42 | * was changed. | 48 | * was changed. |
43 | * This function will load the external database and afterwards | 49 | * This function will load the external database and afterwards |
44 | * rejoin the local changes. Therefore the local database will be set consistent. | 50 | * rejoin the local changes. Therefore the local database will be set consistent. |
45 | */ | 51 | */ |
46 | virtual bool reload(); | 52 | virtual bool reload(); |
47 | 53 | ||
48 | /** Save contacts database. | 54 | /** Save contacts database. |
49 | * Save is more a "commit". After calling this function, all changes are public available. | 55 | * Save is more a "commit". After calling this function, all changes are public available. |
50 | * @return true if successful | 56 | * @return true if successful |
51 | */ | 57 | */ |
52 | virtual bool save(); | 58 | bool save(); |
53 | 59 | ||
54 | /** | 60 | /** |
55 | * if the resource was changed externally | 61 | * if the resource was changed externally |
56 | * You should use the signal handling instead of polling possible changes ! | 62 | * You should use the signal handling instead of polling possible changes ! |
57 | * zecke: Do you implement a signal for otodoaccess ? | 63 | * zecke: Do you implement a signal for otodoaccess ? |
58 | */ | 64 | */ |
59 | bool wasChangedExternally()const; | 65 | bool wasChangedExternally()const; |
60 | 66 | ||
61 | /** | 67 | /** |
62 | * return a List of records | 68 | * return a List of records |
63 | * you can iterate over them | 69 | * you can iterate over them |
64 | */ | 70 | */ |
65 | virtual List allRecords()const; | 71 | virtual List allRecords()const; |
66 | 72 | ||
67 | /** | 73 | /** |
68 | * queryByExample. | 74 | * queryByExample. |
69 | * @see otodoaccess, ocontactaccess | 75 | * @see otodoaccess, ocontactaccess |
70 | */ | 76 | */ |
71 | virtual List queryByExample( const T& t, int querySettings ); | 77 | virtual List queryByExample( const T& t, int querySettings ); |
72 | 78 | ||
73 | /** | 79 | /** |
74 | * find the OPimRecord uid | 80 | * find the OPimRecord uid |
75 | */ | 81 | */ |
76 | virtual T find( int uid )const; | 82 | virtual T find( int uid )const; |
77 | 83 | ||
78 | /** | 84 | /** |
79 | * read ahead cache find method ;) | 85 | * read ahead cache find method ;) |
80 | */ | 86 | */ |
81 | virtual T find( int uid, const QArray<int>&, | 87 | virtual T find( int uid, const QArray<int>&, |
82 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; | 88 | uint current, typename OTemplateBase<T>::CacheDirection dir = OTemplateBase<T>::Forward )const; |
83 | 89 | ||
84 | /* invalidate cache here */ | 90 | /* invalidate cache here */ |
85 | /** | 91 | /** |
86 | * clears the backend and invalidates the backend | 92 | * clears the backend and invalidates the backend |
87 | */ | 93 | */ |
88 | virtual void clear() ; | 94 | void clear() ; |
89 | 95 | ||
90 | /** | 96 | /** |
91 | * add T to the backend | 97 | * add T to the backend |
92 | * @param t The item to add. | 98 | * @param t The item to add. |
93 | * @return <i>true</i> if added successfully. | 99 | * @return <i>true</i> if added successfully. |
94 | */ | 100 | */ |
95 | virtual bool add( const T& t ) ; | 101 | virtual bool add( const T& t ) ; |
96 | bool add( const OPimRecord& ); | 102 | bool add( const OPimRecord& ); |
97 | 103 | ||
98 | /* only the uid matters */ | 104 | /* only the uid matters */ |
99 | /** | 105 | /** |
100 | * remove T from the backend | 106 | * remove T from the backend |
101 | * @param t The item to remove | 107 | * @param t The item to remove |
102 | * @return <i>true</i> if successful. | 108 | * @return <i>true</i> if successful. |
103 | */ | 109 | */ |
104 | virtual bool remove( const T& t ); | 110 | virtual bool remove( const T& t ); |
105 | 111 | ||
106 | /** | 112 | /** |
107 | * remove the OPimRecord with uid | 113 | * remove the OPimRecord with uid |
108 | * @param uid The ID of the item to remove | 114 | * @param uid The ID of the item to remove |
109 | * @return <i>true</i> if successful. | 115 | * @return <i>true</i> if successful. |
110 | */ | 116 | */ |
111 | virtual bool remove( int uid ); | 117 | bool remove( int uid ); |
118 | bool remove( const OPimRecord& ); | ||
112 | 119 | ||
113 | /** | 120 | /** |
114 | * replace T from backend | 121 | * replace T from backend |
115 | * @param t The item to replace | 122 | * @param t The item to replace |
116 | * @return <i>true</i> if successful. | 123 | * @return <i>true</i> if successful. |
117 | */ | 124 | */ |
118 | virtual bool replace( const T& t) ; | 125 | virtual bool replace( const T& t) ; |
119 | 126 | ||
120 | void setReadAhead( uint count ); | 127 | void setReadAhead( uint count ); |
121 | /** | 128 | /** |
122 | * @internal | 129 | * @internal |
123 | */ | 130 | */ |
124 | void cache( const T& )const; | 131 | void cache( const T& )const; |
125 | void setSaneCacheSize( int ); | 132 | void setSaneCacheSize( int ); |
133 | |||
134 | QArray<int> records()const; | ||
126 | protected: | 135 | protected: |
127 | /** | 136 | /** |
128 | * invalidate the cache | 137 | * invalidate the cache |
129 | */ | 138 | */ |
130 | void invalidateCache(); | 139 | void invalidateCache(); |
131 | 140 | ||
132 | void setBackEnd( BackEnd* end ); | 141 | void setBackEnd( BackEnd* end ); |
133 | /** | 142 | /** |
134 | * returns the backend | 143 | * returns the backend |
135 | */ | 144 | */ |
136 | BackEnd* backEnd(); | 145 | BackEnd* backEnd(); |
137 | BackEnd* m_backEnd; | 146 | BackEnd* m_backEnd; |
138 | Cache m_cache; | 147 | Cache m_cache; |
139 | 148 | ||
140 | }; | 149 | }; |
141 | 150 | ||
142 | template <class T> | 151 | template <class T> |
143 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) | 152 | OPimAccessTemplate<T>::OPimAccessTemplate( BackEnd* end ) |
144 | : OTemplateBase<T>(), m_backEnd( end ) | 153 | : OTemplateBase<T>(), m_backEnd( end ) |
145 | { | 154 | { |
146 | if (end ) | 155 | if (end ) |
147 | end->setFrontend( this ); | 156 | end->setFrontend( this ); |
148 | } | 157 | } |
149 | template <class T> | 158 | template <class T> |
150 | OPimAccessTemplate<T>::~OPimAccessTemplate() { | 159 | OPimAccessTemplate<T>::~OPimAccessTemplate() { |
151 | qWarning("~OPimAccessTemplate<T>"); | 160 | qWarning("~OPimAccessTemplate<T>"); |
152 | delete m_backEnd; | 161 | delete m_backEnd; |
153 | } | 162 | } |
154 | template <class T> | 163 | template <class T> |
155 | bool OPimAccessTemplate<T>::load() { | 164 | bool OPimAccessTemplate<T>::load() { |
156 | invalidateCache(); | 165 | invalidateCache(); |
157 | return m_backEnd->load(); | 166 | return m_backEnd->load(); |
158 | } | 167 | } |
159 | template <class T> | 168 | template <class T> |
160 | bool OPimAccessTemplate<T>::reload() { | 169 | bool OPimAccessTemplate<T>::reload() { |
161 | invalidateCache(); // zecke: I think this should be added (se) | 170 | invalidateCache(); // zecke: I think this should be added (se) |
162 | return m_backEnd->reload(); | 171 | return m_backEnd->reload(); |
163 | } | 172 | } |
164 | template <class T> | 173 | template <class T> |
165 | bool OPimAccessTemplate<T>::save() { | 174 | bool OPimAccessTemplate<T>::save() { |
166 | return m_backEnd->save(); | 175 | return m_backEnd->save(); |
167 | } | 176 | } |
168 | template <class T> | 177 | template <class T> |
169 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { | 178 | typename OPimAccessTemplate<T>::List OPimAccessTemplate<T>::allRecords()const { |
170 | QArray<int> ints = m_backEnd->allRecords(); | 179 | QArray<int> ints = m_backEnd->allRecords(); |
171 | List lis(ints, this ); | 180 | List lis(ints, this ); |
172 | return lis; | 181 | return lis; |
173 | } | 182 | } |
174 | template <class T> | 183 | template <class T> |
184 | QArray<int> OPimAccessTemplate<T>::records()const { | ||
185 | return m_backEnd->allRecords(); | ||
186 | } | ||
187 | template <class T> | ||
175 | typename OPimAccessTemplate<T>::List | 188 | typename OPimAccessTemplate<T>::List |
176 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { | 189 | OPimAccessTemplate<T>::queryByExample( const T& t, int sortOrder ) { |
177 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); | 190 | QArray<int> ints = m_backEnd->queryByExample( t, sortOrder ); |
178 | 191 | ||
179 | List lis(ints, this ); | 192 | List lis(ints, this ); |
180 | return lis; | 193 | return lis; |
181 | } | 194 | } |
182 | template <class T> | 195 | template <class T> |
183 | T OPimAccessTemplate<T>::find( int uid ) const{ | 196 | T OPimAccessTemplate<T>::find( int uid ) const{ |
184 | T t = m_backEnd->find( uid ); | 197 | T t = m_backEnd->find( uid ); |
185 | cache( t ); | 198 | cache( t ); |
186 | return t; | 199 | return t; |
187 | } | 200 | } |
188 | template <class T> | 201 | template <class T> |
189 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, | 202 | T OPimAccessTemplate<T>::find( int uid, const QArray<int>& ar, |
190 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { | 203 | uint current, typename OTemplateBase<T>::CacheDirection dir )const { |
191 | /* | 204 | /* |
192 | * better do T.isEmpty() | 205 | * better do T.isEmpty() |
193 | * after a find this way we would | 206 | * after a find this way we would |
194 | * avoid two finds in QCache... | 207 | * avoid two finds in QCache... |
195 | */ | 208 | */ |
196 | // qWarning("find it now %d", uid ); | 209 | // qWarning("find it now %d", uid ); |
197 | if (m_cache.contains( uid ) ) { | 210 | if (m_cache.contains( uid ) ) { |
198 | return m_cache.find( uid ); | 211 | return m_cache.find( uid ); |
199 | } | 212 | } |
200 | 213 | ||
201 | T t = m_backEnd->find( uid, ar, current, dir ); | 214 | T t = m_backEnd->find( uid, ar, current, dir ); |
202 | cache( t ); | 215 | cache( t ); |
203 | return t; | 216 | return t; |
204 | } | 217 | } |
205 | template <class T> | 218 | template <class T> |
206 | void OPimAccessTemplate<T>::clear() { | 219 | void OPimAccessTemplate<T>::clear() { |
207 | invalidateCache(); | 220 | invalidateCache(); |
208 | m_backEnd->clear(); | 221 | m_backEnd->clear(); |
209 | } | 222 | } |
210 | template <class T> | 223 | template <class T> |
211 | bool OPimAccessTemplate<T>::add( const T& t ) { | 224 | bool OPimAccessTemplate<T>::add( const T& t ) { |
212 | cache( t ); | 225 | cache( t ); |
213 | return m_backEnd->add( t ); | 226 | return m_backEnd->add( t ); |
214 | } | 227 | } |
215 | template <class T> | 228 | template <class T> |
216 | bool OPimAccessTemplate<T>::add( const OPimRecord& rec) { | 229 | bool OPimAccessTemplate<T>::add( const OPimRecord& rec) { |
217 | /* same type */ | 230 | /* same type */ |
218 | if ( rec.rtti() == T::rtti() ) { | 231 | if ( rec.rtti() == T::rtti() ) { |
219 | const T &t = static_cast<const T&>(rec); | 232 | const T &t = static_cast<const T&>(rec); |
220 | return add(t); | 233 | return add(t); |
221 | } | 234 | } |
222 | return false; | 235 | return false; |
223 | } | 236 | } |
224 | template <class T> | 237 | template <class T> |
225 | bool OPimAccessTemplate<T>::remove( const T& t ) { | 238 | bool OPimAccessTemplate<T>::remove( const T& t ) { |
226 | return remove( t.uid() ); | 239 | return remove( t.uid() ); |
227 | } | 240 | } |
228 | template <class T> | 241 | template <class T> |
229 | bool OPimAccessTemplate<T>::remove( int uid ) { | 242 | bool OPimAccessTemplate<T>::remove( int uid ) { |
230 | m_cache.remove( uid ); | 243 | m_cache.remove( uid ); |
231 | return m_backEnd->remove( uid ); | 244 | return m_backEnd->remove( uid ); |
232 | } | 245 | } |
233 | template <class T> | 246 | template <class T> |
247 | bool OPimAccessTemplate<T>::remove( const OPimRecord& rec) { | ||
248 | return remove( rec.uid() ); | ||
249 | } | ||
250 | template <class T> | ||
234 | bool OPimAccessTemplate<T>::replace( const T& t ) { | 251 | bool OPimAccessTemplate<T>::replace( const T& t ) { |
235 | m_cache.replace( t ); | 252 | m_cache.replace( t ); |
236 | return m_backEnd->replace( t ); | 253 | return m_backEnd->replace( t ); |
237 | } | 254 | } |
238 | template <class T> | 255 | template <class T> |
239 | void OPimAccessTemplate<T>::invalidateCache() { | 256 | void OPimAccessTemplate<T>::invalidateCache() { |
240 | m_cache.invalidate(); | 257 | m_cache.invalidate(); |
241 | } | 258 | } |
242 | template <class T> | 259 | template <class T> |
243 | typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { | 260 | typename OPimAccessTemplate<T>::BackEnd* OPimAccessTemplate<T>::backEnd() { |
244 | return m_backEnd; | 261 | return m_backEnd; |
245 | } | 262 | } |
246 | template <class T> | 263 | template <class T> |
247 | bool OPimAccessTemplate<T>::wasChangedExternally()const { | 264 | bool OPimAccessTemplate<T>::wasChangedExternally()const { |
248 | return false; | 265 | return false; |
249 | } | 266 | } |
250 | template <class T> | 267 | template <class T> |
251 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { | 268 | void OPimAccessTemplate<T>::setBackEnd( BackEnd* end ) { |
252 | m_backEnd = end; | 269 | m_backEnd = end; |
253 | if (m_backEnd ) | 270 | if (m_backEnd ) |
254 | m_backEnd->setFrontend( this ); | 271 | m_backEnd->setFrontend( this ); |
255 | } | 272 | } |
256 | template <class T> | 273 | template <class T> |
257 | void OPimAccessTemplate<T>::cache( const T& t ) const{ | 274 | void OPimAccessTemplate<T>::cache( const T& t ) const{ |
258 | /* hacky we need to work around the const*/ | 275 | /* hacky we need to work around the const*/ |
259 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); | 276 | ((OPimAccessTemplate<T>*)this)->m_cache.add( t ); |
260 | } | 277 | } |
261 | template <class T> | 278 | template <class T> |
262 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { | 279 | void OPimAccessTemplate<T>::setSaneCacheSize( int size ) { |
263 | m_cache.setSize( size ); | 280 | m_cache.setSize( size ); |
264 | } | 281 | } |
265 | template <class T> | 282 | template <class T> |
266 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { | 283 | void OPimAccessTemplate<T>::setReadAhead( uint count ) { |
267 | m_backEnd->setReadAhead( count ); | 284 | m_backEnd->setReadAhead( count ); |
268 | } | 285 | } |
269 | #endif | 286 | #endif |
diff --git a/libopie/pim/opimcache.h b/libopie/pim/opimcache.h index 839550c..73414e5 100644 --- a/libopie/pim/opimcache.h +++ b/libopie/pim/opimcache.h | |||
@@ -1,79 +1,85 @@ | |||
1 | #ifndef OPIE_PIM_CACHE_H | 1 | #ifndef OPIE_PIM_CACHE_H |
2 | #define OPIE_PIM_CACHE_H | 2 | #define OPIE_PIM_CACHE_H |
3 | 3 | ||
4 | #include <qintcache.h> | 4 | #include <qintcache.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
7 | 7 | ||
8 | template <class T = OPimRecord> | 8 | template <class T = OPimRecord> |
9 | class OPimCacheItem { | 9 | class OPimCacheItem { |
10 | public: | 10 | public: |
11 | OPimCacheItem( const T& t = T() ); | 11 | OPimCacheItem( const T& t = T() ); |
12 | OPimCacheItem( const OPimCacheItem& ); | ||
12 | ~OPimCacheItem(); | 13 | ~OPimCacheItem(); |
13 | 14 | ||
15 | OPimCacheItem &operator=( const OPimCacheItem& ); | ||
16 | |||
14 | T record()const; | 17 | T record()const; |
15 | void setRecord( const T& ); | 18 | void setRecord( const T& ); |
16 | private: | 19 | private: |
17 | T m_t; | 20 | T m_t; |
18 | }; | 21 | }; |
19 | 22 | ||
20 | /** | 23 | /** |
21 | * OPimCache for caching the items | 24 | * OPimCache for caching the items |
22 | * We support adding, removing | 25 | * We support adding, removing |
23 | * and finding | 26 | * and finding |
24 | */ | 27 | */ |
25 | template <class T = OPimRecord> | 28 | template <class T = OPimRecord> |
26 | class OPimCache { | 29 | class OPimCache { |
27 | public: | 30 | public: |
28 | typedef OPimCacheItem<T> Item; | 31 | typedef OPimCacheItem<T> Item; |
29 | OPimCache(); | 32 | OPimCache(); |
33 | OPimCache( const OPimCache& ); | ||
30 | ~OPimCache(); | 34 | ~OPimCache(); |
31 | 35 | ||
36 | OPimCache &operator=( const OPimCache& ); | ||
37 | |||
32 | bool contains(int uid)const; | 38 | bool contains(int uid)const; |
33 | void invalidate(); | 39 | void invalidate(); |
34 | void setSize( int size ); | 40 | void setSize( int size ); |
35 | 41 | ||
36 | T find(int uid )const; | 42 | T find(int uid )const; |
37 | void add( const T& ); | 43 | void add( const T& ); |
38 | void remove( int uid ); | 44 | void remove( int uid ); |
39 | void replace( const T& ); | 45 | void replace( const T& ); |
40 | 46 | ||
41 | private: | 47 | private: |
42 | QIntCache<Item> m_cache; | 48 | QIntCache<Item> m_cache; |
43 | }; | 49 | }; |
44 | 50 | ||
45 | // Implementation | 51 | // Implementation |
46 | template <class T> | 52 | template <class T> |
47 | OPimCacheItem<T>::OPimCacheItem( const T& t ) | 53 | OPimCacheItem<T>::OPimCacheItem( const T& t ) |
48 | : m_t(t) { | 54 | : m_t(t) { |
49 | } | 55 | } |
50 | template <class T> | 56 | template <class T> |
51 | OPimCacheItem<T>::~OPimCacheItem() { | 57 | OPimCacheItem<T>::~OPimCacheItem() { |
52 | 58 | ||
53 | } | 59 | } |
54 | template <class T> | 60 | template <class T> |
55 | T OPimCacheItem<T>::record()const { | 61 | T OPimCacheItem<T>::record()const { |
56 | return m_t; | 62 | return m_t; |
57 | } | 63 | } |
58 | template <class T> | 64 | template <class T> |
59 | void OPimCacheItem<T>::setRecord( const T& t ) { | 65 | void OPimCacheItem<T>::setRecord( const T& t ) { |
60 | m_t = t; | 66 | m_t = t; |
61 | } | 67 | } |
62 | // Cache | 68 | // Cache |
63 | template <class T> | 69 | template <class T> |
64 | OPimCache<T>::OPimCache() | 70 | OPimCache<T>::OPimCache() |
65 | : m_cache(100, 53 ) | 71 | : m_cache(100, 53 ) |
66 | { | 72 | { |
67 | m_cache.setAutoDelete( TRUE ); | 73 | m_cache.setAutoDelete( TRUE ); |
68 | } | 74 | } |
69 | template <class T> | 75 | template <class T> |
70 | OPimCache<T>::~OPimCache() { | 76 | OPimCache<T>::~OPimCache() { |
71 | 77 | ||
72 | } | 78 | } |
73 | template <class T> | 79 | template <class T> |
74 | bool OPimCache<T>::contains(int uid )const { | 80 | bool OPimCache<T>::contains(int uid )const { |
75 | Item* it = m_cache.find( uid, FALSE ); | 81 | Item* it = m_cache.find( uid, FALSE ); |
76 | if (!it) | 82 | if (!it) |
77 | return false; | 83 | return false; |
78 | return true; | 84 | return true; |
79 | } | 85 | } |
diff --git a/libopie/pim/opimmainwindow.cpp b/libopie/pim/opimmainwindow.cpp index 92be2fd..7e57f3a 100644 --- a/libopie/pim/opimmainwindow.cpp +++ b/libopie/pim/opimmainwindow.cpp | |||
@@ -1,71 +1,105 @@ | |||
1 | #include <qapplication.h> | 1 | #include <qapplication.h> |
2 | #include <qcopchannel_qws.h> | 2 | #include <qcopchannel_qws.h> |
3 | 3 | ||
4 | #include <qpe/qcopenvelope_qws.h> | 4 | #include <qpe/qcopenvelope_qws.h> |
5 | 5 | ||
6 | #include "opimresolver.h" | ||
6 | #include "opimmainwindow.h" | 7 | #include "opimmainwindow.h" |
7 | 8 | ||
8 | OPimMainWindow::OPimMainWindow( const QString& service, QWidget* parent, | 9 | OPimMainWindow::OPimMainWindow( const QString& service, QWidget* parent, |
9 | const char* name, WFlags flag ) | 10 | const char* name, WFlags flag ) |
10 | : QMainWindow( parent, name, flag ), m_service( service ), m_fallBack(0l) { | 11 | : QMainWindow( parent, name, flag ), m_rtti(-1), m_service( service ), m_fallBack(0l) { |
11 | 12 | ||
12 | /* | 13 | /* |
13 | * let's generate our QCopChannel | 14 | * let's generate our QCopChannel |
14 | */ | 15 | */ |
15 | m_str = QString("QPE/"+m_service).local8Bit(); | 16 | m_str = QString("QPE/"+m_service).local8Bit(); |
16 | m_channel= new QCopChannel(m_str, this ); | 17 | m_channel= new QCopChannel(m_str, this ); |
17 | connect(m_channel, SIGNAL(received(const QCString&, const QByteArray& ) ), | 18 | connect(m_channel, SIGNAL(received(const QCString&, const QByteArray& ) ), |
18 | this, SLOT( appMessage( const QCString&, const QByteArray& ) ) ); | 19 | this, SLOT( appMessage( const QCString&, const QByteArray& ) ) ); |
19 | 20 | ||
20 | /* connect flush and reload */ | 21 | /* connect flush and reload */ |
21 | connect(qApp, SIGNAL(flush() ), | 22 | connect(qApp, SIGNAL(flush() ), |
22 | this, SLOT(flush() ) ); | 23 | this, SLOT(flush() ) ); |
23 | connect(qApp, SIGNAL(reload() ), | 24 | connect(qApp, SIGNAL(reload() ), |
24 | this, SLOT(reload() ) ); | 25 | this, SLOT(reload() ) ); |
25 | } | 26 | } |
26 | OPimMainWindow::~OPimMainWindow() { | 27 | OPimMainWindow::~OPimMainWindow() { |
27 | delete m_channel; | 28 | delete m_channel; |
28 | } | 29 | } |
29 | QCopChannel* OPimMainWindow::channel() { | 30 | QCopChannel* OPimMainWindow::channel() { |
30 | return m_channel; | 31 | return m_channel; |
31 | } | 32 | } |
33 | void OPimMainWindow::doSetDocument( const QString& ) { | ||
34 | |||
35 | } | ||
32 | void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) { | 36 | void OPimMainWindow::appMessage( const QCString& cmd, const QByteArray& array ) { |
33 | /* | 37 | /* |
34 | * create demands to create | 38 | * create demands to create |
35 | * a new record... | 39 | * a new record... |
36 | */ | 40 | */ |
37 | QDataStream stream(array, IO_ReadOnly); | 41 | QDataStream stream(array, IO_ReadOnly); |
38 | if ( cmd == "create()" ) { | 42 | if ( cmd == "create()" ) { |
39 | int uid = create(); | 43 | int uid = create(); |
40 | QCopEnvelope e(m_str, "created(int)" ); | 44 | QCopEnvelope e(m_str, "created(int)" ); |
41 | e << uid; | 45 | e << uid; |
42 | }else if ( cmd == "remove(int)" ) { | 46 | }else if ( cmd == "remove(int)" ) { |
43 | int uid; | 47 | int uid; |
44 | stream >> uid; | 48 | stream >> uid; |
45 | bool rem = remove( uid ); | 49 | bool rem = remove( uid ); |
46 | QCopEnvelope e(m_str, "removed(bool)" ); | 50 | QCopEnvelope e(m_str, "removed(bool)" ); |
47 | e << rem; | 51 | e << rem; |
48 | }else if ( cmd == "beam(int,int)" ) { | 52 | }else if ( cmd == "beam(int,int)" ) { |
49 | int uid, trans; | 53 | int uid, trans; |
50 | stream >> uid; | 54 | stream >> uid; |
51 | stream >> trans; | 55 | stream >> trans; |
52 | beam( uid, trans ); | 56 | beam( uid, trans ); |
53 | }else if ( cmd == "show(int)" ) { | 57 | }else if ( cmd == "show(int)" ) { |
54 | int uid; | 58 | int uid; |
55 | stream >> uid; | 59 | stream >> uid; |
56 | show( uid ); | 60 | show( uid ); |
57 | }else if ( cmd == "edit(int)" ) { | 61 | }else if ( cmd == "edit(int)" ) { |
58 | int uid; | 62 | int uid; |
59 | stream >> uid; | 63 | stream >> uid; |
60 | edit( uid ); | 64 | edit( uid ); |
61 | }else if ( cmd == "add(int,QByteArray)" ) { | 65 | }else if ( cmd == "add(int,QByteArray)" ) { |
62 | int rtti; | 66 | int rtti; |
63 | QByteArray array; | 67 | QByteArray array; |
64 | stream >> rtti; | 68 | stream >> rtti; |
65 | stream >> array; | 69 | stream >> array; |
66 | m_fallBack = record(rtti, array ); | 70 | m_fallBack = record(rtti, array ); |
67 | if (!m_fallBack) return; | 71 | if (!m_fallBack) return; |
68 | add( *m_fallBack ); | 72 | add( *m_fallBack ); |
69 | delete m_fallBack; | 73 | delete m_fallBack; |
70 | } | 74 | } |
71 | } | 75 | } |
76 | /* implement the url scripting here */ | ||
77 | void OPimMainWindow::setDocument( const QString& str) { | ||
78 | doSetDocument( str ); | ||
79 | } | ||
80 | /* | ||
81 | * we now try to get the array demarshalled | ||
82 | * check if the rtti matches this one | ||
83 | */ | ||
84 | OPimRecord* OPimMainWindow::record( int rtti, const QByteArray& array ) { | ||
85 | if ( service() != rtti ) | ||
86 | return 0l; | ||
87 | |||
88 | OPimRecord* record = OPimResolver::self()->record( rtti ); | ||
89 | QDataStream str(array, IO_ReadOnly ); | ||
90 | if ( !record || !record->loadFromStream(str) ) { | ||
91 | delete record; | ||
92 | record = 0l; | ||
93 | } | ||
94 | |||
95 | return record; | ||
96 | } | ||
97 | /* | ||
98 | * get the rtti for the service | ||
99 | */ | ||
100 | int OPimMainWindow::service() { | ||
101 | if ( m_rtti == -1 ) | ||
102 | m_rtti = OPimResolver::self()->serviceId( m_service ); | ||
103 | |||
104 | return m_rtti; | ||
105 | } | ||
diff --git a/libopie/pim/opimmainwindow.h b/libopie/pim/opimmainwindow.h index 94100bd..34b8a71 100644 --- a/libopie/pim/opimmainwindow.h +++ b/libopie/pim/opimmainwindow.h | |||
@@ -1,79 +1,89 @@ | |||
1 | #ifndef OPIE_PIM_MAINWINDOW_H | 1 | #ifndef OPIE_PIM_MAINWINDOW_H |
2 | #define OPIE_PIM_MAINWINDOW_H | 2 | #define OPIE_PIM_MAINWINDOW_H |
3 | 3 | ||
4 | #include <qmainwindow.h> | 4 | #include <qmainwindow.h> |
5 | 5 | ||
6 | #include <opie/opimrecord.h> | 6 | #include <opie/opimrecord.h> |
7 | 7 | ||
8 | /** | 8 | /** |
9 | * This is a common Opie PIM MainWindow | 9 | * This is a common Opie PIM MainWindow |
10 | * it takes care of the QCOP internals | 10 | * it takes care of the QCOP internals |
11 | * and implements some functions | 11 | * and implements some functions |
12 | * for the URL scripting schema | 12 | * for the URL scripting schema |
13 | */ | 13 | */ |
14 | /* | 14 | /* |
15 | * due Qt and Templates with signal and slots | 15 | * due Qt and Templates with signal and slots |
16 | * do not work that good :( | 16 | * do not work that good :( |
17 | * (Ok how to moc a template ;) ) | 17 | * (Ok how to moc a template ;) ) |
18 | * We will have the mainwindow which calls a struct which | 18 | * We will have the mainwindow which calls a struct which |
19 | * is normally reimplemented as a template ;) | 19 | * is normally reimplemented as a template ;) |
20 | */ | 20 | */ |
21 | 21 | ||
22 | class QCopChannel; | 22 | class QCopChannel; |
23 | class OPimMainWindow : public QMainWindow { | 23 | class OPimMainWindow : public QMainWindow { |
24 | Q_OBJECT | 24 | Q_OBJECT |
25 | public: | 25 | public: |
26 | enum TransPort { BlueTooth=0, | 26 | enum TransPort { BlueTooth=0, |
27 | IrDa }; | 27 | IrDa }; |
28 | 28 | ||
29 | OPimMainWindow( const QString& service, QWidget *parent = 0, const char* name = 0, | 29 | OPimMainWindow( const QString& service, QWidget *parent = 0, const char* name = 0, |
30 | WFlags f = WType_TopLevel); | 30 | WFlags f = WType_TopLevel); |
31 | virtual ~OPimMainWindow(); | 31 | virtual ~OPimMainWindow(); |
32 | 32 | ||
33 | 33 | ||
34 | protected slots: | 34 | protected slots: |
35 | /* | ||
36 | * called when a setDocument | ||
37 | * couldn't be handled by this window | ||
38 | */ | ||
39 | virtual void doSetDocument( const QString& ); | ||
35 | /* for syncing */ | 40 | /* for syncing */ |
36 | virtual void flush() = 0; | 41 | virtual void flush() = 0; |
37 | virtual void reload() = 0; | 42 | virtual void reload() = 0; |
38 | 43 | ||
39 | /** create a new Records and return the uid */ | 44 | /** create a new Records and return the uid */ |
40 | virtual int create() = 0; | 45 | virtual int create() = 0; |
41 | /** remove a record with UID == uid */ | 46 | /** remove a record with UID == uid */ |
42 | virtual bool remove( int uid ) = 0; | 47 | virtual bool remove( int uid ) = 0; |
43 | /** beam the record with UID = uid */ | 48 | /** beam the record with UID = uid */ |
44 | virtual void beam( int uid , int transport = IrDa) = 0; | 49 | virtual void beam( int uid , int transport = IrDa) = 0; |
45 | 50 | ||
46 | /** show the record with UID == uid */ | 51 | /** show the record with UID == uid */ |
47 | virtual void show( int uid ) = 0; | 52 | virtual void show( int uid ) = 0; |
48 | /** edit the record */ | 53 | /** edit the record */ |
49 | virtual void edit( int uid ) = 0; | 54 | virtual void edit( int uid ) = 0; |
50 | 55 | ||
51 | /** make a copy of it! */ | 56 | /** make a copy of it! */ |
52 | virtual void add( const OPimRecord& ) = 0; | 57 | virtual void add( const OPimRecord& ) = 0; |
53 | 58 | ||
54 | /* I would love to do this as a template | 59 | |
55 | * but can't think of a right way | ||
56 | * because I need signal and slots -zecke | ||
57 | */ | ||
58 | /* | ||
59 | * the only pointer in the whole PIM API :( | ||
60 | */ | ||
61 | virtual OPimRecord* record( int rtti, const QByteArray& ) = 0; | ||
62 | QCopChannel* channel(); | 60 | QCopChannel* channel(); |
63 | 61 | ||
64 | private slots: | 62 | private slots: |
65 | void appMessage( const QCString&, const QByteArray& ); | 63 | void appMessage( const QCString&, const QByteArray& ); |
64 | void setDocument( const QString& ); | ||
66 | 65 | ||
67 | 66 | ||
68 | private: | 67 | private: |
69 | class Private; | 68 | class Private; |
70 | Private* d; | 69 | Private* d; |
71 | 70 | ||
71 | int m_rtti; | ||
72 | QCopChannel* m_channel; | 72 | QCopChannel* m_channel; |
73 | QString m_service; | 73 | QString m_service; |
74 | QCString m_str; | 74 | QCString m_str; |
75 | OPimRecord* m_fallBack; | 75 | OPimRecord* m_fallBack; |
76 | |||
77 | /* I would love to do this as a template | ||
78 | * but can't think of a right way | ||
79 | * because I need signal and slots -zecke | ||
80 | */ | ||
81 | /* | ||
82 | * the only pointer in the whole PIM API :( | ||
83 | */ | ||
84 | virtual OPimRecord* record( int rtti, const QByteArray& ) ; | ||
85 | int service(); | ||
76 | }; | 86 | }; |
77 | 87 | ||
78 | 88 | ||
79 | #endif | 89 | #endif |
diff --git a/libopie/pim/opimrecord.cpp b/libopie/pim/opimrecord.cpp index 49b5bf9..ac0f4a9 100644 --- a/libopie/pim/opimrecord.cpp +++ b/libopie/pim/opimrecord.cpp | |||
@@ -1,84 +1,166 @@ | |||
1 | #include <qarray.h> | ||
2 | |||
1 | #include <qpe/categories.h> | 3 | #include <qpe/categories.h> |
2 | #include <qpe/categoryselect.h> | 4 | #include <qpe/categoryselect.h> |
3 | 5 | ||
4 | #include "opimrecord.h" | 6 | #include "opimrecord.h" |
5 | 7 | ||
6 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); | 8 | Qtopia::UidGen OPimRecord::m_uidGen( Qtopia::UidGen::Qtopia ); |
7 | 9 | ||
8 | 10 | ||
9 | OPimRecord::OPimRecord( int uid ) | 11 | OPimRecord::OPimRecord( int uid ) |
10 | : Qtopia::Record() { | 12 | : Qtopia::Record() { |
11 | 13 | ||
12 | setUid( uid ); | 14 | setUid( uid ); |
13 | } | 15 | } |
14 | OPimRecord::~OPimRecord() { | 16 | OPimRecord::~OPimRecord() { |
15 | } | 17 | } |
16 | OPimRecord::OPimRecord( const OPimRecord& rec ) | 18 | OPimRecord::OPimRecord( const OPimRecord& rec ) |
17 | : Qtopia::Record( rec ) | 19 | : Qtopia::Record( rec ) |
18 | { | 20 | { |
19 | (*this) = rec; | 21 | (*this) = rec; |
20 | } | 22 | } |
21 | 23 | ||
22 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { | 24 | OPimRecord &OPimRecord::operator=( const OPimRecord& rec) { |
23 | Qtopia::Record::operator=( rec ); | 25 | Qtopia::Record::operator=( rec ); |
24 | m_xrefman = rec.m_xrefman; | 26 | m_xrefman = rec.m_xrefman; |
25 | 27 | ||
26 | return *this; | 28 | return *this; |
27 | } | 29 | } |
28 | /* | 30 | /* |
29 | * category names | 31 | * category names |
30 | */ | 32 | */ |
31 | QStringList OPimRecord::categoryNames()const { | 33 | QStringList OPimRecord::categoryNames()const { |
32 | QStringList list; | 34 | QStringList list; |
33 | QArray<int> cats = categories(); | 35 | QArray<int> cats = categories(); |
34 | Categories catDB; | 36 | Categories catDB; |
35 | catDB.load( categoryFileName() ); | 37 | catDB.load( categoryFileName() ); |
36 | 38 | ||
37 | for (uint i = 0; i < cats.count(); i++ ) { | 39 | for (uint i = 0; i < cats.count(); i++ ) { |
38 | list << catDB.label("Todo List", cats[i] ); | 40 | list << catDB.label("Todo List", cats[i] ); |
39 | } | 41 | } |
40 | 42 | ||
41 | return list; | 43 | return list; |
42 | } | 44 | } |
43 | void OPimRecord::setCategoryNames( const QStringList& ) { | 45 | void OPimRecord::setCategoryNames( const QStringList& ) { |
44 | 46 | ||
45 | } | 47 | } |
46 | void OPimRecord::addCategoryName( const QString& ) { | 48 | void OPimRecord::addCategoryName( const QString& ) { |
47 | Categories catDB; | 49 | Categories catDB; |
48 | catDB.load( categoryFileName() ); | 50 | catDB.load( categoryFileName() ); |
49 | 51 | ||
50 | 52 | ||
51 | } | 53 | } |
52 | bool OPimRecord::isEmpty()const { | 54 | bool OPimRecord::isEmpty()const { |
53 | return ( uid() == 0 ); | 55 | return ( uid() == 0 ); |
54 | } | 56 | } |
55 | /*QString OPimRecord::crossToString()const { | 57 | /*QString OPimRecord::crossToString()const { |
56 | QString str; | 58 | QString str; |
57 | QMap<QString, QArray<int> >::ConstIterator it; | 59 | QMap<QString, QArray<int> >::ConstIterator it; |
58 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { | 60 | for (it = m_relations.begin(); it != m_relations.end(); ++it ) { |
59 | QArray<int> id = it.data(); | 61 | QArray<int> id = it.data(); |
60 | for ( uint i = 0; i < id.size(); ++i ) { | 62 | for ( uint i = 0; i < id.size(); ++i ) { |
61 | str += it.key() + "," + QString::number( i ) + ";"; | 63 | str += it.key() + "," + QString::number( i ) + ";"; |
62 | } | 64 | } |
63 | } | 65 | } |
64 | str = str.remove( str.length()-1, 1); // strip the ; | 66 | str = str.remove( str.length()-1, 1); // strip the ; |
65 | //qWarning("IDS " + str ); | 67 | //qWarning("IDS " + str ); |
66 | 68 | ||
67 | return str; | 69 | return str; |
68 | }*/ | 70 | }*/ |
69 | /* if uid = 1 assign a new one */ | 71 | /* if uid = 1 assign a new one */ |
70 | void OPimRecord::setUid( int uid ) { | 72 | void OPimRecord::setUid( int uid ) { |
71 | if ( uid == 1) | 73 | if ( uid == 1) |
72 | uid = uidGen().generate(); | 74 | uid = uidGen().generate(); |
73 | 75 | ||
74 | Qtopia::Record::setUid( uid ); | 76 | Qtopia::Record::setUid( uid ); |
75 | }; | 77 | }; |
76 | Qtopia::UidGen &OPimRecord::uidGen() { | 78 | Qtopia::UidGen &OPimRecord::uidGen() { |
77 | return m_uidGen; | 79 | return m_uidGen; |
78 | } | 80 | } |
79 | OPimXRefManager &OPimRecord::xrefmanager() { | 81 | OPimXRefManager &OPimRecord::xrefmanager() { |
80 | return m_xrefman; | 82 | return m_xrefman; |
81 | } | 83 | } |
82 | int OPimRecord::rtti(){ | 84 | int OPimRecord::rtti(){ |
83 | return 0; | 85 | return 0; |
84 | } | 86 | } |
87 | |||
88 | /** | ||
89 | * now let's put our data into the stream | ||
90 | */ | ||
91 | /* | ||
92 | * First read UID | ||
93 | * Categories | ||
94 | * XRef | ||
95 | */ | ||
96 | bool OPimRecord::loadFromStream( QDataStream& stream ) { | ||
97 | int Int; | ||
98 | uint UInt; | ||
99 | stream >> Int; | ||
100 | setUid(Int); | ||
101 | |||
102 | /** Categories */ | ||
103 | stream >> UInt; | ||
104 | QArray<int> array(UInt); | ||
105 | for (uint i = 0; i < UInt; i++ ) { | ||
106 | stream >> array[i]; | ||
107 | } | ||
108 | setCategories( array ); | ||
109 | |||
110 | /* | ||
111 | * now we do the X-Ref stuff | ||
112 | */ | ||
113 | OPimXRef xref; | ||
114 | stream >> UInt; | ||
115 | for ( uint i = 0; i < UInt; i++ ) { | ||
116 | xref.setPartner( OPimXRef::One, partner( stream ) ); | ||
117 | xref.setPartner( OPimXRef::Two, partner( stream ) ); | ||
118 | m_xrefman.add( xref ); | ||
119 | } | ||
120 | |||
121 | return true; | ||
122 | } | ||
123 | bool OPimRecord::saveToStream( QDataStream& stream )const { | ||
124 | /** UIDs */ | ||
125 | |||
126 | stream << uid(); | ||
127 | |||
128 | /** Categories */ | ||
129 | stream << categories().count(); | ||
130 | for ( uint i = 0; i < categories().count(); i++ ) { | ||
131 | stream << categories()[i]; | ||
132 | } | ||
133 | |||
134 | /* | ||
135 | * first the XRef count | ||
136 | * then the xrefs | ||
137 | */ | ||
138 | stream << m_xrefman.list().count(); | ||
139 | for ( OPimXRef::ValueList::ConstIterator it = m_xrefman.list().begin(); | ||
140 | it != m_xrefman.list().end(); ++it ) { | ||
141 | flush( (*it).partner( OPimXRef::One), stream ); | ||
142 | flush( (*it).partner( OPimXRef::Two), stream ); | ||
143 | } | ||
144 | return true; | ||
145 | } | ||
146 | void OPimRecord::flush( const OPimXRefPartner& par, QDataStream& str ) const{ | ||
147 | str << par.service(); | ||
148 | str << par.uid(); | ||
149 | str << par.field(); | ||
150 | } | ||
151 | OPimXRefPartner OPimRecord::partner( QDataStream& stream ) { | ||
152 | OPimXRefPartner par; | ||
153 | QString str; | ||
154 | int i; | ||
155 | |||
156 | stream >> str; | ||
157 | par.setService( str ); | ||
158 | |||
159 | stream >> i; | ||
160 | par.setUid( i ); | ||
161 | |||
162 | stream >> i ; | ||
163 | par.setField( i ); | ||
164 | |||
165 | return par; | ||
166 | } | ||
diff --git a/libopie/pim/opimrecord.h b/libopie/pim/opimrecord.h index ec99a13..665530f 100644 --- a/libopie/pim/opimrecord.h +++ b/libopie/pim/opimrecord.h | |||
@@ -1,51 +1,52 @@ | |||
1 | #ifndef OPIE_PIM_RECORD_H | 1 | #ifndef OPIE_PIM_RECORD_H |
2 | #define OPIE_PIM_RECORD_H | 2 | #define OPIE_PIM_RECORD_H |
3 | 3 | ||
4 | #include <qdatastream.h> | ||
4 | #include <qmap.h> | 5 | #include <qmap.h> |
5 | #include <qstring.h> | 6 | #include <qstring.h> |
6 | #include <qstringlist.h> | 7 | #include <qstringlist.h> |
7 | 8 | ||
8 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
9 | 10 | ||
10 | #include <opie/opimxrefmanager.h> | 11 | #include <opie/opimxrefmanager.h> |
11 | 12 | ||
12 | /** | 13 | /** |
13 | * This is the base class for | 14 | * This is the base class for |
14 | * all PIM Records | 15 | * all PIM Records |
15 | * | 16 | * |
16 | */ | 17 | */ |
17 | class OPimRecord : public Qtopia::Record { | 18 | class OPimRecord : public Qtopia::Record { |
18 | public: | 19 | public: |
19 | /** | 20 | /** |
20 | * c'tor | 21 | * c'tor |
21 | * uid of 0 isEmpty | 22 | * uid of 0 isEmpty |
22 | * uid of 1 will be assigned a new one | 23 | * uid of 1 will be assigned a new one |
23 | */ | 24 | */ |
24 | OPimRecord(int uid = 0); | 25 | OPimRecord(int uid = 0); |
25 | ~OPimRecord(); | 26 | ~OPimRecord(); |
26 | 27 | ||
27 | /** | 28 | /** |
28 | * copy c'tor | 29 | * copy c'tor |
29 | */ | 30 | */ |
30 | OPimRecord( const OPimRecord& rec ); | 31 | OPimRecord( const OPimRecord& rec ); |
31 | 32 | ||
32 | /** | 33 | /** |
33 | * copy operator | 34 | * copy operator |
34 | */ | 35 | */ |
35 | OPimRecord &operator=( const OPimRecord& ); | 36 | OPimRecord &operator=( const OPimRecord& ); |
36 | 37 | ||
37 | /** | 38 | /** |
38 | * category names resolved | 39 | * category names resolved |
39 | */ | 40 | */ |
40 | QStringList categoryNames()const; | 41 | QStringList categoryNames()const; |
41 | 42 | ||
42 | /** | 43 | /** |
43 | * set category names they will be resolved | 44 | * set category names they will be resolved |
44 | */ | 45 | */ |
45 | void setCategoryNames( const QStringList& ); | 46 | void setCategoryNames( const QStringList& ); |
46 | 47 | ||
47 | /** | 48 | /** |
48 | * addCategoryName adds a name | 49 | * addCategoryName adds a name |
49 | * to the internal category list | 50 | * to the internal category list |
50 | */ | 51 | */ |
51 | void addCategoryName( const QString& ); | 52 | void addCategoryName( const QString& ); |
@@ -60,63 +61,74 @@ public: | |||
60 | * toRichText summary | 61 | * toRichText summary |
61 | */ | 62 | */ |
62 | virtual QString toRichText()const = 0; | 63 | virtual QString toRichText()const = 0; |
63 | 64 | ||
64 | /** | 65 | /** |
65 | * a small one line summary | 66 | * a small one line summary |
66 | */ | 67 | */ |
67 | virtual QString toShortText()const = 0; | 68 | virtual QString toShortText()const = 0; |
68 | 69 | ||
69 | /** | 70 | /** |
70 | * the name of the Record | 71 | * the name of the Record |
71 | */ | 72 | */ |
72 | virtual QString type()const = 0; | 73 | virtual QString type()const = 0; |
73 | 74 | ||
74 | /** | 75 | /** |
75 | * converts the internal structure to a map | 76 | * converts the internal structure to a map |
76 | */ | 77 | */ |
77 | virtual QMap<int, QString> toMap()const = 0; | 78 | virtual QMap<int, QString> toMap()const = 0; |
78 | 79 | ||
79 | /** | 80 | /** |
80 | * key value representation of extra items | 81 | * key value representation of extra items |
81 | */ | 82 | */ |
82 | virtual QMap<QString, QString> toExtraMap()const = 0; | 83 | virtual QMap<QString, QString> toExtraMap()const = 0; |
83 | 84 | ||
84 | /** | 85 | /** |
85 | * the name for a recordField | 86 | * the name for a recordField |
86 | */ | 87 | */ |
87 | virtual QString recordField(int)const = 0; | 88 | virtual QString recordField(int)const = 0; |
88 | 89 | ||
89 | /** | 90 | /** |
90 | * returns a reference of the | 91 | * returns a reference of the |
91 | * Cross Reference Manager | 92 | * Cross Reference Manager |
92 | * Partner 'One' is THIS PIM RECORD! | 93 | * Partner 'One' is THIS PIM RECORD! |
93 | * 'Two' is the Partner where we link to | 94 | * 'Two' is the Partner where we link to |
94 | */ | 95 | */ |
95 | OPimXRefManager& xrefmanager(); | 96 | OPimXRefManager& xrefmanager(); |
96 | 97 | ||
97 | /** | 98 | /** |
98 | * set the uid | 99 | * set the uid |
99 | */ | 100 | */ |
100 | virtual void setUid( int uid ); | 101 | virtual void setUid( int uid ); |
101 | 102 | ||
102 | /* | 103 | /* |
103 | * used inside the Templates for casting | 104 | * used inside the Templates for casting |
104 | * REIMPLEMENT in your .... | 105 | * REIMPLEMENT in your .... |
105 | */ | 106 | */ |
106 | static int rtti(); | 107 | static int rtti(); |
107 | 108 | ||
109 | /** | ||
110 | * some marshalling and de marshalling code | ||
111 | * saves the OPimRecord | ||
112 | * to and from a DataStream | ||
113 | */ | ||
114 | virtual bool loadFromStream(QDataStream& ); | ||
115 | virtual bool saveToStream( QDataStream& stream )const; | ||
116 | |||
108 | protected: | 117 | protected: |
109 | Qtopia::UidGen &uidGen(); | 118 | Qtopia::UidGen &uidGen(); |
110 | // QString crossToString()const; | 119 | // QString crossToString()const; |
111 | 120 | ||
112 | private: | 121 | private: |
113 | class OPimRecordPrivate; | 122 | class OPimRecordPrivate; |
114 | OPimRecordPrivate *d; | 123 | OPimRecordPrivate *d; |
115 | OPimXRefManager m_xrefman; | 124 | OPimXRefManager m_xrefman; |
116 | static Qtopia::UidGen m_uidGen; | 125 | static Qtopia::UidGen m_uidGen; |
117 | 126 | ||
127 | private: | ||
128 | void flush( const OPimXRefPartner&, QDataStream& stream )const; | ||
129 | OPimXRefPartner partner( QDataStream& ); | ||
118 | }; | 130 | }; |
119 | 131 | ||
120 | 132 | ||
121 | 133 | ||
122 | #endif | 134 | #endif |
diff --git a/libopie/pim/opimresolver.cpp b/libopie/pim/opimresolver.cpp new file mode 100644 index 0000000..4ebbd6e --- a/dev/null +++ b/libopie/pim/opimresolver.cpp | |||
@@ -0,0 +1,198 @@ | |||
1 | #include <qcopchannel_qws.h> | ||
2 | |||
3 | #include <qpe/qcopenvelope_qws.h> | ||
4 | |||
5 | #include "otodoaccess.h" | ||
6 | #include "ocontactaccess.h" | ||
7 | |||
8 | //#include "opimfactory.h" | ||
9 | #include "opimresolver.h" | ||
10 | |||
11 | OPimResolver* OPimResolver::m_self = 0l; | ||
12 | |||
13 | OPimResolver::OPimResolver() { | ||
14 | /* the built in channels */ | ||
15 | m_builtIns << "Todolist" << "Addressbook" << "Datebook"; | ||
16 | } | ||
17 | OPimResolver* OPimResolver::self() { | ||
18 | if (!m_self) | ||
19 | m_self = new OPimResolver(); | ||
20 | |||
21 | return m_self; | ||
22 | } | ||
23 | |||
24 | /* | ||
25 | * FIXME use a cache here too | ||
26 | */ | ||
27 | OPimRecord* OPimResolver::record( const QString& service, int uid ) { | ||
28 | OPimRecord* rec = 0l; | ||
29 | OPimBase* base = backend( service ); | ||
30 | |||
31 | if ( base ) | ||
32 | rec = base->record( uid ); | ||
33 | delete base; | ||
34 | |||
35 | return rec; | ||
36 | } | ||
37 | OPimRecord* OPimResolver::record( const QString& service ) { | ||
38 | return record( serviceId( service ) ); | ||
39 | } | ||
40 | OPimRecord* OPimResolver::record( int rtti ) { | ||
41 | OPimRecord* rec = 0l; | ||
42 | switch( rtti ) { | ||
43 | case 1: /* todolist */ | ||
44 | rec = new OTodo(); | ||
45 | case 2: /* contact */ | ||
46 | rec = new OContact(); | ||
47 | default: | ||
48 | break; | ||
49 | } | ||
50 | /* | ||
51 | * FIXME resolve externally | ||
52 | */ | ||
53 | if (!rec ) { | ||
54 | ; | ||
55 | } | ||
56 | return 0l; | ||
57 | } | ||
58 | bool OPimResolver::isBuiltIn( const QString& str) const{ | ||
59 | return m_builtIns.contains( str ); | ||
60 | } | ||
61 | QCString OPimResolver::qcopChannel( enum BuiltIn& built)const { | ||
62 | QCString str("QPE/"); | ||
63 | switch( built ) { | ||
64 | case TodoList: | ||
65 | str += "Todolist"; | ||
66 | break; | ||
67 | case DateBook: | ||
68 | str += "Datebook"; | ||
69 | break; | ||
70 | case AddressBook: | ||
71 | str += "Addressbook"; | ||
72 | break; | ||
73 | default: | ||
74 | break; | ||
75 | } | ||
76 | |||
77 | return str; | ||
78 | } | ||
79 | QCString OPimResolver::qcopChannel( const QString& service )const { | ||
80 | QCString str("QPE/"); | ||
81 | str += service.latin1(); | ||
82 | return str; | ||
83 | } | ||
84 | /* | ||
85 | * Implement services!! | ||
86 | * FIXME | ||
87 | */ | ||
88 | QCString OPimResolver::applicationChannel( enum BuiltIn& built)const { | ||
89 | QCString str("QPE/Application/"); | ||
90 | switch( built ) { | ||
91 | case TodoList: | ||
92 | str += "todolist"; | ||
93 | break; | ||
94 | case DateBook: | ||
95 | str += "datebook"; | ||
96 | break; | ||
97 | case AddressBook: | ||
98 | str += "addressbook"; | ||
99 | break; | ||
100 | } | ||
101 | |||
102 | return str; | ||
103 | } | ||
104 | QCString OPimResolver::applicationChannel( const QString& service )const { | ||
105 | QCString str("QPE/Application/"); | ||
106 | |||
107 | if ( isBuiltIn( service ) ) { | ||
108 | if ( service == "Todolist" ) | ||
109 | str += "todolist"; | ||
110 | else if ( service == "Datebook" ) | ||
111 | str += "datebook"; | ||
112 | else if ( service == "Addressbook" ) | ||
113 | str += "addressbook"; | ||
114 | }else | ||
115 | ; // FIXME for additional stuff | ||
116 | |||
117 | return str; | ||
118 | } | ||
119 | QStringList OPimResolver::services()const { | ||
120 | return m_builtIns; | ||
121 | } | ||
122 | QString OPimResolver::serviceName( int rtti ) const{ | ||
123 | QString str; | ||
124 | switch ( rtti ) { | ||
125 | case TodoList: | ||
126 | str = "Todolist"; | ||
127 | break; | ||
128 | case DateBook: | ||
129 | str = "Datebook"; | ||
130 | break; | ||
131 | case AddressBook: | ||
132 | str = "Addressbook"; | ||
133 | break; | ||
134 | default: | ||
135 | break; | ||
136 | } | ||
137 | return str; | ||
138 | // FIXME me for 3rd party | ||
139 | } | ||
140 | int OPimResolver::serviceId( const QString& service ) { | ||
141 | int rtti = 0; | ||
142 | if ( service == "Todolist" ) | ||
143 | rtti = TodoList; | ||
144 | else if ( service == "Datebook" ) | ||
145 | rtti = DateBook; | ||
146 | else if ( service == "Addressbook" ) | ||
147 | rtti = AddressBook; | ||
148 | |||
149 | return rtti; | ||
150 | } | ||
151 | /** | ||
152 | * check if the 'service' is registered and if so we'll | ||
153 | */ | ||
154 | bool OPimResolver::add( const QString& service, const OPimRecord& rec) { | ||
155 | if ( QCopChannel::isRegistered( applicationChannel( service ) ) ) { | ||
156 | QByteArray data; | ||
157 | QDataStream arg(data, IO_WriteOnly ); | ||
158 | if ( rec.saveToStream( arg ) ) { | ||
159 | QCopEnvelope env( applicationChannel( service ), "add(int,QByteArray)" ); | ||
160 | env << rec.rtti(); | ||
161 | env << data; | ||
162 | }else | ||
163 | return false; | ||
164 | }else{ | ||
165 | OPimBase* base = backend( service ); | ||
166 | if (!base ) return false; | ||
167 | |||
168 | base->load(); | ||
169 | base->add( rec ); | ||
170 | base->save(); | ||
171 | delete base; | ||
172 | } | ||
173 | |||
174 | return true; | ||
175 | } | ||
176 | OPimBase* OPimResolver::backend( const QString& service ) { | ||
177 | return backend( serviceId( service ) ); | ||
178 | } | ||
179 | OPimBase* OPimResolver::backend( int rtti ) { | ||
180 | OPimBase* base = 0l; | ||
181 | switch( rtti ) { | ||
182 | case TodoList: | ||
183 | base = new OTodoAccess(); | ||
184 | break; | ||
185 | case DateBook: | ||
186 | break; | ||
187 | case AddressBook: | ||
188 | base = new OContactAccess("Resolver"); | ||
189 | break; | ||
190 | default: | ||
191 | break; | ||
192 | } | ||
193 | // FIXME for 3rd party | ||
194 | if (!base ) | ||
195 | ; | ||
196 | |||
197 | return base; | ||
198 | } | ||
diff --git a/libopie/pim/opimresolver.h b/libopie/pim/opimresolver.h index 86ae3eb..1ce1619 100644 --- a/libopie/pim/opimresolver.h +++ b/libopie/pim/opimresolver.h | |||
@@ -1,56 +1,90 @@ | |||
1 | #ifndef OPIE_PIM_RESOLVER | 1 | #ifndef OPIE_PIM_RESOLVER |
2 | #define OPIE_PIM_RESOLVER | 2 | #define OPIE_PIM_RESOLVER |
3 | 3 | ||
4 | #include <qstring.h> | 4 | #include <qstring.h> |
5 | #include <qvaluelist.h> | 5 | #include <qvaluelist.h> |
6 | 6 | ||
7 | #include <opie/otemplatebase.h> | ||
8 | |||
7 | /** | 9 | /** |
8 | * OPimResolver is a MetaClass to access | 10 | * OPimResolver is a MetaClass to access |
9 | * available backends read only. | 11 | * available backends read only. |
10 | * It will be used to resolve uids + app names | 12 | * It will be used to resolve uids + app names |
11 | * to full informations | 13 | * to full informations |
12 | * to traverse through a list of alarms, reminders | 14 | * to traverse through a list of alarms, reminders |
13 | * to get access to built in PIM functionality | 15 | * to get access to built in PIM functionality |
14 | * and to more stuff | 16 | * and to more stuff |
15 | * THE PERFORMANCE will depend on THE BACKEND | 17 | * THE PERFORMANCE will depend on THE BACKEND |
16 | * USING XML is a waste of memory!!!!! | 18 | * USING XML is a waste of memory!!!!! |
17 | */ | 19 | */ |
18 | class OPimResolver : public QObject { | 20 | class OPimResolver { |
19 | public: | 21 | public: |
20 | enum BuiltIn { TodoList = 0, | 22 | enum BuiltIn { TodoList = 0, |
21 | DateBook, | 23 | DateBook, |
22 | AddressBook | 24 | AddressBook |
23 | }; | 25 | }; |
24 | static OPimResolver* self(); | 26 | static OPimResolver* self(); |
25 | 27 | ||
26 | 28 | ||
27 | /* | 29 | /** |
28 | * return a record for a uid | 30 | * return a record for a uid |
29 | * and an app | 31 | * and an service |
32 | * You've THE OWNERSHIP NOW! | ||
30 | */ | 33 | */ |
31 | OPimRecord &record( const QString& service, int uid ); | 34 | OPimRecord *record( const QString& service, int uid ); |
32 | 35 | ||
33 | /** | 36 | /** |
34 | * return the QCopChannel for service | 37 | * return the QCopChannel for service |
35 | * When we will use Qtopia Services it will be used here | 38 | * When we will use Qtopia Services it will be used here |
36 | */ | 39 | */ |
37 | QString qcopChannel( enum BuiltIn& )const; | 40 | QCString qcopChannel( enum BuiltIn& )const; |
38 | QString qcopChannel( const QString& service ); | 41 | QCString qcopChannel( const QString& service )const; |
42 | |||
43 | /** | ||
44 | * The Application channel (QPE/Application/name) | ||
45 | */ | ||
46 | QCString applicationChannel( enum BuiltIn& )const; | ||
47 | QCString applicationChannel( const QString& service )const; | ||
39 | 48 | ||
40 | /** | 49 | /** |
41 | * return a list of available services | 50 | * return a list of available services |
42 | */ | 51 | */ |
43 | QStringList services()const; | 52 | QStringList services()const; |
44 | 53 | inline QString serviceName(int rrti )const; | |
54 | int serviceId( const QString& Service); | ||
45 | /** | 55 | /** |
46 | * add a record to a service... ;) | 56 | * add a record to a service... ;) |
47 | */ | 57 | */ |
48 | bool add( const QString& service, const OPimRecord& ); | 58 | bool add( const QString& service, const OPimRecord& ); |
49 | 59 | ||
60 | |||
61 | /** | ||
62 | * record returns an empty record for a given service. | ||
63 | * Be sure to delete it!!! | ||
64 | * | ||
65 | */ | ||
66 | OPimRecord* record( const QString& service ); | ||
67 | OPimRecord* record( int rtti ); | ||
68 | |||
69 | /** | ||
70 | * you can cast to your | ||
71 | */ | ||
72 | OPimBase* backend( const QString& service ); | ||
73 | OPimBase* backend( int rtti ); | ||
50 | private: | 74 | private: |
51 | OPimResolver(); | 75 | OPimResolver(); |
52 | OPimRecord *m_last; | 76 | void loadData(); |
77 | inline bool isBuiltIn( const QString& )const; | ||
78 | OPimRecord* recordExtern( const QString&, int ); | ||
79 | OPimRecord* recordExtern( const QString& ); | ||
80 | |||
81 | static OPimResolver* m_self; | ||
82 | struct Data; | ||
83 | class Private; | ||
53 | 84 | ||
54 | }: | 85 | Data* data; |
86 | Private* d; | ||
87 | QStringList m_builtIns; | ||
88 | }; | ||
55 | 89 | ||
56 | #endif | 90 | #endif |
diff --git a/libopie/pim/otemplatebase.h b/libopie/pim/otemplatebase.h index b855919..29fb6ec 100644 --- a/libopie/pim/otemplatebase.h +++ b/libopie/pim/otemplatebase.h | |||
@@ -1,32 +1,91 @@ | |||
1 | #ifndef OPIE_TEMPLATE_BASE_H | 1 | #ifndef OPIE_TEMPLATE_BASE_H |
2 | #define OPIE_TEMPLATE_BASE_H | 2 | #define OPIE_TEMPLATE_BASE_H |
3 | 3 | ||
4 | #include <qarray.h> | 4 | #include <qarray.h> |
5 | 5 | ||
6 | #include "opimrecord.h" | 6 | #include <opie/opimrecord.h> |
7 | |||
7 | 8 | ||
8 | /** | 9 | /** |
10 | * Templates do not have a base class, This is why | ||
11 | * we've this class | ||
12 | * this is here to give us the possibility | ||
13 | * to have a common base class | ||
14 | * You may not want to use that interface internaly | ||
15 | * POOR mans interface | ||
16 | */ | ||
17 | struct OPimBase { | ||
18 | /** | ||
19 | * return the rtti | ||
20 | */ | ||
21 | virtual int rtti()= 0; | ||
22 | virtual OPimRecord* record()const = 0; | ||
23 | virtual OPimRecord* record(int uid)const = 0; | ||
24 | virtual bool add( const OPimRecord& ) = 0; | ||
25 | virtual bool remove( int uid ) = 0; | ||
26 | virtual bool remove( const OPimRecord& ) = 0; | ||
27 | virtual void clear() = 0; | ||
28 | virtual bool load() = 0; | ||
29 | virtual bool save() = 0; | ||
30 | virtual QArray<int> records()const = 0; | ||
31 | /* | ||
32 | * ADD editing here? | ||
33 | * -zecke | ||
34 | */ | ||
35 | |||
36 | }; | ||
37 | /** | ||
9 | * internal template base | 38 | * internal template base |
39 | * T needs to implement the copy c'tor!!! | ||
10 | */ | 40 | */ |
11 | template <class T = OPimRecord> | 41 | template <class T = OPimRecord> |
12 | class OTemplateBase { | 42 | class OTemplateBase : public OPimBase { |
13 | public: | 43 | public: |
14 | enum CacheDirection { Forward=0, Reverse }; | 44 | enum CacheDirection { Forward=0, Reverse }; |
15 | OTemplateBase() { | 45 | OTemplateBase() { |
16 | }; | 46 | }; |
17 | virtual ~OTemplateBase() { | 47 | virtual ~OTemplateBase() { |
18 | } | 48 | } |
19 | virtual T find( int uid )const = 0; | 49 | virtual T find( int uid )const = 0; |
20 | 50 | ||
21 | /** | 51 | /** |
22 | * read ahead find | 52 | * read ahead find |
23 | */ | 53 | */ |
24 | virtual T find( int uid, const QArray<int>& items, | 54 | virtual T find( int uid, const QArray<int>& items, |
25 | uint current, CacheDirection dir = Forward )const = 0; | 55 | uint current, CacheDirection dir = Forward )const = 0; |
26 | virtual void cache( const T& )const = 0; | 56 | virtual void cache( const T& )const = 0; |
27 | virtual void setSaneCacheSize( int ) = 0; | 57 | virtual void setSaneCacheSize( int ) = 0; |
28 | 58 | ||
59 | /* reimplement of OPimBase */ | ||
60 | int rtti(); | ||
61 | OPimRecord* record()const; | ||
62 | OPimRecord* record(int uid )const; | ||
63 | static T* rec(); | ||
29 | }; | 64 | }; |
30 | 65 | ||
66 | /* | ||
67 | * implementation | ||
68 | */ | ||
69 | template <class T> | ||
70 | int | ||
71 | OTemplateBase<T>::rtti() { | ||
72 | return T::rtti(); | ||
73 | } | ||
74 | template <class T> | ||
75 | OPimRecord* OTemplateBase<T>::record()const { | ||
76 | T* t = new T; | ||
77 | return t; | ||
78 | } | ||
79 | template <class T> | ||
80 | OPimRecord* OTemplateBase<T>::record(int uid )const { | ||
81 | T t2 = find(uid ); | ||
82 | T* t1 = new T(t2); | ||
83 | |||
84 | return t1; | ||
85 | }; | ||
86 | template <class T> | ||
87 | T* OTemplateBase<T>::rec() { | ||
88 | return new T; | ||
89 | } | ||
31 | 90 | ||
32 | #endif | 91 | #endif |
diff --git a/libopie/pim/otodo.cpp b/libopie/pim/otodo.cpp index ece624a..cde2b3d 100644 --- a/libopie/pim/otodo.cpp +++ b/libopie/pim/otodo.cpp | |||
@@ -1,66 +1,67 @@ | |||
1 | 1 | ||
2 | #include <qobject.h> | 2 | #include <qobject.h> |
3 | #include <qshared.h> | 3 | #include <qshared.h> |
4 | 4 | ||
5 | 5 | ||
6 | 6 | ||
7 | #include <qpe/palmtopuidgen.h> | 7 | #include <qpe/palmtopuidgen.h> |
8 | #include <qpe/stringutil.h> | 8 | #include <qpe/stringutil.h> |
9 | #include <qpe/palmtoprecord.h> | 9 | #include <qpe/palmtoprecord.h> |
10 | #include <qpe/stringutil.h> | 10 | #include <qpe/stringutil.h> |
11 | #include <qpe/categories.h> | 11 | #include <qpe/categories.h> |
12 | #include <qpe/categoryselect.h> | 12 | #include <qpe/categoryselect.h> |
13 | 13 | ||
14 | 14 | ||
15 | #include "opimstate.h" | 15 | #include "opimstate.h" |
16 | #include "orecur.h" | 16 | #include "orecur.h" |
17 | #include "opimmaintainer.h" | 17 | #include "opimmaintainer.h" |
18 | #include "opimnotifymanager.h" | 18 | #include "opimnotifymanager.h" |
19 | #include "opimresolver.h" | ||
19 | 20 | ||
20 | #include "otodo.h" | 21 | #include "otodo.h" |
21 | 22 | ||
22 | 23 | ||
23 | struct OTodo::OTodoData : public QShared { | 24 | struct OTodo::OTodoData : public QShared { |
24 | OTodoData() : QShared() { | 25 | OTodoData() : QShared() { |
25 | }; | 26 | }; |
26 | 27 | ||
27 | QDate date; | 28 | QDate date; |
28 | bool isCompleted:1; | 29 | bool isCompleted:1; |
29 | bool hasDate:1; | 30 | bool hasDate:1; |
30 | int priority; | 31 | int priority; |
31 | QString desc; | 32 | QString desc; |
32 | QString sum; | 33 | QString sum; |
33 | QMap<QString, QString> extra; | 34 | QMap<QString, QString> extra; |
34 | ushort prog; | 35 | ushort prog; |
35 | OPimState state; | 36 | OPimState state; |
36 | ORecur recur; | 37 | ORecur recur; |
37 | OPimMaintainer maintainer; | 38 | OPimMaintainer maintainer; |
38 | QDate start; | 39 | QDate start; |
39 | QDate completed; | 40 | QDate completed; |
40 | OPimNotifyManager notifiers; | 41 | OPimNotifyManager notifiers; |
41 | }; | 42 | }; |
42 | 43 | ||
43 | OTodo::OTodo(const OTodo &event ) | 44 | OTodo::OTodo(const OTodo &event ) |
44 | : OPimRecord( event ), data( event.data ) | 45 | : OPimRecord( event ), data( event.data ) |
45 | { | 46 | { |
46 | data->ref(); | 47 | data->ref(); |
47 | // qWarning("ref up"); | 48 | // qWarning("ref up"); |
48 | } | 49 | } |
49 | OTodo::~OTodo() { | 50 | OTodo::~OTodo() { |
50 | 51 | ||
51 | // qWarning("~OTodo " ); | 52 | // qWarning("~OTodo " ); |
52 | if ( data->deref() ) { | 53 | if ( data->deref() ) { |
53 | // qWarning("OTodo::dereffing"); | 54 | // qWarning("OTodo::dereffing"); |
54 | delete data; | 55 | delete data; |
55 | data = 0l; | 56 | data = 0l; |
56 | } | 57 | } |
57 | } | 58 | } |
58 | OTodo::OTodo(bool completed, int priority, | 59 | OTodo::OTodo(bool completed, int priority, |
59 | const QArray<int> &category, | 60 | const QArray<int> &category, |
60 | const QString& summary, | 61 | const QString& summary, |
61 | const QString &description, | 62 | const QString &description, |
62 | ushort progress, | 63 | ushort progress, |
63 | bool hasDate, QDate date, int uid ) | 64 | bool hasDate, QDate date, int uid ) |
64 | : OPimRecord( uid ) | 65 | : OPimRecord( uid ) |
65 | { | 66 | { |
66 | // qWarning("OTodoData " + summary); | 67 | // qWarning("OTodoData " + summary); |
@@ -372,50 +373,50 @@ QMap<int, QString> OTodo::toMap() const { | |||
372 | } | 373 | } |
373 | 374 | ||
374 | QMap<QString, QString> OTodo::toExtraMap()const { | 375 | QMap<QString, QString> OTodo::toExtraMap()const { |
375 | return data->extra; | 376 | return data->extra; |
376 | } | 377 | } |
377 | /** | 378 | /** |
378 | * change or modify looks at the ref count and either | 379 | * change or modify looks at the ref count and either |
379 | * creates a new QShared Object or it can modify it | 380 | * creates a new QShared Object or it can modify it |
380 | * right in place | 381 | * right in place |
381 | */ | 382 | */ |
382 | void OTodo::changeOrModify() { | 383 | void OTodo::changeOrModify() { |
383 | if ( data->count != 1 ) { | 384 | if ( data->count != 1 ) { |
384 | qWarning("changeOrModify"); | 385 | qWarning("changeOrModify"); |
385 | data->deref(); | 386 | data->deref(); |
386 | OTodoData* d2 = new OTodoData(); | 387 | OTodoData* d2 = new OTodoData(); |
387 | copy(data, d2 ); | 388 | copy(data, d2 ); |
388 | data = d2; | 389 | data = d2; |
389 | } | 390 | } |
390 | } | 391 | } |
391 | // WATCHOUT | 392 | // WATCHOUT |
392 | /* | 393 | /* |
393 | * if you add something to the Data struct | 394 | * if you add something to the Data struct |
394 | * be sure to copy it here | 395 | * be sure to copy it here |
395 | */ | 396 | */ |
396 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { | 397 | void OTodo::copy( OTodoData* src, OTodoData* dest ) { |
397 | dest->date = src->date; | 398 | dest->date = src->date; |
398 | dest->isCompleted = src->isCompleted; | 399 | dest->isCompleted = src->isCompleted; |
399 | dest->hasDate = src->hasDate; | 400 | dest->hasDate = src->hasDate; |
400 | dest->priority = src->priority; | 401 | dest->priority = src->priority; |
401 | dest->desc = src->desc; | 402 | dest->desc = src->desc; |
402 | dest->sum = src->sum; | 403 | dest->sum = src->sum; |
403 | dest->extra = src->extra; | 404 | dest->extra = src->extra; |
404 | dest->prog = src->prog; | 405 | dest->prog = src->prog; |
405 | dest->state = src->state; | 406 | dest->state = src->state; |
406 | dest->recur = src->recur; | 407 | dest->recur = src->recur; |
407 | dest->maintainer = src->maintainer; | 408 | dest->maintainer = src->maintainer; |
408 | dest->start = src->start; | 409 | dest->start = src->start; |
409 | dest->completed = src->completed; | 410 | dest->completed = src->completed; |
410 | dest->notifiers = src->notifiers; | 411 | dest->notifiers = src->notifiers; |
411 | } | 412 | } |
412 | QString OTodo::type() const { | 413 | QString OTodo::type() const { |
413 | return QString::fromLatin1("OTodo"); | 414 | return QString::fromLatin1("OTodo"); |
414 | } | 415 | } |
415 | QString OTodo::recordField(int /*id*/ )const { | 416 | QString OTodo::recordField(int /*id*/ )const { |
416 | return QString::null; | 417 | return QString::null; |
417 | } | 418 | } |
418 | 419 | ||
419 | int OTodo::rtti(){ | 420 | int OTodo::rtti(){ |
420 | return 1; | 421 | return OPimResolver::TodoList; |
421 | } | 422 | } |
diff --git a/libopie/pim/otodoaccess.cpp b/libopie/pim/otodoaccess.cpp index d860411..5e89a1b 100644 --- a/libopie/pim/otodoaccess.cpp +++ b/libopie/pim/otodoaccess.cpp | |||
@@ -1,86 +1,56 @@ | |||
1 | #include <qdatetime.h> | 1 | #include <qdatetime.h> |
2 | 2 | ||
3 | #include <qpe/alarmserver.h> | 3 | #include <qpe/alarmserver.h> |
4 | 4 | ||
5 | // #include "otodoaccesssql.h" | 5 | // #include "otodoaccesssql.h" |
6 | #include "otodoaccess.h" | 6 | #include "otodoaccess.h" |
7 | #include "obackendfactory.h" | 7 | #include "obackendfactory.h" |
8 | 8 | ||
9 | OTodoAccess::OTodoAccess( OTodoAccessBackend* end ) | 9 | OTodoAccess::OTodoAccess( OTodoAccessBackend* end, enum Access ) |
10 | : QObject(), OPimAccessTemplate<OTodo>( end ), m_todoBackEnd( end ) | 10 | : QObject(), OPimAccessTemplate<OTodo>( end ), m_todoBackEnd( end ) |
11 | { | 11 | { |
12 | // if (end == 0l ) | 12 | // if (end == 0l ) |
13 | // m_todoBackEnd = new OTodoAccessBackendSQL( QString::null); | 13 | // m_todoBackEnd = new OTodoAccessBackendSQL( QString::null); |
14 | 14 | ||
15 | // Zecke: Du musst hier noch für das XML-Backend einen Appnamen übergeben ! | 15 | // Zecke: Du musst hier noch für das XML-Backend einen Appnamen übergeben ! |
16 | if (end == 0l ) | 16 | if (end == 0l ) |
17 | m_todoBackEnd = OBackendFactory<OTodoAccessBackend>::Default ("todo", QString::null); | 17 | m_todoBackEnd = OBackendFactory<OTodoAccessBackend>::Default ("todo", QString::null); |
18 | 18 | ||
19 | setBackEnd( m_todoBackEnd ); | 19 | setBackEnd( m_todoBackEnd ); |
20 | } | 20 | } |
21 | OTodoAccess::~OTodoAccess() { | 21 | OTodoAccess::~OTodoAccess() { |
22 | // qWarning("~OTodoAccess"); | 22 | // qWarning("~OTodoAccess"); |
23 | } | 23 | } |
24 | void OTodoAccess::mergeWith( const QValueList<OTodo>& list ) { | 24 | void OTodoAccess::mergeWith( const QValueList<OTodo>& list ) { |
25 | QValueList<OTodo>::ConstIterator it; | 25 | QValueList<OTodo>::ConstIterator it; |
26 | for ( it = list.begin(); it != list.end(); ++it ) { | 26 | for ( it = list.begin(); it != list.end(); ++it ) { |
27 | replace( (*it) ); | 27 | replace( (*it) ); |
28 | } | 28 | } |
29 | } | 29 | } |
30 | OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, | 30 | OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, |
31 | const QDate& end, | 31 | const QDate& end, |
32 | bool includeNoDates ) { | 32 | bool includeNoDates ) { |
33 | QArray<int> ints = m_todoBackEnd->effectiveToDos( start, end, includeNoDates ); | 33 | QArray<int> ints = m_todoBackEnd->effectiveToDos( start, end, includeNoDates ); |
34 | 34 | ||
35 | List lis( ints, this ); | 35 | List lis( ints, this ); |
36 | return lis; | 36 | return lis; |
37 | } | 37 | } |
38 | OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, | 38 | OTodoAccess::List OTodoAccess::effectiveToDos( const QDate& start, |
39 | bool includeNoDates ) { | 39 | bool includeNoDates ) { |
40 | return effectiveToDos( start, QDate::currentDate(), | 40 | return effectiveToDos( start, QDate::currentDate(), |
41 | includeNoDates ); | 41 | includeNoDates ); |
42 | } | 42 | } |
43 | OTodoAccess::List OTodoAccess::overDue() { | 43 | OTodoAccess::List OTodoAccess::overDue() { |
44 | List lis( m_todoBackEnd->overDue(), this ); | 44 | List lis( m_todoBackEnd->overDue(), this ); |
45 | return lis; | 45 | return lis; |
46 | } | 46 | } |
47 | void OTodoAccess::addAlarm( const OTodo& event) { | ||
48 | /* FIXME use the new notifier architecture | ||
49 | if (!event.hasAlarmDateTime() ) | ||
50 | return; | ||
51 | |||
52 | QDateTime now = QDateTime::currentDateTime(); | ||
53 | QDateTime schedule = event.alarmDateTime(); | ||
54 | |||
55 | if ( schedule > now ){ | ||
56 | AlarmServer::addAlarm( schedule, | ||
57 | "QPE/Application/todolist", | ||
58 | "alarm(QDateTime,int)", event.uid() ); | ||
59 | |||
60 | } | ||
61 | */ | ||
62 | } | ||
63 | void OTodoAccess::delAlarm( int uid) { | ||
64 | |||
65 | QDateTime schedule; // Create null DateTime | ||
66 | |||
67 | // I hope this will remove all scheduled alarms | ||
68 | // with the given uid !? | ||
69 | // If not: I have to rethink how to remove already | ||
70 | // scheduled events... (se) | ||
71 | // it should be fine -zecke | ||
72 | // qWarning("Removing alarm for event with uid %d", uid ); | ||
73 | AlarmServer::deleteAlarm( schedule , | ||
74 | "QPE/Application/todolist", | ||
75 | "alarm(QDateTime,int)", uid ); | ||
76 | } | ||
77 | /* sort order */ | 47 | /* sort order */ |
78 | OTodoAccess::List OTodoAccess::sorted( bool ascending, int sort,int filter, int cat ) { | 48 | OTodoAccess::List OTodoAccess::sorted( bool ascending, int sort,int filter, int cat ) { |
79 | QArray<int> ints = m_todoBackEnd->sorted( ascending, sort, | 49 | QArray<int> ints = m_todoBackEnd->sorted( ascending, sort, |
80 | filter, cat ); | 50 | filter, cat ); |
81 | OTodoAccess::List list( ints, this ); | 51 | OTodoAccess::List list( ints, this ); |
82 | return list; | 52 | return list; |
83 | } | 53 | } |
84 | void OTodoAccess::removeAllCompleted() { | 54 | void OTodoAccess::removeAllCompleted() { |
85 | m_todoBackEnd->removeAllCompleted(); | 55 | m_todoBackEnd->removeAllCompleted(); |
86 | } | 56 | } |
diff --git a/libopie/pim/otodoaccess.h b/libopie/pim/otodoaccess.h index c079155..2bb87dc 100644 --- a/libopie/pim/otodoaccess.h +++ b/libopie/pim/otodoaccess.h | |||
@@ -1,98 +1,87 @@ | |||
1 | #ifndef OPIE_TODO_ACCESS_H | 1 | #ifndef OPIE_TODO_ACCESS_H |
2 | #define OPIE_TODO_ACCESS_H | 2 | #define OPIE_TODO_ACCESS_H |
3 | 3 | ||
4 | #include <qobject.h> | 4 | #include <qobject.h> |
5 | #include <qvaluelist.h> | 5 | #include <qvaluelist.h> |
6 | 6 | ||
7 | #include "otodo.h" | 7 | #include "otodo.h" |
8 | #include "otodoaccessbackend.h" | 8 | #include "otodoaccessbackend.h" |
9 | #include "opimaccesstemplate.h" | 9 | #include "opimaccesstemplate.h" |
10 | 10 | ||
11 | 11 | ||
12 | /** | 12 | /** |
13 | * OTodoAccess | 13 | * OTodoAccess |
14 | * the class to get access to | 14 | * the class to get access to |
15 | * the todolist | 15 | * the todolist |
16 | */ | 16 | */ |
17 | class OTodoAccess : public QObject, public OPimAccessTemplate<OTodo> { | 17 | class OTodoAccess : public QObject, public OPimAccessTemplate<OTodo> { |
18 | Q_OBJECT | 18 | Q_OBJECT |
19 | public: | 19 | public: |
20 | enum SortOrder { Completed = 0, | 20 | enum SortOrder { Completed = 0, |
21 | Priority, | 21 | Priority, |
22 | Description, | 22 | Description, |
23 | Deadline }; | 23 | Deadline }; |
24 | enum SortFilter{ Category =1, | 24 | enum SortFilter{ Category =1, |
25 | OnlyOverDue= 2, | 25 | OnlyOverDue= 2, |
26 | DoNotShowCompleted =4 }; | 26 | DoNotShowCompleted =4 }; |
27 | /** | 27 | /** |
28 | * if you use 0l | 28 | * if you use 0l |
29 | * the default resource will be | 29 | * the default resource will be |
30 | * picked up | 30 | * picked up |
31 | */ | 31 | */ |
32 | OTodoAccess( OTodoAccessBackend* = 0l); | 32 | OTodoAccess( OTodoAccessBackend* = 0l, enum Access acc = Random ); |
33 | ~OTodoAccess(); | 33 | ~OTodoAccess(); |
34 | 34 | ||
35 | 35 | ||
36 | /* our functions here */ | 36 | /* our functions here */ |
37 | /** | 37 | /** |
38 | * include todos from start to end | 38 | * include todos from start to end |
39 | * includeNoDates whether or not to include | 39 | * includeNoDates whether or not to include |
40 | * events with no dates | 40 | * events with no dates |
41 | */ | 41 | */ |
42 | List effectiveToDos( const QDate& start, | 42 | List effectiveToDos( const QDate& start, |
43 | const QDate& end, | 43 | const QDate& end, |
44 | bool includeNoDates = true ); | 44 | bool includeNoDates = true ); |
45 | 45 | ||
46 | /** | 46 | /** |
47 | * start | 47 | * start |
48 | * end date taken from the currentDate() | 48 | * end date taken from the currentDate() |
49 | */ | 49 | */ |
50 | List effectiveToDos( const QDate& start, | 50 | List effectiveToDos( const QDate& start, |
51 | bool includeNoDates = true ); | 51 | bool includeNoDates = true ); |
52 | 52 | ||
53 | 53 | ||
54 | /** | 54 | /** |
55 | * return overdue OTodos | 55 | * return overdue OTodos |
56 | */ | 56 | */ |
57 | List overDue(); | 57 | List overDue(); |
58 | 58 | ||
59 | /** | 59 | /** |
60 | * | 60 | * |
61 | */ | 61 | */ |
62 | List sorted( bool ascending, int sortOrder, int sortFilter, int cat ); | 62 | List sorted( bool ascending, int sortOrder, int sortFilter, int cat ); |
63 | 63 | ||
64 | /** | 64 | /** |
65 | * merge a list of OTodos into | 65 | * merge a list of OTodos into |
66 | * the resource | 66 | * the resource |
67 | */ | 67 | */ |
68 | void mergeWith( const QValueList<OTodo>& ); | 68 | void mergeWith( const QValueList<OTodo>& ); |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * delete all already completed items | 71 | * delete all already completed items |
72 | */ | 72 | */ |
73 | void removeAllCompleted(); | 73 | void removeAllCompleted(); |
74 | 74 | ||
75 | signals: | 75 | signals: |
76 | /** | 76 | /** |
77 | * if the OTodoAccess was changed | 77 | * if the OTodoAccess was changed |
78 | */ | 78 | */ |
79 | void signalChanged( const OTodoAccess* ); | 79 | void signalChanged( const OTodoAccess* ); |
80 | private: | 80 | private: |
81 | /** | ||
82 | * add an Alarm to the AlarmServer | ||
83 | */ | ||
84 | void addAlarm( const OTodo& ); | ||
85 | |||
86 | /** | ||
87 | * delete an alarm with the uid from | ||
88 | * the alarm server | ||
89 | */ | ||
90 | void delAlarm( int uid ); | ||
91 | |||
92 | int m_cat; | 81 | int m_cat; |
93 | OTodoAccessBackend* m_todoBackEnd; | 82 | OTodoAccessBackend* m_todoBackEnd; |
94 | class OTodoAccessPrivate; | 83 | class OTodoAccessPrivate; |
95 | OTodoAccessPrivate* d; | 84 | OTodoAccessPrivate* d; |
96 | }; | 85 | }; |
97 | 86 | ||
98 | #endif | 87 | #endif |
diff --git a/libopie/pim/otodoaccessxml.cpp b/libopie/pim/otodoaccessxml.cpp index b2dfe80..21f93a0 100644 --- a/libopie/pim/otodoaccessxml.cpp +++ b/libopie/pim/otodoaccessxml.cpp | |||
@@ -1,181 +1,210 @@ | |||
1 | #include <errno.h> | ||
2 | #include <fcntl.h> | ||
3 | |||
4 | #include <sys/mman.h> | ||
5 | #include <sys/stat.h> | ||
6 | #include <sys/types.h> | ||
7 | |||
8 | #include <unistd.h> | ||
9 | |||
10 | |||
1 | #include <qfile.h> | 11 | #include <qfile.h> |
2 | #include <qvector.h> | 12 | #include <qvector.h> |
3 | 13 | ||
4 | #include <qpe/global.h> | 14 | #include <qpe/global.h> |
5 | #include <qpe/stringutil.h> | 15 | #include <qpe/stringutil.h> |
6 | #include <qpe/timeconversion.h> | 16 | #include <qpe/timeconversion.h> |
7 | 17 | ||
8 | #include <opie/xmltree.h> | 18 | #include <opie/xmltree.h> |
9 | 19 | ||
10 | #include "otodoaccessxml.h" | 20 | #include "otodoaccessxml.h" |
11 | 21 | ||
12 | OTodoAccessXML::OTodoAccessXML( const QString& appName, | 22 | OTodoAccessXML::OTodoAccessXML( const QString& appName, |
13 | const QString& fileName ) | 23 | const QString& fileName ) |
14 | : OTodoAccessBackend(), m_app( appName ), m_opened( false ), m_changed( false ) | 24 | : OTodoAccessBackend(), m_app( appName ), m_opened( false ), m_changed( false ) |
15 | { | 25 | { |
16 | if (!fileName.isEmpty() ) | 26 | if (!fileName.isEmpty() ) |
17 | m_file = fileName; | 27 | m_file = fileName; |
18 | else | 28 | else |
19 | m_file = Global::applicationFileName( "todolist", "todolist.xml" ); | 29 | m_file = Global::applicationFileName( "todolist", "todolist.xml" ); |
20 | } | 30 | } |
21 | OTodoAccessXML::~OTodoAccessXML() { | 31 | OTodoAccessXML::~OTodoAccessXML() { |
22 | 32 | ||
23 | } | 33 | } |
24 | bool OTodoAccessXML::load() { | 34 | bool OTodoAccessXML::load() { |
25 | m_opened = true; | 35 | m_opened = true; |
26 | m_changed = false; | 36 | m_changed = false; |
27 | /* initialize dict */ | 37 | /* initialize dict */ |
28 | /* | 38 | /* |
29 | * UPDATE dict if you change anything!!! | 39 | * UPDATE dict if you change anything!!! |
30 | */ | 40 | */ |
31 | QAsciiDict<int> dict(21); | 41 | QAsciiDict<int> dict(21); |
32 | dict.setAutoDelete( TRUE ); | 42 | dict.setAutoDelete( TRUE ); |
33 | dict.insert("Categories" , new int(OTodo::Category) ); | 43 | dict.insert("Categories" , new int(OTodo::Category) ); |
34 | dict.insert("Uid" , new int(OTodo::Uid) ); | 44 | dict.insert("Uid" , new int(OTodo::Uid) ); |
35 | dict.insert("HasDate" , new int(OTodo::HasDate) ); | 45 | dict.insert("HasDate" , new int(OTodo::HasDate) ); |
36 | dict.insert("Completed" , new int(OTodo::Completed) ); | 46 | dict.insert("Completed" , new int(OTodo::Completed) ); |
37 | dict.insert("Description" , new int(OTodo::Description) ); | 47 | dict.insert("Description" , new int(OTodo::Description) ); |
38 | dict.insert("Summary" , new int(OTodo::Summary) ); | 48 | dict.insert("Summary" , new int(OTodo::Summary) ); |
39 | dict.insert("Priority" , new int(OTodo::Priority) ); | 49 | dict.insert("Priority" , new int(OTodo::Priority) ); |
40 | dict.insert("DateDay" , new int(OTodo::DateDay) ); | 50 | dict.insert("DateDay" , new int(OTodo::DateDay) ); |
41 | dict.insert("DateMonth" , new int(OTodo::DateMonth) ); | 51 | dict.insert("DateMonth" , new int(OTodo::DateMonth) ); |
42 | dict.insert("DateYear" , new int(OTodo::DateYear) ); | 52 | dict.insert("DateYear" , new int(OTodo::DateYear) ); |
43 | dict.insert("Progress" , new int(OTodo::Progress) ); | 53 | dict.insert("Progress" , new int(OTodo::Progress) ); |
44 | dict.insert("Completed", new int(OTodo::Completed) ); | 54 | dict.insert("Completed", new int(OTodo::Completed) ); |
45 | dict.insert("CrossReference", new int(OTodo::CrossReference) ); | 55 | dict.insert("CrossReference", new int(OTodo::CrossReference) ); |
46 | dict.insert("State", new int(OTodo::State) ); | 56 | dict.insert("State", new int(OTodo::State) ); |
47 | dict.insert("Recurrence", new int(OTodo::Recurrence) ); | 57 | dict.insert("Recurrence", new int(OTodo::Recurrence) ); |
48 | dict.insert("Alarms", new int(OTodo::Alarms) ); | 58 | dict.insert("Alarms", new int(OTodo::Alarms) ); |
49 | dict.insert("Reminders", new int(OTodo::Reminders) ); | 59 | dict.insert("Reminders", new int(OTodo::Reminders) ); |
50 | dict.insert("Notifiers", new int(OTodo::Notifiers) ); | 60 | dict.insert("Notifiers", new int(OTodo::Notifiers) ); |
51 | dict.insert("Maintainer", new int(OTodo::Maintainer) ); | 61 | dict.insert("Maintainer", new int(OTodo::Maintainer) ); |
52 | 62 | ||
53 | // here the custom XML parser from TT it's GPL | 63 | // here the custom XML parser from TT it's GPL |
54 | // but we want to push OpiePIM... to TT..... | 64 | // but we want to push OpiePIM... to TT..... |
55 | QFile f(m_file ); | 65 | // mmap part from zecke :) |
56 | if (!f.open(IO_ReadOnly) ) | 66 | int fd = ::open( QFile::encodeName(m_file).data(), O_RDONLY ); |
67 | struct stat attribut; | ||
68 | if ( fd < 0 ) return false; | ||
69 | |||
70 | if ( fstat(fd, &attribut ) == -1 ) { | ||
71 | ::close( fd ); | ||
57 | return false; | 72 | return false; |
73 | } | ||
74 | void* map_addr = ::mmap(NULL, attribut.st_size, PROT_READ, MAP_SHARED, fd, 0 ); | ||
75 | if ( map_addr == ( (caddr_t)-1) ) { | ||
76 | ::close(fd ); | ||
77 | return false; | ||
78 | } | ||
79 | /* advise the kernel who we want to read it */ | ||
80 | ::madvise( map_addr, attribut.st_size, MADV_SEQUENTIAL ); | ||
81 | /* we do not the file any more */ | ||
82 | ::close( fd ); | ||
58 | 83 | ||
59 | QByteArray ba = f.readAll(); | 84 | char* dt = (char*)map_addr; |
60 | f.close(); | 85 | int len = attribut.st_size; |
61 | char* dt = ba.data(); | ||
62 | int len = ba.size(); | ||
63 | int i = 0; | 86 | int i = 0; |
64 | char *point; | 87 | char *point; |
65 | const char* collectionString = "<Task "; | 88 | const char* collectionString = "<Task "; |
89 | int strLen = strlen(collectionString); | ||
66 | while ( dt+i != 0 && ( point = strstr( dt+i, collectionString ) ) != 0l ) { | 90 | while ( dt+i != 0 && ( point = strstr( dt+i, collectionString ) ) != 0l ) { |
67 | i = point -dt; | 91 | i = point -dt; |
68 | i+= strlen(collectionString); | 92 | i+= strLen; |
93 | qWarning("Found a start at %d %d", i, (point-dt) ); | ||
94 | |||
69 | OTodo ev; | 95 | OTodo ev; |
70 | m_year = m_month = m_day = 0; | 96 | m_year = m_month = m_day = 0; |
71 | 97 | ||
72 | while ( TRUE ) { | 98 | while ( TRUE ) { |
73 | while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') ) | 99 | while ( i < len && (dt[i] == ' ' || dt[i] == '\n' || dt[i] == '\r') ) |
74 | ++i; | 100 | ++i; |
75 | if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') ) | 101 | if ( i >= len-2 || (dt[i] == '/' && dt[i+1] == '>') ) |
76 | break; | 102 | break; |
77 | 103 | ||
78 | // we have another attribute, read it. | 104 | // we have another attribute, read it. |
79 | int j = i; | 105 | int j = i; |
80 | while ( j < len && dt[j] != '=' ) | 106 | while ( j < len && dt[j] != '=' ) |
81 | ++j; | 107 | ++j; |
82 | QCString attr( dt+i, j-i+1); | 108 | QCString attr( dt+i, j-i+1); |
83 | 109 | ||
84 | i = ++j; // skip = | 110 | i = ++j; // skip = |
85 | 111 | ||
86 | // find the start of quotes | 112 | // find the start of quotes |
87 | while ( i < len && dt[i] != '"' ) | 113 | while ( i < len && dt[i] != '"' ) |
88 | ++i; | 114 | ++i; |
89 | j = ++i; | 115 | j = ++i; |
90 | 116 | ||
91 | bool haveUtf = FALSE; | 117 | bool haveUtf = FALSE; |
92 | bool haveEnt = FALSE; | 118 | bool haveEnt = FALSE; |
93 | while ( j < len && dt[j] != '"' ) { | 119 | while ( j < len && dt[j] != '"' ) { |
94 | if ( ((unsigned char)dt[j]) > 0x7f ) | 120 | if ( ((unsigned char)dt[j]) > 0x7f ) |
95 | haveUtf = TRUE; | 121 | haveUtf = TRUE; |
96 | if ( dt[j] == '&' ) | 122 | if ( dt[j] == '&' ) |
97 | haveEnt = TRUE; | 123 | haveEnt = TRUE; |
98 | ++j; | 124 | ++j; |
99 | } | 125 | } |
100 | if ( i == j ) { | 126 | if ( i == j ) { |
101 | // empty value | 127 | // empty value |
102 | i = j + 1; | 128 | i = j + 1; |
103 | continue; | 129 | continue; |
104 | } | 130 | } |
105 | 131 | ||
106 | QCString value( dt+i, j-i+1 ); | 132 | QCString value( dt+i, j-i+1 ); |
107 | i = j + 1; | 133 | i = j + 1; |
108 | 134 | ||
109 | QString str = (haveUtf ? QString::fromUtf8( value ) | 135 | QString str = (haveUtf ? QString::fromUtf8( value ) |
110 | : QString::fromLatin1( value ) ); | 136 | : QString::fromLatin1( value ) ); |
111 | if ( haveEnt ) | 137 | if ( haveEnt ) |
112 | str = Qtopia::plainString( str ); | 138 | str = Qtopia::plainString( str ); |
113 | 139 | ||
114 | /* | 140 | /* |
115 | * add key + value | 141 | * add key + value |
116 | */ | 142 | */ |
117 | todo( &dict, ev, attr, str ); | 143 | todo( &dict, ev, attr, str ); |
118 | 144 | ||
119 | } | 145 | } |
120 | /* | 146 | /* |
121 | * now add it | 147 | * now add it |
122 | */ | 148 | */ |
149 | qWarning("End at %d", i ); | ||
123 | if (m_events.contains( ev.uid() ) || ev.uid() == 0) { | 150 | if (m_events.contains( ev.uid() ) || ev.uid() == 0) { |
124 | ev.setUid( 1 ); | 151 | ev.setUid( 1 ); |
125 | m_changed = true; | 152 | m_changed = true; |
126 | } | 153 | } |
127 | if ( ev.hasDueDate() ) { | 154 | if ( ev.hasDueDate() ) { |
128 | ev.setDueDate( QDate(m_year, m_month, m_day) ); | 155 | ev.setDueDate( QDate(m_year, m_month, m_day) ); |
129 | } | 156 | } |
130 | m_events.insert(ev.uid(), ev ); | 157 | m_events.insert(ev.uid(), ev ); |
131 | m_year = m_month = m_day = -1; | 158 | m_year = m_month = m_day = -1; |
132 | } | 159 | } |
133 | 160 | ||
161 | munmap(map_addr, attribut.st_size ); | ||
162 | |||
134 | qWarning("counts %d records loaded!", m_events.count() ); | 163 | qWarning("counts %d records loaded!", m_events.count() ); |
135 | return true; | 164 | return true; |
136 | } | 165 | } |
137 | bool OTodoAccessXML::reload() { | 166 | bool OTodoAccessXML::reload() { |
138 | return load(); | 167 | return load(); |
139 | } | 168 | } |
140 | bool OTodoAccessXML::save() { | 169 | bool OTodoAccessXML::save() { |
141 | // qWarning("saving"); | 170 | // qWarning("saving"); |
142 | if (!m_opened || !m_changed ) { | 171 | if (!m_opened || !m_changed ) { |
143 | // qWarning("not saving"); | 172 | // qWarning("not saving"); |
144 | return true; | 173 | return true; |
145 | } | 174 | } |
146 | QString strNewFile = m_file + ".new"; | 175 | QString strNewFile = m_file + ".new"; |
147 | QFile f( strNewFile ); | 176 | QFile f( strNewFile ); |
148 | if (!f.open( IO_WriteOnly|IO_Raw ) ) | 177 | if (!f.open( IO_WriteOnly|IO_Raw ) ) |
149 | return false; | 178 | return false; |
150 | 179 | ||
151 | int written; | 180 | int written; |
152 | QString out; | 181 | QString out; |
153 | out = "<!DOCTYPE Tasks>\n<Tasks>\n"; | 182 | out = "<!DOCTYPE Tasks>\n<Tasks>\n"; |
154 | 183 | ||
155 | // for all todos | 184 | // for all todos |
156 | QMap<int, OTodo>::Iterator it; | 185 | QMap<int, OTodo>::Iterator it; |
157 | for (it = m_events.begin(); it != m_events.end(); ++it ) { | 186 | for (it = m_events.begin(); it != m_events.end(); ++it ) { |
158 | out+= "<Task " + toString( (*it) ) + " />\n"; | 187 | out+= "<Task " + toString( (*it) ) + " />\n"; |
159 | QCString cstr = out.utf8(); | 188 | QCString cstr = out.utf8(); |
160 | written = f.writeBlock( cstr.data(), cstr.length() ); | 189 | written = f.writeBlock( cstr.data(), cstr.length() ); |
161 | 190 | ||
162 | /* less written then we wanted */ | 191 | /* less written then we wanted */ |
163 | if ( written != (int)cstr.length() ) { | 192 | if ( written != (int)cstr.length() ) { |
164 | f.close(); | 193 | f.close(); |
165 | QFile::remove( strNewFile ); | 194 | QFile::remove( strNewFile ); |
166 | return false; | 195 | return false; |
167 | } | 196 | } |
168 | out = QString::null; | 197 | out = QString::null; |
169 | } | 198 | } |
170 | 199 | ||
171 | out += "</Tasks>"; | 200 | out += "</Tasks>"; |
172 | QCString cstr = out.utf8(); | 201 | QCString cstr = out.utf8(); |
173 | written = f.writeBlock( cstr.data(), cstr.length() ); | 202 | written = f.writeBlock( cstr.data(), cstr.length() ); |
174 | 203 | ||
175 | if ( written != (int)cstr.length() ) { | 204 | if ( written != (int)cstr.length() ) { |
176 | f.close(); | 205 | f.close(); |
177 | QFile::remove( strNewFile ); | 206 | QFile::remove( strNewFile ); |
178 | return false; | 207 | return false; |
179 | } | 208 | } |
180 | /* flush before renaming */ | 209 | /* flush before renaming */ |
181 | f.close(); | 210 | f.close(); |