mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
feat(core): set group title for loaded groups
Replace double static_cast of pointer with reinterpret_cast. reinterpret_cast in unsafe because the underlying data may be meaningless in the new type, static cast to void then to a new pointer type has exactly the same problem. This is our intention here.
This commit is contained in:
parent
cbf2a1801f
commit
8db744a505
|
@ -44,6 +44,26 @@ const QString Core::TOX_EXT = ".tox";
|
||||||
|
|
||||||
#define ASSERT_CORE_THREAD assert(QThread::currentThread() == coreThread.get())
|
#define ASSERT_CORE_THREAD assert(QThread::currentThread() == coreThread.get())
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
bool LogConferenceTitleError(TOX_ERR_CONFERENCE_TITLE error)
|
||||||
|
{
|
||||||
|
switch(error)
|
||||||
|
{
|
||||||
|
case TOX_ERR_CONFERENCE_TITLE_OK:
|
||||||
|
break;
|
||||||
|
case TOX_ERR_CONFERENCE_TITLE_CONFERENCE_NOT_FOUND:
|
||||||
|
qWarning() << "Conference title not found";
|
||||||
|
break;
|
||||||
|
case TOX_ERR_CONFERENCE_TITLE_INVALID_LENGTH:
|
||||||
|
qWarning() << "Invalid conference title length";
|
||||||
|
break;
|
||||||
|
case TOX_ERR_CONFERENCE_TITLE_FAIL_SEND:
|
||||||
|
qWarning() << "Failed to send title packet";
|
||||||
|
}
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
|
||||||
Core::Core(QThread* coreThread)
|
Core::Core(QThread* coreThread)
|
||||||
: tox(nullptr)
|
: tox(nullptr)
|
||||||
, av(nullptr)
|
, av(nullptr)
|
||||||
|
@ -451,8 +471,7 @@ void Core::onGroupInvite(Tox* tox, uint32_t friendId, Tox_Conference_Type type,
|
||||||
const uint8_t* cookie, size_t length, void* vCore)
|
const uint8_t* cookie, size_t length, void* vCore)
|
||||||
{
|
{
|
||||||
Core* core = static_cast<Core*>(vCore);
|
Core* core = static_cast<Core*>(vCore);
|
||||||
// static_cast is used twice to replace using unsafe reinterpret_cast
|
const QByteArray data(reinterpret_cast<const char*>(cookie), length);
|
||||||
const QByteArray data(static_cast<const char*>(static_cast<const void*>(cookie)), length);
|
|
||||||
const GroupInvite inviteInfo(friendId, type, data);
|
const GroupInvite inviteInfo(friendId, type, data);
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case TOX_CONFERENCE_TYPE_TEXT:
|
case TOX_CONFERENCE_TYPE_TEXT:
|
||||||
|
@ -1025,7 +1044,18 @@ void Core::loadGroups()
|
||||||
tox_conference_get_chatlist(tox.get(), groupIds);
|
tox_conference_get_chatlist(tox.get(), groupIds);
|
||||||
|
|
||||||
for(size_t i = 0; i < groupCount; ++i) {
|
for(size_t i = 0; i < groupCount; ++i) {
|
||||||
emit emptyGroupCreated(static_cast<int>(groupIds[i]));
|
TOX_ERR_CONFERENCE_TITLE error;
|
||||||
|
size_t titleSize = tox_conference_get_title_size(tox.get(), groupIds[i], &error);
|
||||||
|
if (LogConferenceTitleError(error)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
QByteArray name(titleSize, Qt::Uninitialized);
|
||||||
|
if (!tox_conference_get_title(tox.get(), groupIds[i], reinterpret_cast<uint8_t*>(name.data()), &error))
|
||||||
|
if (LogConferenceTitleError(error)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
emit emptyGroupCreated(static_cast<int>(groupIds[i]), ToxString(name).getQString());
|
||||||
}
|
}
|
||||||
|
|
||||||
delete[] groupIds;
|
delete[] groupIds;
|
||||||
|
@ -1114,7 +1144,7 @@ QString Core::getGroupPeerName(int groupId, int peerId) const
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray name(length, Qt::Uninitialized);
|
QByteArray name(length, Qt::Uninitialized);
|
||||||
uint8_t* namePtr = static_cast<uint8_t*>(static_cast<void*>(name.data()));
|
uint8_t* namePtr = reinterpret_cast<uint8_t*>(name.data());
|
||||||
bool success = tox_conference_peer_get_name(tox.get(), groupId, peerId, namePtr, &error);
|
bool success = tox_conference_peer_get_name(tox.get(), groupId, peerId, namePtr, &error);
|
||||||
if (!parsePeerQueryError(error) || !success) {
|
if (!parsePeerQueryError(error) || !success) {
|
||||||
qWarning() << "getGroupPeerName: Unknown error";
|
qWarning() << "getGroupPeerName: Unknown error";
|
||||||
|
@ -1179,7 +1209,7 @@ QStringList Core::getGroupPeerNames(int groupId) const
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray name(length, Qt::Uninitialized);
|
QByteArray name(length, Qt::Uninitialized);
|
||||||
uint8_t* namePtr = static_cast<uint8_t*>(static_cast<void*>(name.data()));
|
uint8_t* namePtr = reinterpret_cast<uint8_t*>(name.data());
|
||||||
bool ok = tox_conference_peer_get_name(tox.get(), groupId, i, namePtr, &error);
|
bool ok = tox_conference_peer_get_name(tox.get(), groupId, i, namePtr, &error);
|
||||||
if (ok && parsePeerQueryError(error)) {
|
if (ok && parsePeerQueryError(error)) {
|
||||||
names.append(ToxString(name).getQString());
|
names.append(ToxString(name).getQString());
|
||||||
|
@ -1267,7 +1297,7 @@ uint32_t Core::joinGroupchat(const GroupInvite& inviteInfo) const
|
||||||
const uint32_t friendId = inviteInfo.getFriendId();
|
const uint32_t friendId = inviteInfo.getFriendId();
|
||||||
const uint8_t confType = inviteInfo.getType();
|
const uint8_t confType = inviteInfo.getType();
|
||||||
const QByteArray invite = inviteInfo.getInvite();
|
const QByteArray invite = inviteInfo.getInvite();
|
||||||
const uint8_t* const cookie = static_cast<const uint8_t*>(static_cast<const void*>(invite.data()));
|
const uint8_t* const cookie = reinterpret_cast<const uint8_t*>(invite.data());
|
||||||
const size_t cookieLength = invite.length();
|
const size_t cookieLength = invite.length();
|
||||||
switch (confType) {
|
switch (confType) {
|
||||||
case TOX_CONFERENCE_TYPE_TEXT: {
|
case TOX_CONFERENCE_TYPE_TEXT: {
|
||||||
|
|
|
@ -190,7 +190,7 @@ signals:
|
||||||
void friendRemoved(uint32_t friendId);
|
void friendRemoved(uint32_t friendId);
|
||||||
void friendLastSeenChanged(uint32_t friendId, const QDateTime& dateTime);
|
void friendLastSeenChanged(uint32_t friendId, const QDateTime& dateTime);
|
||||||
|
|
||||||
void emptyGroupCreated(int groupnumber);
|
void emptyGroupCreated(int groupnumber, const QString& title = QString());
|
||||||
void groupInviteReceived(const GroupInvite& inviteInfo);
|
void groupInviteReceived(const GroupInvite& inviteInfo);
|
||||||
void groupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
void groupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
||||||
void groupNamelistChanged(int groupnumber, int peernumber, uint8_t change);
|
void groupNamelistChanged(int groupnumber, int peernumber, uint8_t change);
|
||||||
|
|
|
@ -1907,16 +1907,19 @@ Group* Widget::createGroup(int groupId)
|
||||||
return newgroup;
|
return newgroup;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Widget::onEmptyGroupCreated(int groupId)
|
void Widget::onEmptyGroupCreated(int groupId, const QString& title)
|
||||||
{
|
{
|
||||||
Group* group = createGroup(groupId);
|
Group* group = createGroup(groupId);
|
||||||
if (!group) {
|
if (!group) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (title.isEmpty()) {
|
||||||
// Only rename group if groups are visible.
|
// Only rename group if groups are visible.
|
||||||
if (Widget::getInstance()->groupsVisible()) {
|
if (Widget::getInstance()->groupsVisible()) {
|
||||||
groupWidgets[groupId]->editName();
|
groupWidgets[groupId]->editName();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
group->setTitle(QString(), title);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -167,7 +167,7 @@ public slots:
|
||||||
void updateFriendActivity(const Friend* frnd);
|
void updateFriendActivity(const Friend* frnd);
|
||||||
void onMessageSendResult(uint32_t friendId, const QString& message, int messageId);
|
void onMessageSendResult(uint32_t friendId, const QString& message, int messageId);
|
||||||
void onReceiptRecieved(int friendId, int receipt);
|
void onReceiptRecieved(int friendId, int receipt);
|
||||||
void onEmptyGroupCreated(int groupId);
|
void onEmptyGroupCreated(int groupId, const QString& title);
|
||||||
void onGroupInviteReceived(const GroupInvite& inviteInfo);
|
void onGroupInviteReceived(const GroupInvite& inviteInfo);
|
||||||
void onGroupInviteAccepted(const GroupInvite& inviteInfo);
|
void onGroupInviteAccepted(const GroupInvite& inviteInfo);
|
||||||
void onGroupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
void onGroupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user