1
0
mirror of https://github.com/etesync/android synced 2025-01-25 15:10:55 +00:00

Fix a bug that deletes entities remotely even if they have changed remotely (closes #197)

This commit is contained in:
rfc2822 2014-03-14 23:14:32 +01:00
parent 8a02601cfc
commit b1ffdbfa95
2 changed files with 14 additions and 8 deletions

View File

@ -222,7 +222,8 @@ public abstract class LocalCollection<T extends Resource> {
public void clearDirty(Resource resource) {
pendingOperations.add(ContentProviderOperation
.newUpdate(ContentUris.withAppendedId(entriesURI(), resource.getLocalID()))
.withValue(entryColumnDirty(), 0).build());
.withValue(entryColumnDirty(), 0)
.build());
}
public void commit() throws LocalStorageException {

View File

@ -109,15 +109,20 @@ public class SyncManager {
try {
Resource res = local.findById(id, false);
if (res.getName() != null) // is this resource even present remotely?
try {
remote.delete(res);
local.delete(res);
count++;
} catch(NotFoundException e) {
Log.i(TAG, "Locally-deleted resource has already been removed from server");
} catch(PreconditionFailedException e) {
Log.i(TAG, "Locally-deleted resource has been changed on the server in the meanwhile");
}
// always delete locally so that the record with the DELETED flag doesn't cause another deletion attempt
local.delete(res);
count++;
} catch (RecordNotFoundException e) {
Log.e(TAG, "Couldn't read locally-deleted record", e);
Log.wtf(TAG, "Couldn't read locally-deleted record", e);
}
} finally {
local.commit();
@ -141,7 +146,7 @@ public class SyncManager {
} catch (ValidationException e) {
Log.e(TAG, "Couldn't create entity for adding: " + e.toString());
} catch (RecordNotFoundException e) {
Log.e(TAG, "Couldn't read new record", e);
Log.wtf(TAG, "Couldn't read new record", e);
}
} finally {
local.commit();