Add RejectsOrders to disallow orders for offmap aircraft etc
This commit is contained in:
@@ -170,6 +170,7 @@
|
|||||||
<Compile Include="Traits\EditorTilesetFilter.cs" />
|
<Compile Include="Traits\EditorTilesetFilter.cs" />
|
||||||
<Compile Include="Traits\Health.cs" />
|
<Compile Include="Traits\Health.cs" />
|
||||||
<Compile Include="Traits\LintAttributes.cs" />
|
<Compile Include="Traits\LintAttributes.cs" />
|
||||||
|
<Compile Include="Traits\RejectsOrders.cs" />
|
||||||
<Compile Include="Traits\Player\DeveloperMode.cs" />
|
<Compile Include="Traits\Player\DeveloperMode.cs" />
|
||||||
<Compile Include="Traits\Player\PlayerResources.cs" />
|
<Compile Include="Traits\Player\PlayerResources.cs" />
|
||||||
<Compile Include="Traits\Render\RenderSimple.cs" />
|
<Compile Include="Traits\Render\RenderSimple.cs" />
|
||||||
|
|||||||
43
OpenRA.Game/Traits/RejectsOrders.cs
Normal file
43
OpenRA.Game/Traits/RejectsOrders.cs
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
#region Copyright & License Information
|
||||||
|
/*
|
||||||
|
* Copyright 2007-2013 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. For more information,
|
||||||
|
* see COPYING.
|
||||||
|
*/
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
|
using OpenRA.Network;
|
||||||
|
|
||||||
|
namespace OpenRA.Traits
|
||||||
|
{
|
||||||
|
public class RejectsOrdersInfo : ITraitInfo
|
||||||
|
{
|
||||||
|
public readonly string[] Except = { };
|
||||||
|
|
||||||
|
public object Create(ActorInitializer init) { return new RejectsOrders(this); }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class RejectsOrders
|
||||||
|
{
|
||||||
|
public string[] Except { get { return info.Except; } }
|
||||||
|
|
||||||
|
readonly RejectsOrdersInfo info;
|
||||||
|
|
||||||
|
public RejectsOrders(RejectsOrdersInfo info)
|
||||||
|
{
|
||||||
|
this.info = info;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class RejectsOrdersExts
|
||||||
|
{
|
||||||
|
public static bool AcceptsOrder(this Actor self, string orderString)
|
||||||
|
{
|
||||||
|
var r = self.TraitOrDefault<RejectsOrders>();
|
||||||
|
return r == null || r.Except.Contains(orderString);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,7 +8,6 @@
|
|||||||
*/
|
*/
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using OpenRA.Network;
|
using OpenRA.Network;
|
||||||
|
|
||||||
namespace OpenRA.Traits
|
namespace OpenRA.Traits
|
||||||
@@ -40,7 +39,7 @@ namespace OpenRA.Traits
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return order.Subject.AcceptsOrder(order.OrderString);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -166,6 +166,7 @@ C17:
|
|||||||
-TargetableUnit:
|
-TargetableUnit:
|
||||||
-GainsExperience:
|
-GainsExperience:
|
||||||
FlyAwayOnIdle:
|
FlyAwayOnIdle:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
A10:
|
A10:
|
||||||
Inherits: ^Plane
|
Inherits: ^Plane
|
||||||
@@ -194,6 +195,7 @@ A10:
|
|||||||
-Selectable:
|
-Selectable:
|
||||||
-GainsExperience:
|
-GainsExperience:
|
||||||
FlyAwayOnIdle:
|
FlyAwayOnIdle:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
TRAN.Husk:
|
TRAN.Husk:
|
||||||
Inherits: ^HelicopterHusk
|
Inherits: ^HelicopterHusk
|
||||||
|
|||||||
@@ -29,6 +29,7 @@ BOAT:
|
|||||||
AutoTarget:
|
AutoTarget:
|
||||||
AllowMovement: false
|
AllowMovement: false
|
||||||
WithSmoke:
|
WithSmoke:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
LST:
|
LST:
|
||||||
Inherits: ^Ship
|
Inherits: ^Ship
|
||||||
@@ -68,4 +69,4 @@ LST:
|
|||||||
PipCount: 5
|
PipCount: 5
|
||||||
AttackMove:
|
AttackMove:
|
||||||
JustMove: true
|
JustMove: true
|
||||||
|
RejectsOrders:
|
||||||
|
|||||||
@@ -60,6 +60,7 @@ FRIGATE:
|
|||||||
-Selectable:
|
-Selectable:
|
||||||
-GainsExperience:
|
-GainsExperience:
|
||||||
FlyAwayOnIdle:
|
FlyAwayOnIdle:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
ORNI:
|
ORNI:
|
||||||
Inherits: ^Helicopter
|
Inherits: ^Helicopter
|
||||||
@@ -120,6 +121,7 @@ ORNI.bomber:
|
|||||||
Name: Ornithopter
|
Name: Ornithopter
|
||||||
LeavesHusk:
|
LeavesHusk:
|
||||||
HuskActor: ORNI.bomber.Husk
|
HuskActor: ORNI.bomber.Husk
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
CARRYALL.infantry:
|
CARRYALL.infantry:
|
||||||
ParaDrop:
|
ParaDrop:
|
||||||
@@ -149,6 +151,7 @@ CARRYALL.infantry:
|
|||||||
Name: Carryall
|
Name: Carryall
|
||||||
LeavesHusk:
|
LeavesHusk:
|
||||||
HuskActor: CARRYALL.infantry.Husk
|
HuskActor: CARRYALL.infantry.Husk
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
BADR:
|
BADR:
|
||||||
Inherits: CARRYALL.infantry
|
Inherits: CARRYALL.infantry
|
||||||
|
|||||||
@@ -33,6 +33,7 @@ BADR:
|
|||||||
Interval: 2
|
Interval: 2
|
||||||
-EjectOnDeath:
|
-EjectOnDeath:
|
||||||
-GpsDot:
|
-GpsDot:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
BADR.Bomber:
|
BADR.Bomber:
|
||||||
CarpetBomb:
|
CarpetBomb:
|
||||||
@@ -70,6 +71,7 @@ BADR.Bomber:
|
|||||||
Interval: 2
|
Interval: 2
|
||||||
-EjectOnDeath:
|
-EjectOnDeath:
|
||||||
-GpsDot:
|
-GpsDot:
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
MIG:
|
MIG:
|
||||||
Inherits: ^Plane
|
Inherits: ^Plane
|
||||||
@@ -341,6 +343,7 @@ U2:
|
|||||||
SmokeTrailWhenDamaged:
|
SmokeTrailWhenDamaged:
|
||||||
Offset: -1c43,0,0
|
Offset: -1c43,0,0
|
||||||
Interval: 2
|
Interval: 2
|
||||||
|
RejectsOrders:
|
||||||
|
|
||||||
BADR.Husk:
|
BADR.Husk:
|
||||||
Inherits: ^PlaneHusk
|
Inherits: ^PlaneHusk
|
||||||
|
|||||||
Reference in New Issue
Block a user