mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-26 13:38:06 +03:00
Callback structs implement Steamworks.ISteamCallback
This commit is contained in:
parent
ede67d51cd
commit
cf8aa9501c
File diff suppressed because it is too large
Load Diff
@ -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( "[" ) )
|
||||||
|
Loading…
x
Reference in New Issue
Block a user