Fixed a few bugs in the split() method and added in some new functionality for splitting of energy/fluid/gas! Unpairedbracket, shouldn't hurt you unless you modified split()
This commit is contained in:
parent
869660d8bf
commit
5272d169c4
4 changed files with 81 additions and 19 deletions
|
@ -1,7 +1,6 @@
|
||||||
package mekanism.api.transmitters;
|
package mekanism.api.transmitters;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -188,39 +187,55 @@ public abstract class DynamicNetwork<A, N extends DynamicNetwork<A, N>> implemen
|
||||||
|
|
||||||
TileEntity[] connectedBlocks = new TileEntity[6];
|
TileEntity[] connectedBlocks = new TileEntity[6];
|
||||||
boolean[] dealtWith = {false, false, false, false, false, false};
|
boolean[] dealtWith = {false, false, false, false, false, false};
|
||||||
|
List<NetworkFinder> newNetworks = new ArrayList<NetworkFinder>();
|
||||||
|
|
||||||
for(ForgeDirection direction : ForgeDirection.VALID_DIRECTIONS)
|
for(ForgeDirection side : ForgeDirection.VALID_DIRECTIONS)
|
||||||
{
|
{
|
||||||
TileEntity sideTile = Object3D.get((TileEntity)splitPoint).getFromSide(direction).getTileEntity(((TileEntity)splitPoint).worldObj);
|
TileEntity sideTile = Object3D.get((TileEntity)splitPoint).getFromSide(side).getTileEntity(((TileEntity)splitPoint).worldObj);
|
||||||
|
|
||||||
if(sideTile != null)
|
if(sideTile != null)
|
||||||
{
|
{
|
||||||
connectedBlocks[Arrays.asList(ForgeDirection.values()).indexOf(direction)] = sideTile;
|
connectedBlocks[side.ordinal()] = sideTile;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int countOne = 0; countOne < connectedBlocks.length; countOne++)
|
for(int count = 0; count < connectedBlocks.length; count++)
|
||||||
{
|
{
|
||||||
TileEntity connectedBlockA = connectedBlocks[countOne];
|
TileEntity connectedBlockA = connectedBlocks[count];
|
||||||
|
|
||||||
if(TransmissionType.checkTransmissionType(connectedBlockA, getTransmissionType()) && !dealtWith[countOne])
|
if(TransmissionType.checkTransmissionType(connectedBlockA, getTransmissionType()) && !dealtWith[count])
|
||||||
{
|
{
|
||||||
NetworkFinder finder = new NetworkFinder(((TileEntity)splitPoint).worldObj, getTransmissionType(), Object3D.get(connectedBlockA), Object3D.get((TileEntity)splitPoint));
|
NetworkFinder finder = new NetworkFinder(((TileEntity)splitPoint).worldObj, getTransmissionType(), Object3D.get(connectedBlockA), Object3D.get((TileEntity)splitPoint));
|
||||||
List<Object3D> partNetwork = finder.exploreNetwork();
|
List<Object3D> partNetwork = finder.exploreNetwork();
|
||||||
|
|
||||||
for(int countTwo = countOne + 1; countTwo < connectedBlocks.length; countTwo++)
|
for(int check = count; check < connectedBlocks.length; check++)
|
||||||
{
|
{
|
||||||
TileEntity connectedBlockB = connectedBlocks[countTwo];
|
if(check == count)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if(TransmissionType.checkTransmissionType(connectedBlockB, getTransmissionType()) && !dealtWith[countTwo])
|
TileEntity connectedBlockB = connectedBlocks[check];
|
||||||
|
|
||||||
|
if(TransmissionType.checkTransmissionType(connectedBlockB, getTransmissionType()) && !dealtWith[check])
|
||||||
{
|
{
|
||||||
if(partNetwork.contains(Object3D.get(connectedBlockB)))
|
if(partNetwork.contains(Object3D.get(connectedBlockB)))
|
||||||
{
|
{
|
||||||
dealtWith[countTwo] = true;
|
dealtWith[check] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
newNetworks.add(finder);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(newNetworks.size() > 0)
|
||||||
|
{
|
||||||
|
Object[] metaArray = getMetaArray(newNetworks);
|
||||||
|
|
||||||
|
for(NetworkFinder finder : newNetworks)
|
||||||
|
{
|
||||||
Set<ITransmitter<N>> newNetCables = new HashSet<ITransmitter<N>>();
|
Set<ITransmitter<N>> newNetCables = new HashSet<ITransmitter<N>>();
|
||||||
|
|
||||||
for(Object3D node : finder.iterated)
|
for(Object3D node : finder.iterated)
|
||||||
|
@ -237,6 +252,7 @@ public abstract class DynamicNetwork<A, N extends DynamicNetwork<A, N>> implemen
|
||||||
}
|
}
|
||||||
|
|
||||||
ITransmitterNetwork<A, N> newNetwork = create(newNetCables);
|
ITransmitterNetwork<A, N> newNetwork = create(newNetCables);
|
||||||
|
newNetwork.onNewFromSplit(newNetworks.indexOf(finder), metaArray);
|
||||||
newNetwork.refresh();
|
newNetwork.refresh();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -245,6 +261,15 @@ public abstract class DynamicNetwork<A, N extends DynamicNetwork<A, N>> implemen
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object[] getMetaArray(List<NetworkFinder> networks)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNewFromSplit(int netIndex, Object[] metaArray) {}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setFixed(boolean value)
|
public void setFixed(boolean value)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
package mekanism.api.transmitters;
|
package mekanism.api.transmitters;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import mekanism.api.transmitters.DynamicNetwork.NetworkFinder;
|
||||||
|
|
||||||
public interface ITransmitterNetwork<A, N extends DynamicNetwork<A, N>>
|
public interface ITransmitterNetwork<A, N extends DynamicNetwork<A, N>>
|
||||||
{
|
{
|
||||||
public void tick();
|
public void tick();
|
||||||
|
@ -33,4 +36,21 @@ public interface ITransmitterNetwork<A, N extends DynamicNetwork<A, N>>
|
||||||
public void setFixed(boolean value);
|
public void setFixed(boolean value);
|
||||||
|
|
||||||
public TransmissionType getTransmissionType();
|
public TransmissionType getTransmissionType();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a network's meta value right before it is split. This will then be passed onto "onNewFromSplit()" in
|
||||||
|
* every single new network that is created from the original split.
|
||||||
|
* @param size - the amount of new networks that are being created
|
||||||
|
* @return meta obj
|
||||||
|
*/
|
||||||
|
public Object[] getMetaArray(List<NetworkFinder> networks);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called right after a new network is created after being split, before it is refreshed. Passes in it's index
|
||||||
|
* in the amount of networks being created, as well as the meta value that was retrieved on the original network
|
||||||
|
* by getMetaObj().
|
||||||
|
* @param netIndex - the index of the network being created
|
||||||
|
* @param meta - meta obj
|
||||||
|
*/
|
||||||
|
public void onNewFromSplit(int netIndex, Object[] metaArray);
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,13 +102,16 @@ public abstract class PartTransmitter<N extends DynamicNetwork<?, N>> extends Pa
|
||||||
|
|
||||||
if(possibleTransmitters != currentTransmitterConnections)
|
if(possibleTransmitters != currentTransmitterConnections)
|
||||||
{
|
{
|
||||||
byte or = (byte)(possibleTransmitters | currentTransmitterConnections);
|
//TODO @unpairedbracket, I don't think this is necessary; I couldn't tell a difference without it,
|
||||||
|
//and it results in many extra possible recursive calls on the network
|
||||||
|
|
||||||
|
/*byte or = (byte)(possibleTransmitters | currentTransmitterConnections);
|
||||||
|
|
||||||
if(or != possibleTransmitters)
|
if(or != possibleTransmitters)
|
||||||
{
|
{
|
||||||
((DynamicNetwork<?, N>)getTransmitterNetwork()).split((ITransmitter<N>)tile());
|
((DynamicNetwork<?, N>)getTransmitterNetwork()).split((ITransmitter<N>)tile());
|
||||||
setTransmitterNetwork(null);
|
setTransmitterNetwork(null);
|
||||||
}
|
}*/
|
||||||
|
|
||||||
for(ForgeDirection side : ForgeDirection.VALID_DIRECTIONS)
|
for(ForgeDirection side : ForgeDirection.VALID_DIRECTIONS)
|
||||||
{
|
{
|
||||||
|
@ -254,9 +257,6 @@ public abstract class PartTransmitter<N extends DynamicNetwork<?, N>> extends Pa
|
||||||
super.preRemove();
|
super.preRemove();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void chunkLoad() {}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onAdded()
|
public void onAdded()
|
||||||
{
|
{
|
||||||
|
|
|
@ -170,7 +170,7 @@ public class ListUtils
|
||||||
return (List<V>)Arrays.asList(values);
|
return (List<V>)Arrays.asList(values);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static double[] splitNum(int size, double num)
|
public static double[] splitDouble(int size, double num)
|
||||||
{
|
{
|
||||||
double[] split = new double[size];
|
double[] split = new double[size];
|
||||||
|
|
||||||
|
@ -186,4 +186,21 @@ public class ListUtils
|
||||||
|
|
||||||
return split;
|
return split;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int[] splitInt(int size, int num)
|
||||||
|
{
|
||||||
|
int[] split = new int[size];
|
||||||
|
|
||||||
|
for(int i = 0; i < size; i++)
|
||||||
|
{
|
||||||
|
int remain = num%size;
|
||||||
|
int ret = (num-remain)/size;
|
||||||
|
ret += remain;
|
||||||
|
|
||||||
|
split[i] = ret;
|
||||||
|
num -= remain;
|
||||||
|
}
|
||||||
|
|
||||||
|
return split;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue