diff options
| author | Alan Conway <aconway@apache.org> | 2007-02-06 15:01:45 +0000 | 
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2007-02-06 15:01:45 +0000 | 
| commit | fbd97f554b04a109c95c01fe6ad538c5f50161af (patch) | |
| tree | 0324d02ee4f8d6ca2387d1d3ff85bcd61a123a34 /cpp/lib/broker/BrokerChannel.cpp | |
| parent | 80b1b0b5f443bfb3c9d62a80e1419c224d0229d8 (diff) | |
| download | qpid-python-fbd97f554b04a109c95c01fe6ad538c5f50161af.tar.gz | |
* broker/Reference, tests/ReferenceTest: class representing a reference.
* broker/BrokerChannel.cpp (complete): get destination exchange from Message,
  don't assume only one message in progress (could have multiple
  references open.)
* broker/BrokerMessageMessage.cpp,.h: Contains transfer body and
  vector of append bodies. Construct from Reference.
* broker/CompletionHandler.h: Extracted from BrokerMessage, used for
  MessageMessage also.
* broker/ExchangeRegistry.cpp: Moved throw for missing exchanges to
  registry. 
* cpp/tests/start_broker: Increased wait time to 5 secs.
* cpp/tests/*: renamed DummyChannel  as MockChannel.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/branches/qpid.0-9@504172 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/lib/broker/BrokerChannel.cpp')
| -rw-r--r-- | cpp/lib/broker/BrokerChannel.cpp | 30 | 
1 files changed, 16 insertions, 14 deletions
| diff --git a/cpp/lib/broker/BrokerChannel.cpp b/cpp/lib/broker/BrokerChannel.cpp index 96215a60ed..c0250815e8 100644 --- a/cpp/lib/broker/BrokerChannel.cpp +++ b/cpp/lib/broker/BrokerChannel.cpp @@ -78,7 +78,7 @@ void Channel::consume(string& tag, Queue::shared_ptr queue, bool acks,                        bool exclusive, ConnectionToken* const connection,                        const FieldTable*)  { -	if(tag.empty()) tag = tagGenerator.generate(); +    if(tag.empty()) tag = tagGenerator.generate();      ConsumerImpl* c(new ConsumerImpl(this, tag, queue, connection, acks));      try{          queue->consume(c, exclusive);//may throw exception @@ -187,6 +187,8 @@ void Channel::ConsumerImpl::requestDispatch(){      if(blocked) queue->dispatch();  } +// FIXME aconway 2007-02-05: Drop exchange member, calculate from +// message in ::complete().  void Channel::handlePublish(Message* _message, Exchange::shared_ptr _exchange){      Message::shared_ptr message(_message);      exchange = _exchange; @@ -207,19 +209,19 @@ void Channel::handleHeartbeat(boost::shared_ptr<AMQHeartbeatBody>) {      // TODO aconway 2007-01-17: Implement heartbeating.  } -void Channel::complete(Message::shared_ptr& msg){ -    if(exchange){ -        if(transactional){ -            TxPublish* deliverable = new TxPublish(msg); -            exchange->route(*deliverable, msg->getRoutingKey(), &(msg->getHeaderProperties()->getHeaders())); -            txBuffer.enlist(new DeletingTxOp(deliverable)); -        }else{ -            DeliverableMessage deliverable(msg); -            exchange->route(deliverable, msg->getRoutingKey(), &(msg->getHeaderProperties()->getHeaders())); -        } -        exchange.reset(); -    }else{ -        std::cout << "Exchange not known in Channel::complete(Message::shared_ptr&)" << std::endl; +void Channel::complete(Message::shared_ptr msg) { +    Exchange::shared_ptr exchange = +        connection.broker.getExchanges().get(msg->getExchange()); +    assert(exchange.get()); +    if(transactional) { +        std::auto_ptr<TxPublish> deliverable(new TxPublish(msg)); +        exchange->route(*deliverable, msg->getRoutingKey(), +                        &(msg->getHeaderProperties()->getHeaders())); +        txBuffer.enlist(new DeletingTxOp(deliverable.release())); +    } else { +        DeliverableMessage deliverable(msg); +        exchange->route(deliverable, msg->getRoutingKey(), +                        &(msg->getHeaderProperties()->getHeaders()));      }  } | 
