Synchronized tile modification with updating

This commit is contained in:
Anuken
2018-02-17 16:04:09 -05:00
parent 30d0d7715a
commit a79dfe29ef
4 changed files with 25 additions and 22 deletions

View File

@ -1,7 +1,7 @@
#Autogenerated file. Do not modify.
#Sat Feb 17 13:59:09 EST 2018
#Sat Feb 17 14:39:13 EST 2018
version=beta
androidBuildCode=235
name=Mindustry
code=3.3
build=23
build=custom build

View File

@ -106,17 +106,19 @@ public class TileEntity extends Entity{
@Override
public void update(){
if(health != 0 && health < tile.block().health && !(tile.block() instanceof Wall) &&
Mathf.chance(0.009f*Timers.delta()*(1f-health/tile.block().health))){
synchronized (tile) {
if (health != 0 && health < tile.block().health && !(tile.block() instanceof Wall) &&
Mathf.chance(0.009f * Timers.delta() * (1f - health / tile.block().health))) {
Effects.effect(Fx.smoke, x+Mathf.range(4), y+Mathf.range(4));
}
Effects.effect(Fx.smoke, x + Mathf.range(4), y + Mathf.range(4));
}
if(health <= 0){
onDeath();
if (health <= 0) {
onDeath();
}
tile.block().update(tile);
}
tile.block().update(tile);
}
public int totalItems(){

View File

@ -260,18 +260,20 @@ public class Tile{
}
public void changed(){
if(entity != null){
entity.remove();
entity = null;
}
Block block = block();
if(block.destructible || block.update){
entity = block.getEntity().init(this, block.update);
}
synchronized (this) {
if (entity != null) {
entity.remove();
entity = null;
}
updateOcclusion();
Block block = block();
if (block.destructible || block.update) {
entity = block.getEntity().init(this, block.update);
}
updateOcclusion();
}
}
@Override

View File

@ -143,7 +143,6 @@ public class Conveyor extends Block{
@Override
public boolean acceptItem(Item item, Tile tile, Tile source){
if(tile.entity == null) return false;
int direction = source == null ? 0 : Math.abs(source.relativeTo(tile.x, tile.y) - tile.getRotation());
float minitem = tile.<ConveyorEntity>entity().minitem;
return (((direction == 0) && minitem > 0.05f) ||