mirror of
https://github.com/Facepunch/Facepunch.Steamworks.git
synced 2025-01-12 06:38:01 +03:00
Made SteamNative.SteamApi less hacky to initialize
This commit is contained in:
parent
5890fea9e6
commit
67fb987288
@ -36,7 +36,7 @@ namespace Facepunch.Steamworks.Interop
|
|||||||
{
|
{
|
||||||
isServer = false;
|
isServer = false;
|
||||||
|
|
||||||
api = new SteamNative.SteamApi( steamworks, (IntPtr) 1 );
|
api = new SteamNative.SteamApi();
|
||||||
|
|
||||||
if ( !api.SteamAPI_Init() )
|
if ( !api.SteamAPI_Init() )
|
||||||
return false;
|
return false;
|
||||||
@ -63,7 +63,7 @@ namespace Facepunch.Steamworks.Interop
|
|||||||
{
|
{
|
||||||
isServer = true;
|
isServer = true;
|
||||||
|
|
||||||
api = new SteamNative.SteamApi( steamworks, ( IntPtr)1 );
|
api = new SteamNative.SteamApi();
|
||||||
|
|
||||||
if ( !api.SteamInternal_GameServer_Init( IpAddress, usPort, GamePort, QueryPort, eServerMode, pchVersionString ) )
|
if ( !api.SteamInternal_GameServer_Init( IpAddress, usPort, GamePort, QueryPort, eServerMode, pchVersionString ) )
|
||||||
{
|
{
|
||||||
|
@ -10,20 +10,18 @@ namespace SteamNative
|
|||||||
// Holds a platform specific implentation
|
// Holds a platform specific implentation
|
||||||
//
|
//
|
||||||
internal Platform.Interface platform;
|
internal Platform.Interface platform;
|
||||||
internal Facepunch.Steamworks.BaseSteamworks steamworks;
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Constructor decides which implementation to use based on current platform
|
// Constructor decides which implementation to use based on current platform
|
||||||
//
|
//
|
||||||
internal SteamApi( Facepunch.Steamworks.BaseSteamworks steamworks, IntPtr pointer )
|
internal SteamApi()
|
||||||
{
|
{
|
||||||
this.steamworks = steamworks;
|
|
||||||
|
|
||||||
if ( Platform.IsWindows64 ) platform = new Platform.Win64( pointer );
|
if ( Platform.IsWindows64 ) platform = new Platform.Win64( ((IntPtr)1) );
|
||||||
else if ( Platform.IsWindows32 ) platform = new Platform.Win32( pointer );
|
else if ( Platform.IsWindows32 ) platform = new Platform.Win32( ((IntPtr)1) );
|
||||||
else if ( Platform.IsLinux32 ) platform = new Platform.Linux32( pointer );
|
else if ( Platform.IsLinux32 ) platform = new Platform.Linux32( ((IntPtr)1) );
|
||||||
else if ( Platform.IsLinux64 ) platform = new Platform.Linux64( pointer );
|
else if ( Platform.IsLinux64 ) platform = new Platform.Linux64( ((IntPtr)1) );
|
||||||
else if ( Platform.IsOsx ) platform = new Platform.Mac( pointer );
|
else if ( Platform.IsOsx ) platform = new Platform.Mac( ((IntPtr)1) );
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -41,12 +41,32 @@ namespace Generator
|
|||||||
WriteLine( "// Holds a platform specific implentation" );
|
WriteLine( "// Holds a platform specific implentation" );
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
WriteLine( "internal Platform.Interface platform;" );
|
WriteLine( "internal Platform.Interface platform;" );
|
||||||
|
|
||||||
|
if ( classname != "SteamApi" )
|
||||||
WriteLine( "internal Facepunch.Steamworks.BaseSteamworks steamworks;" );
|
WriteLine( "internal Facepunch.Steamworks.BaseSteamworks steamworks;" );
|
||||||
|
|
||||||
WriteLine();
|
WriteLine();
|
||||||
|
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
WriteLine( "// Constructor decides which implementation to use based on current platform" );
|
WriteLine( "// Constructor decides which implementation to use based on current platform" );
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
|
|
||||||
|
if ( classname == "SteamApi" )
|
||||||
|
{
|
||||||
|
|
||||||
|
StartBlock( $"internal {InterfaceNameToClass( classname )}()" );
|
||||||
|
{
|
||||||
|
WriteLine( "" );
|
||||||
|
WriteLine( "if ( Platform.IsWindows64 ) platform = new Platform.Win64( ((IntPtr)1) );" );
|
||||||
|
WriteLine( "else if ( Platform.IsWindows32 ) platform = new Platform.Win32( ((IntPtr)1) );" );
|
||||||
|
WriteLine( "else if ( Platform.IsLinux32 ) platform = new Platform.Linux32( ((IntPtr)1) );" );
|
||||||
|
WriteLine( "else if ( Platform.IsLinux64 ) platform = new Platform.Linux64( ((IntPtr)1) );" );
|
||||||
|
WriteLine( "else if ( Platform.IsOsx ) platform = new Platform.Mac( ((IntPtr)1) );" );
|
||||||
|
}
|
||||||
|
EndBlock();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
StartBlock( $"internal {InterfaceNameToClass( classname )}( Facepunch.Steamworks.BaseSteamworks steamworks, IntPtr pointer )" );
|
StartBlock( $"internal {InterfaceNameToClass( classname )}( Facepunch.Steamworks.BaseSteamworks steamworks, IntPtr pointer )" );
|
||||||
{
|
{
|
||||||
WriteLine( "this.steamworks = steamworks;" );
|
WriteLine( "this.steamworks = steamworks;" );
|
||||||
@ -58,6 +78,8 @@ namespace Generator
|
|||||||
WriteLine( "else if ( Platform.IsOsx ) platform = new Platform.Mac( pointer );" );
|
WriteLine( "else if ( Platform.IsOsx ) platform = new Platform.Mac( pointer );" );
|
||||||
}
|
}
|
||||||
EndBlock();
|
EndBlock();
|
||||||
|
}
|
||||||
|
|
||||||
WriteLine();
|
WriteLine();
|
||||||
|
|
||||||
WriteLine( "//" );
|
WriteLine( "//" );
|
||||||
|
Loading…
x
Reference in New Issue
Block a user