Diffstat (limited to 'kabc/plugins/qtopia/resourceqtopia.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r-- | kabc/plugins/qtopia/resourceqtopia.cpp | 101 |
1 files changed, 81 insertions, 20 deletions
diff --git a/kabc/plugins/qtopia/resourceqtopia.cpp b/kabc/plugins/qtopia/resourceqtopia.cpp index deb218b..b7263bb 100644 --- a/kabc/plugins/qtopia/resourceqtopia.cpp +++ b/kabc/plugins/qtopia/resourceqtopia.cpp @@ -30,6 +30,7 @@ $Id$ #include <qdir.h> #include <qfile.h> +#include <qtextstream.h> #include <qfileinfo.h> #include <qregexp.h> //US #include <qtimer.h> @@ -90,8 +91,6 @@ ResourceQtopia::~ResourceQtopia() if (mConverter != 0) delete mConverter; - if(mAccess != 0) - delete mAccess; } void ResourceQtopia::writeConfig( KConfig *config ) @@ -120,13 +119,6 @@ bool ResourceQtopia::doOpen() { qDebug("ResourceQtopia::doOpen(): %s", fileName().latin1()); - mAccess = new AddressBookAccess(); - - if ( !mAccess ) { - qDebug("Unable to load file() %s", fileName().latin1()); - return false; - } - if (mConverter == 0) { @@ -136,8 +128,6 @@ bool ResourceQtopia::doOpen() { QString msg("Unable to initialize qtopia converter. Most likely a problem with the category file"); qDebug(msg); - delete mAccess; - mAccess = 0; return false; } } @@ -149,11 +139,7 @@ void ResourceQtopia::doClose() { qDebug("ResourceQtopia::doClose: %s", fileName().latin1()); - if(mAccess) - { - delete mAccess; - mAccess = 0; - } + // it seems so, that deletion of access deletes backend as well //delete backend; @@ -162,6 +148,47 @@ void ResourceQtopia::doClose() bool ResourceQtopia::load() { + + QFile file( fileName() ); + if ( !file.open(IO_ReadOnly ) ) { + return false; + } + + QDomDocument doc("mydocument" ); + if ( !doc.setContent( &file ) ) { + file.close(); + return false; + } + bool res; + QDomElement docElem = doc.documentElement( ); + QDomNode n = docElem.firstChild(); + while ( !n.isNull() ) { + QDomElement e = n.toElement(); + if ( !e.isNull() ) { + if ( e.tagName() == QString::fromLatin1( "Contacts" ) ) { // we're looking for them + QDomNode no = e.firstChild(); + while ( !no.isNull() ) { + QDomElement el = no.toElement(); + if ( !el.isNull() ) { + KABC::Addressee addressee; + res = mConverter->qtopiaToAddressee( el, addressee ); + if ( !addressee.isEmpty() && res ) + { + addressee.setResource( this ); + addressBook()->insertAddressee( addressee ); + } + } + + no = no.nextSibling(); + } + } + } + + n = n.nextSibling(); + } + +#if 0 +/ old code qDebug("ResourceQtopia::load: %s", fileName().latin1()); AddressBookIterator it(*mAccess); @@ -174,7 +201,7 @@ bool ResourceQtopia::load() KABC::Addressee addressee; - res = mConverter->qtopiaToAddressee( (*contact), addressee ); + //LRres = mConverter->qtopiaToAddressee( (*contact), addressee ); if ( !addressee.isEmpty() && res ) { @@ -182,12 +209,46 @@ bool ResourceQtopia::load() addressBook()->insertAddressee( addressee ); } } - +#endif return true; } bool ResourceQtopia::save( Ticket *ticket ) { + + mDirWatch.stopScan(); + KABC::AddressBook::Iterator it; + bool res; + //pending open file for stream + QTextStream *stream;// = tempFile->textStream(); + stream->setEncoding( QTextStream::UnicodeUTF8 ); + *stream << "<?xml version=\"1.0\" encoding=\"UTF-8\"?><!DOCTYPE Addressbook ><AddressBook>" << endl; + *stream << " <Groups>" << endl; + *stream << " </Groups>" << endl; + *stream << " <Contacts> " << endl; + // for all entries + KABC::Addressee ab; + for ( it = addressBook()->begin(); it != addressBook()->end(); ++it ) { + KABC::Addressee addressee = (*it); + res = mConverter->addresseeToQtopia( addressee, stream ); + if (!res == true) + { + qDebug("Unable to convert Addressee %s", addressee.formattedName().latin1()); + } + } + + + *stream << "</Contacts>" << endl; + *stream << "</AddressBook>" << endl; + //pending close file + mDirWatch.startScan(); + + delete ticket; + unlock( fileName() ); + + +#if 0 + //old code qDebug("ResourceQtopia::save: %s", fileName().latin1()); mDirWatch.stopScan(); @@ -199,7 +260,7 @@ bool ResourceQtopia::save( Ticket *ticket ) PimContact c; KABC::Addressee addressee = (*it); - res = mConverter->addresseeToQtopia( *it, c ); + //res = mConverter->addresseeToQtopia( *it, c ); if (res == true) { mAccess->addContact(c); @@ -218,7 +279,7 @@ bool ResourceQtopia::save( Ticket *ticket ) delete ticket; unlock( fileName() ); - +#endif return true; } |