diff --git a/megamek/src/megamek/common/actions/WeaponAttackAction.java b/megamek/src/megamek/common/actions/WeaponAttackAction.java index 5b94efd80ca..c9b78a62e4f 100644 --- a/megamek/src/megamek/common/actions/WeaponAttackAction.java +++ b/megamek/src/megamek/common/actions/WeaponAttackAction.java @@ -4210,7 +4210,7 @@ else if ((atype != null) // Aerospace target modifiers if (te != null && te.isAero() && te.isAirborne()) { - IAero a = (IAero) te; + final IAero a = (IAero) te; // is the target at zero velocity if ((a.getCurrentVelocity() == 0) && !(a.isSpheroid() && !game.getBoard().inSpace())) { @@ -4234,19 +4234,24 @@ else if ((atype != null) // Target hidden in the sensor shadow of a larger spacecraft if (game.getOptions().booleanOption(OptionsConstants.ADVAERORULES_STRATOPS_SENSOR_SHADOW) && game.getBoard().inSpace()) { - for (Entity en : Compute.getAdjacentEntitiesAlongAttack(ae.getPosition(), target.getPosition(), game)) { - if (!en.isEnemyOf(te) && en.isLargeCraft() - && ((en.getWeight() - te.getWeight()) >= -STRATOPS_SENSOR_SHADOW_WEIGHT_DIFF)) { - toHit.addModifier(+1, Messages.getString("WeaponAttackAction.SensorShadow")); - break; - } - } - for (Entity en : game.getEntitiesVector(target.getPosition())) { - if (!en.isEnemyOf(te) && en.isLargeCraft() && !en.equals((Entity) a) - && ((en.getWeight() - te.getWeight()) >= -STRATOPS_SENSOR_SHADOW_WEIGHT_DIFF)) { - toHit.addModifier(+1, Messages.getString("WeaponAttackAction.SensorShadow")); - break; - } + if (Compute.getAdjacentEntitiesAlongAttack(ae.getPosition(), target.getPosition(), game).stream() + .anyMatch(en -> + !en.isEnemyOf(a) + && en.isLargeCraft() + && en.getWeight() - a.getWeight() >= -STRATOPS_SENSOR_SHADOW_WEIGHT_DIFF + ) + ) { + toHit.addModifier(+1, Messages.getString("WeaponAttackAction.SensorShadow")); + } + if (game.getEntitiesVector(target.getPosition()).stream() + .anyMatch(en -> + !en.isEnemyOf(a) + && en.isLargeCraft() + && !en.equals(a) + && en.getWeight() - a.getWeight() >= -STRATOPS_SENSOR_SHADOW_WEIGHT_DIFF + ) + ) { + toHit.addModifier(+1, Messages.getString("WeaponAttackAction.SensorShadow")); } } }