mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-28 03:20:11 +01:00
Feature net udp (#2347)
* add PMTU discovery #2329 * add socket gather/scatter capabilities #2330 (win, udp) * enable WSAPoll * add FastMemoryPool * add receiveFrom() with native args * allow copying of StringTokenizer * add AtomicFlag and SpinlockMutex * update .gitignore * UDPServer and client #2343 (windows) * fix warnings * fix warnings * regenerate Net VS solutions * regenerate CppUnit projects/solutions * clang fixes * gcc fixes * try to fix travis * more travis fixes * more travis fixes * handle UDPClient exception * fix makefiles and init order warnings * add UNIX gather/scatter sendto/recvfrom implementations and tests * run travis tests as sudo * try to run tests as sudo, 2nd attempt * fix warning * use mutex in reactor * lock-order-inversion in SocketReactor #2346 * add PMTU discovery #2329 (linux) * ICMPSocket does not check reply address #1921 * remove some ignored tests * add PMTU discovery #2329 (reconcile logic with #1921) * fix native receiveFrome() * reinstate ignoring of proxy errors * add testMTU to ignore list * add include atomic * NTPClient not checking reply address #2348 * some ICMP/MTU fixes * UDPSocketReader cleanup * resolve some socket inheritance warnings * add NTP time sync to ignored tests * SocketNotifier not thread-safe #2345 * prevent x64 samples build attempt for win32 * build TestApp and Library * fix ICMP tests * regen VS projects * regen VS projects and add missing 2012 files * remove debug prints
This commit is contained in:
committed by
GitHub
parent
da15142f69
commit
c4e676d36d
@@ -115,10 +115,9 @@ void SocketReactor::run()
|
||||
|
||||
bool SocketReactor::hasSocketHandlers()
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
|
||||
if (!_pollSet.empty())
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
for (EventHandlerMap::iterator it = _handlers.begin(); it != _handlers.end(); ++it)
|
||||
{
|
||||
if (it->second->accepts(_pReadableNotification) ||
|
||||
@@ -157,21 +156,9 @@ const Poco::Timespan& SocketReactor::getTimeout() const
|
||||
|
||||
void SocketReactor::addEventHandler(const Socket& socket, const Poco::AbstractObserver& observer)
|
||||
{
|
||||
NotifierPtr pNotifier;
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
|
||||
EventHandlerMap::iterator it = _handlers.find(socket);
|
||||
if (it == _handlers.end())
|
||||
{
|
||||
pNotifier = new SocketNotifier(socket);
|
||||
_handlers[socket] = pNotifier;
|
||||
}
|
||||
else pNotifier = it->second;
|
||||
NotifierPtr pNotifier = getNotifier(socket, true);
|
||||
|
||||
if (!pNotifier->hasObserver(observer))
|
||||
pNotifier->addObserver(this, observer);
|
||||
}
|
||||
if (!pNotifier->hasObserver(observer)) pNotifier->addObserver(this, observer);
|
||||
|
||||
int mode = 0;
|
||||
if (pNotifier->accepts(_pReadableNotification)) mode |= PollSet::POLL_READ;
|
||||
@@ -183,44 +170,40 @@ void SocketReactor::addEventHandler(const Socket& socket, const Poco::AbstractOb
|
||||
|
||||
bool SocketReactor::hasEventHandler(const Socket& socket, const Poco::AbstractObserver& observer)
|
||||
{
|
||||
NotifierPtr pNotifier;
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
|
||||
EventHandlerMap::iterator it = _handlers.find(socket);
|
||||
if (it != _handlers.end())
|
||||
{
|
||||
if (it->second->hasObserver(observer))
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
NotifierPtr pNotifier = getNotifier(socket);
|
||||
if (!pNotifier) return false;
|
||||
if (pNotifier->hasObserver(observer)) return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
SocketReactor::NotifierPtr SocketReactor::getNotifier(const Socket& socket, bool makeNew)
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
|
||||
EventHandlerMap::iterator it = _handlers.find(socket);
|
||||
if (it != _handlers.end()) return it->second;
|
||||
else if (makeNew) return (_handlers[socket] = new SocketNotifier(socket));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
void SocketReactor::removeEventHandler(const Socket& socket, const Poco::AbstractObserver& observer)
|
||||
{
|
||||
NotifierPtr pNotifier;
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
|
||||
EventHandlerMap::iterator it = _handlers.find(socket);
|
||||
if (it != _handlers.end())
|
||||
{
|
||||
pNotifier = it->second;
|
||||
if (pNotifier->hasObserver(observer) && pNotifier->countObservers() == 1)
|
||||
{
|
||||
_handlers.erase(it);
|
||||
_pollSet.remove(socket);
|
||||
}
|
||||
}
|
||||
}
|
||||
NotifierPtr pNotifier = getNotifier(socket);
|
||||
if (pNotifier && pNotifier->hasObserver(observer))
|
||||
{
|
||||
if(pNotifier->countObservers() == 1)
|
||||
{
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
_handlers.erase(socket);
|
||||
}
|
||||
_pollSet.remove(socket);
|
||||
}
|
||||
pNotifier->removeObserver(this, observer);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
@@ -255,15 +238,8 @@ void SocketReactor::onBusy()
|
||||
|
||||
void SocketReactor::dispatch(const Socket& socket, SocketNotification* pNotification)
|
||||
{
|
||||
NotifierPtr pNotifier;
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
EventHandlerMap::iterator it = _handlers.find(socket);
|
||||
if (it != _handlers.end())
|
||||
pNotifier = it->second;
|
||||
else
|
||||
return;
|
||||
}
|
||||
NotifierPtr pNotifier = getNotifier(socket);
|
||||
if (!pNotifier) return;
|
||||
dispatch(pNotifier, pNotification);
|
||||
}
|
||||
|
||||
@@ -271,9 +247,9 @@ void SocketReactor::dispatch(const Socket& socket, SocketNotification* pNotifica
|
||||
void SocketReactor::dispatch(SocketNotification* pNotification)
|
||||
{
|
||||
std::vector<NotifierPtr> delegates;
|
||||
delegates.reserve(_handlers.size());
|
||||
{
|
||||
ScopedLock lock(_mutex);
|
||||
delegates.reserve(_handlers.size());
|
||||
for (EventHandlerMap::iterator it = _handlers.begin(); it != _handlers.end(); ++it)
|
||||
delegates.push_back(it->second);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user