mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-26 13:38:06 +03:00
Unity Win32 callback fixes
This commit is contained in:
parent
d7808bf424
commit
b7727a10e1
@ -16,16 +16,29 @@ namespace Facepunch.Steamworks
|
|||||||
//
|
//
|
||||||
// Windows Config
|
// Windows Config
|
||||||
//
|
//
|
||||||
if ( platform == "WindowsEditor" || platform == "Windows" )
|
if ( platform == "WindowsEditor" || platform == "WindowsPlayer" )
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// 32bit windows unity uses a stdcall
|
// 32bit windows unity uses a stdcall
|
||||||
//
|
//
|
||||||
if ( IntPtr.Size == 4 ) UseThisCall = false;
|
if ( IntPtr.Size == 4 ) UseThisCall = false;
|
||||||
|
|
||||||
ForcePlatform( OperatingSystem.Windows, IntPtr.Size == 4 ? Architecture.x86 : Architecture.x64 );
|
ForcePlatform( OperatingSystem.Windows, IntPtr.Size == 4 ? Architecture.x86 : Architecture.x64 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( platform == "OSXEditor" || platform == "OSXPlayer" || platform == "OSXDashboardPlayer" )
|
||||||
|
{
|
||||||
|
ForcePlatform( OperatingSystem.Osx, IntPtr.Size == 4 ? Architecture.x86 : Architecture.x64 );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( platform == "LinuxPlayer" || platform == "LinuxEditor" )
|
||||||
|
{
|
||||||
|
ForcePlatform( OperatingSystem.Linux, IntPtr.Size == 4 ? Architecture.x86 : Architecture.x64 );
|
||||||
|
}
|
||||||
|
|
||||||
|
Console.WriteLine( "Facepunch.Steamworks Unity: " + platform );
|
||||||
|
Console.WriteLine( "Facepunch.Steamworks Os: " + SteamNative.Platform.Os );
|
||||||
|
Console.WriteLine( "Facepunch.Steamworks Arch: " + SteamNative.Platform.Arch );
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -30,9 +30,16 @@ namespace SteamNative
|
|||||||
//
|
//
|
||||||
internal class ThisCall
|
internal class ThisCall
|
||||||
{
|
{
|
||||||
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate void Result( IntPtr thisptr, IntPtr pvParam );
|
[UnmanagedFunctionPointer( CallingConvention.ThisCall )] public delegate void Result( IntPtr thisptr, IntPtr pvParam );
|
||||||
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate void ResultWithInfo( IntPtr thisptr, IntPtr pvParam, bool bIOFailure, SteamNative.SteamAPICall_t hSteamAPICall );
|
[UnmanagedFunctionPointer( CallingConvention.ThisCall )] public delegate void ResultWithInfo( IntPtr thisptr, IntPtr pvParam, bool bIOFailure, SteamNative.SteamAPICall_t hSteamAPICall );
|
||||||
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate int GetSize( IntPtr thisptr );
|
[UnmanagedFunctionPointer( CallingConvention.ThisCall )] public delegate int GetSize( IntPtr thisptr );
|
||||||
|
}
|
||||||
|
|
||||||
|
internal class StdCall
|
||||||
|
{
|
||||||
|
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate void Result( IntPtr pvParam );
|
||||||
|
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate void ResultWithInfo( IntPtr pvParam, bool bIOFailure, SteamNative.SteamAPICall_t hSteamAPICall );
|
||||||
|
[UnmanagedFunctionPointer( CallingConvention.StdCall )] public delegate int GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ namespace SteamNative
|
|||||||
internal class Linux32 : Interface
|
internal class Linux32 : Interface
|
||||||
{
|
{
|
||||||
internal IntPtr _ptr;
|
internal IntPtr _ptr;
|
||||||
public bool IsValid { get{ return _ptr != null; } }
|
public bool IsValid { get{ return _ptr != IntPtr.Zero; } }
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor sets pointer to native class
|
// Constructor sets pointer to native class
|
||||||
|
@ -8,7 +8,7 @@ namespace SteamNative
|
|||||||
internal class Linux64 : Interface
|
internal class Linux64 : Interface
|
||||||
{
|
{
|
||||||
internal IntPtr _ptr;
|
internal IntPtr _ptr;
|
||||||
public bool IsValid { get{ return _ptr != null; } }
|
public bool IsValid { get{ return _ptr != IntPtr.Zero; } }
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor sets pointer to native class
|
// Constructor sets pointer to native class
|
||||||
|
@ -8,7 +8,7 @@ namespace SteamNative
|
|||||||
internal class Mac : Interface
|
internal class Mac : Interface
|
||||||
{
|
{
|
||||||
internal IntPtr _ptr;
|
internal IntPtr _ptr;
|
||||||
public bool IsValid { get{ return _ptr != null; } }
|
public bool IsValid { get{ return _ptr != IntPtr.Zero; } }
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor sets pointer to native class
|
// Constructor sets pointer to native class
|
||||||
|
@ -8,7 +8,7 @@ namespace SteamNative
|
|||||||
internal class Win32 : Interface
|
internal class Win32 : Interface
|
||||||
{
|
{
|
||||||
internal IntPtr _ptr;
|
internal IntPtr _ptr;
|
||||||
public bool IsValid { get{ return _ptr != null; } }
|
public bool IsValid { get{ return _ptr != IntPtr.Zero; } }
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor sets pointer to native class
|
// Constructor sets pointer to native class
|
||||||
|
@ -8,7 +8,7 @@ namespace SteamNative
|
|||||||
internal class Win64 : Interface
|
internal class Win64 : Interface
|
||||||
{
|
{
|
||||||
internal IntPtr _ptr;
|
internal IntPtr _ptr;
|
||||||
public bool IsValid { get{ return _ptr != null; } }
|
public bool IsValid { get{ return _ptr != IntPtr.Zero; } }
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor sets pointer to native class
|
// Constructor sets pointer to native class
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -246,10 +246,40 @@ namespace Generator
|
|||||||
WriteLine( "// Create the functions we need for the vtable" );
|
WriteLine( "// Create the functions we need for the vtable" );
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
|
|
||||||
|
StartBlock( "if ( Facepunch.Steamworks.Config.UseThisCall )" );
|
||||||
|
{
|
||||||
|
CallresultFunctions( c, Result, "ThisCall", "_" );
|
||||||
|
}
|
||||||
|
Else();
|
||||||
|
{
|
||||||
|
CallresultFunctions( c, Result, "StdCall", "" );
|
||||||
|
}
|
||||||
|
EndBlock();
|
||||||
|
|
||||||
|
WriteLine( "" );
|
||||||
|
WriteLine( "//" );
|
||||||
|
WriteLine( "// Create the callback object" );
|
||||||
|
WriteLine( "//" );
|
||||||
|
WriteLine( $"var cb = new Callback();" );
|
||||||
|
WriteLine( $"cb.vTablePtr = handle.vTablePtr;" );
|
||||||
|
WriteLine( $"cb.CallbackFlags = steamworks.IsGameServer ? (byte) SteamNative.Callback.Flags.GameServer : (byte) 0;" );
|
||||||
|
WriteLine( $"cb.CallbackId = CallbackId;" );
|
||||||
|
|
||||||
|
WriteLine( "" );
|
||||||
|
WriteLine( "//" );
|
||||||
|
WriteLine( "// Pin the callback, so it doesn't get garbage collected and we can pass the pointer to native" );
|
||||||
|
WriteLine( "//" );
|
||||||
|
WriteLine( $"handle.PinnedCallback = GCHandle.Alloc( cb, GCHandleType.Pinned );" );
|
||||||
|
}
|
||||||
|
|
||||||
|
private void CallresultFunctions( SteamApiDefinition.StructDef c, bool Result, string ThisCall, string ThisArg )
|
||||||
|
{
|
||||||
|
var ThisArgC = ThisArg.Length > 0 ? $"{ThisArg}, " : "";
|
||||||
|
|
||||||
if ( Result )
|
if ( Result )
|
||||||
{
|
{
|
||||||
WriteLine( $"Callback.ThisCall.Result funcA = ( _, p ) => {{ handle.Dispose(); CallbackFunction( FromPointer( p ), false ); }};" );
|
WriteLine( $"Callback.{ThisCall}.Result funcA = ( {ThisArgC}p ) => {{ handle.Dispose(); CallbackFunction( FromPointer( p ), false ); }};" );
|
||||||
StartBlock( $"Callback.ThisCall.ResultWithInfo funcB = ( _, p, bIOFailure, hSteamAPICall ) => " );
|
StartBlock( $"Callback.{ThisCall}.ResultWithInfo funcB = ( {ThisArgC}p, bIOFailure, hSteamAPICall ) => " );
|
||||||
{
|
{
|
||||||
WriteLine( "if ( hSteamAPICall != call ) return;" );
|
WriteLine( "if ( hSteamAPICall != call ) return;" );
|
||||||
WriteLine();
|
WriteLine();
|
||||||
@ -262,18 +292,18 @@ namespace Generator
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
WriteLine( $"Callback.ThisCall.Result funcA = ( _, p ) => {{ CallbackFunction( FromPointer( p ), false ); }};" );
|
WriteLine( $"Callback.{ThisCall}.Result funcA = ( {ThisArgC}p ) => {{ CallbackFunction( FromPointer( p ), false ); }};" );
|
||||||
WriteLine( $"Callback.ThisCall.ResultWithInfo funcB = ( _, p, bIOFailure, hSteamAPICall ) => {{ CallbackFunction( FromPointer( p ), bIOFailure ); }};" );
|
WriteLine( $"Callback.{ThisCall}.ResultWithInfo funcB = ( {ThisArgC}p, bIOFailure, hSteamAPICall ) => {{ CallbackFunction( FromPointer( p ), bIOFailure ); }};" );
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteLine( $"Callback.ThisCall.GetSize funcC = ( _ ) => Marshal.SizeOf( typeof( {c.Name} ) );" );
|
WriteLine( $"Callback.{ThisCall}.GetSize funcC = ( {ThisArg} ) => Marshal.SizeOf( typeof( {c.Name} ) );" );
|
||||||
WriteLine();
|
WriteLine();
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
WriteLine( "// If this platform is PackSmall, use PackSmall versions of everything instead" );
|
WriteLine( "// If this platform is PackSmall, use PackSmall versions of everything instead" );
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
StartBlock( "if ( Platform.PackSmall )" );
|
StartBlock( "if ( Platform.PackSmall )" );
|
||||||
{
|
{
|
||||||
WriteLine( $"funcC = ( _ ) => {{ return Marshal.SizeOf( typeof( PackSmall ) ); }};" );
|
WriteLine( $"funcC = ( {ThisArg} ) => Marshal.SizeOf( typeof( PackSmall ) );" );
|
||||||
}
|
}
|
||||||
EndBlock();
|
EndBlock();
|
||||||
|
|
||||||
@ -309,21 +339,6 @@ namespace Generator
|
|||||||
EndBlock();
|
EndBlock();
|
||||||
|
|
||||||
WriteLine( "Marshal.StructureToPtr( vTable, handle.vTablePtr, false );" );
|
WriteLine( "Marshal.StructureToPtr( vTable, handle.vTablePtr, false );" );
|
||||||
|
|
||||||
WriteLine( "" );
|
|
||||||
WriteLine( "//" );
|
|
||||||
WriteLine( "// Create the callback object" );
|
|
||||||
WriteLine( "//" );
|
|
||||||
WriteLine( $"var cb = new Callback();" );
|
|
||||||
WriteLine( $"cb.vTablePtr = handle.vTablePtr;" );
|
|
||||||
WriteLine( $"cb.CallbackFlags = steamworks.IsGameServer ? (byte) SteamNative.Callback.Flags.GameServer : (byte) 0;" );
|
|
||||||
WriteLine( $"cb.CallbackId = CallbackId;" );
|
|
||||||
|
|
||||||
WriteLine( "" );
|
|
||||||
WriteLine( "//" );
|
|
||||||
WriteLine( "// Pin the callback, so it doesn't get garbage collected and we can pass the pointer to native" );
|
|
||||||
WriteLine( "//" );
|
|
||||||
WriteLine( $"handle.PinnedCallback = GCHandle.Alloc( cb, GCHandleType.Pinned );" );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user