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.
This commit is contained in:
Eric House 2020-06-21 11:32:19 -07:00
parent 1398e1ed55
commit 4a3f5d5a44

View file

@ -97,7 +97,7 @@ public class BTInviteDelegate extends InviteDelegate {
for ( Iterator<TwoStringPair> iter = pairs.iterator(); for ( Iterator<TwoStringPair> iter = pairs.iterator();
iter.hasNext(); ) { iter.hasNext(); ) {
TwoStringPair pair = iter.next(); TwoStringPair pair = iter.next();
if ( pair.str2.equals( dev ) ) { if ( TextUtils.equals( pair.str2, dev ) ) {
iter.remove(); iter.remove();
break; break;
} }
@ -105,6 +105,18 @@ public class BTInviteDelegate extends InviteDelegate {
} }
} }
private void removeNulls()
{
for ( Iterator<TwoStringPair> 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; } boolean empty() { return pairs == null || pairs.size() == 0; }
private void sort() private void sort()
@ -316,6 +328,7 @@ public class BTInviteDelegate extends InviteDelegate {
if ( null == sPersisted ) { if ( null == sPersisted ) {
try { try {
sPersisted = (Persisted)DBUtils.getSerializableFor( context, KEY_PERSIST ); sPersisted = (Persisted)DBUtils.getSerializableFor( context, KEY_PERSIST );
sPersisted.removeNulls(); // clean up earlier mistakes
} catch ( Exception ex ) {} // NPE, de-serialization problems, etc. } catch ( Exception ex ) {} // NPE, de-serialization problems, etc.
if ( null == sPersisted ) { if ( null == sPersisted ) {