summaryrefslogtreecommitdiff
authoreilers <eilers>2002-10-02 16:18:11 (UTC)
committer eilers <eilers>2002-10-02 16:18:11 (UTC)
commit1400bbe439c47f0bd168d602d961235c638a861b (patch) (unidiff)
tree2612a28330ee6b48d6f06b476448cee66308c9f3
parent140d28d0fd72015616351702f085ca9f0c9a959c (diff)
downloadopie-1400bbe439c47f0bd168d602d961235c638a861b.zip
opie-1400bbe439c47f0bd168d602d961235c638a861b.tar.gz
opie-1400bbe439c47f0bd168d602d961235c638a861b.tar.bz2
debugged and seems to work almost perfectly ..
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/pim/ocontactaccess.cpp8
-rw-r--r--libopie2/opiepim/core/ocontactaccess.cpp8
2 files changed, 14 insertions, 2 deletions
diff --git a/libopie/pim/ocontactaccess.cpp b/libopie/pim/ocontactaccess.cpp
index 2d808f7..8a8ff08 100644
--- a/libopie/pim/ocontactaccess.cpp
+++ b/libopie/pim/ocontactaccess.cpp
@@ -1,109 +1,115 @@
1/* 1/*
2 * Class to manage the Contacts. 2 * Class to manage the Contacts.
3 * 3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 * 5 *
6 * ===================================================================== 6 * =====================================================================
7 *This program is free software; you can redistribute it and/or 7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public 8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either 9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version. 10 * version 2 of the License, or (at your option) any later version.
11 * ===================================================================== 11 * =====================================================================
12 * Info: This class could just work with a change in the header-file 12 * Info: This class could just work with a change in the header-file
13 * of the Contact class ! Therefore our libopie only compiles 13 * of the Contact class ! Therefore our libopie only compiles
14 * with our version of libqpe 14 * with our version of libqpe
15 * ===================================================================== 15 * =====================================================================
16 * ToDo: XML-Backend: Automatic reload if something was changed... 16 * ToDo: XML-Backend: Automatic reload if something was changed...
17 * 17 *
18 * 18 *
19 * ===================================================================== 19 * =====================================================================
20 * Version: $Id$ 20 * Version: $Id$
21 * ===================================================================== 21 * =====================================================================
22 * History: 22 * History:
23 * $Log$ 23 * $Log$
24 * Revision 1.2 2002/10/02 16:18:11 eilers
25 * debugged and seems to work almost perfectly ..
26 *
24 * Revision 1.1 2002/09/27 17:11:44 eilers 27 * Revision 1.1 2002/09/27 17:11:44 eilers
25 * Added API for accessing the Contact-Database ! It is compiling, but 28 * Added API for accessing the Contact-Database ! It is compiling, but
26 * please do not expect that anything is working ! 29 * please do not expect that anything is working !
27 * I will debug that stuff in the next time .. 30 * I will debug that stuff in the next time ..
28 * Please read README_COMPILE for compiling ! 31 * Please read README_COMPILE for compiling !
29 * 32 *
30 * 33 *
31 */ 34 */
32 35
33#include "ocontactaccess.h" 36#include "ocontactaccess.h"
34 37
35#include <qasciidict.h> 38#include <qasciidict.h>
36#include <qdatetime.h> 39#include <qdatetime.h>
37#include <qfile.h> 40#include <qfile.h>
38#include <qregexp.h> 41#include <qregexp.h>
39#include <qlist.h> 42#include <qlist.h>
40#include <qcopchannel_qws.h> 43#include <qcopchannel_qws.h>
41 44
42//#include <qpe/qcopenvelope_qws.h> 45//#include <qpe/qcopenvelope_qws.h>
43#include <qpe/global.h> 46#include <qpe/global.h>
44 47
45#include <errno.h> 48#include <errno.h>
46#include <fcntl.h> 49#include <fcntl.h>
47#include <unistd.h> 50#include <unistd.h>
48#include <stdlib.h> 51#include <stdlib.h>
49 52
50#include "ocontactaccessbackend_xml.h" 53#include "ocontactaccessbackend_xml.h"
51 54
52 55
53OContactAccess::OContactAccess ( const QString appname, const QString filename, 56OContactAccess::OContactAccess ( const QString appname, const QString filename,
54 OContactAccessBackend* end, bool autosync ): 57 OContactAccessBackend* end, bool autosync ):
55 OPimAccessTemplate<OContact>( end ), 58 OPimAccessTemplate<OContact>( end ),
56 m_changed ( false ) 59 m_changed ( false )
57{ 60{
58 /* take care of the backend. If there is no one defined, we 61 /* take care of the backend. If there is no one defined, we
59 * will use the XML-Backend as default (until we have a cute SQL-Backend..). 62 * will use the XML-Backend as default (until we have a cute SQL-Backend..).
60 */ 63 */
61 if( end == 0 ) { 64 if( end == 0 ) {
62 end = new OContactAccessBackend_XML( appname, filename ); 65 end = new OContactAccessBackend_XML( appname, filename );
63 } 66 }
67 // Set backend locally and in template
64 m_backEnd = end; 68 m_backEnd = end;
69 OPimAccessTemplate<OContact>::setBackEnd (end);
70
65 71
66 /* Connect signal of external db change to function */ 72 /* Connect signal of external db change to function */
67 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this ); 73 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this );
68 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)), 74 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)),
69 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 75 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
70 if ( autosync ){ 76 if ( autosync ){
71 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this ); 77 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this );
72 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)), 78 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)),
73 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 79 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
74 } 80 }
75 81
76 82
77} 83}
78OContactAccess::~OContactAccess () 84OContactAccess::~OContactAccess ()
79{ 85{
80 /* The user may forget to save the changed database, therefore try to 86 /* The user may forget to save the changed database, therefore try to
81 * do it for him.. 87 * do it for him..
82 */ 88 */
83 if ( m_changed ) 89 if ( m_changed )
84 save(); 90 save();
85 delete m_backEnd; 91 // delete m_backEnd; is done by template..
86} 92}
87 93
88bool OContactAccess::load() 94bool OContactAccess::load()
89{ 95{
90 return ( m_backEnd->load() ); 96 return ( m_backEnd->load() );
91} 97}
92 98
93bool OContactAccess::save () 99bool OContactAccess::save ()
94{ 100{
95 /* If the database was changed externally, we could not save the 101 /* If the database was changed externally, we could not save the
96 * Data. This will remove added items which is unacceptable ! 102 * Data. This will remove added items which is unacceptable !
97 * Therefore: Reload database and merge the data... 103 * Therefore: Reload database and merge the data...
98 */ 104 */
99 if ( m_backEnd->wasChangedExternally() ) 105 if ( m_backEnd->wasChangedExternally() )
100 reload(); 106 reload();
101 107
102 if ( m_changed ){ 108 if ( m_changed ){
103 bool status = m_backEnd->save(); 109 bool status = m_backEnd->save();
104 if ( !status ) return false; 110 if ( !status ) return false;
105 111
106 m_changed = false; 112 m_changed = false;
107 /* Now tell everyone that new data is available. 113 /* Now tell everyone that new data is available.
108 */ 114 */
109 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" ); 115 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" );
diff --git a/libopie2/opiepim/core/ocontactaccess.cpp b/libopie2/opiepim/core/ocontactaccess.cpp
index 2d808f7..8a8ff08 100644
--- a/libopie2/opiepim/core/ocontactaccess.cpp
+++ b/libopie2/opiepim/core/ocontactaccess.cpp
@@ -1,109 +1,115 @@
1/* 1/*
2 * Class to manage the Contacts. 2 * Class to manage the Contacts.
3 * 3 *
4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de) 4 * Copyright (c) 2002 by Stefan Eilers (Eilers.Stefan@epost.de)
5 * 5 *
6 * ===================================================================== 6 * =====================================================================
7 *This program is free software; you can redistribute it and/or 7 *This program is free software; you can redistribute it and/or
8 *modify it under the terms of the GNU Library General Public 8 *modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either 9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version. 10 * version 2 of the License, or (at your option) any later version.
11 * ===================================================================== 11 * =====================================================================
12 * Info: This class could just work with a change in the header-file 12 * Info: This class could just work with a change in the header-file
13 * of the Contact class ! Therefore our libopie only compiles 13 * of the Contact class ! Therefore our libopie only compiles
14 * with our version of libqpe 14 * with our version of libqpe
15 * ===================================================================== 15 * =====================================================================
16 * ToDo: XML-Backend: Automatic reload if something was changed... 16 * ToDo: XML-Backend: Automatic reload if something was changed...
17 * 17 *
18 * 18 *
19 * ===================================================================== 19 * =====================================================================
20 * Version: $Id$ 20 * Version: $Id$
21 * ===================================================================== 21 * =====================================================================
22 * History: 22 * History:
23 * $Log$ 23 * $Log$
24 * Revision 1.2 2002/10/02 16:18:11 eilers
25 * debugged and seems to work almost perfectly ..
26 *
24 * Revision 1.1 2002/09/27 17:11:44 eilers 27 * Revision 1.1 2002/09/27 17:11:44 eilers
25 * Added API for accessing the Contact-Database ! It is compiling, but 28 * Added API for accessing the Contact-Database ! It is compiling, but
26 * please do not expect that anything is working ! 29 * please do not expect that anything is working !
27 * I will debug that stuff in the next time .. 30 * I will debug that stuff in the next time ..
28 * Please read README_COMPILE for compiling ! 31 * Please read README_COMPILE for compiling !
29 * 32 *
30 * 33 *
31 */ 34 */
32 35
33#include "ocontactaccess.h" 36#include "ocontactaccess.h"
34 37
35#include <qasciidict.h> 38#include <qasciidict.h>
36#include <qdatetime.h> 39#include <qdatetime.h>
37#include <qfile.h> 40#include <qfile.h>
38#include <qregexp.h> 41#include <qregexp.h>
39#include <qlist.h> 42#include <qlist.h>
40#include <qcopchannel_qws.h> 43#include <qcopchannel_qws.h>
41 44
42//#include <qpe/qcopenvelope_qws.h> 45//#include <qpe/qcopenvelope_qws.h>
43#include <qpe/global.h> 46#include <qpe/global.h>
44 47
45#include <errno.h> 48#include <errno.h>
46#include <fcntl.h> 49#include <fcntl.h>
47#include <unistd.h> 50#include <unistd.h>
48#include <stdlib.h> 51#include <stdlib.h>
49 52
50#include "ocontactaccessbackend_xml.h" 53#include "ocontactaccessbackend_xml.h"
51 54
52 55
53OContactAccess::OContactAccess ( const QString appname, const QString filename, 56OContactAccess::OContactAccess ( const QString appname, const QString filename,
54 OContactAccessBackend* end, bool autosync ): 57 OContactAccessBackend* end, bool autosync ):
55 OPimAccessTemplate<OContact>( end ), 58 OPimAccessTemplate<OContact>( end ),
56 m_changed ( false ) 59 m_changed ( false )
57{ 60{
58 /* take care of the backend. If there is no one defined, we 61 /* take care of the backend. If there is no one defined, we
59 * will use the XML-Backend as default (until we have a cute SQL-Backend..). 62 * will use the XML-Backend as default (until we have a cute SQL-Backend..).
60 */ 63 */
61 if( end == 0 ) { 64 if( end == 0 ) {
62 end = new OContactAccessBackend_XML( appname, filename ); 65 end = new OContactAccessBackend_XML( appname, filename );
63 } 66 }
67 // Set backend locally and in template
64 m_backEnd = end; 68 m_backEnd = end;
69 OPimAccessTemplate<OContact>::setBackEnd (end);
70
65 71
66 /* Connect signal of external db change to function */ 72 /* Connect signal of external db change to function */
67 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this ); 73 QCopChannel *dbchannel = new QCopChannel( "QPE/PIM", this );
68 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)), 74 connect( dbchannel, SIGNAL(received(const QCString &, const QByteArray &)),
69 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 75 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
70 if ( autosync ){ 76 if ( autosync ){
71 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this ); 77 QCopChannel *syncchannel = new QCopChannel( "QPE/Sync", this );
72 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)), 78 connect( syncchannel, SIGNAL(received(const QCString &, const QByteArray &)),
73 this, SLOT(copMessage( const QCString &, const QByteArray &)) ); 79 this, SLOT(copMessage( const QCString &, const QByteArray &)) );
74 } 80 }
75 81
76 82
77} 83}
78OContactAccess::~OContactAccess () 84OContactAccess::~OContactAccess ()
79{ 85{
80 /* The user may forget to save the changed database, therefore try to 86 /* The user may forget to save the changed database, therefore try to
81 * do it for him.. 87 * do it for him..
82 */ 88 */
83 if ( m_changed ) 89 if ( m_changed )
84 save(); 90 save();
85 delete m_backEnd; 91 // delete m_backEnd; is done by template..
86} 92}
87 93
88bool OContactAccess::load() 94bool OContactAccess::load()
89{ 95{
90 return ( m_backEnd->load() ); 96 return ( m_backEnd->load() );
91} 97}
92 98
93bool OContactAccess::save () 99bool OContactAccess::save ()
94{ 100{
95 /* If the database was changed externally, we could not save the 101 /* If the database was changed externally, we could not save the
96 * Data. This will remove added items which is unacceptable ! 102 * Data. This will remove added items which is unacceptable !
97 * Therefore: Reload database and merge the data... 103 * Therefore: Reload database and merge the data...
98 */ 104 */
99 if ( m_backEnd->wasChangedExternally() ) 105 if ( m_backEnd->wasChangedExternally() )
100 reload(); 106 reload();
101 107
102 if ( m_changed ){ 108 if ( m_changed ){
103 bool status = m_backEnd->save(); 109 bool status = m_backEnd->save();
104 if ( !status ) return false; 110 if ( !status ) return false;
105 111
106 m_changed = false; 112 m_changed = false;
107 /* Now tell everyone that new data is available. 113 /* Now tell everyone that new data is available.
108 */ 114 */
109 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" ); 115 QCopEnvelope e( "QPE/PIM", "addressbookUpdated()" );