summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon MacMullen <simon@rabbitmq.com>2012-04-11 16:03:54 +0100
committerSimon MacMullen <simon@rabbitmq.com>2012-04-11 16:03:54 +0100
commite9e81c2ad6f1b2ab7418190ab5c297363871e975 (patch)
tree10dbd785d2526778ac79f5dd0029e04d6c465d88
parent02a8e0520c2f0d879c66ce9de04ab9b9675236ca (diff)
parent35f18fd5135385be672a421e5a50a3f2fc29a208 (diff)
downloadrabbitmq-server-e9e81c2ad6f1b2ab7418190ab5c297363871e975.tar.gz
Merge bug24862
-rw-r--r--src/rabbit_exchange.erl7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/rabbit_exchange.erl b/src/rabbit_exchange.erl
index 83e28c44..0249155c 100644
--- a/src/rabbit_exchange.erl
+++ b/src/rabbit_exchange.erl
@@ -242,6 +242,13 @@ info_all(VHostPath) -> map(VHostPath, fun (X) -> info(X) end).
info_all(VHostPath, Items) -> map(VHostPath, fun (X) -> info(X, Items) end).
+%% Optimisation
+route(#exchange{name = #resource{name = <<"">>, virtual_host = VHost}},
+ #delivery{message = #basic_message{routing_keys = RKs}}) ->
+ QNames = [rabbit_misc:r(VHost, queue, RK) || RK <- RKs],
+ lists:usort([QName || #amqqueue{name = QName}
+ <- rabbit_amqqueue:lookup(QNames)]);
+
route(X = #exchange{name = XName}, Delivery) ->
route1(Delivery, {queue:from_list([X]), XName, []}).