/*
* Created on Feb 9, 2005
* Created by Alon Rohter
* Copyright (C) 2004-2005 Aelitis, All Rights Reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* AELITIS, SAS au capital de 46,603.30 euros
* 8 Allee Lenotre, La Grille Royale, 78600 Le Mesnil le Roi, France.
*
*/
package org.gudy.azureus2.pluginsimpl.local.network;
import java.util.HashMap;
import org.gudy.azureus2.plugins.messaging.*;
import org.gudy.azureus2.plugins.messaging.bittorrent.BTMessageManager;
import org.gudy.azureus2.plugins.network.*;
import org.gudy.azureus2.pluginsimpl.local.messaging.MessageAdapter;
import com.aelitis.azureus.core.peermanager.messaging.bittorrent.BTMessage;
/**
*
*/
public class IncomingMessageQueueImpl implements IncomingMessageQueue {
private final com.aelitis.azureus.core.networkmanager.IncomingMessageQueue core_queue;
private final HashMap registrations = new HashMap();
protected IncomingMessageQueueImpl( com.aelitis.azureus.core.networkmanager.IncomingMessageQueue core_queue ) {
this.core_queue = core_queue;
}
public void registerListener( IncomingMessageQueueListener listener ) {
registerListenerSupport( listener, false );
}
public void registerPriorityListener( IncomingMessageQueueListener listener ) {
registerListenerSupport( listener, true );
}
private void registerListenerSupport( final IncomingMessageQueueListener listener, final boolean is_priority ) {
com.aelitis.azureus.core.networkmanager.IncomingMessageQueue.MessageQueueListener core_listener =
new com.aelitis.azureus.core.networkmanager.IncomingMessageQueue.MessageQueueListener() {
public boolean messageReceived( com.aelitis.azureus.core.peermanager.messaging.Message message ) {
if( message instanceof MessageAdapter ) {
//the message must have been originally decoded by plugin decoder
//so just use original plugin message...i.e. unwrap out of MessageAdapter
return listener.messageReceived( ((MessageAdapter)message).getPluginMessage() );
}
//message originally decoded by core
if ( message instanceof BTMessage ){
return listener.messageReceived( BTMessageManager.wrapCoreMessage((BTMessage)message ));
}else{
return listener.messageReceived( new MessageAdapter( message ));
}
}
public void protocolBytesReceived( int byte_count ) { listener.bytesReceived( byte_count ); }
public void dataBytesReceived( int byte_count ) { listener.bytesReceived( byte_count ); }
public boolean
isPriority()
{
return( is_priority );
}
};
registrations.put( listener, core_listener ); //save this mapping for later
core_queue.registerQueueListener( core_listener );
}
public void deregisterListener( IncomingMessageQueueListener listener ) {
//retrieve saved mapping
com.aelitis.azureus.core.networkmanager.IncomingMessageQueue.MessageQueueListener core_listener =
(com.aelitis.azureus.core.networkmanager.IncomingMessageQueue.MessageQueueListener)registrations.remove( listener );
if( core_listener != null ) {
core_queue.cancelQueueListener( core_listener );
}
}
public void notifyOfExternalReceive( Message message ) {
if( message instanceof MessageAdapter ) {
//the message must have been originally created by core and wrapped
//so just use original core message...i.e. unwrap out of MessageAdapter
core_queue.notifyOfExternallyReceivedMessage( ((MessageAdapter)message).getCoreMessage() );
return;
}
//message originally created by plugin
core_queue.notifyOfExternallyReceivedMessage( new MessageAdapter( message ) );
}
public int getPercentDoneOfCurrentMessage() {
return core_queue.getPercentDoneOfCurrentMessage();
}
}