diff --git a/OpenRA.Mods.Common/Traits/RejectsOrders.cs b/OpenRA.Mods.Common/Traits/RejectsOrders.cs index 3b842d8438..5ced75b6cd 100644 --- a/OpenRA.Mods.Common/Traits/RejectsOrders.cs +++ b/OpenRA.Mods.Common/Traits/RejectsOrders.cs @@ -15,24 +15,20 @@ using OpenRA.Traits; namespace OpenRA.Mods.Common.Traits { [Desc("Can be used to make a unit partly uncontrollable by the player.")] - public class RejectsOrdersInfo : ITraitInfo + public class RejectsOrdersInfo : UpgradableTraitInfo { [Desc("Possible values include Attack, AttackMove, Guard, Move.")] public readonly HashSet Except = new HashSet(); - public object Create(ActorInitializer init) { return new RejectsOrders(this); } + public override object Create(ActorInitializer init) { return new RejectsOrders(this); } } - public class RejectsOrders + public class RejectsOrders : UpgradableTrait { - public HashSet Except { get { return info.Except; } } - - readonly RejectsOrdersInfo info; + public HashSet Except { get { return Info.Except; } } public RejectsOrders(RejectsOrdersInfo info) - { - this.info = info; - } + : base(info) { } } public static class RejectsOrdersExts @@ -40,7 +36,7 @@ namespace OpenRA.Mods.Common.Traits public static bool AcceptsOrder(this Actor self, string orderString) { var r = self.TraitOrDefault(); - return r == null || r.Except.Contains(orderString); + return r == null || r.IsTraitDisabled || r.Except.Contains(orderString); } } }