Auto retry search without keywords

pull/210/head
M66B 2 years ago
parent d128c9284a
commit 1fe67df028

@ -509,20 +509,38 @@ public class BoundaryCallbackMessages extends PagedList.BoundaryCallback<TupleMe
return search(true, browsable.keywords, protocol, state); return search(true, browsable.keywords, protocol, state);
} catch (Throwable ex) { } catch (Throwable ex) {
EntityLog.log(context, ex.toString()); EntityLog.log(context, ex.toString());
if (ex instanceof ProtocolException && if (ex instanceof ProtocolException && ex.getMessage() != null)
ex.getMessage() != null && try {
ex.getMessage().contains("full text search not supported")) { boolean retry = false;
String msg = context.getString(R.string.title_service_auth, String remark = null;
account.host + ": " + getMessage(ex)); if (ex.getMessage().contains("full text search not supported")) {
ApplicationEx.getMainHandler().post(new Runnable() { retry = true;
@Override criteria.in_message = false;
public void run() { } else if (ex.getMessage().contains("invalid search criteria")) {
if (intf != null) // invalid SEARCH command syntax, invalid search criteria syntax
intf.onWarning(msg); retry = true;
criteria.in_keywords = false;
remark = "Keyword search not supported?";
} }
});
criteria.in_message = false; if (retry) {
} String msg = context.getString(R.string.title_service_auth,
account.host + ": " +
(remark == null ? "" : remark + " - ") +
getMessage(ex));
ApplicationEx.getMainHandler().post(new Runnable() {
@Override
public void run() {
if (intf != null)
intf.onWarning(msg);
}
});
return search(true, browsable.keywords, protocol, state);
}
} catch (Throwable exex) {
Log.w(exex);
}
} }
return search(false, browsable.keywords, protocol, state); return search(false, browsable.keywords, protocol, state);

Loading…
Cancel
Save