diff options
| author | Ted Ross <tross@apache.org> | 2011-03-03 13:55:11 +0000 |
|---|---|---|
| committer | Ted Ross <tross@apache.org> | 2011-03-03 13:55:11 +0000 |
| commit | 5edf77f2c04c8428117a04d1d1a4b4cfc1770072 (patch) | |
| tree | 6d856e7bb541478d0a938ea64fab3a64edc0ae94 /qpid/cpp/src/qmf/AgentSession.cpp | |
| parent | 53a0c88af1f7afd3a0827f8ca586450a0456c40b (diff) | |
| download | qpid-python-5edf77f2c04c8428117a04d1d1a4b4cfc1770072.tar.gz | |
QPID-3046 - Updates
- Additional header comments
- Added pendingEvents method to ConsoleSession and AgentSession
- Ensure that nextEvent will not block if timeout is IMMEDIATE (ConsoleSession and AgentSession).
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1076625 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src/qmf/AgentSession.cpp')
| -rw-r--r-- | qpid/cpp/src/qmf/AgentSession.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/qpid/cpp/src/qmf/AgentSession.cpp b/qpid/cpp/src/qmf/AgentSession.cpp index 4c5a72a467..71d369325f 100644 --- a/qpid/cpp/src/qmf/AgentSession.cpp +++ b/qpid/cpp/src/qmf/AgentSession.cpp @@ -72,6 +72,7 @@ namespace qmf { void open(); void close(); bool nextEvent(AgentEvent& e, Duration t); + int pendingEvents() const; void registerSchema(Schema& s); DataAddr addData(Data& d, const string& n, bool persist); @@ -161,6 +162,7 @@ const string& AgentSession::getName() const { return impl->getName(); } void AgentSession::open() { impl->open(); } void AgentSession::close() { impl->close(); } bool AgentSession::nextEvent(AgentEvent& e, Duration t) { return impl->nextEvent(e, t); } +int AgentSession::pendingEvents() const { return impl->pendingEvents(); } void AgentSession::registerSchema(Schema& s) { impl->registerSchema(s); } DataAddr AgentSession::addData(Data& d, const string& n, bool p) { return impl->addData(d, n, p); } void AgentSession::delData(const DataAddr& a) { impl->delData(a); } @@ -318,7 +320,7 @@ bool AgentSessionImpl::nextEvent(AgentEvent& event, Duration timeout) uint64_t milliseconds = timeout.getMilliseconds(); qpid::sys::Mutex::ScopedLock l(lock); - if (eventQueue.empty()) + if (eventQueue.empty() && milliseconds > 0) cond.wait(lock, qpid::sys::AbsTime(qpid::sys::now(), qpid::sys::Duration(milliseconds * qpid::sys::TIME_MSEC))); @@ -332,6 +334,13 @@ bool AgentSessionImpl::nextEvent(AgentEvent& event, Duration timeout) } +int AgentSessionImpl::pendingEvents() const +{ + qpid::sys::Mutex::ScopedLock l(lock); + return eventQueue.size(); +} + + void AgentSessionImpl::registerSchema(Schema& schema) { if (!schema.isFinalized()) |
