From 836718aa263039c0e1daef0ba75593a3d35b5cdc Mon Sep 17 00:00:00 2001 From: Mick Sayson Date: Sat, 9 Nov 2019 14:08:15 -0800 Subject: [PATCH] fix(groups): Fix invalid group list on group member join The call to Core::getGroupPeerNames is expected to return a list where the index in the list is the group member id. In any error case we were previously breaking this constraint. It turns out that every time someone joins a group we call this function before they have a valid name resulting in their id not being added to the list. This fix ensures that the list coming out of Core::getGroupPeerNames always has a full list. Fixes #5838 --- src/core/core.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/core/core.cpp b/src/core/core.cpp index 159cb47c2..98807887a 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -1242,6 +1242,7 @@ QStringList Core::getGroupPeerNames(int groupId) const TOX_ERR_CONFERENCE_PEER_QUERY error; size_t length = tox_conference_peer_get_name_size(tox.get(), groupId, i, &error); if (!parsePeerQueryError(error)) { + names.append(QString()); continue; } @@ -1250,9 +1251,13 @@ QStringList Core::getGroupPeerNames(int groupId) const bool ok = tox_conference_peer_get_name(tox.get(), groupId, i, namePtr, &error); if (ok && parsePeerQueryError(error)) { names.append(ToxString(name).getQString()); + } else { + names.append(QString()); } } + assert(names.size() == nPeers); + return names; }