Add set flags

pull/194/merge
M66B 3 years ago
parent 7f67e79839
commit ebd2d24a6b

@ -869,7 +869,10 @@ class Core {
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
boolean uid_command = prefs.getBoolean("uid_command", false); boolean uid_command = prefs.getBoolean("uid_command", false);
if (flag != Flags.Flag.SEEN && flag != Flags.Flag.FLAGGED) if (flag != Flags.Flag.SEEN &&
flag != Flags.Flag.ANSWERED &&
flag != Flags.Flag.FLAGGED &&
flag != Flags.Flag.DELETED)
throw new IllegalArgumentException("Invalid flag=" + flag); throw new IllegalArgumentException("Invalid flag=" + flag);
if (folder.read_only) if (folder.read_only)
@ -880,9 +883,15 @@ class Core {
if (flag == Flags.Flag.SEEN) { if (flag == Flags.Flag.SEEN) {
db.message().setMessageSeen(message.id, false); db.message().setMessageSeen(message.id, false);
db.message().setMessageUiSeen(message.id, false); db.message().setMessageUiSeen(message.id, false);
} else if (flag == Flags.Flag.ANSWERED) {
db.message().setMessageAnswered(message.id, false);
db.message().setMessageUiAnswered(message.id, false);
} else if (flag == Flags.Flag.FLAGGED) { } else if (flag == Flags.Flag.FLAGGED) {
db.message().setMessageFlagged(message.id, false); db.message().setMessageFlagged(message.id, false);
db.message().setMessageUiFlagged(message.id, false, null); db.message().setMessageUiFlagged(message.id, false, null);
} else if (flag == Flags.Flag.DELETED) {
db.message().setMessageDeleted(message.id, false);
db.message().setMessageUiDeleted(message.id, false);
} }
return; return;
} }
@ -897,8 +906,12 @@ class Core {
throw new MessagingException("Set flag: uid missing"); throw new MessagingException("Set flag: uid missing");
if (flag == Flags.Flag.SEEN && !message.seen.equals(set)) if (flag == Flags.Flag.SEEN && !message.seen.equals(set))
uids.add(message.uid); uids.add(message.uid);
else if (flag == Flags.Flag.ANSWERED && !message.answered.equals(set))
uids.add(message.uid);
else if (flag == Flags.Flag.FLAGGED && !message.flagged.equals(set)) else if (flag == Flags.Flag.FLAGGED && !message.flagged.equals(set))
uids.add(message.uid); uids.add(message.uid);
else if (flag == Flags.Flag.DELETED && !message.deleted.equals(set))
uids.add(message.uid);
} }
if (uids.size() == 0) if (uids.size() == 0)
@ -908,8 +921,12 @@ class Core {
String flags; String flags;
if (flag == Flags.Flag.SEEN) if (flag == Flags.Flag.SEEN)
flags = "\\Seen"; flags = "\\Seen";
else if (flag == Flags.Flag.ANSWERED)
flags = "\\Answered";
else if (flag == Flags.Flag.FLAGGED) else if (flag == Flags.Flag.FLAGGED)
flags = "\\Flagged"; flags = "\\Flagged";
else if (flag == Flags.Flag.DELETED)
flags = "\\Deleted";
else else
throw new IllegalArgumentException("Unknown flag=" + flag); throw new IllegalArgumentException("Unknown flag=" + flag);
@ -940,8 +957,12 @@ class Core {
for (EntityMessage message : messages) for (EntityMessage message : messages)
if (flag == Flags.Flag.SEEN && !message.seen.equals(set)) if (flag == Flags.Flag.SEEN && !message.seen.equals(set))
db.message().setMessageSeen(message.id, set); db.message().setMessageSeen(message.id, set);
else if (flag == Flags.Flag.ANSWERED && !message.answered.equals(set))
db.message().setMessageAnswered(message.id, set);
else if (flag == Flags.Flag.FLAGGED && !message.flagged.equals(set)) else if (flag == Flags.Flag.FLAGGED && !message.flagged.equals(set))
db.message().setMessageFlagged(message.id, set); db.message().setMessageFlagged(message.id, set);
else if (flag == Flags.Flag.DELETED && !message.deleted.equals(set))
db.message().setMessageDeleted(message.id, set);
} }
private static void onSeen(Context context, JSONArray jargs, EntityFolder folder, EntityMessage message, POP3Folder ifolder) throws JSONException { private static void onSeen(Context context, JSONArray jargs, EntityFolder folder, EntityMessage message, POP3Folder ifolder) throws JSONException {

Loading…
Cancel
Save