author | zautrix <zautrix> | 2005-04-21 22:07:10 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-04-21 22:07:10 (UTC) |
commit | 6284b1d7d597463347b471ed8ec2770f4e2d449b (patch) (unidiff) | |
tree | 5444a13ed788191733fec406791ddf03ec246b59 /kabc | |
parent | fd38343ef53c9b2a48208f747100579703cc1814 (diff) | |
download | kdepimpi-6284b1d7d597463347b471ed8ec2770f4e2d449b.zip kdepimpi-6284b1d7d597463347b471ed8ec2770f4e2d449b.tar.gz kdepimpi-6284b1d7d597463347b471ed8ec2770f4e2d449b.tar.bz2 |
fixes
-rw-r--r-- | kabc/plugins/file/resourcefile.cpp | 49 | ||||
-rw-r--r-- | kabc/plugins/file/resourcefile.h | 1 |
2 files changed, 48 insertions, 2 deletions
diff --git a/kabc/plugins/file/resourcefile.cpp b/kabc/plugins/file/resourcefile.cpp index 2bd9e71..c89939d 100644 --- a/kabc/plugins/file/resourcefile.cpp +++ b/kabc/plugins/file/resourcefile.cpp | |||
@@ -34,24 +34,25 @@ $Id$ | |||
34 | #include <qfile.h> | 34 | #include <qfile.h> |
35 | #include <qfileinfo.h> | 35 | #include <qfileinfo.h> |
36 | #include <qregexp.h> | 36 | #include <qregexp.h> |
37 | #include <qtimer.h> | 37 | #include <qtimer.h> |
38 | 38 | ||
39 | #include <kapplication.h> | 39 | #include <kapplication.h> |
40 | #include <kconfig.h> | 40 | #include <kconfig.h> |
41 | #include <kdebug.h> | 41 | #include <kdebug.h> |
42 | #include <klocale.h> | 42 | #include <klocale.h> |
43 | //US #include <ksavefile.h> | 43 | //US #include <ksavefile.h> |
44 | #include <kstandarddirs.h> | 44 | #include <kstandarddirs.h> |
45 | #include <kmessagebox.h> | 45 | #include <kmessagebox.h> |
46 | #include <kglobalsettings.h> | ||
46 | 47 | ||
47 | #include "formatfactory.h" | 48 | #include "formatfactory.h" |
48 | 49 | ||
49 | #include "resource.h" | 50 | #include "resource.h" |
50 | #include "resourcefileconfig.h" | 51 | #include "resourcefileconfig.h" |
51 | #include "stdaddressbook.h" | 52 | #include "stdaddressbook.h" |
52 | #define NO_DIRWATCH | 53 | #define NO_DIRWATCH |
53 | #include "resourcefile.h" | 54 | #include "resourcefile.h" |
54 | 55 | ||
55 | //#define ALLOW_LOCKING | 56 | //#define ALLOW_LOCKING |
56 | 57 | ||
57 | 58 | ||
@@ -70,46 +71,47 @@ __declspec(dllexport) | |||
70 | return new KRES::PluginFactory<ResourceFile,ResourceFileConfig>(); | 71 | return new KRES::PluginFactory<ResourceFile,ResourceFileConfig>(); |
71 | } | 72 | } |
72 | #ifndef _WIN32_ | 73 | #ifndef _WIN32_ |
73 | } | 74 | } |
74 | #endif | 75 | #endif |
75 | 76 | ||
76 | ResourceFile::ResourceFile( const KConfig *config ) | 77 | ResourceFile::ResourceFile( const KConfig *config ) |
77 | : Resource( config ) , mFormat( 0 ) | 78 | : Resource( config ) , mFormat( 0 ) |
78 | { | 79 | { |
79 | QString fileName, formatName, default_fileName; | 80 | QString fileName, formatName, default_fileName; |
80 | 81 | ||
81 | default_fileName = StdAddressBook::fileName(); | 82 | default_fileName = StdAddressBook::fileName(); |
82 | 83 | mLastBackupDate = -1; | |
83 | KConfig *cfg = (KConfig *)config; | 84 | KConfig *cfg = (KConfig *)config; |
84 | if ( cfg ) { | 85 | if ( cfg ) { |
85 | fileName = cfg->readEntry( "FileName", default_fileName ); | 86 | fileName = cfg->readEntry( "FileName", default_fileName ); |
86 | formatName = cfg->readEntry( "FileFormat", "vcard" ); | 87 | formatName = cfg->readEntry( "FileFormat", "vcard" ); |
87 | mFamily = cfg->readEntry( "ResourceName", "std" ); | 88 | mFamily = cfg->readEntry( "ResourceName", "std" ); |
89 | mLastBackupDate = cfg->readNumEntry( "LastBackupDate", 0 ); | ||
88 | } else { | 90 | } else { |
89 | fileName = default_fileName; | 91 | fileName = default_fileName; |
90 | formatName = "vcard"; | 92 | formatName = "vcard"; |
91 | } | 93 | } |
92 | 94 | ||
93 | init( fileName, formatName ); | 95 | init( fileName, formatName ); |
94 | } | 96 | } |
95 | 97 | ||
96 | ResourceFile::ResourceFile( const QString &fileName , | 98 | ResourceFile::ResourceFile( const QString &fileName , |
97 | const QString &formatName ) | 99 | const QString &formatName ) |
98 | : Resource( 0 ) | 100 | : Resource( 0 ) |
99 | { | 101 | { |
100 | // qDebug("ResourceFile::ResourceFile : 3 %s, %s", fileName.latin1(), formatName.latin1()); | 102 | // qDebug("ResourceFile::ResourceFile : 3 %s, %s", fileName.latin1(), formatName.latin1()); |
101 | 103 | ||
102 | 104 | ||
103 | 105 | mLastBackupDate = -1; | |
104 | init( fileName, formatName ); | 106 | init( fileName, formatName ); |
105 | } | 107 | } |
106 | 108 | ||
107 | void ResourceFile::init( const QString &fileName, const QString &formatName ) | 109 | void ResourceFile::init( const QString &fileName, const QString &formatName ) |
108 | { | 110 | { |
109 | mFormatName = formatName; | 111 | mFormatName = formatName; |
110 | 112 | ||
111 | FormatFactory *factory = FormatFactory::self(); | 113 | FormatFactory *factory = FormatFactory::self(); |
112 | mFormat = factory->format( mFormatName ); | 114 | mFormat = factory->format( mFormatName ); |
113 | 115 | ||
114 | if ( !mFormat ) { | 116 | if ( !mFormat ) { |
115 | mFormatName = "vcard"; | 117 | mFormatName = "vcard"; |
@@ -248,24 +250,67 @@ bool ResourceFile::save( Ticket *ticket ) | |||
248 | bool ok = false; | 250 | bool ok = false; |
249 | if ( saveFile.status() == 0 && saveFile.file() ) | 251 | if ( saveFile.status() == 0 && saveFile.file() ) |
250 | { | 252 | { |
251 | mFormat->saveAll( addressBook(), this, saveFile.file() ); | 253 | mFormat->saveAll( addressBook(), this, saveFile.file() ); |
252 | ok = saveFile.close(); | 254 | ok = saveFile.close(); |
253 | } | 255 | } |
254 | */ | 256 | */ |
255 | 257 | ||
256 | //US ToDo: write backupfile | 258 | //US ToDo: write backupfile |
257 | #ifndef NO_DIRWATCH | 259 | #ifndef NO_DIRWATCH |
258 | mDirWatch.stopScan(); | 260 | mDirWatch.stopScan(); |
259 | #endif | 261 | #endif |
262 | if ( mLastBackupDate >= 0 && mFamily != "sync_res") { | ||
263 | KConfig conf (locateLocal("config","microkdeglobalrc")); | ||
264 | conf.setGroup( "BackupSettings" ); | ||
265 | bool b_enabled = conf.readBoolEntry( "BackupEnabled" ); | ||
266 | if ( b_enabled ) { | ||
267 | int num = conf.readNumEntry( "BackupNumbers" ); | ||
268 | int d_count = conf.readNumEntry( "BackupDayCount" ); | ||
269 | bool stdDir = conf.readBoolEntry( "BackupUseDefaultDir" ); | ||
270 | QString bupDir = conf.readEntry( "BackupDatadir" ); | ||
271 | QDate reference ( 2000,1,1 ); | ||
272 | int daysTo = reference.daysTo ( QDate::currentDate() ); | ||
273 | bool saveDate = false; | ||
274 | if ( daysTo - d_count >= mLastBackupDate ) { | ||
275 | qDebug("KA: Last backup was %d days ago ", daysTo - mLastBackupDate ); | ||
276 | if ( stdDir ) | ||
277 | bupDir = KGlobalSettings::backupDataDir(); | ||
278 | int retval = KApplication::createBackup( fileName(), bupDir, num ); | ||
279 | if ( retval == 0 ) { | ||
280 | qDebug("KO: Backup cancelled. Will try again tomorrow "); | ||
281 | // retval == 0 : backup skipped for today, try again tomorrow | ||
282 | mLastBackupDate = daysTo - d_count+1; | ||
283 | saveDate = true; | ||
284 | } else if ( retval == 1 ){ | ||
285 | qDebug("KO: Backup created."); | ||
286 | // backup ok | ||
287 | mLastBackupDate = daysTo; | ||
288 | saveDate = true; | ||
289 | } else if ( retval == 2 ){ | ||
290 | qDebug("KO: Backup globally cancelled."); | ||
291 | // backup globally cancelled | ||
292 | b_enabled = false; | ||
293 | } | ||
294 | if ( !b_enabled ) { | ||
295 | conf.writeEntry( "mBackupEnabled", false ); | ||
296 | } | ||
297 | if ( saveDate ) { | ||
298 | KConfig config ( locateLocal("config","kabcrc") ); | ||
299 | config.setGroup( "Resource_" + identifier() ); | ||
300 | config.writeEntry( "LastBackupDate", mLastBackupDate ); | ||
301 | } | ||
302 | } | ||
303 | } | ||
304 | } | ||
260 | QFile info; | 305 | QFile info; |
261 | info.setName( fileName() ); | 306 | info.setName( fileName() ); |
262 | bool ok = info.open( IO_WriteOnly ); | 307 | bool ok = info.open( IO_WriteOnly ); |
263 | if ( ok ) { | 308 | if ( ok ) { |
264 | mFormat->saveAll( addressBook(), this, &info ); | 309 | mFormat->saveAll( addressBook(), this, &info ); |
265 | 310 | ||
266 | info.close(); | 311 | info.close(); |
267 | ok = true; | 312 | ok = true; |
268 | } | 313 | } |
269 | else { | 314 | else { |
270 | 315 | ||
271 | } | 316 | } |
diff --git a/kabc/plugins/file/resourcefile.h b/kabc/plugins/file/resourcefile.h index 3e9edfc..61da154 100644 --- a/kabc/plugins/file/resourcefile.h +++ b/kabc/plugins/file/resourcefile.h | |||
@@ -138,24 +138,25 @@ public: | |||
138 | virtual void cleanUp(); | 138 | virtual void cleanUp(); |
139 | 139 | ||
140 | protected slots: | 140 | protected slots: |
141 | void fileChanged(); | 141 | void fileChanged(); |
142 | 142 | ||
143 | protected: | 143 | protected: |
144 | void init( const QString &fileName, const QString &format ); | 144 | void init( const QString &fileName, const QString &format ); |
145 | 145 | ||
146 | bool lock( const QString &fileName ); | 146 | bool lock( const QString &fileName ); |
147 | void unlock( const QString &fileName ); | 147 | void unlock( const QString &fileName ); |
148 | 148 | ||
149 | private: | 149 | private: |
150 | int mLastBackupDate; | ||
150 | QString mFamily; | 151 | QString mFamily; |
151 | QString mFileName2; | 152 | QString mFileName2; |
152 | QString mFormatName; | 153 | QString mFormatName; |
153 | 154 | ||
154 | FormatPlugin *mFormat; | 155 | FormatPlugin *mFormat; |
155 | 156 | ||
156 | QString mLockUniqueName; | 157 | QString mLockUniqueName; |
157 | #ifndef NO_DIRWATCH | 158 | #ifndef NO_DIRWATCH |
158 | KDirWatch mDirWatch; | 159 | KDirWatch mDirWatch; |
159 | #endif | 160 | #endif |
160 | }; | 161 | }; |
161 | 162 | ||