Cache SDS folder/account

pull/72/head
M66B 6 years ago
parent 738f10425f
commit 982fb06316

@ -37,6 +37,8 @@ public class SearchDataSource extends PositionalDataSource<TupleMessageEx> imple
private long fid; private long fid;
private String search; private String search;
private EntityFolder folder;
private EntityAccount account;
private IMAPStore istore = null; private IMAPStore istore = null;
private IMAPFolder ifolder; private IMAPFolder ifolder;
private Message[] imessages; private Message[] imessages;
@ -91,8 +93,8 @@ public class SearchDataSource extends PositionalDataSource<TupleMessageEx> imple
@Override @Override
public void loadRange(LoadRangeParams params, LoadRangeCallback<TupleMessageEx> callback) { public void loadRange(LoadRangeParams params, LoadRangeCallback<TupleMessageEx> callback) {
Log.i(Helper.TAG, "SDS load range");
try { try {
Log.i(Helper.TAG, "SDS load range");
SearchResult result = search(search, params.startPosition, params.loadSize); SearchResult result = search(search, params.startPosition, params.loadSize);
callback.onResult(result.messages); callback.onResult(result.messages);
} catch (Throwable ex) { } catch (Throwable ex) {
@ -103,11 +105,11 @@ public class SearchDataSource extends PositionalDataSource<TupleMessageEx> imple
private SearchResult search(String term, int from, int count) throws MessagingException, UnsupportedEncodingException { private SearchResult search(String term, int from, int count) throws MessagingException, UnsupportedEncodingException {
Log.i(Helper.TAG, "SDS search from=" + from + " count=" + count); Log.i(Helper.TAG, "SDS search from=" + from + " count=" + count);
DB db = DB.getInstance(context);
EntityFolder folder = db.folder().getFolder(fid);
EntityAccount account = db.account().getAccount(folder.account);
if (istore == null) { if (istore == null) {
DB db = DB.getInstance(context);
folder = db.folder().getFolder(fid);
account = db.account().getAccount(folder.account);
Properties props = MessageHelper.getSessionProperties(); Properties props = MessageHelper.getSessionProperties();
Session isession = Session.getInstance(props, null); Session isession = Session.getInstance(props, null);

Loading…
Cancel
Save