Collect keywords

pull/146/head
M66B 6 years ago
parent e9d9278129
commit fa90cf96b6

@ -874,8 +874,6 @@ public class ServiceSynchronize extends LifecycleService {
db.folder().setFolderState(folder.id, "connected"); db.folder().setFolderState(folder.id, "connected");
db.folder().setFolderError(folder.id, null); db.folder().setFolderError(folder.id, null);
updateKeywords(db, folder, ifolder.getPermanentFlags().getUserFlags());
Log.i(Helper.TAG, account.name + " folder " + folder.name + " flags=" + ifolder.getPermanentFlags()); Log.i(Helper.TAG, account.name + " folder " + folder.name + " flags=" + ifolder.getPermanentFlags());
// Synchronize folder // Synchronize folder
@ -1316,17 +1314,6 @@ public class ServiceSynchronize extends LifecycleService {
} }
} }
private void updateKeywords(DB db, EntityFolder folder, String[] merge) {
List<String> keywords = new ArrayList<>(Arrays.asList(folder.keywords));
for (String keyword : merge)
if (!keywords.contains(keyword))
keywords.add(keyword);
Collections.sort(keywords);
db.folder().setFolderKeywords(folder.id, DB.Converters.fromStringArray(keywords.toArray(new String[0])));
}
private void processOperations(EntityFolder folder, Session isession, IMAPStore istore, IMAPFolder ifolder, ServiceState state) throws MessagingException, JSONException, IOException { private void processOperations(EntityFolder folder, Session isession, IMAPStore istore, IMAPFolder ifolder, ServiceState state) throws MessagingException, JSONException, IOException {
synchronized (lock) { synchronized (lock) {
try { try {
@ -1524,10 +1511,6 @@ public class ServiceSynchronize extends LifecycleService {
} else } else
keywords.remove(keyword); keywords.remove(keyword);
db.message().setMessageKeywords(message.id, DB.Converters.fromStringArray(keywords.toArray(new String[0]))); db.message().setMessageKeywords(message.id, DB.Converters.fromStringArray(keywords.toArray(new String[0])));
if (!set)
keywords.add(keyword);
updateKeywords(db, folder, keywords.toArray(new String[0]));
} }
private void doAdd(EntityFolder folder, Session isession, IMAPFolder ifolder, EntityMessage message, JSONArray jargs, DB db) throws MessagingException, JSONException, IOException { private void doAdd(EntityFolder folder, Session isession, IMAPFolder ifolder, EntityMessage message, JSONArray jargs, DB db) throws MessagingException, JSONException, IOException {
@ -2193,6 +2176,19 @@ public class ServiceSynchronize extends LifecycleService {
db.message().updateMessage(message); db.message().updateMessage(message);
} }
List<String> fkeywords = new ArrayList<>(Arrays.asList(folder.keywords));
for (String keyword : keywords)
if (!fkeywords.contains(keyword)) {
Log.i(Helper.TAG, folder.name + " adding keyword=" + keyword);
fkeywords.add(keyword);
}
if (folder.keywords.length != fkeywords.size()) {
Collections.sort(fkeywords);
db.folder().setFolderKeywords(folder.id, DB.Converters.fromStringArray(fkeywords.toArray(new String[0])));
}
return message.id; return message.id;
} }

Loading…
Cancel
Save