From c909bc32b78c6e6e612ab6a6fd548dce3d8276f3 Mon Sep 17 00:00:00 2001 From: Mylo Fawcett Date: Sat, 7 Sep 2024 02:09:11 +0200 Subject: [PATCH] Don't set local close code when remote closes the connection --- lib/src/gateway/shard_runner.dart | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/lib/src/gateway/shard_runner.dart b/lib/src/gateway/shard_runner.dart index 756e08577..e14d67ec0 100644 --- a/lib/src/gateway/shard_runner.dart +++ b/lib/src/gateway/shard_runner.dart @@ -360,7 +360,16 @@ class ShardConnection extends Stream implements StreamSink { _currentRateLimitEnd.complete(); _currentRateLimitEnd = Completer(); }); - websocket.done.then((_) => close()); + websocket.done.then((_) { + _rateLimitResetTimer.cancel(); + if (!_currentRateLimitEnd.isCompleted) { + _currentRateLimitEnd + // Don't report an uncaught async error for the future. + ..future.ignore() + ..completeError(StateError('Connection is closed'), StackTrace.current); + } + _sentController.close(); + }); } static Future connect(String gatewayUri, ShardRunner runner) async { @@ -435,15 +444,9 @@ class ShardConnection extends Stream implements StreamSink { Future close([int code = 1000]) async { localCloseCode ??= code; - _rateLimitResetTimer.cancel(); - if (!_currentRateLimitEnd.isCompleted) { - _currentRateLimitEnd - // Install an error handler so the error is not counted as uncaught. - ..future.catchError((e) {}) - ..completeError(StateError('Connection is closed'), StackTrace.current); - } await websocket.close(code); - await _sentController.close(); + + return done; } @override