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 New Issue
	
	Block a user
	 Daniel Gultsch
						Daniel Gultsch