summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/broker/DirectExchange.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2007-06-27 12:39:49 +0000
committerGordon Sim <gsim@apache.org>2007-06-27 12:39:49 +0000
commit5a88e6f19bddc0b9f6da4712b616f5f08b4dec25 (patch)
tree6d32b3a3ef5416bb40027852b98eda9389cbbb6c /cpp/src/qpid/broker/DirectExchange.cpp
parent4add83a2d2482a51f447ca71d2385ae19ea173fa (diff)
downloadqpid-python-5a88e6f19bddc0b9f6da4712b616f5f08b4dec25.tar.gz
Added preview of exchange- and binding- query methods that have been approved for 0-10.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@551144 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/broker/DirectExchange.cpp')
-rw-r--r--cpp/src/qpid/broker/DirectExchange.cpp19
1 files changed, 19 insertions, 0 deletions
diff --git a/cpp/src/qpid/broker/DirectExchange.cpp b/cpp/src/qpid/broker/DirectExchange.cpp
index 01817144d6..7b516414c0 100644
--- a/cpp/src/qpid/broker/DirectExchange.cpp
+++ b/cpp/src/qpid/broker/DirectExchange.cpp
@@ -69,6 +69,25 @@ void DirectExchange::route(Deliverable& msg, const string& routingKey, const Fie
}
}
+
+bool DirectExchange::isBound(Queue::shared_ptr queue, const string* const routingKey, const FieldTable* const)
+{
+ if (routingKey) {
+ Bindings::iterator i = bindings.find(*routingKey);
+ return i != bindings.end() && (!queue || find(i->second.begin(), i->second.end(), queue) != i->second.end());
+ } else if (!queue) {
+ //if no queue or routing key is specified, just report whether any bindings exist
+ return bindings.size() > 0;
+ } else {
+ for (Bindings::iterator i = bindings.begin(); i != bindings.end(); i++) {
+ if (find(i->second.begin(), i->second.end(), queue) != i->second.end()) {
+ return true;
+ }
+ }
+ return false;
+ }
+}
+
DirectExchange::~DirectExchange(){
}