Simplification

pull/209/head
M66B 2 years ago
parent 4e42b46614
commit 859e7da4c6

@ -747,11 +747,6 @@ class Core {
if (message != null && if (message != null &&
!EntityOperation.SEEN.equals(op.name)) !EntityOperation.SEEN.equals(op.name))
db.message().deleteMessage(message.id); db.message().deleteMessage(message.id);
if (EntityOperation.FETCH.equals(op.name)) {
long uid = jargs.getLong(0);
db.message().deleteMessage(folder.id, uid);
}
} }
db.setTransactionSuccessful(); db.setTransactionSuccessful();
@ -1756,19 +1751,16 @@ class Core {
boolean invalidate = jargs.optBoolean(1); boolean invalidate = jargs.optBoolean(1);
boolean removed = jargs.optBoolean(2); boolean removed = jargs.optBoolean(2);
if (uid < 0)
throw new MessageRemovedException(folder.name + " fetch uid=" + uid);
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
EntityAccount account = db.account().getAccount(folder.account); EntityAccount account = db.account().getAccount(folder.account);
if (account == null) if (account == null)
throw new IllegalArgumentException("account missing"); throw new IllegalArgumentException("account missing");
try { try {
if (removed) { if (uid < 0)
db.message().deleteMessage(folder.id, uid); throw new MessageRemovedException(folder.name + " fetch uid=" + uid);
if (removed)
throw new MessageRemovedException("removed uid=" + uid); throw new MessageRemovedException("removed uid=" + uid);
}
MimeMessage imessage = (MimeMessage) ifolder.getMessageByUID(uid); MimeMessage imessage = (MimeMessage) ifolder.getMessageByUID(uid);
if (imessage == null) if (imessage == null)
@ -1838,7 +1830,8 @@ class Core {
if (!stats.isEmpty()) if (!stats.isEmpty())
EntityLog.log(context, EntityLog.Type.Statistics, EntityLog.log(context, EntityLog.Type.Statistics,
account.name + "/" + folder.name + " fetch stats " + stats); account.name + "/" + folder.name + " fetch stats " + stats);
} catch (MessageRemovedException | MessageRemovedIOException ex) { } catch (Throwable ex) {
if (MessageHelper.isRemoved(ex)) {
Log.i(ex); Log.i(ex);
if (account.isGmail() && EntityFolder.USER.equals(folder.type)) { if (account.isGmail() && EntityFolder.USER.equals(folder.type)) {
@ -1854,7 +1847,10 @@ class Core {
} }
} }
db.message().deleteMessage(folder.id, uid); int count = db.message().deleteMessage(folder.id, uid);
Log.i(folder.name + " delete local uid=" + uid + " count=" + count);
} else
throw ex;
} finally { } finally {
int count = MessageHelper.getMessageCount(ifolder); int count = MessageHelper.getMessageCount(ifolder);
db.folder().setFolderTotal(folder.id, count < 0 ? null : count, new Date().getTime()); db.folder().setFolderTotal(folder.id, count < 0 ? null : count, new Date().getTime());

Loading…
Cancel
Save