Merge branch 'v1.9' into v1.9-bidir

This commit is contained in:
Andrew Nelless 2017-05-22 21:40:44 +01:00
commit 3e5cb09e19
25 changed files with 71 additions and 66 deletions

View File

@ -4,4 +4,4 @@
SYNERGY_VERSION_MAJOR = 1 SYNERGY_VERSION_MAJOR = 1
SYNERGY_VERSION_MINOR = 9 SYNERGY_VERSION_MINOR = 9
SYNERGY_VERSION_PATCH = 0 SYNERGY_VERSION_PATCH = 0
SYNERGY_VERSION_STAGE = git SYNERGY_VERSION_STAGE = rc4

View File

@ -111,7 +111,7 @@ endif()
string (TIMESTAMP SYNERGY_BUILD_DATE "%Y%m%d" UTC) string (TIMESTAMP SYNERGY_BUILD_DATE "%Y%m%d" UTC)
if (SYNERGY_VERSION_STAGE STREQUAL "git") if (SYNERGY_VERSION_STAGE STREQUAL "git")
set (SYNERGY_SNAPSHOT_INFO "${SYNERGY_BUILD_DATE}.${SYNERGY_REVISION}") set (SYNERGY_SNAPSHOT_INFO ".${SYNERGY_BUILD_DATE}.${SYNERGY_REVISION}")
set (SYNERGY_VERSION_TAG "b${SYNERGY_BUILD_DATE}-${SYNERGY_REVISION}") set (SYNERGY_VERSION_TAG "b${SYNERGY_BUILD_DATE}-${SYNERGY_REVISION}")
else() else()
set (SYNERGY_SNAPSHOT_INFO "") set (SYNERGY_SNAPSHOT_INFO "")

View File

@ -7,7 +7,7 @@ Source: https://symless.com/synergy/downloads
Vendor: Symless Vendor: Symless
Packager: Symless <engineering@symless.com> Packager: Symless <engineering@symless.com>
License: GPLv2 License: GPLv2
Release: @SYNERGY_BUILD_NUMBER@.@SYNERGY_SNAPSHOT_INFO@%{?dist} Release: @SYNERGY_BUILD_NUMBER@@SYNERGY_SNAPSHOT_INFO@%{?dist}
%description %description
Synergy allows you to share one mouse and keyboard between multiple computers. Synergy allows you to share one mouse and keyboard between multiple computers.

View File

