Prevent crash

pull/180/head
M66B 5 years ago
parent e3413d4c69
commit 9db851be98

@ -4190,45 +4190,58 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
String thread = args.getString("thread"); String thread = args.getString("thread");
long id = args.getLong("id"); long id = args.getLong("id");
EntityAccount account;
EntityFolder trash;
EntityFolder archive;
boolean trashable = false;
boolean snoozable = false;
boolean archivable = false;
DB db = DB.getInstance(context); DB db = DB.getInstance(context);
try {
db.beginTransaction();
EntityAccount account = db.account().getAccount(aid); account = db.account().getAccount(aid);
if (account != null && account.color != null) if (account != null && account.color != null)
args.putInt("color", account.color); args.putInt("color", account.color);
EntityFolder trash = db.folder().getFolderByType(aid, EntityFolder.TRASH); trash = db.folder().getFolderByType(aid, EntityFolder.TRASH);
EntityFolder archive = db.folder().getFolderByType(aid, EntityFolder.ARCHIVE); archive = db.folder().getFolderByType(aid, EntityFolder.ARCHIVE);
List<EntityMessage> messages = db.message().getMessagesByThread( List<EntityMessage> messages = db.message().getMessagesByThread(
aid, thread, threading ? null : id, null); aid, thread, threading ? null : id, null);
for (EntityMessage message : messages) {
EntityFolder folder = db.folder().getFolder(message.folder);
if (!folder.read_only &&
!EntityFolder.DRAFTS.equals(folder.type) &&
!EntityFolder.OUTBOX.equals(folder.type) &&
// allow sent
!EntityFolder.TRASH.equals(folder.type) &&
!EntityFolder.JUNK.equals(folder.type))
trashable = true;
if (!EntityFolder.OUTBOX.equals(folder.type))
snoozable = true;
if (!folder.read_only &&
!EntityFolder.isOutgoing(folder.type) &&
!EntityFolder.TRASH.equals(folder.type) &&
!EntityFolder.JUNK.equals(folder.type) &&
!EntityFolder.ARCHIVE.equals(folder.type))
archivable = true;
}
boolean trashable = false; db.setTransactionSuccessful();
boolean snoozable = false; } finally {
boolean archivable = false; db.endTransaction();
for (EntityMessage message : messages) {
EntityFolder folder = db.folder().getFolder(message.folder);
if (!folder.read_only &&
!EntityFolder.DRAFTS.equals(folder.type) &&
!EntityFolder.OUTBOX.equals(folder.type) &&
// allow sent
!EntityFolder.TRASH.equals(folder.type) &&
!EntityFolder.JUNK.equals(folder.type))
trashable = true;
if (!EntityFolder.OUTBOX.equals(folder.type))
snoozable = true;
if (!folder.read_only &&
!EntityFolder.isOutgoing(folder.type) &&
!EntityFolder.TRASH.equals(folder.type) &&
!EntityFolder.JUNK.equals(folder.type) &&
!EntityFolder.ARCHIVE.equals(folder.type))
archivable = true;
} }
return new Boolean[]{ return new Boolean[]{
trash == null || account.protocol == EntityAccount.TYPE_POP, trash == null ||
(account != null && account.protocol == EntityAccount.TYPE_POP),
trashable, trashable,
snoozable, snoozable,
archivable && archive != null}; archivable && archive != null};

Loading…
Cancel
Save