mirror of
https://github.com/amerkoleci/Vortice.Win32.git
synced 2026-01-14 16:16:04 +08:00
More generated and prettier name
This commit is contained in:
@@ -51,7 +51,7 @@ public class ApiType
|
||||
public bool Flags { get; set; }
|
||||
public bool Scoped { get; set; }
|
||||
public string IntegerBase { get; set; }
|
||||
public ApiEnumValue[] Values { get; set; }
|
||||
public IList<ApiEnumValue> Values { get; set; } = new List<ApiEnumValue>();
|
||||
|
||||
// Struct
|
||||
public int Size { get; set; }
|
||||
|
||||
@@ -3,7 +3,6 @@
|
||||
|
||||
using System.Text;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Linq;
|
||||
|
||||
namespace Generator;
|
||||
|
||||
@@ -58,11 +57,23 @@ public static class Program
|
||||
{ "DXGI_RECLAIM_RESOURCE_RESULTS", "DXGI_RECLAIM_RESOURCE_RESULT" },
|
||||
{ "DXGI_HARDWARE_COMPOSITION_SUPPORT_FLAGS", "DXGI_HARDWARE_COMPOSITION_SUPPORT_FLAG" },
|
||||
{ "DXGI_DEBUG_RLO_FLAGS", "DXGI_DEBUG_RLO" },
|
||||
{ "DXGI_OFFER_RESOURCE_FLAGS", "DXGI_OFFER_RESOURCE_FLAG" },
|
||||
};
|
||||
|
||||
private static readonly Dictionary<string, string> s_knownEnumValueNames = new()
|
||||
{
|
||||
{ "DXGI_FORMAT_420_OPAQUE", "Opaque420" }
|
||||
{ "DXGI_FORMAT_420_OPAQUE", "Opaque420" },
|
||||
{ "DXGI_OUTDUPL_COMPOSITED_UI_CAPTURE_ONLY", "CompositedUICaptureOnly" },
|
||||
};
|
||||
|
||||
private static readonly Dictionary<string, bool> s_generatedEnums = new()
|
||||
{
|
||||
{"DXGI_CPU_ACCESS", false },
|
||||
{"DXGI_USAGE", true },
|
||||
{"DXGI_MAP", true },
|
||||
{"DXGI_PRESENT", true },
|
||||
{"DXGI_MWA", true },
|
||||
{"DXGI_ENUM_MODES", true },
|
||||
};
|
||||
|
||||
private static readonly HashSet<string> s_ignoredParts = new(StringComparer.OrdinalIgnoreCase)
|
||||
@@ -81,7 +92,12 @@ public static class Program
|
||||
{
|
||||
{ "DXGI_ADAPTER_FLAG", "AdapterFlags" },
|
||||
{ "DXGI_ADAPTER_FLAG3", "AdapterFlags3" },
|
||||
{ "DXGI_SWAP_CHAIN_FLAG", "SwapChainFlags" }
|
||||
{ "DXGI_SWAP_CHAIN_FLAG", "SwapChainFlags" },
|
||||
|
||||
// Generated
|
||||
{ "DXGI_MAP", "MapFlags" },
|
||||
{ "DXGI_ENUM_MODES", "EnumModesFlags" },
|
||||
{ "DXGI_MWA", "WindowAssociationFlags" },
|
||||
};
|
||||
|
||||
private static readonly Dictionary<string, string> s_structFieldTypeRemap = new()
|
||||
@@ -94,6 +110,8 @@ public static class Program
|
||||
{ "DXGI_SWAP_CHAIN_DESC1::Flags", "DXGI_SWAP_CHAIN_FLAG" },
|
||||
};
|
||||
|
||||
private static bool s_generateUnmanagedDocs = true;
|
||||
|
||||
public static int Main(string[] args)
|
||||
{
|
||||
string outputPath = AppContext.BaseDirectory;
|
||||
@@ -165,6 +183,19 @@ public static class Program
|
||||
if (ShouldSkipConstant(constant))
|
||||
continue;
|
||||
|
||||
bool skipValue = false;
|
||||
foreach (var enumToGenerate in s_generatedEnums)
|
||||
{
|
||||
if (constant.Name.StartsWith(enumToGenerate.Key))
|
||||
{
|
||||
skipValue = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (skipValue)
|
||||
continue;
|
||||
|
||||
string typeName = GetTypeName(constant.Type);
|
||||
if (typeName == "Guid")
|
||||
{
|
||||
@@ -193,6 +224,59 @@ public static class Program
|
||||
writer.WriteLine($"#endregion Enums");
|
||||
writer.WriteLine();
|
||||
|
||||
// Generated enums -> from constants
|
||||
writer.WriteLine($"#region Generated Enums");
|
||||
var createdEnums = new Dictionary<string, ApiType>();
|
||||
|
||||
foreach (var constant in api.Constants)
|
||||
{
|
||||
if (ShouldSkipConstant(constant))
|
||||
continue;
|
||||
|
||||
foreach (var enumToGenerate in s_generatedEnums)
|
||||
{
|
||||
if (constant.Name.StartsWith(enumToGenerate.Key))
|
||||
{
|
||||
ApiType createdEnumType;
|
||||
if (!createdEnums.ContainsKey(enumToGenerate.Key))
|
||||
{
|
||||
ApiType apiType = new()
|
||||
{
|
||||
Name = enumToGenerate.Key,
|
||||
Kind = "Enum",
|
||||
Flags = enumToGenerate.Value,
|
||||
Scoped = false,
|
||||
IntegerBase = constant.Type.Name
|
||||
};
|
||||
createdEnums.Add(enumToGenerate.Key, apiType);
|
||||
createdEnumType = apiType;
|
||||
}
|
||||
else
|
||||
{
|
||||
createdEnumType = createdEnums[enumToGenerate.Key];
|
||||
}
|
||||
|
||||
ApiEnumValue enumValue = new ApiEnumValue
|
||||
{
|
||||
Name = constant.Name,
|
||||
Value = constant.Value
|
||||
};
|
||||
createdEnumType.Values.Add(enumValue);
|
||||
|
||||
//string enumValueName = GetPrettyFieldName(constant.Name, createdEnumName);
|
||||
//writer.WriteLine($"{enumValueName} = {constant.Value},");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
foreach (ApiType enumType in createdEnums.Values)
|
||||
{
|
||||
GenerateEnum(writer, enumType);
|
||||
}
|
||||
|
||||
writer.WriteLine($"#endregion Generated Enums");
|
||||
writer.WriteLine();
|
||||
|
||||
writer.WriteLine($"#region Structs");
|
||||
foreach (ApiType structType in api.Types.Where(item => item.Kind.ToLowerInvariant() == "struct"))
|
||||
{
|
||||
@@ -208,14 +292,24 @@ public static class Program
|
||||
string baseTypeName = GetTypeName(enumType.IntegerBase);
|
||||
AddCsMapping(writer.Api, enumType.Name, csTypeName);
|
||||
|
||||
writer.WriteLine($"/// <unmanaged>{enumType.Name}</unmanaged>");
|
||||
if (s_generateUnmanagedDocs)
|
||||
writer.WriteLine($"/// <unmanaged>{enumType.Name}</unmanaged>");
|
||||
|
||||
if (enumType.Flags)
|
||||
{
|
||||
writer.WriteLine("[Flags]");
|
||||
}
|
||||
|
||||
bool noneAdded = false;
|
||||
using (writer.PushBlock($"public enum {csTypeName} : {baseTypeName}"))
|
||||
{
|
||||
if (enumType.Flags &&
|
||||
!enumType.Values.Any(item => GetPrettyFieldName(item.Name, enumPrefix) == "None"))
|
||||
{
|
||||
writer.WriteLine("None = 0,");
|
||||
noneAdded = true;
|
||||
}
|
||||
|
||||
foreach (ApiEnumValue value in enumType.Values)
|
||||
{
|
||||
if (value.Name.EndsWith("_FORCE_DWORD") ||
|
||||
@@ -223,7 +317,16 @@ public static class Program
|
||||
continue;
|
||||
|
||||
string enumValueName = GetPrettyFieldName(value.Name, enumPrefix);
|
||||
writer.WriteLine($"/// <unmanaged>{value.Name}</unmanaged>");
|
||||
if (s_generateUnmanagedDocs)
|
||||
{
|
||||
writer.WriteLine($"/// <unmanaged>{value.Name}</unmanaged>");
|
||||
}
|
||||
|
||||
if (enumValueName.StartsWith("DXGI_MSG_"))
|
||||
{
|
||||
enumValueName = enumValueName.Substring("DXGI_MSG_".Length);
|
||||
}
|
||||
|
||||
writer.WriteLine($"{enumValueName} = {value.Value},");
|
||||
}
|
||||
}
|
||||
@@ -236,7 +339,11 @@ public static class Program
|
||||
string csTypeName = GetDataTypeName(structType.Name, out string structPrefix);
|
||||
AddCsMapping(writer.Api, structType.Name, csTypeName);
|
||||
|
||||
writer.WriteLine($"/// <unmanaged>{structType.Name}</unmanaged>");
|
||||
if (s_generateUnmanagedDocs)
|
||||
{
|
||||
writer.WriteLine($"/// <unmanaged>{structType.Name}</unmanaged>");
|
||||
}
|
||||
|
||||
using (writer.PushBlock($"public partial struct {csTypeName}"))
|
||||
{
|
||||
foreach (ApiStructField field in structType.Fields)
|
||||
@@ -246,7 +353,10 @@ public static class Program
|
||||
|
||||
string fieldValueName = GetPrettyFieldName(field.Name, structPrefix);
|
||||
string fieldTypeName = GetTypeName(field.Type);
|
||||
//writer.WriteLine($"/// <unmanaged>{field.Name}</unmanaged>");
|
||||
if (s_generateUnmanagedDocs)
|
||||
{
|
||||
//writer.WriteLine($"/// <unmanaged>{field.Name}</unmanaged>");
|
||||
}
|
||||
|
||||
string remapFieldLookUp = $"{structType.Name}::{field.Name}";
|
||||
if (s_structFieldTypeRemap.TryGetValue(remapFieldLookUp, out string? remapType))
|
||||
@@ -321,7 +431,8 @@ public static class Program
|
||||
|
||||
private static bool ShouldSkipConstant(ApiDataConstant constant)
|
||||
{
|
||||
if (constant.Name == "_FACDXGI")
|
||||
if (constant.Name == "_FACDXGI" ||
|
||||
constant.Name == "DXGI_FORMAT_DEFINED")
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -19,12 +19,6 @@ namespace Win32.Graphics.Dxgi.Common;
|
||||
|
||||
public static partial class Apis
|
||||
{
|
||||
public const uint DXGI_CPU_ACCESS_NONE = 0;
|
||||
public const uint DXGI_CPU_ACCESS_DYNAMIC = 1;
|
||||
public const uint DXGI_CPU_ACCESS_READ_WRITE = 2;
|
||||
public const uint DXGI_CPU_ACCESS_SCRATCH = 3;
|
||||
public const uint DXGI_CPU_ACCESS_FIELD = 15;
|
||||
public const uint DXGI_FORMAT_DEFINED = 1;
|
||||
public const uint DXGI_STANDARD_MULTISAMPLE_QUALITY_PATTERN = 4294967295;
|
||||
public const uint DXGI_CENTER_MULTISAMPLE_QUALITY_PATTERN = 4294967294;
|
||||
}
|
||||
@@ -388,6 +382,24 @@ public enum AlphaMode : uint
|
||||
|
||||
#endregion Enums
|
||||
|
||||
#region Generated Enums
|
||||
/// <unmanaged>DXGI_CPU_ACCESS</unmanaged>
|
||||
public enum CpuAccess : uint
|
||||
{
|
||||
/// <unmanaged>DXGI_CPU_ACCESS_NONE</unmanaged>
|
||||
None = 0,
|
||||
/// <unmanaged>DXGI_CPU_ACCESS_DYNAMIC</unmanaged>
|
||||
Dynamic = 1,
|
||||
/// <unmanaged>DXGI_CPU_ACCESS_READ_WRITE</unmanaged>
|
||||
ReadWrite = 2,
|
||||
/// <unmanaged>DXGI_CPU_ACCESS_SCRATCH</unmanaged>
|
||||
Scratch = 3,
|
||||
/// <unmanaged>DXGI_CPU_ACCESS_FIELD</unmanaged>
|
||||
Field = 15,
|
||||
}
|
||||
|
||||
#endregion Generated Enums
|
||||
|
||||
#region Structs
|
||||
/// <unmanaged>DXGI_RATIONAL</unmanaged>
|
||||
public partial struct Rational
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -4,23 +4,3 @@
|
||||
using static Win32.Graphics.Dxgi.Apis;
|
||||
|
||||
namespace Win32.Graphics.Dxgi;
|
||||
|
||||
[Flags]
|
||||
public enum Usage : uint
|
||||
{
|
||||
ShaderInput = DXGI_USAGE_SHADER_INPUT,
|
||||
RenderTargetOutput = DXGI_USAGE_RENDER_TARGET_OUTPUT,
|
||||
Backbuffer = DXGI_USAGE_BACK_BUFFER,
|
||||
Shared = DXGI_USAGE_SHARED,
|
||||
ReadOnly = DXGI_USAGE_READ_ONLY,
|
||||
DiscardOnPresent = DXGI_USAGE_DISCARD_ON_PRESENT,
|
||||
UnorderedAccess = DXGI_USAGE_UNORDERED_ACCESS
|
||||
}
|
||||
|
||||
[Flags]
|
||||
public enum MapFlags : uint
|
||||
{
|
||||
Read = DXGI_MAP_READ,
|
||||
Write = DXGI_MAP_WRITE,
|
||||
Discard = DXGI_MAP_DISCARD
|
||||
}
|
||||
|
||||
@@ -16,20 +16,20 @@ public readonly struct Luid : IEquatable<Luid>
|
||||
/// <summary>
|
||||
/// The low bits of the luid.
|
||||
/// </summary>
|
||||
private readonly uint lowPart;
|
||||
private readonly uint _lowPart;
|
||||
|
||||
/// <summary>
|
||||
/// The high bits of the luid.
|
||||
/// </summary>
|
||||
private readonly int highPart;
|
||||
private readonly int _highPart;
|
||||
|
||||
/// <inheritdoc/>
|
||||
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
||||
public bool Equals(Luid other)
|
||||
{
|
||||
return
|
||||
this.lowPart == other.lowPart &&
|
||||
this.highPart == other.highPart;
|
||||
_lowPart == other._lowPart &&
|
||||
_highPart == other._highPart;
|
||||
}
|
||||
|
||||
/// <inheritdoc/>
|
||||
@@ -42,26 +42,26 @@ public readonly struct Luid : IEquatable<Luid>
|
||||
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
||||
public override int GetHashCode()
|
||||
{
|
||||
return HashCode.Combine(lowPart, highPart);
|
||||
return HashCode.Combine(_lowPart, _highPart);
|
||||
}
|
||||
|
||||
/// <inheritdoc/>
|
||||
public override string ToString()
|
||||
{
|
||||
return (((long)this.highPart) << 32 | this.lowPart).ToString();
|
||||
return (((long)this._highPart) << 32 | this._lowPart).ToString();
|
||||
}
|
||||
|
||||
#if NET6_0_OR_GREATER
|
||||
/// <inheritdoc/>
|
||||
public string ToString(string? format, IFormatProvider? formatProvider)
|
||||
{
|
||||
return (((long)this.highPart) << 32 | this.lowPart).ToString(format, formatProvider);
|
||||
return (((long)_highPart) << 32 | _lowPart).ToString(format, formatProvider);
|
||||
}
|
||||
|
||||
/// <inheritdoc/>
|
||||
public bool TryFormat(Span<char> destination, out int charsWritten, ReadOnlySpan<char> format, IFormatProvider? provider)
|
||||
{
|
||||
return (((long)this.highPart) << 32 | this.lowPart).TryFormat(destination, out charsWritten, format, provider);
|
||||
return (((long)_highPart) << 32 | _lowPart).TryFormat(destination, out charsWritten, format, provider);
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -72,10 +72,7 @@ public readonly struct Luid : IEquatable<Luid>
|
||||
/// <param name="b">The second <see cref="Luid"/> value to compare.</param>
|
||||
/// <returns>Whether <paramref name="a"/> and <paramref name="b"/> are the same.</returns>
|
||||
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
||||
public static bool operator ==(Luid a, Luid b)
|
||||
{
|
||||
return a.Equals(b);
|
||||
}
|
||||
public static bool operator ==(Luid a, Luid b) => a.Equals(b);
|
||||
|
||||
/// <summary>
|
||||
/// Check whether two <see cref="Luid"/> values are different.
|
||||
@@ -84,8 +81,5 @@ public readonly struct Luid : IEquatable<Luid>
|
||||
/// <param name="b">The second <see cref="Luid"/> value to compare.</param>
|
||||
/// <returns>Whether <paramref name="a"/> and <paramref name="b"/> are different.</returns>
|
||||
[MethodImpl(MethodImplOptions.AggressiveInlining)]
|
||||
public static bool operator !=(Luid a, Luid b)
|
||||
{
|
||||
return !a.Equals(b);
|
||||
}
|
||||
public static bool operator !=(Luid a, Luid b) => !a.Equals(b);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user