Applied-Energistics-2-tiler.../me/cache/NetworkMonitor.java

127 lines
3.1 KiB
Java
Raw Normal View History

package appeng.me.cache;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.Map.Entry;
2014-01-05 09:43:49 +01:00
import java.util.Set;
import appeng.api.networking.events.MENetworkStorageEvent;
2014-01-05 09:43:49 +01:00
import appeng.api.networking.security.BaseActionSource;
import appeng.api.storage.IMEInventoryHandler;
import appeng.api.storage.IMEMonitorHandlerReceiver;
2014-01-01 22:46:16 +01:00
import appeng.api.storage.MEMonitorHandler;
import appeng.api.storage.StorageChannel;
import appeng.api.storage.data.IAEStack;
2014-01-05 09:43:49 +01:00
import appeng.api.storage.data.IItemList;
import appeng.me.storage.ItemWatcher;
2014-01-01 22:46:16 +01:00
public class NetworkMonitor<T extends IAEStack<T>> extends MEMonitorHandler<T>
{
final private GridStorageCache myGridCache;
final private StorageChannel myChannel;
boolean sendEvent = false;
2014-01-05 09:43:49 +01:00
public void forceUpdate()
{
hasChanged = true;
Iterator<Entry<IMEMonitorHandlerReceiver<T>, Object>> i = getListeners();
while (i.hasNext())
{
Entry<IMEMonitorHandlerReceiver<T>, Object> o = i.next();
IMEMonitorHandlerReceiver<T> recv = o.getKey();
if ( recv.isValid( o.getValue() ) )
recv.onListUpdate();
else
i.remove();
}
2014-01-05 09:43:49 +01:00
}
public NetworkMonitor(GridStorageCache cache, StorageChannel chan) {
2014-02-21 22:04:51 +01:00
super( null, chan );
myGridCache = cache;
myChannel = chan;
}
final static public LinkedList depth = new LinkedList();
@Override
protected void postChangesToListeners(Iterable<T> changes, BaseActionSource src)
{
postChange( true, changes, src );
}
protected void postChange(boolean Add, Iterable<T> changes, BaseActionSource src)
{
if ( depth.contains( this ) )
return;
depth.push( this );
sendEvent = true;
notifyListenersOfChange( changes, src );
IItemList<T> myStorageList = getStorageList();
for (T changedItem : changes)
{
2014-09-21 01:34:38 +02:00
T difference = changedItem;
if ( !Add && changedItem != null )
2014-09-21 01:34:38 +02:00
(difference = changedItem.copy()).setStackSize( -changedItem.getStackSize() );
if ( myGridCache.interestManager.containsKey( changedItem ) )
{
Set<ItemWatcher> list = myGridCache.interestManager.get( changedItem );
if ( !list.isEmpty() )
{
IAEStack fullStack = myStorageList.findPrecise( changedItem );
if ( fullStack == null )
{
fullStack = changedItem.copy();
fullStack.setStackSize( 0 );
}
myGridCache.interestManager.enableTransactions();
for (ItemWatcher iw : list)
2014-09-21 01:34:38 +02:00
iw.getHost().onStackChange( myStorageList, fullStack, difference, src, getChannel() );
myGridCache.interestManager.disableTransactions();
}
}
}
Object last = depth.pop();
if ( last != this )
throw new RuntimeException( "Invalid Access to Networked Storage API detected." );
}
public void onTick()
{
if ( sendEvent )
{
sendEvent = false;
2014-01-20 17:41:37 +01:00
myGridCache.myGrid.postEvent( new MENetworkStorageEvent( this, myChannel ) );
}
}
@Override
protected IMEInventoryHandler getHandler()
{
switch (myChannel)
{
case ITEMS:
return myGridCache.getItemInventoryHandler();
case FLUIDS:
return myGridCache.getFluidInventoryHandler();
default:
}
return null;
}
}