From 37d774b9da650baf2ad60c6c5c80b26b6ab27c3d Mon Sep 17 00:00:00 2001 From: Eric House Date: Sun, 21 Jun 2020 11:32:19 -0700 Subject: [PATCH] on load, remove records missing a device Can't test because changing the class meant the thing couldn't be deserialized. Oh well. It was likely a fluke that caused the null dev entry anyway. --- .../org/eehouse/android/xw4/BTInviteDelegate.java | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BTInviteDelegate.java b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BTInviteDelegate.java index da106a17f..4367ab5b3 100644 --- a/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BTInviteDelegate.java +++ b/xwords4/android/app/src/main/java/org/eehouse/android/xw4/BTInviteDelegate.java @@ -97,7 +97,7 @@ public class BTInviteDelegate extends InviteDelegate { for ( Iterator iter = pairs.iterator(); iter.hasNext(); ) { TwoStringPair pair = iter.next(); - if ( pair.str2.equals( dev ) ) { + if ( TextUtils.equals( pair.str2, dev ) ) { iter.remove(); break; } @@ -105,6 +105,18 @@ public class BTInviteDelegate extends InviteDelegate { } } + private void removeNulls() + { + for ( Iterator iter = pairs.iterator(); + iter.hasNext(); ) { + TwoStringPair pair = iter.next(); + if ( TextUtils.isEmpty( pair.str2 ) ) { + Log.d( TAG, "removeNulls(): removing!!" ); + iter.remove(); + } + } + } + boolean empty() { return pairs == null || pairs.size() == 0; } private void sort() @@ -316,6 +328,7 @@ public class BTInviteDelegate extends InviteDelegate { if ( null == sPersisted ) { try { sPersisted = (Persisted)DBUtils.getSerializableFor( context, KEY_PERSIST ); + sPersisted.removeNulls(); // clean up earlier mistakes } catch ( Exception ex ) {} // NPE, de-serialization problems, etc. if ( null == sPersisted ) {