ralint: verify voices, support (and still verify) @-form prerequisites.
This commit is contained in:
@@ -21,7 +21,6 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using OpenRA.FileFormats;
|
||||
using OpenRA.Support;
|
||||
using OpenRA.Traits;
|
||||
using Tao.OpenAl;
|
||||
|
||||
|
||||
@@ -30,9 +30,9 @@ namespace OpenRA.Traits
|
||||
public virtual object Create(ActorInitializer init) { return new Valued(); }
|
||||
}
|
||||
|
||||
class BuildableInfo : ValuedInfo
|
||||
public class BuildableInfo : ValuedInfo
|
||||
{
|
||||
public readonly string[] Prerequisites = { };
|
||||
[ActorReference]public readonly string[] Prerequisites = { };
|
||||
[ActorReference] public readonly string[] BuiltAt = { };
|
||||
|
||||
public readonly string Icon = null;
|
||||
|
||||
@@ -1,7 +1,4 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
|
||||
namespace OpenRA.Traits
|
||||
{
|
||||
@@ -12,4 +9,7 @@ namespace OpenRA.Traits
|
||||
|
||||
[AttributeUsage(AttributeTargets.Field)]
|
||||
public class WeaponReferenceAttribute : Attribute { }
|
||||
|
||||
[AttributeUsage(AttributeTargets.Field)]
|
||||
public class VoiceReferenceAttribute : Attribute { }
|
||||
}
|
||||
|
||||
@@ -24,6 +24,7 @@ namespace OpenRA.Traits
|
||||
{
|
||||
public readonly int Priority = 10;
|
||||
public readonly int[] Bounds = null;
|
||||
[VoiceReference]
|
||||
public readonly string Voice = null;
|
||||
public readonly float Radius = 10;
|
||||
}
|
||||
|
||||
@@ -30,6 +30,7 @@ namespace OpenRA.Traits
|
||||
public readonly string Image = null;
|
||||
public readonly string Description = "";
|
||||
public readonly string LongDesc = "";
|
||||
[ActorReference]
|
||||
public readonly string[] Prerequisites = { };
|
||||
public readonly int TechLevel = -1;
|
||||
public readonly bool GivenAuto = true;
|
||||
|
||||
@@ -24,6 +24,7 @@ namespace OpenRA.Traits
|
||||
{
|
||||
class TransformsOnDeployInfo : TraitInfo<TransformsOnDeploy>
|
||||
{
|
||||
[ActorReference]
|
||||
public readonly string TransformsInto = null;
|
||||
public readonly int[] Offset = null;
|
||||
public readonly int[] DeployDirections = new int[] {96};
|
||||
|
||||
@@ -18,9 +18,7 @@
|
||||
*/
|
||||
#endregion
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics;
|
||||
using System.Linq;
|
||||
using OpenRA.FileFormats;
|
||||
|
||||
@@ -34,7 +32,6 @@ namespace OpenRA.Traits
|
||||
public class HazardLayer : ITerrainCost
|
||||
{
|
||||
List<Pair<Actor, Hazard>>[,] hazards;
|
||||
Map map;
|
||||
|
||||
public HazardLayer( World world )
|
||||
{
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Reflection;
|
||||
using System.Linq;
|
||||
using OpenRA;
|
||||
using OpenRA.FileFormats;
|
||||
using OpenRA.GameRules;
|
||||
@@ -8,7 +9,7 @@ using OpenRA.Traits;
|
||||
|
||||
namespace RALint
|
||||
{
|
||||
static class Program
|
||||
static class RALint
|
||||
{
|
||||
/* todo: move this into the engine? dpstool, seqed, editor, etc all need it (or something similar) */
|
||||
static void InitializeEngineWithMods(string[] mods)
|
||||
@@ -32,10 +33,18 @@ namespace RALint
|
||||
++errors;
|
||||
}
|
||||
|
||||
static Dictionary<string, int> ValidPrereqs;
|
||||
|
||||
static int Main(string[] args)
|
||||
{
|
||||
InitializeEngineWithMods(args);
|
||||
|
||||
// all the @something names which actually EXIST.
|
||||
var psuedoPrereqs = Rules.Info.Values.Select(a => a.Traits.GetOrDefault<BuildableInfo>()).Where(b => b != null)
|
||||
.Select(b => b.AlternateName).Where(n => n != null).SelectMany(a => a).Select(a => a.ToLowerInvariant()).Distinct();
|
||||
|
||||
ValidPrereqs = Rules.Info.Keys.Concat(psuedoPrereqs).ToDictionary(a => a, a => 0);
|
||||
|
||||
foreach (var actorInfo in Rules.Info)
|
||||
foreach (var traitInfo in actorInfo.Value.Traits.WithInterface<ITraitInfo>())
|
||||
CheckTrait(actorInfo.Value, traitInfo);
|
||||
@@ -55,9 +64,11 @@ namespace RALint
|
||||
foreach (var field in actualType.GetFields())
|
||||
{
|
||||
if (field.HasAttribute<ActorReferenceAttribute>())
|
||||
CheckReference(actorInfo, traitInfo, field, Rules.Info, "actor");
|
||||
CheckReference(actorInfo, traitInfo, field, ValidPrereqs, "actor");
|
||||
if (field.HasAttribute<WeaponReferenceAttribute>())
|
||||
CheckReference(actorInfo, traitInfo, field, Rules.Weapons, "weapon");
|
||||
if (field.HasAttribute<VoiceReferenceAttribute>())
|
||||
CheckReference(actorInfo, traitInfo, field, Rules.Voices, "voice");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -47,7 +47,7 @@
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="Program.cs" />
|
||||
<Compile Include="RALint.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
|
||||
Reference in New Issue
Block a user