author | ulf69 <ulf69> | 2004-07-12 23:34:33 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-07-12 23:34:33 (UTC) |
commit | bce030bdee5c381d7937ef3d2b1b49ce24bbd1ae (patch) (side-by-side diff) | |
tree | e92c85b28da2db2552f64be567e511c13106cc82 | |
parent | c4d51e8f5ecf7be146ee53ea2bbe3af6fca25d4d (diff) | |
download | kdepimpi-bce030bdee5c381d7937ef3d2b1b49ce24bbd1ae.zip kdepimpi-bce030bdee5c381d7937ef3d2b1b49ce24bbd1ae.tar.gz kdepimpi-bce030bdee5c381d7937ef3d2b1b49ce24bbd1ae.tar.bz2 |
added first version of the qtopia resourcefiles. The content is of no meaning
-rw-r--r-- | kabc/plugins/qtopia/qtopiaE.pro | 32 | ||||
-rw-r--r-- | kabc/plugins/qtopia/resourceqtopia.cpp | 410 | ||||
-rw-r--r-- | kabc/plugins/qtopia/resourceqtopia.h | 152 | ||||
-rw-r--r-- | kabc/plugins/qtopia/resourceqtopiaconfig.cpp | 107 | ||||
-rw-r--r-- | kabc/plugins/qtopia/resourceqtopiaconfig.h | 58 |
5 files changed, 759 insertions, 0 deletions
diff --git a/kabc/plugins/qtopia/qtopiaE.pro b/kabc/plugins/qtopia/qtopiaE.pro new file mode 100644 index 0000000..d945c31 --- a/dev/null +++ b/kabc/plugins/qtopia/qtopiaE.pro @@ -0,0 +1,32 @@ +TEMPLATE = lib +CONFIG += qt warn_on +#release debug +TARGET = microkabc_qtopia + +INCLUDEPATH += ../.. ../../converter/opie ../../../microkde ../../../microkde/kdecore ../../../microkde/kio/kfile ../../../qtcompat $(QPEDIR)/include $(OPIEDIR)/include + + +OBJECTS_DIR = obj/$(PLATFORM) +MOC_DIR = moc/$(PLATFORM) +DESTDIR = $(QPEDIR)/lib +LIBS += -lmicrokde +LIBS += -lmicrokabc +LIBS += -L$(QPEDIR)/lib +LIBS += -L$(OPIEDIR)/lib +LIBS += -lopie +LIBS += -lqpe +LIBS += -lqte +LIBS += -lmicrokabc_opieconverter +#LIBS += -L../../lib/$(PLATFORM) + + +INTERFACES = \ + +HEADERS = \ + resourceqtopia.h \ + resourceqtopiaconfig.h \ + +SOURCES = \ + resourceqtopia.cpp \ + resourceqtopiaconfig.cpp \ + diff --git a/kabc/plugins/qtopia/resourceqtopia.cpp b/kabc/plugins/qtopia/resourceqtopia.cpp new file mode 100644 index 0000000..3d9d28b --- a/dev/null +++ b/kabc/plugins/qtopia/resourceqtopia.cpp @@ -0,0 +1,410 @@ +/* + This file is part of libkabc. + Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +/* +Enhanced Version of the file for platform independent KDE tools. +Copyright (c) 2004 Ulf Schenk + +$Id$ +*/ + +#include <sys/types.h> +#include <sys/stat.h> +#include <unistd.h> + +#include <qdir.h> +#include <qfile.h> +#include <qfileinfo.h> +#include <qregexp.h> +#include <qtimer.h> + +#include <kapplication.h> +#include <kconfig.h> +#include <kdebug.h> +#include <klocale.h> +//US #include <ksavefile.h> +#include <kstandarddirs.h> + +//US #include "formatfactory.h" +//US #include <qpe/qpeapplication.h> + +#include <opie/ocontactaccess.h> +#include <opie/ocontactaccessbackend_xml.h> + +#include "resource.h" +#include "resourceqtopiaconfig.h" +#include "stdaddressbook.h" + +#include "opieconverter.h" + +#include "resourceqtopia.h" + +using namespace KABC; +extern "C" +{ + void *init_microkabc_qtopia() + { + return new KRES::PluginFactory<ResourceOpie,ResourceOpieConfig>(); + } +} + +ResourceOpie::ResourceOpie( const KConfig *config ) + : Resource( config ), mConverter (0) +{ + QString fileName = QDir::homeDirPath() + "/Applications/addressbook/addressbook.xml"; + + KConfig *cfg = (KConfig *)config; + if ( cfg ) { + fileName = cfg->readEntry( "FileName", fileName ); + + } + +// qDebug("ResourceOpie::ResourceOpie : %s", fileName.latin1() ); + + init( fileName ); +} + +ResourceOpie::ResourceOpie( const QString &fileName ) + : Resource( 0 ) +{ +// qDebug("ResourceOpie::ResourceOpie : 3 %s", fileName.latin1()); + init( fileName ); +} + +void ResourceOpie::init( const QString &fileName ) +{ + +/*US we have no KDirWatch. SO simulate the signals from inside the apropriate methods + connect( &mDirWatch, SIGNAL( dirty(const QString&) ), SLOT( fileChanged() ) ); + connect( &mDirWatch, SIGNAL( created(const QString&) ), SLOT( fileChanged() ) ); + connect( &mDirWatch, SIGNAL( deleted(const QString&) ), SLOT( fileChanged() ) ); +*/ + //US opie addressbook is always readonly +//US setReadOnly( true ); + + setFileName( fileName ); + +} + +ResourceOpie::~ResourceOpie() +{ + if (mConverter != 0) + delete mConverter; +} + +void ResourceOpie::writeConfig( KConfig *config ) +{ + //US opie addressbook is always readonly +//US setReadOnly( true ); + + Resource::writeConfig( config ); + + config->writeEntry( "FileName", mFileName ); + +// qDebug("ResourceFile::writeConfig format %s, %s", mFileName.latin1(), mFormatName.latin1()); + +} + +Ticket *ResourceOpie::requestSaveTicket() +{ + kdDebug(5700) << "ResourceOpie::requestSaveTicket()" << endl; + + if ( !addressBook() ) return 0; + + if ( !lock( mFileName ) ) { + kdDebug(5700) << "ResourceOpie::requestSaveTicket(): Unable to lock file '" + << mFileName << "'" << endl; + return 0; + } + return createTicket( this ); +} + + +bool ResourceOpie::doOpen() +{ +// qDebug("ResourceOpie::doOpen() %s", mFileName.latin1()); +/*US + QFile file( mFileName ); + + if ( !file.exists() ) { + // try to create the file + bool ok = file.open( IO_WriteOnly ); + if ( ok ) + file.close(); + + return ok; + } else { + if ( !file.open( IO_ReadWrite ) ) + return false; + + if ( file.size() == 0 ) { + file.close(); + return true; + } + +//US bool ok = mFormat->checkFormat( &file ); + bool ok = true; + + file.close(); + + return ok; + } +*/ + qDebug("ResourceOpie::doOpen() has to be fixed - %s", mFileName.latin1()); + return true; +} + +void ResourceOpie::doClose() +{ +// qDebug("ResourceOpie::doClose() %s", mFileName.latin1()); +} + +bool ResourceOpie::load() +{ +// qDebug("ResourceOpie::load() %s", mFileName.latin1()); + kdDebug(5700) << "ResourceOpie::load(): '" << mFileName << "'" << endl; + + qDebug("ResourceOpie::load: Try to load file() %s", mFileName.latin1()); + + OContactAccessBackend_XML* backend = new OContactAccessBackend_XML( "KDEPim/Pi", mFileName ); + OContactAccess* access = new OContactAccess("KDEPim/Pi", 0l, backend, false); + + if ( !access ) { + qDebug("Unable to load file() %s", mFileName.latin1()); + addressBook()->error( i18n( "Unable to load file '%1'." ).arg( mFileName ) ); + return false; + } + + access -> setReadAhead( 32 ); // Use ReadAhead-Cache if available + + bool res = false; + if (mConverter == 0) + { + mConverter = new OpieConverter(); + res = mConverter->init(); + if ( !res ) + { + qDebug("Unable to initialize opie converter. Most likely a problem with the category file"); + addressBook()->error( i18n( "Unable to initialize opie converter. Most likely a problem with the category file" ) ); + delete access; + return false; + } + } + + + OContactAccess::List::Iterator it; + OContactAccess::List allList = access->allRecords(); + for ( it = allList.begin(); it != allList.end(); ++it ) + { + OContact c = (*it); + + KABC::Addressee addressee; + + res = mConverter->opieToAddressee( c, addressee ); + + if ( !addressee.isEmpty() && res ) + { + addressee.setResource( this ); + addressBook()->insertAddressee( addressee ); + } + +// qDebug("found %s", c.fullName().latin1()); + } + + delete access; + // it seems so, that deletion of access deletes backend as well + //delete backend; + + return true; +} + +bool ResourceOpie::save( Ticket *ticket ) +{ + qDebug("ResourceOpie::save() has to be fixed - %s", mFileName.latin1()); +/*US + + qDebug("ResourceOpie::save %s", mFileName.latin1()); + kdDebug(5700) << "ResourceOpie::save()" << endl; + + // create backup file + QString extension = "_" + QString::number( QDate::currentDate().dayOfWeek() ); +*/ +/*US we use a simpler method to create a backupfile + + (void) KSaveFile::backupFile( mFileName, QString::null + ,extension ); + + KSaveFile saveFile( mFileName ); + bool ok = false; + if ( saveFile.status() == 0 && saveFile.file() ) + { + mFormat->saveAll( addressBook(), this, saveFile.file() ); + ok = saveFile.close(); + } +*/ +/*US +//US ToDo: write backupfile + QFile info; + info.setName( mFileName ); + bool ok = info.open( IO_WriteOnly ); + if ( ok ) { +//US mFormat->saveAll( addressBook(), this, &info ); + + info.close(); + ok = true; + } + else { + + } + + if ( !ok ) + addressBook()->error( i18n( "Unable to save file '%1'." ).arg( mFileName ) ); + + delete ticket; + unlock( mFileName ); + + return ok; + + qDebug("ResourceOpie::save has to be changed"); +*/ + return true; + +} + +bool ResourceOpie::lock( const QString &fileName ) +{ + qDebug("ResourceOpie::lock() has to be fixed - %s", mFileName.latin1()); + +/*US +// qDebug("ResourceOpie::lock() %s", fileName.latin1()); + kdDebug(5700) << "ResourceOpie::lock()" << endl; + + QString fn = fileName; + +//US change the implementation how the lockfilename is getting created +//US fn.replace( QRegExp("/"), "_" ); +//US QString lockName = locateLocal( "data", "kabc/lock/" + fn + ".lock" ); + + KURL url(fn); + QString lockName = locateLocal( "data", "kabc/lock/" + url.fileName() + ".lock" ); + + kdDebug(5700) << "-- lock name: " << lockName << endl; + + if (QFile::exists( lockName )) return false; + + QString lockUniqueName; + lockUniqueName = fn + KApplication::randomString( 8 ); + + url = lockUniqueName; +//US mLockUniqueName = locateLocal( "data", "kabc/lock/" + lockUniqueName ); + mLockUniqueName = locateLocal( "data", "kabc/lock/" + url.fileName() ); + kdDebug(5700) << "-- lock unique name: " << mLockUniqueName << endl; + + // Create unique file + QFile file( mLockUniqueName ); + file.open( IO_WriteOnly ); + file.close(); + + // Create lock file + int result = ::link( QFile::encodeName( mLockUniqueName ), + QFile::encodeName( lockName ) ); + + if ( result == 0 ) { + addressBook()->emitAddressBookLocked(); + return true; + } + + // TODO: check stat + + return false; +*/ + + return true; +} + +void ResourceOpie::unlock( const QString &fileName ) +{ + qDebug("ResourceOpie::unlock() has to be fixed - %s", mFileName.latin1()); +/*US +// qDebug("ResourceOpie::unlock() %s", fileName.latin1()); + + QString fn = fileName; +//US change the implementation how the lockfilename is getting created +//US fn.replace( QRegExp( "/" ), "_" ); +//US QString lockName = locateLocal( "data", "kabc/lock/" + fn + ".lock" ); +//US QString lockName = fn + ".lock"; + KURL url(fn); + QString lockName = locateLocal( "data", "kabc/lock/" + url.fileName() + ".lock" ); + + QFile::remove( lockName ); + QFile::remove( mLockUniqueName ); + addressBook()->emitAddressBookUnlocked(); +*/ +} + +void ResourceOpie::setFileName( const QString &fileName ) +{ +/*US ToDo: no synchronization so far. Has to be changed in the future + mDirWatch.stopScan(); + mDirWatch.removeFile( mFileName ); +*/ + mFileName = fileName; + + +/*US ToDo: no synchronization so far. Has to be changed in the future + mDirWatch.addFile( mFileName ); + mDirWatch.startScan(); +*/ +//US simulate KDirWatch event + fileChanged(); +} + +QString ResourceOpie::fileName() const +{ + return mFileName; +} + +void ResourceOpie::fileChanged() +{ + // There is a small theoretical chance that KDirWatch calls us before + // we are fully constructed + if (!addressBook()) + return; + load(); + addressBook()->emitAddressBookChanged(); +} + +void ResourceOpie::removeAddressee( const Addressee &addr ) +{ +/*US + QFile::remove( QFile::encodeName( locateLocal( "data", "kabc/photos/" ) + addr.uid() ) ); + QFile::remove( QFile::encodeName( locateLocal( "data", "kabc/logos/" ) + addr.uid() ) ); + QFile::remove( QFile::encodeName( locateLocal( "data", "kabc/sounds/" ) + addr.uid() ) ); +*/ +} + +void ResourceOpie::cleanUp() +{ +// qDebug("ResourceOpie::cleanup() %s", mFileName.latin1()); + + unlock( mFileName ); +} + +//US #include "resourceopie.moc" diff --git a/kabc/plugins/qtopia/resourceqtopia.h b/kabc/plugins/qtopia/resourceqtopia.h new file mode 100644 index 0000000..ea0b5ee --- a/dev/null +++ b/kabc/plugins/qtopia/resourceqtopia.h @@ -0,0 +1,152 @@ +/* + This file is part of libkabc. + Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +/* +Enhanced Version of the file for platform independent KDE tools. +Copyright (c) 2004 Ulf Schenk + +$Id$ +*/ + + +#ifndef KABC_RESOURCEQTOPIA_H +#define KABC_RESOURCEQTOPIA_H + +#include <kconfig.h> +#include <kdirwatch.h> + +#include <sys/types.h> + +#include "resource.h" + + +//class QTimer; +//class FormatPlugin; + +namespace KABC { + +//US class FormatPlugin; +class ResourceConfigWidget; +class OpieConverter; +/** + @internal +*/ +class ResourceOpie : public Resource +{ + Q_OBJECT + +public: + + /** + Constructor. + + @param cfg The config object where custom resource settings are stored. + */ + ResourceOpie( const KConfig *cfg ); + + /** + Construct file resource on file @arg fileName using format @arg formatName. + */ + ResourceOpie( const QString &fileName ); + + /** + * Destructor. + */ + ~ResourceOpie(); + + /** + Writes the config back. + */ + virtual void writeConfig( KConfig *cfg ); + + /** + * Tries to open the file and checks for the proper format. + * This method should be called before @ref load(). + */ + virtual bool doOpen(); + + /** + * Closes the file again. + */ + virtual void doClose(); + + /** + * Requests a save ticket, that is used by @ref save() + */ + virtual Ticket *requestSaveTicket(); + + /** + * Loads all addressees from file to the address book. + * Returns true if all addressees could be loaded otherwise false. + */ + virtual bool load(); + + /** + * Saves all addresses from address book to file. + * Returns true if all addressees could be saved otherwise false. + * + * @param ticket The ticket returned by @ref requestSaveTicket() + */ + virtual bool save( Ticket *ticket ); + + /** + * Set name of file to be used for saving. + */ + void setFileName( const QString & ); + + /** + * Return name of file used for loading and saving the address book. + */ + QString fileName() const; + + /** + * Remove a addressee from its source. + * This method is mainly called by KABC::AddressBook. + */ + virtual void removeAddressee( const Addressee& addr ); + + /** + * This method is called by an error handler if the application + * crashed + */ + virtual void cleanUp(); + +protected slots: + void fileChanged(); + +protected: + void init( const QString &fileName ); + + bool lock( const QString &fileName ); + void unlock( const QString &fileName ); + +private: + OpieConverter* mConverter; + + QString mFileName; + + QString mLockUniqueName; + + KDirWatch mDirWatch; +}; + +} + +#endif diff --git a/kabc/plugins/qtopia/resourceqtopiaconfig.cpp b/kabc/plugins/qtopia/resourceqtopiaconfig.cpp new file mode 100644 index 0000000..8cb8505 --- a/dev/null +++ b/kabc/plugins/qtopia/resourceqtopiaconfig.cpp @@ -0,0 +1,107 @@ +/* + This file is part of libkabc. + Copyright (c) 2002 Tobias Koenig <tokoe@kde.org> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +/* +Enhanced Version of the file for platform independent KDE tools. +Copyright (c) 2004 Ulf Schenk + +$Id$ +*/ + +#include <qlabel.h> +#include <qlayout.h> + +#include <kdebug.h> +#include <klocale.h> +#include <kstandarddirs.h> +#include <kdialog.h> + +#include <unistd.h> + +#include <qdir.h> +#include <qfile.h> +#include "resourceqtopia.h" +//US #include <qpe/qpeapplication.h> + +//US #include "stdaddressbook.h" + +#include "resourceqtopiaconfig.h" + +using namespace KABC; + +ResourceOpieConfig::ResourceOpieConfig( QWidget* parent, const char* name ) + : ConfigWidget( parent, name ) +{ +//qDebug("ResourceFileConfig::ResourceFileConfig"); + + QGridLayout *mainLayout = new QGridLayout( this, 1, 2, 0, + KDialog::spacingHint() ); + + QLabel *label = new QLabel( i18n( "Location:" ), this ); + mFileNameEdit = new KURLRequester( this ); + + connect( mFileNameEdit, SIGNAL( textChanged( const QString & ) ), + SLOT( checkFilePermissions( const QString & ) ) ); + + mainLayout->addWidget( label, 0, 0 ); + mainLayout->addWidget( mFileNameEdit, 0, 1 ); +} + +void ResourceOpieConfig::loadSettings( KRES::Resource *res ) +{ +//US ResourceFile *resource = dynamic_cast<ResourceFile*>( res ); + ResourceOpie *resource = (ResourceOpie*)( res ); + + if ( !resource ) { + kdDebug(5700) << "ResourceOpieConfig::loadSettings(): cast failed" << endl; + return; + } + + mFileNameEdit->setURL( resource->fileName() ); + if ( mFileNameEdit->url().isEmpty() ) + mFileNameEdit->setURL( QDir::homeDirPath() + "/Applications/addressbook/addressbook.xml" ); + + //US Opie resources are ReadOnly by definition + emit setPersistentReadOnly( true ); +} + +void ResourceOpieConfig::saveSettings( KRES::Resource *res ) +{ +//US ResourceFile *resource = dynamic_cast<ResourceFile*>( res ); + ResourceOpie *resource = (ResourceOpie*)( res ); + + if ( !resource ) { + kdDebug(5700) << "ResourceOpieConfig::saveSettings(): cast failed" << endl; + return; + } + + resource->setFileName( mFileNameEdit->url() ); +} + +void ResourceOpieConfig::checkFilePermissions( const QString& fileName ) +{ + // If file exist but is not writeable... +/*US + if ( access( QFile::encodeName( fileName ), F_OK ) == 0 ) + emit setReadOnly( access( QFile::encodeName( fileName ), W_OK ) < 0 ); +*/ +} + +//US #include "resourceopieconfig.moc" diff --git a/kabc/plugins/qtopia/resourceqtopiaconfig.h b/kabc/plugins/qtopia/resourceqtopiaconfig.h new file mode 100644 index 0000000..0d80625 --- a/dev/null +++ b/kabc/plugins/qtopia/resourceqtopiaconfig.h @@ -0,0 +1,58 @@ +/* + This file is part of libkabc. + Copyright (c) 2002 Tobias Koenig <tokoe@kde.org> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + + +/* +Enhanced Version of the file for platform independent KDE tools. +Copyright (c) 2004 Ulf Schenk + +$Id$ +*/ + +#ifndef RESOURCEQTOPIACONFIG_H +#define RESOURCEQTOPIACONFIG_H + +#include <kurlrequester.h> + +#include <kresources/configwidget.h> + +namespace KABC { + +class ResourceOpieConfig : public KRES::ConfigWidget +{ + Q_OBJECT + +public: + ResourceOpieConfig( QWidget* parent = 0, const char* name = 0 ); + +public slots: + void loadSettings( KRES::Resource *resource ); + void saveSettings( KRES::Resource *resource ); + +protected slots: + void checkFilePermissions( const QString& fileName ); + +private: + KURLRequester* mFileNameEdit; +}; + +} + +#endif |