@ -19,6 +19,7 @@
DataDownloader::DataDownloader(QObject* parent) : DataDownloader::DataDownloader(QObject* parent) :
QObject(parent), QObject(parent),
m_pReply(nullptr),
m_IsFinished(false) m_IsFinished(false)
{ {
connect(&m_NetworkManager, SIGNAL(finished(QNetworkReply*)), connect(&m_NetworkManager, SIGNAL(finished(QNetworkReply*)),

View File

@ -38,7 +38,7 @@ ScreenSetupView::ScreenSetupView(QWidget* parent) :
verticalHeader()->hide(); verticalHeader()->hide();
} }
void ScreenSetupView::setModel(ScreenSetupModel* model) void ScreenSetupView::setModel(QAbstractItemModel* model)
{ {
QTableView::setModel(model); QTableView::setModel(model);
setTableSize(); setTableSize();

View File

@ -39,7 +39,7 @@ class ScreenSetupView : public QTableView
ScreenSetupView(QWidget* parent); ScreenSetupView(QWidget* parent);
public: public:
void setModel(ScreenSetupModel* model); void setModel(QAbstractItemModel* model) override;
ScreenSetupModel* model() const; ScreenSetupModel* model() const;
protected: protected:

View File

@ -25,7 +25,7 @@ ZeroconfServer::ZeroconfServer(QObject* parent) :
{ {
} }
void ZeroconfServer::incomingConnection(int socketDescriptor) void ZeroconfServer::incomingConnection(qintptr socketDescriptor)
{ {
ZeroconfThread* thread = new ZeroconfThread(socketDescriptor, this); ZeroconfThread* thread = new ZeroconfThread(socketDescriptor, this);
connect(thread, SIGNAL(finished()), thread, SLOT(deleteLater())); connect(thread, SIGNAL(finished()), thread, SLOT(deleteLater()));

View File

@ -30,7 +30,7 @@ public:
ZeroconfServer(QObject* parent = 0); ZeroconfServer(QObject* parent = 0);
protected: protected:
void incomingConnection(int socketDescriptor); void incomingConnection(qintptr socketDescriptor) override;
private: private:
QStringList fortunes; QStringList fortunes;

View File

@ -42,7 +42,7 @@ int
IArchString::convStringWCToMB(char* dst, IArchString::convStringWCToMB(char* dst,
const wchar_t* src, UInt32 n, bool* errors) const wchar_t* src, UInt32 n, bool* errors)
{ {
int len = 0; ptrdiff_t len = 0;
bool dummyErrors; bool dummyErrors;
if (errors == NULL) { if (errors == NULL) {
@ -58,14 +58,14 @@ IArchString::convStringWCToMB(char* dst,
if (dst == NULL) { if (dst == NULL) {
char dummy[MB_LEN_MAX]; char dummy[MB_LEN_MAX];
for (const wchar_t* scan = src; n > 0; ++scan, --n) { for (const wchar_t* scan = src; n > 0; ++scan, --n) {
int mblen = wctomb(dummy, *scan); ptrdiff_t mblen = wctomb(dummy, *scan);
if (mblen == -1) { if (mblen == -1) {
*errors = true; *errors = true;
mblen = 1; mblen = 1;
} }
len += mblen; len += mblen;
} }
int mblen = wctomb(dummy, L'\0'); ptrdiff_t mblen = wctomb(dummy, L'\0');
if (mblen != -1) { if (mblen != -1) {
len += mblen - 1; len += mblen - 1;
} }
@ -73,7 +73,7 @@ IArchString::convStringWCToMB(char* dst,
else { else {
char* dst0 = dst; char* dst0 = dst;
for (const wchar_t* scan = src; n > 0; ++scan, --n) { for (const wchar_t* scan = src; n > 0; ++scan, --n) {
int mblen = wctomb(dst, *scan); ptrdiff_t mblen = wctomb(dst, *scan);
if (mblen == -1) { if (mblen == -1) {
*errors = true; *errors = true;
*dst++ = '?'; *dst++ = '?';
@ -82,12 +82,12 @@ IArchString::convStringWCToMB(char* dst,
dst += mblen; dst += mblen;
} }
} }
int mblen = wctomb(dst, L'\0'); ptrdiff_t mblen = wctomb(dst, L'\0');
if (mblen != -1) { if (mblen != -1) {
// don't include nul terminator // don't include nul terminator
dst += mblen - 1; dst += mblen - 1;
} }
len = (int)(dst - dst0); len = dst - dst0;
} }
ARCH->unlockMutex(s_mutex); ARCH->unlockMutex(s_mutex);
@ -98,7 +98,7 @@ int
IArchString::convStringMBToWC(wchar_t* dst, IArchString::convStringMBToWC(wchar_t* dst,
const char* src, UInt32 n, bool* errors) const char* src, UInt32 n, bool* errors)
{ {
int len = 0; ptrdiff_t len = 0;
wchar_t dummy; wchar_t dummy;
bool dummyErrors; bool dummyErrors;
@ -114,7 +114,7 @@ IArchString::convStringMBToWC(wchar_t* dst,
if (dst == NULL) { if (dst == NULL) {
for (const char* scan = src; n > 0; ) { for (const char* scan = src; n > 0; ) {
int mblen = mbtowc(&dummy, scan, n); ptrdiff_t mblen = mbtowc(&dummy, scan, n);
switch (mblen) { switch (mblen) {
case -2: case -2:
// incomplete last character. convert to unknown character. // incomplete last character. convert to unknown character.
@ -150,7 +150,7 @@ IArchString::convStringMBToWC(wchar_t* dst,
else { else {
wchar_t* dst0 = dst; wchar_t* dst0 = dst;
for (const char* scan = src; n > 0; ++dst) { for (const char* scan = src; n > 0; ++dst) {
int mblen = mbtowc(dst, scan, n); ptrdiff_t mblen = mbtowc(dst, scan, n);
switch (mblen) { switch (mblen) {
case -2: case -2:
// incomplete character. convert to unknown character. // incomplete character. convert to unknown character.
@ -181,7 +181,7 @@ IArchString::convStringMBToWC(wchar_t* dst,
break; break;
} }
} }
len = (int)(dst - dst0); len = dst - dst0;
} }
ARCH->unlockMutex(s_mutex); ARCH->unlockMutex(s_mutex);

View File

@ -311,7 +311,7 @@ ArchNetworkWinsock::listenOnSocket(ArchSocket s)
} }
ArchSocket ArchSocket
ArchNetworkWinsock::acceptSocket(ArchSocket s, ArchNetAddress* addr) ArchNetworkWinsock::acceptSocket(ArchSocket s, ArchNetAddress* const addr)
{ {
assert(s != NULL); assert(s != NULL);
@ -325,7 +325,9 @@ ArchNetworkWinsock::acceptSocket(ArchSocket s, ArchNetAddress* addr)
int err = getsockerror_winsock(); int err = getsockerror_winsock();
delete socket; delete socket;
free(tmp); free(tmp);
if (addr) {
*addr = NULL; *addr = NULL;
}
if (err == WSAEWOULDBLOCK) { if (err == WSAEWOULDBLOCK) {
return NULL; return NULL;
} }
@ -339,7 +341,9 @@ ArchNetworkWinsock::acceptSocket(ArchSocket s, ArchNetAddress* addr)
close_winsock(fd); close_winsock(fd);
delete socket; delete socket;
free(tmp); free(tmp);
if (addr) {
*addr = NULL; *addr = NULL;
}
throw; throw;
} }

View File

@ -39,10 +39,14 @@ static const UINT kFirstReceiverID = WM_USER + 14;
ArchTaskBarWindows* ArchTaskBarWindows::s_instance = NULL; ArchTaskBarWindows* ArchTaskBarWindows::s_instance = NULL;
ArchTaskBarWindows::ArchTaskBarWindows() : ArchTaskBarWindows::ArchTaskBarWindows() :
m_nextID(kFirstReceiverID), m_mutex(NULL),
m_thread(NULL),
m_condVar(NULL), m_condVar(NULL),
m_mutex(NULL) m_ready(false),
m_result(0),
m_thread(NULL),
m_hwnd(NULL),
m_taskBarRestart(0),
m_nextID(kFirstReceiverID)
{ {
// save the singleton instance // save the singleton instance
s_instance = this; s_instance = this;

View File

@ -30,6 +30,7 @@
#include <sstream> #include <sstream>
#include <iomanip> #include <iomanip>
#include <algorithm> #include <algorithm>
#include <cerrno>
namespace synergy { namespace synergy {
namespace string { namespace string {
@ -50,8 +51,8 @@ vformat(const char* fmt, va_list args)
// find highest indexed substitution and the locations of substitutions // find highest indexed substitution and the locations of substitutions
std::vector<size_t> pos; std::vector<size_t> pos;
std::vector<size_t> width; std::vector<size_t> width;
std::vector<int> index; std::vector<size_t> index;
int maxIndex = 0; size_t maxIndex = 0;
for (const char* scan = fmt; *scan != '\0'; ++scan) { for (const char* scan = fmt; *scan != '\0'; ++scan) {
if (*scan == '%') { if (*scan == '%') {
++scan; ++scan;
@ -61,21 +62,22 @@ vformat(const char* fmt, va_list args)
else if (*scan == '%') { else if (*scan == '%') {
// literal // literal
index.push_back(0); index.push_back(0);
pos.push_back(static_cast<int>(scan - 1 - fmt)); pos.push_back(static_cast<size_t>((scan - 1) - fmt));
width.push_back(2); width.push_back(2);
} }
else if (*scan == '{') { else if (*scan == '{') {
// get argument index // get argument index
char* end; char* end;
int i = static_cast<int>(strtol(scan + 1, &end, 10)); errno = 0;
if (*end != '}') { long i = strtol(scan + 1, &end, 10);
if (errno || (i < 0) || (*end != '}')) {
// invalid index -- ignore // invalid index -- ignore
scan = end - 1; scan = end - 1; // BUG if there are digits?
} }
else { else {
index.push_back(i); index.push_back(i);
pos.push_back(static_cast<int>(scan - 1 - fmt)); pos.push_back(static_cast<size_t>((scan - 1) - fmt));
width.push_back(static_cast<int>(end - scan + 2)); width.push_back(static_cast<size_t>((end - scan) + 2));
if (i > maxIndex) { if (i > maxIndex) {
maxIndex = i; maxIndex = i;
} }

View File

@ -45,6 +45,7 @@ IpcLogOutputter::IpcLogOutputter(IpcServer& ipcServer, EIpcClientType clientType
m_running(false), m_running(false),
m_notifyCond(ARCH->newCondVar()), m_notifyCond(ARCH->newCondVar()),
m_notifyMutex(ARCH->newMutex()), m_notifyMutex(ARCH->newMutex()),
m_bufferThreadId(0),
m_bufferWaiting(false), m_bufferWaiting(false),
m_bufferMaxSize(kBufferMaxSize), m_bufferMaxSize(kBufferMaxSize),
m_bufferRateWriteLimit(kBufferRateWriteLimit), m_bufferRateWriteLimit(kBufferRateWriteLimit),

View File

@ -114,7 +114,6 @@ private:
double m_bufferRateTimeLimit; double m_bufferRateTimeLimit;
UInt16 m_bufferWriteCount; UInt16 m_bufferWriteCount;
double m_bufferRateStart; double m_bufferRateStart;
bool m_useThread;
EIpcClientType m_clientType; EIpcClientType m_clientType;
ArchMutex m_runningMutex; ArchMutex m_runningMutex;
}; };

View File

@ -80,7 +80,7 @@ IpcServer::~IpcServer()
for (it = m_clients.begin(); it != m_clients.end(); it++) { for (it = m_clients.begin(); it != m_clients.end(); it++) {
deleteClient(*it); deleteClient(*it);
} }
m_clients.empty(); m_clients.clear();
ARCH->unlockMutex(m_clientsMutex); ARCH->unlockMutex(m_clientsMutex);
ARCH->closeMutex(m_clientsMutex); ARCH->closeMutex(m_clientsMutex);

View File

@ -57,6 +57,7 @@ SecureSocket::SecureSocket(
IEventQueue* events, IEventQueue* events,
SocketMultiplexer* socketMultiplexer) : SocketMultiplexer* socketMultiplexer) :
TCPSocket(events, socketMultiplexer), TCPSocket(events, socketMultiplexer),
m_ssl(nullptr),
m_secureReady(false), m_secureReady(false),
m_fatal(false) m_fatal(false)
{ {
@ -67,6 +68,7 @@ SecureSocket::SecureSocket(
SocketMultiplexer* socketMultiplexer, SocketMultiplexer* socketMultiplexer,
ArchSocket socket) : ArchSocket socket) :
TCPSocket(events, socketMultiplexer, socket), TCPSocket(events, socketMultiplexer, socket),
m_ssl(nullptr),
m_secureReady(false), m_secureReady(false),
m_fatal(false) m_fatal(false)
{ {

View File

@ -330,7 +330,7 @@ TCPSocket::doRead()
memset(buffer, 0, sizeof(buffer)); memset(buffer, 0, sizeof(buffer));
size_t bytesRead = 0; size_t bytesRead = 0;
bytesRead = (int) ARCH->readSocket(m_socket, buffer, sizeof(buffer)); bytesRead = ARCH->readSocket(m_socket, buffer, sizeof(buffer));
if (bytesRead > 0) { if (bytesRead > 0) {
bool wasEmpty = (m_inputBuffer.getSize() == 0); bool wasEmpty = (m_inputBuffer.getSize() == 0);

View File

@ -88,7 +88,11 @@ MSWindowsClipboard::empty()
// mark clipboard as being owned by synergy // mark clipboard as being owned by synergy
HGLOBAL data = GlobalAlloc(GMEM_MOVEABLE | GMEM_DDESHARE, 1); HGLOBAL data = GlobalAlloc(GMEM_MOVEABLE | GMEM_DDESHARE, 1);
SetClipboardData(getOwnershipFormat(), data); if (NULL == SetClipboardData(getOwnershipFormat(), data)) {
LOG((CLOG_DEBUG "failed to set clipboard data"));
GlobalFree(data);
return false;
}
return true; return true;
} }

View File

@ -427,7 +427,7 @@ void
MSWindowsDesks::destroyClass(ATOM windowClass) const MSWindowsDesks::destroyClass(ATOM windowClass) const
{ {
if (windowClass != 0) { if (windowClass != 0) {
UnregisterClass(reinterpret_cast<LPCTSTR>(windowClass), UnregisterClass(MAKEINTATOM(windowClass),
MSWindowsScreen::getWindowInstance()); MSWindowsScreen::getWindowInstance());
} }
} }
@ -437,7 +437,7 @@ MSWindowsDesks::createWindow(ATOM windowClass, const char* name) const
{ {
HWND window = CreateWindowEx(WS_EX_TRANSPARENT | HWND window = CreateWindowEx(WS_EX_TRANSPARENT |
WS_EX_TOOLWINDOW, WS_EX_TOOLWINDOW,
reinterpret_cast<LPCTSTR>(windowClass), MAKEINTATOM(windowClass),
name, name,
WS_POPUP, WS_POPUP,
0, 0, 1, 1, 0, 0, 1, 1,

View File

@ -858,7 +858,7 @@ void
MSWindowsScreen::destroyClass(ATOM windowClass) const MSWindowsScreen::destroyClass(ATOM windowClass) const
{ {
if (windowClass != 0) { if (windowClass != 0) {
UnregisterClass(reinterpret_cast<LPCTSTR>(windowClass), s_windowInstance); UnregisterClass(MAKEINTATOM(windowClass), s_windowInstance);
} }
} }
@ -868,7 +868,7 @@ MSWindowsScreen::createWindow(ATOM windowClass, const char* name) const
HWND window = CreateWindowEx(WS_EX_TOPMOST | HWND window = CreateWindowEx(WS_EX_TOPMOST |
WS_EX_TRANSPARENT | WS_EX_TRANSPARENT |
WS_EX_TOOLWINDOW, WS_EX_TOOLWINDOW,
reinterpret_cast<LPCTSTR>(windowClass), MAKEINTATOM(windowClass),
name, name,
WS_POPUP, WS_POPUP,
0, 0, 1, 1, 0, 0, 1, 1,
@ -889,7 +889,7 @@ MSWindowsScreen::createDropWindow(ATOM windowClass, const char* name) const
WS_EX_TOPMOST | WS_EX_TOPMOST |
WS_EX_TRANSPARENT | WS_EX_TRANSPARENT |
WS_EX_ACCEPTFILES, WS_EX_ACCEPTFILES,
reinterpret_cast<LPCTSTR>(m_class), MAKEINTATOM(m_class),
name, name,
WS_POPUP, WS_POPUP,
0, 0, m_dropWindowSize, m_dropWindowSize, 0, 0, m_dropWindowSize, m_dropWindowSize,
@ -1143,7 +1143,7 @@ MSWindowsScreen::onKey(WPARAM wParam, LPARAM lParam)
KeyModifierMask oldState = pollActiveModifiers(); KeyModifierMask oldState = pollActiveModifiers();
// check for autorepeat // check for autorepeat
if (m_keyState->testAutoRepeat(down, (lParam & 0x40000000u) == 1, button)) { if (m_keyState->testAutoRepeat(down, (lParam & 0x40000000u), button)) {
lParam |= 0x40000000u; lParam |= 0x40000000u;
} }

View File

@ -50,6 +50,9 @@ MSWindowsScreenSaver::MSWindowsScreenSaver() :
m_process(NULL), m_process(NULL),
m_watch(NULL), m_watch(NULL),
m_threadID(0), m_threadID(0),
m_msg(0),
m_wParam(0),
m_lParam(0),
m_active(false) m_active(false)
{ {
// check if screen saver is enabled // check if screen saver is enabled

View File

@ -187,7 +187,7 @@ MSWindowsSession::getActiveDesktopName()
CloseDesktop(hd); CloseDesktop(hd);
} }
} }
catch (std::exception error) { catch (std::exception& error) {
LOG((CLOG_ERR "failed to get active desktop name: %s", error.what())); LOG((CLOG_ERR "failed to get active desktop name: %s", error.what()));
} }

View File

@ -29,31 +29,14 @@
String String
MSWindowsUtil::getString(HINSTANCE instance, DWORD id) MSWindowsUtil::getString(HINSTANCE instance, DWORD id)
{ {
char buffer[1024]; char* msg = NULL;
int size = static_cast<int>(sizeof(buffer) / sizeof(buffer[0])); int n = LoadString(instance, id, reinterpret_cast<LPSTR>(&msg), 0);
char* msg = buffer;
// load string if (n <= 0) {
int n = LoadString(instance, id, msg, size); return String();
msg[n] = '\0';
if (n < size) {
return msg;
} }
// not enough buffer space. keep trying larger buffers until return String (msg, n);
// we get the whole string.
msg = NULL;
do {
size <<= 1;
delete[] msg;
char* msg = new char[size];
n = LoadString(instance, id, msg, size);
} while (n == size);
msg[n] = '\0';
String result(msg);
delete[] msg;
return result;
} }
String String

View File

@ -62,9 +62,11 @@ App::App(IEventQueue* events, CreateTaskBarReceiverFunc createTaskBarReceiver, A
m_suspended(false), m_suspended(false),
m_events(events), m_events(events),
m_args(args), m_args(args),
m_fileLog(nullptr),
m_createTaskBarReceiver(createTaskBarReceiver), m_createTaskBarReceiver(createTaskBarReceiver),
m_appUtil(events), m_appUtil(events),
m_ipcClient(nullptr) m_ipcClient(nullptr),
m_socketMultiplexer(nullptr)
{ {
assert(s_instance == nullptr); assert(s_instance == nullptr);
s_instance = this; s_instance = this;

View File

@ -18,7 +18,7 @@
#include "synergy/Chunk.h" #include "synergy/Chunk.h"
#include "base/String.h" #include "base/String.h"
Chunk::Chunk(size_t size) Chunk::Chunk(size_t size): m_dataSize(0)
{ {
m_chunk = new char[size]; m_chunk = new char[size];
memset(m_chunk, 0, size); memset(m_chunk, 0, size);