load currently open conversation faster
This commit is contained in:
parent
ac9beef98a
commit
aff2b33e27
|
@ -1013,7 +1013,6 @@ public class AxolotlService implements OnAdvancedStreamFeaturesLoaded {
|
||||||
} else {
|
} else {
|
||||||
fetchDeviceListStatus.put(jid, false);
|
fetchDeviceListStatus.put(jid, false);
|
||||||
}
|
}
|
||||||
Log.d(Config.LOGTAG, response.toString());
|
|
||||||
if (callbacks1 != null) {
|
if (callbacks1 != null) {
|
||||||
for (OnDeviceIdsFetched callback1 : callbacks1) {
|
for (OnDeviceIdsFetched callback1 : callbacks1) {
|
||||||
callback1.fetched(jid, null);
|
callback1.fetched(jid, null);
|
||||||
|
|
|
@ -105,6 +105,7 @@ import eu.siacs.conversations.utils.MimeUtils;
|
||||||
import eu.siacs.conversations.utils.OnPhoneContactsLoadedListener;
|
import eu.siacs.conversations.utils.OnPhoneContactsLoadedListener;
|
||||||
import eu.siacs.conversations.utils.PRNGFixes;
|
import eu.siacs.conversations.utils.PRNGFixes;
|
||||||
import eu.siacs.conversations.utils.PhoneHelper;
|
import eu.siacs.conversations.utils.PhoneHelper;
|
||||||
|
import eu.siacs.conversations.utils.QuickLoader;
|
||||||
import eu.siacs.conversations.utils.ReplacingSerialSingleThreadExecutor;
|
import eu.siacs.conversations.utils.ReplacingSerialSingleThreadExecutor;
|
||||||
import eu.siacs.conversations.utils.ReplacingTaskManager;
|
import eu.siacs.conversations.utils.ReplacingTaskManager;
|
||||||
import eu.siacs.conversations.utils.Resolver;
|
import eu.siacs.conversations.utils.Resolver;
|
||||||
|
@ -1392,22 +1393,17 @@ public class XmppConnectionService extends Service {
|
||||||
loadPhoneContacts();
|
loadPhoneContacts();
|
||||||
Log.d(Config.LOGTAG, "restoring messages...");
|
Log.d(Config.LOGTAG, "restoring messages...");
|
||||||
final long startMessageRestore = SystemClock.elapsedRealtime();
|
final long startMessageRestore = SystemClock.elapsedRealtime();
|
||||||
for (Conversation conversation : conversations) {
|
final Conversation quickLoad = QuickLoader.get(this.conversations);
|
||||||
conversation.addAll(0, databaseBackend.getMessages(conversation, Config.PAGE_SIZE));
|
if (quickLoad != null) {
|
||||||
checkDeletedFiles(conversation);
|
restoreMessages(quickLoad);
|
||||||
conversation.findUnsentTextMessages(new Conversation.OnMessageFound() {
|
updateConversationUi();
|
||||||
|
final long diffMessageRestore = SystemClock.elapsedRealtime() - startMessageRestore;
|
||||||
@Override
|
Log.d(Config.LOGTAG,"quickly restored "+quickLoad.getName()+" after " + diffMessageRestore + "ms");
|
||||||
public void onMessageFound(Message message) {
|
|
||||||
markMessage(message, Message.STATUS_WAITING);
|
|
||||||
}
|
}
|
||||||
});
|
for (Conversation conversation : this.conversations) {
|
||||||
conversation.findUnreadMessages(new Conversation.OnMessageFound() {
|
if (quickLoad != conversation) {
|
||||||
@Override
|
restoreMessages(conversation);
|
||||||
public void onMessageFound(Message message) {
|
|
||||||
mNotificationService.pushFromBacklog(message);
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
mNotificationService.finishBacklog(false);
|
mNotificationService.finishBacklog(false);
|
||||||
restoredFromDatabaseLatch.countDown();
|
restoredFromDatabaseLatch.countDown();
|
||||||
|
@ -1419,6 +1415,13 @@ public class XmppConnectionService extends Service {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void restoreMessages(Conversation conversation) {
|
||||||
|
conversation.addAll(0, databaseBackend.getMessages(conversation, Config.PAGE_SIZE));
|
||||||
|
checkDeletedFiles(conversation);
|
||||||
|
conversation.findUnsentTextMessages(message -> markMessage(message, Message.STATUS_WAITING));
|
||||||
|
conversation.findUnreadMessages(message -> mNotificationService.pushFromBacklog(message));
|
||||||
|
}
|
||||||
|
|
||||||
public void loadPhoneContacts() {
|
public void loadPhoneContacts() {
|
||||||
mContactMergerExecutor.execute(() -> PhoneHelper.loadPhoneContacts(XmppConnectionService.this, new OnPhoneContactsLoadedListener() {
|
mContactMergerExecutor.execute(() -> PhoneHelper.loadPhoneContacts(XmppConnectionService.this, new OnPhoneContactsLoadedListener() {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -95,6 +95,7 @@ import eu.siacs.conversations.ui.widget.EditMessage;
|
||||||
import eu.siacs.conversations.utils.ExceptionHelper;
|
import eu.siacs.conversations.utils.ExceptionHelper;
|
||||||
import eu.siacs.conversations.utils.MessageUtils;
|
import eu.siacs.conversations.utils.MessageUtils;
|
||||||
import eu.siacs.conversations.utils.NickValidityChecker;
|
import eu.siacs.conversations.utils.NickValidityChecker;
|
||||||
|
import eu.siacs.conversations.utils.QuickLoader;
|
||||||
import eu.siacs.conversations.utils.StylingHelper;
|
import eu.siacs.conversations.utils.StylingHelper;
|
||||||
import eu.siacs.conversations.utils.TimeframeUtils;
|
import eu.siacs.conversations.utils.TimeframeUtils;
|
||||||
import eu.siacs.conversations.utils.UIHelper;
|
import eu.siacs.conversations.utils.UIHelper;
|
||||||
|
@ -1805,6 +1806,7 @@ public class ConversationFragment extends XmppFragment implements EditMessage.Ke
|
||||||
String uuid = savedInstanceState.getString(STATE_CONVERSATION_UUID);
|
String uuid = savedInstanceState.getString(STATE_CONVERSATION_UUID);
|
||||||
pendingLastMessageUuid.push(savedInstanceState.getString(STATE_LAST_MESSAGE_UUID, null));
|
pendingLastMessageUuid.push(savedInstanceState.getString(STATE_LAST_MESSAGE_UUID, null));
|
||||||
if (uuid != null) {
|
if (uuid != null) {
|
||||||
|
QuickLoader.set(uuid);
|
||||||
this.pendingConversationsUuid.push(uuid);
|
this.pendingConversationsUuid.push(uuid);
|
||||||
String takePhotoUri = savedInstanceState.getString(STATE_PHOTO_URI);
|
String takePhotoUri = savedInstanceState.getString(STATE_PHOTO_URI);
|
||||||
if (takePhotoUri != null) {
|
if (takePhotoUri != null) {
|
||||||
|
@ -1874,6 +1876,7 @@ public class ConversationFragment extends XmppFragment implements EditMessage.Ke
|
||||||
}
|
}
|
||||||
|
|
||||||
public void reInit(Conversation conversation, Bundle extras) {
|
public void reInit(Conversation conversation, Bundle extras) {
|
||||||
|
QuickLoader.set(conversation.getUuid());
|
||||||
this.saveMessageDraftStopAudioPlayer();
|
this.saveMessageDraftStopAudioPlayer();
|
||||||
if (this.reInit(conversation, extras != null)) {
|
if (this.reInit(conversation, extras != null)) {
|
||||||
if (extras != null) {
|
if (extras != null) {
|
||||||
|
|
62
src/main/java/eu/siacs/conversations/utils/QuickLoader.java
Normal file
62
src/main/java/eu/siacs/conversations/utils/QuickLoader.java
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Daniel Gultsch All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation and/or
|
||||||
|
* other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* 3. Neither the name of the copyright holder nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software without
|
||||||
|
* specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package eu.siacs.conversations.utils;
|
||||||
|
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import eu.siacs.conversations.entities.Conversation;
|
||||||
|
|
||||||
|
public class QuickLoader {
|
||||||
|
|
||||||
|
private static String CONVERSATION_UUID = null;
|
||||||
|
private static Object LOCK = new Object();
|
||||||
|
|
||||||
|
public static void set(final String uuid) {
|
||||||
|
synchronized (LOCK) {
|
||||||
|
CONVERSATION_UUID = uuid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Conversation get(List<Conversation> haystack) {
|
||||||
|
synchronized (LOCK) {
|
||||||
|
if (CONVERSATION_UUID == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
for (Conversation conversation : haystack) {
|
||||||
|
if (conversation.getUuid().equals(CONVERSATION_UUID)) {
|
||||||
|
return conversation;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue