1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-25 22:14:32 +00:00

Add interface to request the pid of the running instance.

This commit is contained in:
sledgehammer999 2013-09-15 00:10:01 +03:00 committed by Vladimir Golovnev (Glassez)
parent da561ccd38
commit 89b82778e6
4 changed files with 66 additions and 0 deletions

View File

@ -201,8 +201,62 @@ void QtLocalPeer::receiveConnection()
return; return;
} }
QString message(QString::fromUtf8(uMsg)); QString message(QString::fromUtf8(uMsg));
#ifdef Q_OS_WIN
if (message == "qbt://pid")
socket->write(QByteArray::number(qApp->applicationPid()));
else
socket->write(ack, qstrlen(ack)); socket->write(ack, qstrlen(ack));
#else
socket->write(ack, qstrlen(ack));
#endif
socket->waitForBytesWritten(1000); socket->waitForBytesWritten(1000);
delete socket; delete socket;
#ifdef Q_OS_WIN
if (message == "qbt://pid")
return;
#endif
emit messageReceived(message); //### (might take a long time to return) emit messageReceived(message); //### (might take a long time to return)
} }
#ifdef Q_OS_WIN
ulong QtLocalPeer::getRunningPid() {
if (!isClient())
return false;
QLocalSocket socket;
bool connOk = false;
for (int i = 0; i < 2; i++) {
// Try twice, in case the other instance is just starting up
socket.connectToServer(socketName);
connOk = socket.waitForConnected(5000/2);
if (connOk || i)
break;
Sleep(DWORD(250));
}
if (!connOk)
return false;
QByteArray uMsg("qbt://pid");
QDataStream ds(&socket);
ds.writeBytes(uMsg.constData(), uMsg.size());
bool res = socket.waitForBytesWritten(5000);
res &= socket.waitForReadyRead(5000);
if (!res)
return -1;
while (socket.bytesAvailable() < (int)sizeof(quint32))
socket.waitForReadyRead();
uMsg.clear();
quint32 remaining = socket.bytesAvailable();
uMsg.resize(remaining);
int got = 0;
char* uMsgBuf = uMsg.data();
do {
got = ds.readRawData(uMsgBuf, remaining);
remaining -= got;
uMsgBuf += got;
} while (remaining && got >= 0 && socket.waitForReadyRead(2000));
if (got < 0)
return -1;
return uMsg.toULong();
}
#endif

View File

@ -64,6 +64,9 @@ public:
bool sendMessage(const QString &message, int timeout); bool sendMessage(const QString &message, int timeout);
QString applicationId() const QString applicationId() const
{ return id; } { return id; }
#ifdef Q_OS_WIN
ulong getRunningPid();
#endif
Q_SIGNALS: Q_SIGNALS:
void messageReceived(const QString &message); void messageReceived(const QString &message);

View File

@ -349,3 +349,9 @@ void QtSingleApplication::activateWindow()
\obsolete \obsolete
*/ */
#ifdef Q_OS_WIN
ulong QtSingleApplication::getRunningPid() {
return peer->getRunningPid();
}
#endif

View File

@ -88,6 +88,9 @@ public:
// Obsolete: // Obsolete:
void initialize(bool dummy = true) void initialize(bool dummy = true)
{ isRunning(); Q_UNUSED(dummy) } { isRunning(); Q_UNUSED(dummy) }
#ifdef Q_OS_WIN
ulong getRunningPid();
#endif
public Q_SLOTS: public Q_SLOTS:
bool sendMessage(const QString &message, int timeout = 5000); bool sendMessage(const QString &message, int timeout = 5000);