Batched search

pull/164/head
M66B 5 years ago
parent ee5e109a3c
commit 76f7897489

@ -77,6 +77,8 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
private State state; private State state;
private static final int SEARCH_LIMIT = 1000;
interface IBoundaryCallbackMessages { interface IBoundaryCallbackMessages {
void onLoading(); void onLoading();
@ -163,7 +165,6 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
Boolean seen = null; Boolean seen = null;
Boolean flagged = null; Boolean flagged = null;
Boolean snoozed = null; Boolean snoozed = null;
String find = (TextUtils.isEmpty(query) ? null : query.toLowerCase(Locale.ROOT)); String find = (TextUtils.isEmpty(query) ? null : query.toLowerCase(Locale.ROOT));
if (find != null && find.startsWith(context.getString(R.string.title_search_special_prefix) + ":")) { if (find != null && find.startsWith(context.getString(R.string.title_search_special_prefix) + ":")) {
String special = find.split(":")[1]; String special = find.split(":")[1];
@ -173,49 +174,57 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
flagged = true; flagged = true;
else if (context.getString(R.string.title_search_special_snoozed).equals(special)) else if (context.getString(R.string.title_search_special_snoozed).equals(special))
snoozed = true; snoozed = true;
}
if (state.matches == null) {
state.matches = db.message().matchMessages(folder, "%" + find + "%", seen, flagged, snoozed);
Log.i("Boundary device folder=" + folder +
" query=" + query +
" seen=" + seen +
" flagged=" + flagged +
" snoozed=" + snoozed +
" matches=" + state.matches.size());
} }
int found = 0; int found = 0;
try { try {
db.beginTransaction(); db.beginTransaction();
for (int i = state.index; i < state.matches.size() && found < pageSize && !state.destroyed; i++) { while (found < pageSize && !state.destroyed) {
state.index = i + 1; state.matches = db.message().matchMessages(
folder,
TupleMatch match = state.matches.get(i); "%" + find + "%",
seen, flagged, snoozed,
if (find == null || seen != null || flagged != null || snoozed != null) SEARCH_LIMIT, state.offset);
match.matched = true; Log.i("Boundary device folder=" + folder +
else { " query=" + query +
if (match.matched == null || !match.matched) " seen=" + seen +
try { " flagged=" + flagged +
File file = EntityMessage.getFile(context, match.id); " snoozed=" + snoozed +
if (file.exists()) { " offset=" + state.offset +
String html = Helper.readText(file); " size=" + state.matches.size());
String text = HtmlHelper.getText(html); if (state.matches.size() == 0)
if (text.toLowerCase(Locale.ROOT).contains(find)) break;
match.matched = true;
for (int i = state.index; i < state.matches.size() && found < pageSize && !state.destroyed; i++) {
state.index = i + 1;
TupleMatch match = state.matches.get(i);
if (find == null || seen != null || flagged != null || snoozed != null)
match.matched = true;
else {
if (match.matched == null || !match.matched)
try {
File file = EntityMessage.getFile(context, match.id);
if (file.exists()) {
String html = Helper.readText(file);
String text = HtmlHelper.getText(html);
if (text.toLowerCase(Locale.ROOT).contains(find))
match.matched = true;
}
} catch (IOException ex) {
Log.e(ex);
} }
} catch (IOException ex) { }
Log.e(ex);
}
}
if (match.matched != null && match.matched) { if (match.matched != null && match.matched) {
found++; found++;
db.message().setMessageFound(match.account, match.thread); db.message().setMessageFound(match.account, match.thread);
}
} }
state.offset += SEARCH_LIMIT;
} }
db.setTransactionSuccessful(); db.setTransactionSuccessful();
@ -514,6 +523,7 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
boolean destroyed = false; boolean destroyed = false;
boolean error = false; boolean error = false;
int index = 0; int index = 0;
int offset = 0;
List<TupleMatch> matches = null; List<TupleMatch> matches = null;
MailService iservice = null; MailService iservice = null;

@ -234,8 +234,9 @@ public interface DaoMessage {
" WHEN 0 THEN message.ui_snoozed IS NULL" + " WHEN 0 THEN message.ui_snoozed IS NULL" +
" WHEN 1 THEN message.ui_snoozed IS NOT NULL" + " WHEN 1 THEN message.ui_snoozed IS NOT NULL" +
" ELSE 1 END" + // NULL: true " ELSE 1 END" + // NULL: true
" ORDER BY message.received DESC") " ORDER BY message.received DESC" +
List<TupleMatch> matchMessages(Long folder, String find, Boolean seen, Boolean flagged, Boolean snoozed); " LIMIT :limit OFFSET :offset")
List<TupleMatch> matchMessages(Long folder, String find, Boolean seen, Boolean flagged, Boolean snoozed, int limit, int offset);
@Query("SELECT id" + @Query("SELECT id" +
" FROM message" + " FROM message" +

Loading…
Cancel
Save