mirror of
				https://github.com/oxen-io/session-android.git
				synced 2025-10-25 13:58:40 +00:00 
			
		
		
		
	Revert "Apply contact updates in batches of 50."
This reverts commit 5d9d6ac12b.
			
			
This commit is contained in:
		| @@ -19,7 +19,6 @@ package org.thoughtcrime.securesms.contacts; | ||||
| import android.accounts.Account; | ||||
| import android.annotation.SuppressLint; | ||||
| import android.content.ContentProviderOperation; | ||||
| import android.content.ContentResolver; | ||||
| import android.content.Context; | ||||
| import android.content.OperationApplicationException; | ||||
| import android.database.Cursor; | ||||
| @@ -138,7 +137,7 @@ public class ContactsDatabase { | ||||
|     } | ||||
|  | ||||
|     if (!operations.isEmpty()) { | ||||
|       applyOperationsInBatches(context.getContentResolver(), ContactsContract.AUTHORITY, operations, 50); | ||||
|       context.getContentResolver().applyBatch(ContactsContract.AUTHORITY, operations); | ||||
|     } | ||||
|   } | ||||
|  | ||||
| @@ -533,18 +532,6 @@ public class ContactsDatabase { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private void applyOperationsInBatches(@NonNull ContentResolver contentResolver, | ||||
|                                         @NonNull String authority, | ||||
|                                         @NonNull List<ContentProviderOperation> operations, | ||||
|                                         int batchSize) | ||||
|       throws OperationApplicationException, RemoteException | ||||
|   { | ||||
|     List<List<ContentProviderOperation>> batches = Util.chunk(operations, batchSize); | ||||
|     for (List<ContentProviderOperation> batch : batches) { | ||||
|       contentResolver.applyBatch(authority, new ArrayList<>(batch)); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   private static class ProjectionMappingCursor extends CursorWrapper { | ||||
|  | ||||
|     private final Map<String, String>    projectionMap; | ||||
|   | ||||
| @@ -218,7 +218,7 @@ public class DirectoryHelper { | ||||
|           } | ||||
|         } | ||||
|       } catch (RemoteException | OperationApplicationException e) { | ||||
|         Log.w(TAG, "Failed to update contacts.", e); | ||||
|         Log.w(TAG, e); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -63,7 +63,6 @@ import java.io.UnsupportedEncodingException; | ||||
| import java.security.NoSuchAlgorithmException; | ||||
| import java.security.SecureRandom; | ||||
| import java.text.DecimalFormat; | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
| import java.util.Collection; | ||||
| import java.util.Collections; | ||||
| @@ -78,7 +77,7 @@ import java.util.concurrent.TimeUnit; | ||||
| public class Util { | ||||
|   private static final String TAG = Util.class.getSimpleName(); | ||||
|  | ||||
|   private static volatile Handler handler; | ||||
|   public static Handler handler = new Handler(Looper.getMainLooper()); | ||||
|  | ||||
|   public static <T> List<T> asList(T... elements) { | ||||
|     List<T> result = new LinkedList<>(); | ||||
| @@ -142,17 +141,6 @@ public class Util { | ||||
|     return map.containsKey(key) ? map.get(key) : defaultValue; | ||||
|   } | ||||
|  | ||||
|   public static <E> List<List<E>> chunk(@NonNull List<E> list, int chunkSize) { | ||||
|     List<List<E>> chunks = new ArrayList<>(list.size() / chunkSize); | ||||
|  | ||||
|     for (int i = 0; i < list.size(); i += chunkSize) { | ||||
|       List<E> chunk = list.subList(i, Math.min(list.size(), i + chunkSize)); | ||||
|       chunks.add(chunk); | ||||
|     } | ||||
|  | ||||
|     return chunks; | ||||
|   } | ||||
|  | ||||
|   public static CharSequence getBoldedString(String value) { | ||||
|     SpannableString spanned = new SpannableString(value); | ||||
|     spanned.setSpan(new StyleSpan(Typeface.BOLD), 0, | ||||
| @@ -406,20 +394,20 @@ public class Util { | ||||
|   } | ||||
|  | ||||
|   public static void postToMain(final @NonNull Runnable runnable) { | ||||
|     getHandler().post(runnable); | ||||
|     handler.post(runnable); | ||||
|   } | ||||
|  | ||||
|   public static void runOnMain(final @NonNull Runnable runnable) { | ||||
|     if (isMainThread()) runnable.run(); | ||||
|     else                getHandler().post(runnable); | ||||
|     else                handler.post(runnable); | ||||
|   } | ||||
|  | ||||
|   public static void runOnMainDelayed(final @NonNull Runnable runnable, long delayMillis) { | ||||
|     getHandler().postDelayed(runnable, delayMillis); | ||||
|     handler.postDelayed(runnable, delayMillis); | ||||
|   } | ||||
|  | ||||
|   public static void cancelRunnableOnMain(@NonNull Runnable runnable) { | ||||
|     getHandler().removeCallbacks(runnable); | ||||
|     handler.removeCallbacks(runnable); | ||||
|   } | ||||
|  | ||||
|   public static void runOnMainSync(final @NonNull Runnable runnable) { | ||||
| @@ -522,15 +510,4 @@ public class Util { | ||||
|  | ||||
|     return new DecimalFormat("#,##0.#").format(sizeBytes/Math.pow(1024, digitGroups)) + " " + units[digitGroups]; | ||||
|   } | ||||
|  | ||||
|   private static Handler getHandler() { | ||||
|     if (handler == null) { | ||||
|       synchronized (Util.class) { | ||||
|         if (handler == null) { | ||||
|           handler = new Handler(Looper.getMainLooper()); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     return handler; | ||||
|   } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Greyson Parrelli
					Greyson Parrelli