barrier/src/lib/platform/MSWindowsClipboardAnyTextCo...

150 lines
3.4 KiB
C++
Raw Normal View History

2012-06-10 16:50:54 +00:00
/*
* synergy -- mouse and keyboard sharing utility
* Copyright (C) 2012 Synergy Si Ltd.
* Copyright (C) 2002 Chris Schoeneman
2012-06-10 16:50:54 +00:00
*
* This package is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* found in the file COPYING that should have accompanied this file.
*
* This package is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "platform/MSWindowsClipboardAnyTextConverter.h"
2012-06-10 16:50:54 +00:00
//
2014-11-12 11:44:29 +00:00
// MSWindowsClipboardAnyTextConverter
2012-06-10 16:50:54 +00:00
//
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::MSWindowsClipboardAnyTextConverter()
2012-06-10 16:50:54 +00:00
{
// do nothing
}
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::~MSWindowsClipboardAnyTextConverter()
2012-06-10 16:50:54 +00:00
{
// do nothing
}
IClipboard::EFormat
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::getFormat() const
2012-06-10 16:50:54 +00:00
{
return IClipboard::kText;
}
HANDLE
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::fromIClipboard(const String& data) const
2012-06-10 16:50:54 +00:00
{
// convert linefeeds and then convert to desired encoding
2014-11-11 13:51:47 +00:00
String text = doFromIClipboard(convertLinefeedToWin32(data));
2012-06-10 16:50:54 +00:00
UInt32 size = (UInt32)text.size();
// copy to memory handle
HGLOBAL gData = GlobalAlloc(GMEM_MOVEABLE | GMEM_DDESHARE, size);
if (gData != NULL) {
// get a pointer to the allocated memory
char* dst = (char*)GlobalLock(gData);
if (dst != NULL) {
memcpy(dst, text.data(), size);
GlobalUnlock(gData);
}
else {
GlobalFree(gData);
gData = NULL;
}
}
return gData;
}
2014-11-11 13:51:47 +00:00
String
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::toIClipboard(HANDLE data) const
2012-06-10 16:50:54 +00:00
{
// get datator
const char* src = (const char*)GlobalLock(data);
UInt32 srcSize = (UInt32)GlobalSize(data);
if (src == NULL || srcSize <= 1) {
2014-11-11 13:51:47 +00:00
return String();
2012-06-10 16:50:54 +00:00
}
// convert text
2014-11-11 13:51:47 +00:00
String text = doToIClipboard(String(src, srcSize));
2012-06-10 16:50:54 +00:00
// release handle
GlobalUnlock(data);
// convert newlines
return convertLinefeedToUnix(text);
}
2014-11-11 13:51:47 +00:00
String
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::convertLinefeedToWin32(
2014-11-11 13:51:47 +00:00
const String& src) const
2012-06-10 16:50:54 +00:00
{
// note -- we assume src is a valid UTF-8 string
// count newlines in string
UInt32 numNewlines = 0;
UInt32 n = (UInt32)src.size();
for (const char* scan = src.c_str(); n > 0; ++scan, --n) {
if (*scan == '\n') {
++numNewlines;
}
}
if (numNewlines == 0) {
return src;
}
// allocate new string
2014-11-11 13:51:47 +00:00
String dst;
2012-06-10 16:50:54 +00:00
dst.reserve(src.size() + numNewlines);
// copy string, converting newlines
n = (UInt32)src.size();
for (const char* scan = src.c_str(); n > 0; ++scan, --n) {
if (scan[0] == '\n') {
dst += '\r';
}
dst += scan[0];
}
return dst;
}
2014-11-11 13:51:47 +00:00
String
2014-11-12 11:44:29 +00:00
MSWindowsClipboardAnyTextConverter::convertLinefeedToUnix(
2014-11-11 13:51:47 +00:00
const String& src) const
2012-06-10 16:50:54 +00:00
{
// count newlines in string
UInt32 numNewlines = 0;
UInt32 n = (UInt32)src.size();
for (const char* scan = src.c_str(); n > 0; ++scan, --n) {
if (scan[0] == '\r' && scan[1] == '\n') {
++numNewlines;
}
}
if (numNewlines == 0) {
return src;
}
// allocate new string
2014-11-11 13:51:47 +00:00
String dst;
2012-06-10 16:50:54 +00:00
dst.reserve(src.size());
// copy string, converting newlines
n = (UInt32)src.size();
for (const char* scan = src.c_str(); n > 0; ++scan, --n) {
if (scan[0] != '\r' || scan[1] != '\n') {
dst += scan[0];
}
}
return dst;
}