From dd3ea8adfef868e52098ea24d2ed08320a90e3b9 Mon Sep 17 00:00:00 2001 From: Chih-Hsuan Yen Date: Fri, 20 Aug 2021 21:27:57 +0800 Subject: [PATCH] lib/platform: Fix encoding for text copied between linux and windows Copied from https://github.com/symless/synergy-core/pull/7029. I don't include the application/x-moz-nativehtml part in that patch as I already added it in https://github.com/debauchee/barrier/pull/1164. Fixes https://github.com/debauchee/barrier/issues/1037 Fixes https://github.com/debauchee/barrier/issues/1137 Original author: Serhii Hadzhilov --- ...g-for-text-copied-between-linux-and-windows.bugfix | 2 ++ src/lib/platform/XWindowsClipboardHTMLConverter.cpp | 11 +++++++++-- 2 files changed, 11 insertions(+), 2 deletions(-) create mode 100644 doc/newsfragments/fix-wrong-encoding-for-text-copied-between-linux-and-windows.bugfix diff --git a/doc/newsfragments/fix-wrong-encoding-for-text-copied-between-linux-and-windows.bugfix b/doc/newsfragments/fix-wrong-encoding-for-text-copied-between-linux-and-windows.bugfix new file mode 100644 index 00000000..3b76d060 --- /dev/null +++ b/doc/newsfragments/fix-wrong-encoding-for-text-copied-between-linux-and-windows.bugfix @@ -0,0 +1,2 @@ +Fix wrong encoding for text copied between Linux and Windows +(https://github.com/debauchee/barrier/issues/1037, https://github.com/debauchee/barrier/issues/1137). diff --git a/src/lib/platform/XWindowsClipboardHTMLConverter.cpp b/src/lib/platform/XWindowsClipboardHTMLConverter.cpp index a13e80e4..eae032d5 100644 --- a/src/lib/platform/XWindowsClipboardHTMLConverter.cpp +++ b/src/lib/platform/XWindowsClipboardHTMLConverter.cpp @@ -56,10 +56,17 @@ XWindowsClipboardHTMLConverter::getDataSize() const std::string XWindowsClipboardHTMLConverter::fromIClipboard(const std::string& data) const { - return Unicode::UTF8ToUTF16(data); + return data; } std::string XWindowsClipboardHTMLConverter::toIClipboard(const std::string& data) const { - return Unicode::UTF16ToUTF8(data); + // Older Firefox [1] and possibly other applications use UTF-16 for text/html - handle both + // [1] https://bugzilla.mozilla.org/show_bug.cgi?id=1497580 + if (Unicode::isUTF8(data)) { + return data; + } else { + return Unicode::UTF16ToUTF8(data); + } + return data; }