2021-12-26 06:53:36 +00:00
|
|
|
|
using OWML.Common;
|
2021-08-08 19:04:15 +00:00
|
|
|
|
using QSB.ClientServerStateSync;
|
2021-12-25 06:33:29 +00:00
|
|
|
|
using QSB.ClientServerStateSync.Messages;
|
2020-12-14 16:28:03 +00:00
|
|
|
|
using QSB.Messaging;
|
2020-08-22 19:21:13 +00:00
|
|
|
|
using QSB.Utility;
|
2020-08-10 13:40:06 +00:00
|
|
|
|
|
2021-12-23 21:49:47 +00:00
|
|
|
|
namespace QSB.Player.Messages
|
2020-08-10 13:40:06 +00:00
|
|
|
|
{
|
2022-01-26 07:46:41 +00:00
|
|
|
|
// Can be sent by any client (including host) to signal they want latest player and server information
|
2021-12-23 02:20:53 +00:00
|
|
|
|
public class RequestStateResyncMessage : QSBMessage
|
2020-12-02 21:23:01 +00:00
|
|
|
|
{
|
2021-12-23 02:20:53 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// set to true when we send this, and false when we receive a player info message back. <br/>
|
|
|
|
|
/// this prevents message spam a bit.
|
|
|
|
|
/// </summary>
|
|
|
|
|
internal static bool _waitingForEvent;
|
2020-08-15 19:32:58 +00:00
|
|
|
|
|
2021-12-25 05:42:53 +00:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// used instead of QSBMessageManager.Send to do the extra check
|
|
|
|
|
/// </summary>
|
2021-12-23 02:20:53 +00:00
|
|
|
|
public void Send()
|
2021-12-11 11:47:21 +00:00
|
|
|
|
{
|
|
|
|
|
if (_waitingForEvent)
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_waitingForEvent = true;
|
2021-12-23 02:20:53 +00:00
|
|
|
|
QSBMessageManager.Send(this);
|
2021-12-11 11:47:21 +00:00
|
|
|
|
}
|
2020-08-15 19:52:43 +00:00
|
|
|
|
|
2021-12-23 02:20:53 +00:00
|
|
|
|
public override void OnReceiveLocal()
|
2021-12-11 11:47:21 +00:00
|
|
|
|
{
|
2022-01-29 09:27:00 +00:00
|
|
|
|
DelayUtil.RunFramesLater(60, () =>
|
2021-12-11 11:47:21 +00:00
|
|
|
|
{
|
|
|
|
|
if (_waitingForEvent)
|
|
|
|
|
{
|
2022-01-22 06:29:13 +00:00
|
|
|
|
if (QSBPlayerManager.PlayerList.Count > 1)
|
|
|
|
|
{
|
|
|
|
|
DebugLog.ToConsole($"Did not receive PlayerInformationEvent in time. Setting _waitingForEvent to false.", MessageType.Info);
|
|
|
|
|
}
|
|
|
|
|
|
2021-12-11 11:47:21 +00:00
|
|
|
|
_waitingForEvent = false;
|
|
|
|
|
}
|
2022-01-29 09:27:00 +00:00
|
|
|
|
});
|
2021-12-11 11:47:21 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-12-23 02:20:53 +00:00
|
|
|
|
public override void OnReceiveRemote()
|
2020-12-02 21:23:01 +00:00
|
|
|
|
{
|
2021-12-25 06:15:31 +00:00
|
|
|
|
if (QSBCore.IsHost)
|
2020-12-19 10:56:25 +00:00
|
|
|
|
{
|
2021-12-25 06:33:29 +00:00
|
|
|
|
new ServerStateMessage(ServerStateManager.Instance.GetServerState()) { To = From }.Send();
|
2021-12-25 06:15:31 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-01-26 07:40:38 +00:00
|
|
|
|
new PlayerInformationMessage { To = From }.Send();
|
2021-08-08 19:04:15 +00:00
|
|
|
|
}
|
2020-12-02 21:23:01 +00:00
|
|
|
|
}
|
2021-12-26 12:33:20 +00:00
|
|
|
|
}
|