mirror of
https://github.com/ppy/osu.git
synced 2025-02-16 13:02:55 +08:00
Fix stuck lounge on join failure
This commit is contained in:
parent
85e93c5dde
commit
ab90db7c8d
@ -38,10 +38,10 @@ namespace osu.Game.Screens.Multi.RealtimeMultiplayer
|
|||||||
}
|
}
|
||||||
|
|
||||||
public override void CreateRoom(Room room, Action<Room> onSuccess = null, Action<string> onError = null)
|
public override void CreateRoom(Room room, Action<Room> onSuccess = null, Action<string> onError = null)
|
||||||
=> base.CreateRoom(room, r => joinMultiplayerRoom(r, onSuccess), onError);
|
=> base.CreateRoom(room, r => joinMultiplayerRoom(r, onSuccess, onError), onError);
|
||||||
|
|
||||||
public override void JoinRoom(Room room, Action<Room> onSuccess = null, Action<string> onError = null)
|
public override void JoinRoom(Room room, Action<Room> onSuccess = null, Action<string> onError = null)
|
||||||
=> base.JoinRoom(room, r => joinMultiplayerRoom(r, onSuccess), onError);
|
=> base.JoinRoom(room, r => joinMultiplayerRoom(r, onSuccess, onError), onError);
|
||||||
|
|
||||||
public override void PartRoom()
|
public override void PartRoom()
|
||||||
{
|
{
|
||||||
@ -62,7 +62,7 @@ namespace osu.Game.Screens.Multi.RealtimeMultiplayer
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void joinMultiplayerRoom(Room room, Action<Room> onSuccess = null)
|
private void joinMultiplayerRoom(Room room, Action<Room> onSuccess = null, Action<string> onError = null)
|
||||||
{
|
{
|
||||||
Debug.Assert(room.RoomID.Value != null);
|
Debug.Assert(room.RoomID.Value != null);
|
||||||
|
|
||||||
@ -73,6 +73,7 @@ namespace osu.Game.Screens.Multi.RealtimeMultiplayer
|
|||||||
PartRoom();
|
PartRoom();
|
||||||
if (t.Exception != null)
|
if (t.Exception != null)
|
||||||
Logger.Error(t.Exception, "Failed to join multiplayer room.");
|
Logger.Error(t.Exception, "Failed to join multiplayer room.");
|
||||||
|
onError?.Invoke(t.Exception?.ToString() ?? string.Empty);
|
||||||
}, TaskContinuationOptions.NotOnRanToCompletion);
|
}, TaskContinuationOptions.NotOnRanToCompletion);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user