From 4bf1b8604c572a7b7f582fc6bea7ef8a8c09c861 Mon Sep 17 00:00:00 2001 From: Matthieu Gallien Date: Tue, 19 Mar 2024 09:39:36 +0100 Subject: [PATCH] if desktop client sent a first reply: wait for the menu data may need the user to wait a bit longer but should prevent missing the context menu should still be robust since we only wait indefinitely if desktop client sent a first reply Signed-off-by: Matthieu Gallien --- .../windows/NCContextMenu/NCClientInterface.cpp | 8 +++++++- src/gui/socketapi/socketapi.cpp | 2 +- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/shell_integration/windows/NCContextMenu/NCClientInterface.cpp b/shell_integration/windows/NCContextMenu/NCClientInterface.cpp index 380f4e22291b2..4c5d665139aae 100644 --- a/shell_integration/windows/NCContextMenu/NCClientInterface.cpp +++ b/shell_integration/windows/NCContextMenu/NCClientInterface.cpp @@ -48,7 +48,10 @@ NCClientInterface::ContextMenuInfo NCClientInterface::FetchInfo(const std::wstri ContextMenuInfo info; std::wstring response; int sleptCount = 0; - while (sleptCount < 20) { + constexpr auto noReplyTimeout = 20; + constexpr auto replyTimeout = 200; + bool receivedReplyFromDesktopClient = false; + while ((!receivedReplyFromDesktopClient && sleptCount < noReplyTimeout) || (receivedReplyFromDesktopClient && sleptCount < replyTimeout)) { if (socket.ReadLine(&response)) { if (StringUtil::begins_with(response, wstring(L"REGISTER_PATH:"))) { wstring responsePath = response.substr(14); // length of REGISTER_PATH @@ -65,6 +68,9 @@ NCClientInterface::ContextMenuInfo NCClientInterface::FetchInfo(const std::wstri if (!StringUtil::extractChunks(response, commandName, flags, title)) continue; info.menuItems.push_back({ commandName, flags, title }); + } else if (StringUtil::begins_with(response, wstring(L"GET_MENU_ITEMS:BEGIN"))) { + receivedReplyFromDesktopClient = true; + continue; } else if (StringUtil::begins_with(response, wstring(L"GET_MENU_ITEMS:END"))) { break; // Stop once we completely received the last sent request } diff --git a/src/gui/socketapi/socketapi.cpp b/src/gui/socketapi/socketapi.cpp index dfc70d067ea3e..78af17b4153e1 100644 --- a/src/gui/socketapi/socketapi.cpp +++ b/src/gui/socketapi/socketapi.cpp @@ -1346,7 +1346,7 @@ SocketApi::FileData SocketApi::FileData::parentFolder() const void SocketApi::command_GET_MENU_ITEMS(const QString &argument, OCC::SocketListener *listener) { - listener->sendMessage(QString("GET_MENU_ITEMS:BEGIN")); + listener->sendMessage(QString("GET_MENU_ITEMS:BEGIN"), true); const QStringList files = split(argument); // Find the common sync folder.