Cleaning up

This commit is contained in:
Garry Newman 2019-05-06 21:19:00 +01:00
parent ea97de9c02
commit 63b3cae096
20 changed files with 39 additions and 70 deletions

View File

@ -20,7 +20,7 @@ namespace Steamworks.ServerList
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamMatchmakingServers(); _internal = new ISteamMatchmakingServers();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -21,7 +21,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamApps(); _internal = new ISteamApps();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -142,7 +142,5 @@ namespace Steamworks
/// returns the appID of the current process /// returns the appID of the current process
/// </summary> /// </summary>
public static AppId AppId { get; internal set; } public static AppId AppId { get; internal set; }
public static IDisposable Push() => Realm.Client();
} }
} }

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamFriends(); _internal = new ISteamFriends();
_internal.InitClient(); _internal.Init();
richPresence = new Dictionary<string, string>(); richPresence = new Dictionary<string, string>();
} }

View File

@ -22,7 +22,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamInventory(); _internal = new ISteamInventory();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -13,6 +13,7 @@ namespace Steamworks
public static class SteamMatchmaking public static class SteamMatchmaking
{ {
static ISteamMatchmaking _internal; static ISteamMatchmaking _internal;
internal static ISteamMatchmaking Internal internal static ISteamMatchmaking Internal
{ {
get get
@ -20,7 +21,6 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamMatchmaking(); _internal = new ISteamMatchmaking();
_internal.InitClient();
} }
return _internal; return _internal;

View File

@ -23,7 +23,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamMusic(); _internal = new ISteamMusic();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -18,7 +18,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamNetworkingSockets(); _internal = new ISteamNetworkingSockets();
_internal.InitClient(); _internal.Init();
SocketInterfaces = new Dictionary<uint, SocketInterface>(); SocketInterfaces = new Dictionary<uint, SocketInterface>();
ConnectionInterfaces = new Dictionary<uint, ConnectionInterface>(); ConnectionInterfaces = new Dictionary<uint, ConnectionInterface>();

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamParentalSettings(); _internal = new ISteamParentalSettings();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -17,7 +17,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamParties(); _internal = new ISteamParties();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamRemoteStorage(); _internal = new ISteamRemoteStorage();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamScreenshots(); _internal = new ISteamScreenshots();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -75,7 +75,8 @@ namespace Steamworks
DedicatedServer = true; DedicatedServer = true;
InstallEvents(); InstallEvents();
RunCallbacks();
RunCallbacksAsync();
} }
public static void Shutdown() public static void Shutdown()
@ -92,16 +93,14 @@ namespace Steamworks
SteamGameServer.Shutdown(); SteamGameServer.Shutdown();
} }
internal static async void RunCallbacksAsync()
internal static async void RunCallbacks()
{ {
while ( true ) while ( IsValid )
{ {
await Task.Delay( 16 ); await Task.Delay( 16 );
Update(); Update();
} }
} }
public static void Update() public static void Update()
{ {
try try
@ -373,7 +372,5 @@ namespace Steamworks
Internal.HandleIncomingPacket( (IntPtr)ptr, size, address, port ); Internal.HandleIncomingPacket( (IntPtr)ptr, size, address, port );
} }
} }
public static IDisposable Push() => Realm.Server();
} }
} }

View File

@ -22,7 +22,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamUGC(); _internal = new ISteamUGC();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -22,7 +22,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamUser(); _internal = new ISteamUser();
_internal.InitClient(); _internal.Init();
richPresence = new Dictionary<string, string>(); richPresence = new Dictionary<string, string>();

View File

@ -17,7 +17,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamUserStats(); _internal = new ISteamUserStats();
_internal.InitClient(); _internal.Init();
RequestCurrentStats(); RequestCurrentStats();
} }

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamUtils(); _internal = new ISteamUtils();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -20,7 +20,7 @@ namespace Steamworks
if ( _internal == null ) if ( _internal == null )
{ {
_internal = new ISteamVideo(); _internal = new ISteamVideo();
_internal.InitClient(); _internal.Init();
} }
return _internal; return _internal;

View File

@ -1,43 +0,0 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Text;
namespace Steamworks
{
public static class Realm
{
//
// true = serverside
//
static Stack<bool> _stack = new Stack<bool>();
public static bool IsServer => _stack.Count > 0 && _stack.Peek();
public static bool IsClient => _stack.Count == 0 || !_stack.Peek();
static public IDisposable Server()
{
_stack.Push( true );
return new StackPopper();
}
static public IDisposable Client()
{
_stack.Push( false );
return new StackPopper();
}
public struct StackPopper : IDisposable
{
public void Dispose()
{
_stack.Pop();
}
}
}
}

View File

@ -16,7 +16,24 @@ namespace Steamworks
public virtual string InterfaceName => null; public virtual string InterfaceName => null;
public virtual void InitClient() public void Init()
{
if ( SteamClient.IsValid )
{
InitClient();
return;
}
if ( SteamServer.IsValid )
{
InitServer();
return;
}
throw new System.Exception( "Trying to initialize Steam Interface but Steam not initialized" );
}
public void InitClient()
{ {
var user = SteamAPI.GetHSteamUser(); var user = SteamAPI.GetHSteamUser();
Self = SteamInternal.FindOrCreateUserInterface( user, InterfaceName ); Self = SteamInternal.FindOrCreateUserInterface( user, InterfaceName );
@ -31,7 +48,7 @@ namespace Steamworks
InitInternals(); InitInternals();
} }
public virtual void InitServer() public void InitServer()
{ {
var user = SteamGameServer.GetHSteamUser(); var user = SteamGameServer.GetHSteamUser();
Self = SteamInternal.FindOrCreateGameServerInterface( user, InterfaceName ); Self = SteamInternal.FindOrCreateGameServerInterface( user, InterfaceName );