Cleaned up Disconnect function locking
This commit is contained in:
@@ -113,23 +113,13 @@ namespace Discord.Rpc
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
/// <inheritdoc />
|
public async Task DisconnectAsync()
|
||||||
public Task DisconnectAsync() => DisconnectAsync(null, false);
|
|
||||||
private async Task DisconnectAsync(Exception ex = null, bool isReconnecting = false)
|
|
||||||
{
|
{
|
||||||
if (ex == null)
|
if (_connectTask?.TrySetCanceled() ?? false) return;
|
||||||
{
|
|
||||||
if (_connectTask?.TrySetCanceled() ?? false) return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (_connectTask?.TrySetException(ex) ?? false) return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await _connectionLock.WaitAsync().ConfigureAwait(false);
|
await _connectionLock.WaitAsync().ConfigureAwait(false);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
await DisconnectInternalAsync(ex, isReconnecting).ConfigureAwait(false);
|
await DisconnectInternalAsync(null, false).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
finally { _connectionLock.Release(); }
|
finally { _connectionLock.Release(); }
|
||||||
}
|
}
|
||||||
@@ -174,7 +164,14 @@ namespace Discord.Rpc
|
|||||||
}
|
}
|
||||||
private async Task ReconnectInternalAsync(Exception ex, CancellationToken cancelToken)
|
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
|
try
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -181,22 +181,13 @@ namespace Discord.WebSocket
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
public Task DisconnectAsync() => DisconnectAsync(null, false);
|
public async Task DisconnectAsync()
|
||||||
private async Task DisconnectAsync(Exception ex = null, bool isReconnecting = false)
|
|
||||||
{
|
{
|
||||||
if (ex == null)
|
if (_connectTask?.TrySetCanceled() ?? false) return;
|
||||||
{
|
|
||||||
if (_connectTask?.TrySetCanceled() ?? false) return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (_connectTask?.TrySetException(ex) ?? false) return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await _connectionLock.WaitAsync().ConfigureAwait(false);
|
await _connectionLock.WaitAsync().ConfigureAwait(false);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
await DisconnectInternalAsync(ex, isReconnecting).ConfigureAwait(false);
|
await DisconnectInternalAsync(null, false).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
finally { _connectionLock.Release(); }
|
finally { _connectionLock.Release(); }
|
||||||
}
|
}
|
||||||
@@ -269,7 +260,14 @@ namespace Discord.WebSocket
|
|||||||
}
|
}
|
||||||
private async Task ReconnectInternalAsync(Exception ex, CancellationToken cancelToken)
|
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
|
try
|
||||||
{
|
{
|
||||||
@@ -579,7 +577,7 @@ namespace Discord.WebSocket
|
|||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
await DisconnectAsync(new Exception("Processing READY failed", ex), false);
|
_connectTask.TrySetException(new Exception("Processing READY failed", ex));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user