Issue #1263: Desynchronized nicklist

This is fallout from #1244, which moved models.delNick from using a filter to
using the delete operator.

The delete operator creates a sparse array that has an empty slot for the item
that was deleted. This empty slot is iterable with some constructs, giving a
value of undefined. These unexpected undefined values in the nicklist cause
exceptions to be thrown in some situations, like when calling
models.updateNickSpeak.

To fix this, use Array.splice to remove elements from the nicklist, instead of
the delete operator.
This commit is contained in:
Jon Honeycutt 2024-02-01 18:40:31 -06:00
parent 6cd59b76d7
commit 5765604408
1 changed files with 1 additions and 1 deletions

View File

@ -160,7 +160,7 @@ models.service('models', ['$rootScope', '$filter', 'bufferResume', function($roo
} }
for (i in group.nicks) { for (i in group.nicks) {
if (group.nicks[i].name == nick.name) { if (group.nicks[i].name == nick.name) {
delete group.nicks[i]; group.nicks.splice(i, 1);
break; break;
} }
} }