コード例 #1
0
        public bool TakeMessage(CancellationToken token, out MessageTransportContext context)
        {
            while (!token.IsCancellationRequested)
            {
                // if incoming message is delayed and in future -> push it to the timer queue.
                // timer will be responsible for publishing back.
                byte[] envelope;
                var    result = BlockingCollection <byte[]> .TakeFromAny(_queues, out envelope);

                if (result >= 0)
                {
                    context = new MessageTransportContext(result, envelope, _names[result]);
                    return(true);
                }
            }
            context = null;
            return(false);
        }
コード例 #2
0
ファイル: RabbitMQReader.cs プロジェクト: berkaroad/cqrs
 public void AckMessage(MessageTransportContext message)
 {
     throw new NotImplementedException();
 }
コード例 #3
0
ファイル: RabbitMQReader.cs プロジェクト: berkaroad/cqrs
 public void TryNotifyNack(MessageTransportContext context)
 {
     throw new NotImplementedException();
 }
コード例 #4
0
ファイル: RabbitMQReader.cs プロジェクト: berkaroad/cqrs
 public bool TakeMessage(CancellationToken token, out MessageTransportContext context)
 {
     throw new NotImplementedException();
 }
コード例 #5
0
        public void TryNotifyNack(MessageTransportContext context)
        {
            var id = (int)context.TransportMessage;

            _queues[id].Add(context.Unpacked);
        }
コード例 #6
0
 public void AckMessage(MessageTransportContext message)
 {
 }