Browse Source

Cleaned up Disconnect function locking

tags/1.0-rc
RogueException 9 years ago
parent
commit
dcd13e98e9
2 changed files with 23 additions and 28 deletions
  1. +11
    -14
      src/Discord.Net/Rpc/DiscordRpcClient.cs
  2. +12
    -14
      src/Discord.Net/WebSocket/DiscordSocketClient.cs

+ 11
- 14
src/Discord.Net/Rpc/DiscordRpcClient.cs View File

@@ -113,23 +113,13 @@ namespace Discord.Rpc
}
}
/// <inheritdoc />
/// <inheritdoc />
public Task DisconnectAsync() => DisconnectAsync(null, false);
private async Task DisconnectAsync(Exception ex = null, bool isReconnecting = false)
public async Task DisconnectAsync()
{
if (ex == null)
{
if (_connectTask?.TrySetCanceled() ?? false) return;
}
else
{
if (_connectTask?.TrySetException(ex) ?? false) return;
}

if (_connectTask?.TrySetCanceled() ?? false) return;
await _connectionLock.WaitAsync().ConfigureAwait(false);
try
{
await DisconnectInternalAsync(ex, isReconnecting).ConfigureAwait(false);
await DisconnectInternalAsync(null, false).ConfigureAwait(false);
}
finally { _connectionLock.Release(); }
}
@@ -174,7 +164,14 @@ namespace Discord.Rpc
}
private async Task ReconnectInternalAsync(Exception ex, CancellationToken cancelToken)
{
await DisconnectAsync(null, true).ConfigureAwait(false);
if (ex == null)
{
if (_connectTask?.TrySetCanceled() ?? false) return;
}
else
{
if (_connectTask?.TrySetException(ex) ?? false) return;
}

try
{


+ 12
- 14
src/Discord.Net/WebSocket/DiscordSocketClient.cs View File

@@ -181,22 +181,13 @@ namespace Discord.WebSocket
}
}
/// <inheritdoc />
public Task DisconnectAsync() => DisconnectAsync(null, false);
private async Task DisconnectAsync(Exception ex = null, bool isReconnecting = false)
public async Task DisconnectAsync()
{
if (ex == null)
{
if (_connectTask?.TrySetCanceled() ?? false) return;
}
else
{
if (_connectTask?.TrySetException(ex) ?? false) return;
}

if (_connectTask?.TrySetCanceled() ?? false) return;
await _connectionLock.WaitAsync().ConfigureAwait(false);
try
{
await DisconnectInternalAsync(ex, isReconnecting).ConfigureAwait(false);
await DisconnectInternalAsync(null, false).ConfigureAwait(false);
}
finally { _connectionLock.Release(); }
}
@@ -269,7 +260,14 @@ namespace Discord.WebSocket
}
private async Task ReconnectInternalAsync(Exception ex, CancellationToken cancelToken)
{
await DisconnectAsync(null, true).ConfigureAwait(false);
if (ex == null)
{
if (_connectTask?.TrySetCanceled() ?? false) return;
}
else
{
if (_connectTask?.TrySetException(ex) ?? false) return;
}

try
{
@@ -579,7 +577,7 @@ namespace Discord.WebSocket
}
catch (Exception ex)
{
await DisconnectAsync(new Exception("Processing READY failed", ex), false);
_connectTask.TrySetException(new Exception("Processing READY failed", ex));
return;
}



Loading…
Cancel
Save