summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/rabbit_amqqueue_process.erl13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/rabbit_amqqueue_process.erl b/src/rabbit_amqqueue_process.erl
index 2666847e77..fbab825c76 100644
--- a/src/rabbit_amqqueue_process.erl
+++ b/src/rabbit_amqqueue_process.erl
@@ -801,14 +801,21 @@ maybe_drop_head(AlreadyDropped, State = #q{backing_queue = BQ,
end.
send_reject_publish(#delivery{confirm = true,
- sender = SenderPid,
- msg_seq_no = MsgSeqNo} = Delivery,
+ sender = SenderPid,
+ flow = Flow,
+ msg_seq_no = MsgSeqNo,
+ message = #basic_message{id = MsgId}},
_Delivered,
State = #q{ backing_queue = BQ,
backing_queue_state = BQS,
msg_id_to_channel = MTC}) ->
- {BQS1, MTC1} = discard(Delivery, BQ, BQS, MTC),
gen_server2:cast(SenderPid, {reject_publish, MsgSeqNo, self()}),
+
+ MTC1 = case gb_trees:is_defined(MsgId, MTC) of
+ true -> gb_trees:delete(MsgId, MTC);
+ false -> MTC
+ end,
+ BQS1 = BQ:discard(MsgId, SenderPid, Flow, BQS),
State#q{ backing_queue_state = BQS1, msg_id_to_channel = MTC1 };
send_reject_publish(#delivery{confirm = false},
_Delivered, State) ->