summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon MacMullen <simon@rabbitmq.com>2011-12-02 16:43:41 +0000
committerSimon MacMullen <simon@rabbitmq.com>2011-12-02 16:43:41 +0000
commit1aac220b0eb58f26f523bf4ea193b548edbce329 (patch)
tree2a39ee6084f4c7f0287dd87ec6fd3b035daa7e1f
parentd297dfbe836b4a02a8f31f2d0acbf3f318063e1b (diff)
parentae1bb4d6ab5644b87fd37a89356157449c34dbfe (diff)
downloadrabbitmq-server-git-1aac220b0eb58f26f523bf4ea193b548edbce329.tar.gz
Merge bug 24608 (qproc and mirror_slave disagree on data structure for msg_id_to_channel)
-rw-r--r--src/rabbit_mirror_queue_slave.erl8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/rabbit_mirror_queue_slave.erl b/src/rabbit_mirror_queue_slave.erl
index 73eaed1476..d68063db80 100644
--- a/src/rabbit_mirror_queue_slave.erl
+++ b/src/rabbit_mirror_queue_slave.erl
@@ -526,9 +526,11 @@ promote_me(From, #state { q = Q = #amqqueue { name = QName },
MasterState = rabbit_mirror_queue_master:promote_backing_queue_state(
CPid, BQ, BQS, GM, SS, MonitoringPids),
- MTC = dict:from_list(
- [{MsgId, {ChPid, MsgSeqNo}} ||
- {MsgId, {published, ChPid, MsgSeqNo}} <- dict:to_list(MS)]),
+ MTC = lists:foldl(fun ({MsgId, {published, ChPid, MsgSeqNo}}, MTC0) ->
+ gb_trees:insert(MsgId, {ChPid, MsgSeqNo}, MTC0);
+ (_, MTC0) ->
+ MTC0
+ end, gb_trees:empty(), MSList),
NumAckTags = [NumAckTag || {_MsgId, NumAckTag} <- dict:to_list(MA)],
AckTags = [AckTag || {_Num, AckTag} <- lists:sort(NumAckTags)],
Deliveries = [Delivery || {_ChPid, {PubQ, _PendCh}} <- dict:to_list(SQ),