Merge pull request #8942 from reaperrr/explodes2
Add specific exception message when Explodes cannot find a weapon
This commit is contained in:
@@ -8,6 +8,7 @@
|
|||||||
*/
|
*/
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using OpenRA.Mods.Common.Warheads;
|
using OpenRA.Mods.Common.Warheads;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
@@ -17,7 +18,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
[Desc("This actor explodes when killed.")]
|
[Desc("This actor explodes when killed.")]
|
||||||
public class ExplodesInfo : ITraitInfo
|
public class ExplodesInfo : ITraitInfo
|
||||||
{
|
{
|
||||||
[WeaponReference, Desc("Weapon to use for explosion if ammo/payload is loaded.")]
|
[WeaponReference, FieldLoader.Require, Desc("Weapon to use for explosion if ammo/payload is loaded.")]
|
||||||
public readonly string Weapon = "UnitExplode";
|
public readonly string Weapon = "UnitExplode";
|
||||||
|
|
||||||
[WeaponReference, Desc("Weapon to use for explosion if no ammo/payload is loaded.")]
|
[WeaponReference, Desc("Weapon to use for explosion if no ammo/payload is loaded.")]
|
||||||
@@ -54,9 +55,13 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
var weaponName = ChooseWeaponForExplosion(self);
|
var weaponName = ChooseWeaponForExplosion(self);
|
||||||
if (weaponName == null)
|
if (string.IsNullOrEmpty(weaponName))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (!e.Attacker.World.Map.Rules.Weapons.ContainsKey(weaponName.ToLowerInvariant()))
|
||||||
|
throw new InvalidOperationException("Actor " + self.Info.Name
|
||||||
|
+ ": Could not find weapon '" + weaponName.ToLowerInvariant() + "', check for typos.");
|
||||||
|
|
||||||
var weapon = e.Attacker.World.Map.Rules.Weapons[weaponName.ToLowerInvariant()];
|
var weapon = e.Attacker.World.Map.Rules.Weapons[weaponName.ToLowerInvariant()];
|
||||||
if (weapon.Report != null && weapon.Report.Any())
|
if (weapon.Report != null && weapon.Report.Any())
|
||||||
Sound.Play(weapon.Report.Random(e.Attacker.World.SharedRandom), self.CenterPosition);
|
Sound.Play(weapon.Report.Random(e.Attacker.World.SharedRandom), self.CenterPosition);
|
||||||
|
|||||||
@@ -164,7 +164,7 @@ grenadier:
|
|||||||
IdleSequences: idle
|
IdleSequences: idle
|
||||||
Explodes:
|
Explodes:
|
||||||
Weapon: UnitExplodeSmall
|
Weapon: UnitExplodeSmall
|
||||||
Chance: 100
|
EmptyWeapon: UnitExplodeSmall
|
||||||
AttractsWorms:
|
AttractsWorms:
|
||||||
Intensity: 180
|
Intensity: 180
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user