return;
}
}
JBossDestination dest = (JBossDestination)msg.getJMSDestination();
// This allows the no-local consumers to filter out the messages that come from the same
// connection.
// TODO Do we want to set this for ALL messages. Optimisation is possible here.
msg.setConnectionID(id);
// We must reference the message *before* we send it the destination to be handled. This is
// so we can guarantee that the message doesn't disappear from the store before the
// handling is complete. Each channel then takes copies of the reference if they decide to
// maintain it internally
MessageReference ref = msg.createReference();
long schedDeliveryTime = msg.getScheduledDeliveryTime();
if (schedDeliveryTime > 0)
{
ref.setScheduledDeliveryTime(schedDeliveryTime);
}
if (dest.isDirect())
{
//Route directly to queue - temp kludge for clustering
Binding binding = postOffice.getBindingForQueueName(dest.getName());
if (binding == null)
{
throw new IllegalArgumentException("Cannot find binding for queue " + dest.getName());
}
Queue queue = binding.queue;
Long scid = (Long)ref.getMessage().removeHeader(Message.SOURCE_CHANNEL_ID);
Delivery del = queue.handleMove(ref, scid.longValue());
if (del == null)
{
throw new JMSException("Failed to route " + ref + " to " + dest.getName());
}
}
else if (dest.isQueue())
{
if (!postOffice.route(ref, new JMSCondition(true, dest.getName()), tx))
{
throw new JMSException("Failed to route " + ref + " to " + dest.getName());
}
}
else
{
postOffice.route(ref, new JMSCondition(false, dest.getName()), tx);
}
if (trace) { log.trace("sent " + msg); }
}