Callback structs implement Steamworks.ISteamCallback

This commit is contained in:
Garry Newman 2019-04-13 18:45:09 +01:00
parent ede67d51cd
commit cf8aa9501c
2 changed files with 4522 additions and 4505 deletions

File diff suppressed because it is too large Load Diff

View File

@ -53,15 +53,24 @@ namespace Generator
if ( c.Fields.Any( x => x.Type.Contains( "class CSteamID" ) ) && !ForceLargePackStructs.Contains( c.Name ) ) if ( c.Fields.Any( x => x.Type.Contains( "class CSteamID" ) ) && !ForceLargePackStructs.Contains( c.Name ) )
defaultPack = 4; defaultPack = 4;
var isCallback = !string.IsNullOrEmpty( c.CallbackId );
// //
// Main struct // Main struct
// //
WriteLine( $"[StructLayout( LayoutKind.Sequential, Pack = {defaultPack} )]" ); StartBlock( $"public struct {c.Name}{(isCallback?" : Steamworks.ISteamCallback":"")}" );
StartBlock( $"public struct {c.Name}" );
{ {
if ( !string.IsNullOrEmpty( c.CallbackId ) ) if ( isCallback )
{ {
WriteLine( "internal const int CallbackId = " + c.CallbackId + ";" ); WriteLine( "internal const int CallbackId = " + c.CallbackId + ";" );
WriteLine( "public int GetCallbackId() => CallbackId;" );
WriteLine( "public int GetStructSize() => StructSize();" );
StartBlock( "public Steamworks.ISteamCallback Fill( IntPtr p, int size)" );
{
WriteLine( "return FromPointer( p ); // TODO - USE SIZE HERE SOMEHOW" );
}
EndBlock();
} }
// //
@ -73,13 +82,10 @@ namespace Generator
WriteLine( "//" ); WriteLine( "//" );
WriteLine( "// Read this struct from a pointer, usually from Native. It will automatically do the awesome stuff." ); WriteLine( "// Read this struct from a pointer, usually from Native. It will automatically do the awesome stuff." );
WriteLine( "//" ); WriteLine( "//" );
StartBlock( $"internal static {c.Name} FromPointer( IntPtr p )" ); WriteLine( $"internal static {c.Name} FromPointer( IntPtr p ) => " );
{ {
WriteLine( $"if ( Platform.PackSmall ) return (PackSmall) Marshal.PtrToStructure( p, typeof(PackSmall) );" ); WriteLine( $" Platform.PackSmall ? (({c.Name})(Pack4) Marshal.PtrToStructure( p, typeof(Pack4) )) : (({c.Name})(Pack8) Marshal.PtrToStructure( p, typeof(Pack8) ));" );
WriteLine( $"return ({c.Name}) Marshal.PtrToStructure( p, typeof({c.Name}) );" );
} }
EndBlock();
WriteLine(); WriteLine();
WriteLine( "//" ); WriteLine( "//" );
@ -87,21 +93,19 @@ namespace Generator
WriteLine( "//" ); WriteLine( "//" );
StartBlock( $"internal static int StructSize()" ); StartBlock( $"internal static int StructSize()" );
{ {
WriteLine( $"if ( Platform.PackSmall ) return System.Runtime.InteropServices.Marshal.SizeOf( typeof(PackSmall) );" ); WriteLine( $"return System.Runtime.InteropServices.Marshal.SizeOf( Platform.PackSmall ? typeof(Pack4) : typeof(Pack8) );" );
WriteLine( $"return System.Runtime.InteropServices.Marshal.SizeOf( typeof({c.Name}) );" );
} }
EndBlock(); EndBlock();
if ( defaultPack == 8 ) // if ( defaultPack == 8 )
defaultPack = 4; // defaultPack = 4;
// //
// Small packed struct (for osx, linux) // Small packed struct (for osx, linux)
// //
WriteLine(); WriteLine();
WriteLine( $"[StructLayout( LayoutKind.Sequential, Pack = {defaultPack} )]" ); WriteLine( $"[StructLayout( LayoutKind.Sequential, Pack = 4 )]" );
StartBlock( $"public struct PackSmall" ); StartBlock( $"public struct Pack4" );
{ {
StructFields( c.Fields ); StructFields( c.Fields );
@ -109,22 +113,46 @@ namespace Generator
// Implicit convert from PackSmall to regular // Implicit convert from PackSmall to regular
// //
WriteLine(); WriteLine();
WriteLine( "//" ); Write( $"public static implicit operator {c.Name} ( {c.Name}.Pack4 d ) => " );
WriteLine( $"// Easily convert from PackSmall to {c.Name}" );
WriteLine( "//" );
StartBlock( $"public static implicit operator {c.Name} ( {c.Name}.PackSmall d )" );
{ {
StartBlock( $"return new {c.Name}()" ); Write( $"new {c.Name}{{ " );
{ {
foreach ( var f in c.Fields ) foreach ( var f in c.Fields )
{ {
WriteLine( $"{CleanMemberName( f.Name )} = d.{CleanMemberName( f.Name )}," ); Write( $"{CleanMemberName( f.Name )} = d.{CleanMemberName( f.Name )}," );
} }
} }
EndBlock( ";" ); WriteLine( " };" );
}
} }
EndBlock(); EndBlock();
//
// Small packed struct (for osx, linux)
//
WriteLine();
WriteLine( $"[StructLayout( LayoutKind.Sequential, Pack = {defaultPack} )]" );
StartBlock( $"public struct Pack8" );
{
StructFields( c.Fields );
//
// Implicit convert from PackSmall to regular
//
WriteLine();
Write( $"public static implicit operator {c.Name} ( {c.Name}.Pack8 d ) => " );
{
Write( $"new {c.Name}{{ " );
{
foreach ( var f in c.Fields )
{
Write( $"{CleanMemberName( f.Name )} = d.{CleanMemberName( f.Name )}," );
}
}
WriteLine( " };" );
}
} }
EndBlock(); EndBlock();
@ -182,8 +210,8 @@ namespace Generator
if ( t.StartsWith( "uint8 " ) && t.Contains( "[" ) ) if ( t.StartsWith( "uint8 " ) && t.Contains( "[" ) )
{ {
var num = t.Replace( "uint8", "" ).Trim( '[', ']', ' ' ); var num = t.Replace( "uint8", "" ).Trim( '[', ']', ' ' );
t = "char"; t = "byte[]";
WriteLine( $"[MarshalAs(UnmanagedType.ByValTStr, SizeConst = {num})]" ); WriteLine( $"[MarshalAs(UnmanagedType.ByValArray, SizeConst = {num})] // {m.Name}" );
} }
if ( t.StartsWith( "CSteamID " ) && t.Contains( "[" ) ) if ( t.StartsWith( "CSteamID " ) && t.Contains( "[" ) )