From 71acfaf0149dd87a0be0a00b433f32855c4067fe Mon Sep 17 00:00:00 2001 From: Zimmermann Gyula Date: Wed, 20 Jun 2018 11:36:06 +0200 Subject: [PATCH] Implement HarvesterResourceMultiplier. --- OpenRA.Mods.Common/Traits/Harvester.cs | 4 ++- .../HarvesterResourceMultiplier.cs | 33 +++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 OpenRA.Mods.Common/Traits/Multipliers/HarvesterResourceMultiplier.cs diff --git a/OpenRA.Mods.Common/Traits/Harvester.cs b/OpenRA.Mods.Common/Traits/Harvester.cs index 7bff64806c..3e6c477395 100644 --- a/OpenRA.Mods.Common/Traits/Harvester.cs +++ b/OpenRA.Mods.Common/Traits/Harvester.cs @@ -95,6 +95,7 @@ namespace OpenRA.Mods.Common.Traits INotifyHarvesterAction[] notifyHarvesterAction; ConditionManager conditionManager; int conditionToken = ConditionManager.InvalidConditionToken; + HarvesterResourceMultiplier[] resourceMultipliers; [Sync] public bool LastSearchFailed; [Sync] public Actor OwnerLinkedProc = null; @@ -127,6 +128,7 @@ namespace OpenRA.Mods.Common.Traits void INotifyCreated.Created(Actor self) { notifyHarvesterAction = self.TraitsImplementing().ToArray(); + resourceMultipliers = self.TraitsImplementing().ToArray(); conditionManager = self.TraitOrDefault(); UpdateCondition(self); @@ -249,7 +251,7 @@ namespace OpenRA.Mods.Common.Traits var type = contents.First().Key; var iao = proc.Trait(); var count = Math.Min(contents[type], Info.BaleUnloadAmount); - var value = type.ValuePerUnit * count; + var value = Util.ApplyPercentageModifiers(type.ValuePerUnit * count, resourceMultipliers.Select(m => m.GetModifier())); if (!iao.CanGiveResource(value)) return false; diff --git a/OpenRA.Mods.Common/Traits/Multipliers/HarvesterResourceMultiplier.cs b/OpenRA.Mods.Common/Traits/Multipliers/HarvesterResourceMultiplier.cs new file mode 100644 index 0000000000..e247592169 --- /dev/null +++ b/OpenRA.Mods.Common/Traits/Multipliers/HarvesterResourceMultiplier.cs @@ -0,0 +1,33 @@ +#region Copyright & License Information +/* + * Copyright 2007-2019 The OpenRA Developers (see AUTHORS) + * This file is part of OpenRA, which is free software. It is made + * available to you under the terms of the GNU General Public License + * as published by the Free Software Foundation, either version 3 of + * the License, or (at your option) any later version. For more + * information, see COPYING. + */ +#endregion + +using OpenRA.Traits; + +namespace OpenRA.Mods.Common.Traits +{ + [Desc("Modifies the bale values of this harvester.")] + public class HarvesterResourceMultiplierInfo : ConditionalTraitInfo + { + [FieldLoader.Require] + [Desc("Percentage modifier to apply.")] + public readonly int Modifier = 100; + + public override object Create(ActorInitializer init) { return new HarvesterResourceMultiplier(this); } + } + + public class HarvesterResourceMultiplier : ConditionalTrait, Requires + { + public HarvesterResourceMultiplier(HarvesterResourceMultiplierInfo info) + : base(info) { } + + public int GetModifier() { return IsTraitDisabled ? 100 : Info.Modifier; } + } +}