From 6c9c3809152d0dd3f1b68fb7e8dd131c595a6944 Mon Sep 17 00:00:00 2001 From: Anthony Bilinski Date: Thu, 17 Mar 2022 23:23:30 -0700 Subject: [PATCH] feat(core): Add error parsing for Tox_Err_File_Send_Chunk --- src/core/corefile.cpp | 9 ++++-- util/include/util/toxcoreerrorparser.h | 1 + util/src/toxcoreerrorparser.cpp | 42 ++++++++++++++++++++++++++ 3 files changed, 49 insertions(+), 3 deletions(-) diff --git a/src/core/corefile.cpp b/src/core/corefile.cpp index 30ae36c35..688766d16 100644 --- a/src/core/corefile.cpp +++ b/src/core/corefile.cpp @@ -502,7 +502,9 @@ void CoreFile::onFileDataCallback(Tox* tox, uint32_t friendId, uint32_t fileId, qWarning("onFileDataCallback: Failed to read from file"); file->status = ToxFile::CANCELED; emit coreFile->fileTransferCancelled(*file); - tox_file_send_chunk(tox, friendId, fileId, pos, nullptr, 0, nullptr); + Tox_Err_File_Send_Chunk err; + tox_file_send_chunk(tox, friendId, fileId, pos, nullptr, 0, &err); + PARSE_ERR(err); coreFile->removeFile(friendId, fileId); return; } @@ -510,8 +512,9 @@ void CoreFile::onFileDataCallback(Tox* tox, uint32_t friendId, uint32_t fileId, file->hashGenerator->addData(reinterpret_cast(data.get()), length); } - if (!tox_file_send_chunk(tox, friendId, fileId, pos, data.get(), nread, nullptr)) { - qWarning("onFileDataCallback: Failed to send data chunk"); + Tox_Err_File_Send_Chunk err; + tox_file_send_chunk(tox, friendId, fileId, pos, data.get(), nread, &err); + if (!PARSE_ERR(err)) { return; } if (file->fileKind != TOX_FILE_KIND_AVATAR) { diff --git a/util/include/util/toxcoreerrorparser.h b/util/include/util/toxcoreerrorparser.h index ce4d1e24e..55ae0e815 100644 --- a/util/include/util/toxcoreerrorparser.h +++ b/util/include/util/toxcoreerrorparser.h @@ -53,4 +53,5 @@ namespace ToxcoreErrorParser { bool parseErr(Tox_Err_File_Control error, int line); bool parseErr(Tox_Err_File_Get error, int line); bool parseErr(Tox_Err_File_Send error, int line); + bool parseErr(Tox_Err_File_Send_Chunk error, int line); } // namespace ToxcoreErrorParser diff --git a/util/src/toxcoreerrorparser.cpp b/util/src/toxcoreerrorparser.cpp index 501714ff6..333fb2c05 100644 --- a/util/src/toxcoreerrorparser.cpp +++ b/util/src/toxcoreerrorparser.cpp @@ -501,3 +501,45 @@ bool ToxcoreErrorParser::parseErr(Tox_Err_File_Send error, int line) qCritical() << line << "Unknown Tox_Err_File_Send error code:" << error; return false; } + +bool ToxcoreErrorParser::parseErr(Tox_Err_File_Send_Chunk error, int line) +{ + switch (error) { + case TOX_ERR_FILE_SEND_CHUNK_OK: + return true; + + case TOX_ERR_FILE_SEND_CHUNK_NULL: + qCritical() << line << ": The length parameter was non-zero, but data was NULL."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_FRIEND_NOT_FOUND: + qCritical() << line << ": The friend_number passed did not designate a valid friend."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_FRIEND_NOT_CONNECTED: + qCritical() << line << ": This client is currently not connected to the friend."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_NOT_FOUND: + qCritical() << line << ": No file transfer with the given file number was found for the given friend."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_NOT_TRANSFERRING: + qCritical() << line << ": File transfer was found but isn't in a transferring state."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_INVALID_LENGTH: + qCritical() << line << ": Attempted to send more or less data than requested."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_SENDQ: + qCritical() << line << ": Packet queue is full."; + return false; + + case TOX_ERR_FILE_SEND_CHUNK_WRONG_POSITION: + qCritical() << line << ": Position parameter was wrong."; + return false; + } + qCritical() << line << "Unknown Tox_Err_File_Send_Chunk error code:" << error; + return false; +}