mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-04 06:20:26 +00:00
Small cross account move fix
This commit is contained in:
parent
1a345af89d
commit
a7f495790b
1 changed files with 10 additions and 4 deletions
|
@ -488,18 +488,21 @@ class Core {
|
|||
throw new IllegalArgumentException("uid not found");
|
||||
|
||||
Log.i(folder.name + " appended id=" + message.id + " uid=" + uid);
|
||||
db.message().setMessageUid(message.id, uid);
|
||||
|
||||
if (!folder.id.equals(message.folder))
|
||||
if (folder.id.equals(message.folder))
|
||||
db.message().setMessageUid(message.id, uid);
|
||||
else {
|
||||
// Cross account move
|
||||
try {
|
||||
db.beginTransaction();
|
||||
|
||||
// Cross account move
|
||||
// Mark source read
|
||||
if (autoread) {
|
||||
Log.i(folder.name + " queuing SEEN id=" + message.id);
|
||||
EntityOperation.queue(context, db, message, EntityOperation.SEEN, true);
|
||||
}
|
||||
|
||||
// Delete source
|
||||
Log.i(folder.name + " queuing DELETE id=" + message.id);
|
||||
EntityOperation.queue(context, db, message, EntityOperation.DELETE);
|
||||
|
||||
|
@ -507,7 +510,9 @@ class Core {
|
|||
} finally {
|
||||
db.endTransaction();
|
||||
}
|
||||
}
|
||||
} catch (Throwable ex) {
|
||||
if (folder.id.equals(message.folder))
|
||||
db.message().setMessageUid(message.id, null);
|
||||
throw ex;
|
||||
}
|
||||
|
@ -606,6 +611,7 @@ class Core {
|
|||
}
|
||||
|
||||
if (jargs.length() > 0) {
|
||||
// Cross account move
|
||||
long target = jargs.getLong(2);
|
||||
jargs.remove(2);
|
||||
Log.i(folder.name + " queuing ADD id=" + message.id + ":" + target);
|
||||
|
|
Loading…
Reference in a new issue