summaryrefslogtreecommitdiff
path: root/protocols/Tox/src/tox_connection.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/Tox/src/tox_connection.cpp')
-rw-r--r--protocols/Tox/src/tox_connection.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/protocols/Tox/src/tox_connection.cpp b/protocols/Tox/src/tox_connection.cpp
index 24371e3233..564490e2e1 100644
--- a/protocols/Tox/src/tox_connection.cpp
+++ b/protocols/Tox/src/tox_connection.cpp
@@ -69,9 +69,11 @@ void CToxProto::CheckingThread(void *arg)
else
CheckConnection(tox, retriesCount);
- WaitForSingleObject(hTerminateEvent, 1000);
+ WaitForSingleObject(hTerminateEvent, TOX_CHECKING_INTERVAL);
}
+ hCheckingThread = nullptr;
+
debugLogA(__FUNCTION__": leaving");
}
@@ -104,7 +106,7 @@ void CToxProto::PollingThread(void*)
m_toxThread = &toxThread;
InitToxCore(toxThread.Tox());
BootstrapNodes(toxThread.Tox());
- ForkThread(&CToxProto::CheckingThread, toxThread.Tox());
+ hCheckingThread = ForkThreadEx(&CToxProto::CheckingThread, toxThread.Tox(), nullptr);
while (!isTerminated) {
tox_iterate(toxThread.Tox(), this);
@@ -116,8 +118,7 @@ void CToxProto::PollingThread(void*)
}
SetEvent(hTerminateEvent);
-
- Sleep(TOX_DEFAULT_INTERVAL * 10);
+ WaitForSingleObject(hCheckingThread, TOX_CHECKING_INTERVAL);
UninitToxCore(toxThread.Tox());
m_toxThread = nullptr;