summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/client/Bounds.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2008-04-29 20:15:18 +0000
committerGordon Sim <gsim@apache.org>2008-04-29 20:15:18 +0000
commitacc0dee435e1fa22e3b1e7cdfecf6913bf88988e (patch)
tree729f7a03543acf23380e68897f8788a3e6b45e2e /cpp/src/qpid/client/Bounds.cpp
parenta19ce3b1863f80c1232ec2690cd920325a39d71a (diff)
downloadqpid-python-acc0dee435e1fa22e3b1e7cdfecf6913bf88988e.tar.gz
QPID-974: allow the size of the queue of outgoing frames to be restricted
QPID-544: tidy up configuration (ensuring desired settings are used correctly, allowing tcp socket options to be set etc) git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@652083 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/client/Bounds.cpp')
-rw-r--r--cpp/src/qpid/client/Bounds.cpp55
1 files changed, 55 insertions, 0 deletions
diff --git a/cpp/src/qpid/client/Bounds.cpp b/cpp/src/qpid/client/Bounds.cpp
new file mode 100644
index 0000000000..1df21db941
--- /dev/null
+++ b/cpp/src/qpid/client/Bounds.cpp
@@ -0,0 +1,55 @@
+#include "Bounds.h"
+
+#include "qpid/log/Statement.h"
+
+namespace qpid {
+namespace client {
+
+using sys::Monitor;
+
+Bounds::Bounds(size_t maxSize) : max(maxSize), current(0) {}
+
+bool Bounds::expand(size_t sizeRequired, bool block)
+{
+ if (max) {
+ Monitor::ScopedLock l(lock);
+ current += sizeRequired;
+ if (block) {
+ while (current > max) {
+ QPID_LOG(debug, "Waiting for bounds: " << *this);
+ lock.wait();
+ }
+ QPID_LOG(debug, "Bounds ok: " << *this);
+ }
+ return current <= max;
+ } else {
+ return true;
+ }
+}
+
+void Bounds::reduce(size_t size)
+{
+ if (!max || size == 0) return;
+ Monitor::ScopedLock l(lock);
+ if (current == 0) return;
+ bool needNotify = current > max;
+ current -= std::min(size, current);
+ if (needNotify && current < max) {
+ //todo: notify one at a time, but ensure that all threads are
+ //eventually notified
+ lock.notifyAll();
+ }
+}
+
+size_t Bounds::getCurrentSize()
+{
+ Monitor::ScopedLock l(lock);
+ return current;
+}
+
+std::ostream& operator<<(std::ostream& out, const Bounds& bounds) {
+ out << "current=" << bounds.current << ", max=" << bounds.max << " [" << &bounds << "]";
+ return out;
+}
+
+}} // namespace qpid::client