From c5af1f91cf35de5e0df0a580e9e4fbfb264dcd14 Mon Sep 17 00:00:00 2001 From: Garry Newman Date: Wed, 16 Aug 2017 22:11:00 +0100 Subject: [PATCH] Nicer shutdown, I think --- Facepunch.Steamworks/Interop/Native.cs | 44 ++++++++++---------------- 1 file changed, 17 insertions(+), 27 deletions(-) diff --git a/Facepunch.Steamworks/Interop/Native.cs b/Facepunch.Steamworks/Interop/Native.cs index f79b74b..879febd 100644 --- a/Facepunch.Steamworks/Interop/Native.cs +++ b/Facepunch.Steamworks/Interop/Native.cs @@ -116,27 +116,6 @@ namespace Facepunch.Steamworks.Interop public void Dispose() { - if ( client != null ) - { - if ( hPipe != 0 ) - { - if ( hUser != 0 ) - { - client.ReleaseUser( hPipe, hUser ); - hUser = 0; - } - - client.BReleaseSteamPipe( hPipe ); - hPipe = 0; - } - - if ( !client.BShutdownIfAllPipesClosed() ) - Console.WriteLine( "BShutdownIfAllPipesClosed returned false" ); - - client.Dispose(); - client = null; - } - if ( user != null ) { user.Dispose(); @@ -186,12 +165,7 @@ namespace Facepunch.Steamworks.Interop } if ( gameServer != null ) - { - // - // Calling this can cause the process to hang - // - //gameServer.LogOff(); - + { gameServer.Dispose(); gameServer = null; } @@ -232,6 +206,12 @@ namespace Facepunch.Steamworks.Interop applist = null; } + if ( client != null ) + { + client.Dispose(); + client = null; + } + if ( api != null ) { if ( isServer ) @@ -239,6 +219,16 @@ namespace Facepunch.Steamworks.Interop else api.SteamAPI_Shutdown(); + // + // The functions above destroy the pipeline handles + // and all of the classes. Trying to call a steam function + // at this point will result in a crash - because any + // pointers we stored are not invalid. + // + + hPipe = 0; + hUser = 0; + api.Dispose(); api = null; }