Fixed #332 world not updated during cross-dimensional transportation
This commit is contained in:
parent
71945b0936
commit
3e1c619d98
1 changed files with 25 additions and 6 deletions
|
@ -345,8 +345,19 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
}
|
||||
|
||||
private void state_energizing() {
|
||||
// load remote world
|
||||
final WorldServer worldRemote = Commons.getOrCreateWorldServer(globalPositionRemote.dimensionId);
|
||||
if (worldRemote == null) {
|
||||
WarpDrive.logger.error(String.format("Unable to initialize dimension %d for %s",
|
||||
globalPositionRemote.dimensionId,
|
||||
this));
|
||||
isJammed = true;
|
||||
reasonJammed = String.format("Unable to initialize dimension %d", globalPositionRemote.dimensionId);
|
||||
return;
|
||||
}
|
||||
|
||||
// get entities
|
||||
final EntityValues entityValues = updateEntitiesToEnergize();
|
||||
final EntityValues entityValues = updateEntitiesToEnergize(worldRemote);
|
||||
|
||||
// post event on first tick
|
||||
if (tickEnergizing == WarpDriveConfig.TRANSPORTER_ENERGIZING_CHARGING_TICKS) {
|
||||
|
@ -371,9 +382,9 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
// transfer at final tick
|
||||
if ( vRemoteScanners == null
|
||||
|| vRemoteScanners.isEmpty() ) {
|
||||
energizeEntities(lockStrengthActual, movingEntitiesLocal, world, globalPositionRemote.getBlockPos());
|
||||
energizeEntities(lockStrengthActual, movingEntitiesLocal, worldRemote, globalPositionRemote.getBlockPos());
|
||||
} else {
|
||||
energizeEntities(lockStrengthActual, movingEntitiesLocal, world, vRemoteScanners);
|
||||
energizeEntities(lockStrengthActual, movingEntitiesLocal, worldRemote, vRemoteScanners);
|
||||
}
|
||||
if ( vLocalScanners != null
|
||||
&& !vLocalScanners.isEmpty() ) {
|
||||
|
@ -832,7 +843,7 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
vRemoteScanners = focusValuesRemote.vScanners;
|
||||
|
||||
// update entities in range
|
||||
final EntityValues entityValues = updateEntitiesToEnergize();
|
||||
final EntityValues entityValues = updateEntitiesToEnergize(worldRemote);
|
||||
|
||||
// compute energy cost from range
|
||||
energyCostForAcquiring = Math.max(0, WarpDriveConfig.TRANSPORTER_LOCKING_ENERGY_FACTORS[0]
|
||||
|
@ -1158,7 +1169,7 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
}
|
||||
}
|
||||
|
||||
private EntityValues updateEntitiesToEnergize() {
|
||||
private EntityValues updateEntitiesToEnergize(final WorldServer worldRemote) {
|
||||
final int countLocalScanners = vLocalScanners == null ? 0 : vLocalScanners.size();
|
||||
final int countScanners = vRemoteScanners == null ? countLocalScanners : Math.min(countLocalScanners, vRemoteScanners.size());
|
||||
|
||||
|
@ -1176,7 +1187,6 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
final EntityValues entityValuesLocal = updateEntitiesOnScanners(world, vLocalScanners, countScanners, movingEntitiesLocal);
|
||||
|
||||
// collect all candidates at remote location
|
||||
final World worldRemote = Commons.getOrCreateWorldServer(globalPositionRemote.dimensionId);
|
||||
final EntityValues entityValuesRemote;
|
||||
if (vRemoteScanners != null) {
|
||||
entityValuesRemote = updateEntitiesOnScanners(worldRemote, vRemoteScanners, countScanners, movingEntitiesRemote);
|
||||
|
@ -1305,6 +1315,11 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
}
|
||||
|
||||
private static Entity getCandidateEntityOnScanner(final World world, final BlockPos blockPos, final HashSet<Entity> entitiesOnScanners) {
|
||||
if ( blockPos == null
|
||||
|| world == null ) {
|
||||
return null;
|
||||
}
|
||||
|
||||
final AxisAlignedBB aabb = new AxisAlignedBB(
|
||||
blockPos.getX() - 0.05D,
|
||||
blockPos.getY() - 1.00D,
|
||||
|
@ -1359,6 +1374,10 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
|
|||
}
|
||||
|
||||
private static LinkedHashSet<Entity> getCandidateEntitiesInArea(final World world, final GlobalPosition globalPosition) {
|
||||
if (world == null) {
|
||||
return new LinkedHashSet<>(0);
|
||||
}
|
||||
|
||||
final AxisAlignedBB aabb = new AxisAlignedBB(
|
||||
globalPosition.x - WarpDriveConfig.TRANSPORTER_ENTITY_GRAB_RADIUS_BLOCKS,
|
||||
globalPosition.y - 1.0D,
|
||||
|
|
Loading…
Add table
Reference in a new issue