diff options
author | Simon MacMullen <simon@rabbitmq.com> | 2012-04-11 16:03:54 +0100 |
---|---|---|
committer | Simon MacMullen <simon@rabbitmq.com> | 2012-04-11 16:03:54 +0100 |
commit | e9e81c2ad6f1b2ab7418190ab5c297363871e975 (patch) | |
tree | 10dbd785d2526778ac79f5dd0029e04d6c465d88 | |
parent | 02a8e0520c2f0d879c66ce9de04ab9b9675236ca (diff) | |
parent | 35f18fd5135385be672a421e5a50a3f2fc29a208 (diff) | |
download | rabbitmq-server-e9e81c2ad6f1b2ab7418190ab5c297363871e975.tar.gz |
Merge bug24862
-rw-r--r-- | src/rabbit_exchange.erl | 7 |
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, []}). |