From 2e5b5c6485e56ebe3ac29f14534b109c80f784f1 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 18 Oct 2021 15:12:35 +0100 Subject: [PATCH 01/18] update assetbundles --- AssetBundles/debug | Bin 9046 -> 9047 bytes AssetBundles/debug.manifest | 4 ++-- UnityProject/Assets/DebugVis.mat | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/AssetBundles/debug b/AssetBundles/debug index 98a62156407c6e1b693a734d66bc8a51f4092ad4..71c1eeacaa3af2f63ebfd8bf2ce1b9efa86e7f98 100644 GIT binary patch delta 62 zcmV-E0Kxy(M%PA=B>`8FCMN;bu}Px# delta 61 zcmV-D0K)&*M%G4`5ECMN;au} diff --git a/AssetBundles/debug.manifest b/AssetBundles/debug.manifest index 58b6eecd..3c7b4d6c 100644 --- a/AssetBundles/debug.manifest +++ b/AssetBundles/debug.manifest @@ -1,9 +1,9 @@ ManifestFileVersion: 0 -CRC: 3009665417 +CRC: 3095198160 Hashes: AssetFileHash: serializedVersion: 2 - Hash: dbc913ca95e649d2e00d188ff573830e + Hash: aeeeeba83ed0a32973e863d3787067c0 TypeTreeHash: serializedVersion: 2 Hash: b2ece8ae09df261ff59d764d08696641 diff --git a/UnityProject/Assets/DebugVis.mat b/UnityProject/Assets/DebugVis.mat index 21ccb8f7..78da8673 100644 --- a/UnityProject/Assets/DebugVis.mat +++ b/UnityProject/Assets/DebugVis.mat @@ -73,5 +73,5 @@ Material: - _UVSec: 0 - _ZWrite: 0 m_Colors: - - _Color: {r: 1, g: 0.51526886, b: 0, a: 0.09803922} + - _Color: {r: 1, g: 0.51526886, b: 0, a: 0.05882353} - _EmissionColor: {r: 0, g: 0, b: 0, a: 1} From 0ef03086ae69ae14d37684030d96dd9e91bda500 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Tue, 19 Oct 2021 20:23:53 +0100 Subject: [PATCH 02/18] fix orb issue on scene reload fixes #322 --- QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs | 10 +++++++++- QSB/Utility/DebugGUI.cs | 3 +++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs index bcc44526..aaeb19c7 100644 --- a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs +++ b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs @@ -1,6 +1,7 @@ using QSB.Syncs.Unsectored.Transforms; using QSB.Utility; using QSB.WorldSync; +using QuantumUNET; using System.Collections.Generic; using UnityEngine; @@ -27,7 +28,14 @@ namespace QSB.OrbSync.TransformSync if (originalParent == Locator.GetRootTransform()) { DebugLog.DebugWrite($"{_logName} with AttachedObject {AttachedObject.name} had it's original parent as SolarSystemRoot - Destroying..."); - Destroy(this); + if (QSBCore.IsHost) + { + QNetworkServer.Destroy(gameObject); + } + else + { + DebugLog.ToConsole($"Error - Parent mismatch when not running on host?! A client should never be spawning the orbs.", OWML.Common.MessageType.Error); + } } SetReferenceTransform(originalParent); diff --git a/QSB/Utility/DebugGUI.cs b/QSB/Utility/DebugGUI.cs index 68bada16..812b157c 100644 --- a/QSB/Utility/DebugGUI.cs +++ b/QSB/Utility/DebugGUI.cs @@ -1,4 +1,5 @@ using QSB.ClientServerStateSync; +using QSB.OrbSync.TransformSync; using QSB.Player; using QSB.ProbeSync.TransformSync; using QSB.Syncs; @@ -63,6 +64,8 @@ namespace QSB.Utility } var offset2 = 10f; + GUI.Label(new Rect(420, offset2, 200f, 20f), $"OrbList count : {NomaiOrbTransformSync.OrbTransformSyncs.Count}", guiStyle); + offset2 += _debugLineSpacing; GUI.Label(new Rect(420, offset2, 200f, 20f), $"Player data :", guiStyle); offset2 += _debugLineSpacing; foreach (var player in QSBPlayerManager.PlayerList) From 353de9c90f03befff7a0fb5df2976d43c2a04a28 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 09:10:30 +0100 Subject: [PATCH 03/18] add back in debug actions, add trigger supernova action (properly) --- QSB/Events/EventNames.cs | 1 + QSB/Events/EventType.cs | 5 ++++ QSB/Events/QSBEventManager.cs | 2 ++ QSB/QSB.csproj | 2 ++ QSB/Utility/DebugActions.cs | 23 +++++++++--------- QSB/Utility/Events/DebugEvent.cs | 36 ++++++++++++++++++++++++++++ QSB/Utility/Events/DebugEventEnum.cs | 7 ++++++ 7 files changed, 65 insertions(+), 11 deletions(-) create mode 100644 QSB/Utility/Events/DebugEvent.cs create mode 100644 QSB/Utility/Events/DebugEventEnum.cs diff --git a/QSB/Events/EventNames.cs b/QSB/Events/EventNames.cs index cfbbc0d9..168d66c4 100644 --- a/QSB/Events/EventNames.cs +++ b/QSB/Events/EventNames.cs @@ -86,5 +86,6 @@ public static string QSBStartLoop = "QSBStartLoop"; public static string QSBServerState = "QSBServerState"; public static string QSBClientState = "QSBClientState"; + public static string QSBDebugEvent = "QSBDebugEvent"; } } \ No newline at end of file diff --git a/QSB/Events/EventType.cs b/QSB/Events/EventType.cs index 601253c0..be7a01f7 100644 --- a/QSB/Events/EventType.cs +++ b/QSB/Events/EventType.cs @@ -2,6 +2,11 @@ { public enum EventType { + /* + * MISC. + */ + DebugEvent, + /* * SERVER EVENTS */ diff --git a/QSB/Events/QSBEventManager.cs b/QSB/Events/QSBEventManager.cs index c3cd6c09..68029535 100644 --- a/QSB/Events/QSBEventManager.cs +++ b/QSB/Events/QSBEventManager.cs @@ -24,6 +24,7 @@ using QSB.Tools.Events; using QSB.Tools.ProbeLauncherTool.Events; using QSB.TranslationSync.Events; using QSB.Utility; +using QSB.Utility.Events; using System.Collections.Generic; namespace QSB.Events @@ -67,6 +68,7 @@ namespace QSB.Events new StartLoopEvent(), new ServerStateEvent(), new ClientStateEvent(), + new DebugEvent(), // World Objects new ElevatorEvent(), new GeyserEvent(), diff --git a/QSB/QSB.csproj b/QSB/QSB.csproj index 494c074a..c191550b 100644 --- a/QSB/QSB.csproj +++ b/QSB/QSB.csproj @@ -275,6 +275,8 @@ + + diff --git a/QSB/Utility/DebugActions.cs b/QSB/Utility/DebugActions.cs index f0a5b5e8..03c773de 100644 --- a/QSB/Utility/DebugActions.cs +++ b/QSB/Utility/DebugActions.cs @@ -1,6 +1,9 @@ using OWML.Utils; +using QSB.Events; using QSB.ShipSync; +using QSB.Utility.Events; using UnityEngine; +using UnityEngine.InputSystem; namespace QSB.Utility { @@ -29,34 +32,32 @@ namespace QSB.Utility public void Update() { - return; - if (!QSBCore.DebugMode) { return; } - if (Input.GetKeyDown(KeyCode.Keypad5)) - { - Locator.GetDeathManager().KillPlayer(DeathType.Supernova); - } - - if (Input.GetKeyDown(KeyCode.Keypad4)) + if (Keyboard.current[Key.Numpad4].wasPressedThisFrame) { DamageShipElectricalSystem(); } - if (Input.GetKeyDown(KeyCode.Keypad7)) + if (Keyboard.current[Key.Numpad5].wasPressedThisFrame) + { + QSBEventManager.FireEvent(EventNames.QSBDebugEvent, DebugEventEnum.TriggerSupernova); + } + + if (Keyboard.current[Key.Numpad7].wasPressedThisFrame) { GoToVessel(); } - if (Input.GetKeyDown(KeyCode.Keypad8)) + if (Keyboard.current[Key.Numpad8].wasPressedThisFrame) { InsertWarpCore(); } - if (Input.GetKeyDown(KeyCode.Keypad9)) + if (Keyboard.current[Key.Numpad9].wasPressedThisFrame) { LoadManager.LoadSceneAsync(OWScene.EyeOfTheUniverse, true, LoadManager.FadeType.ToWhite); } diff --git a/QSB/Utility/Events/DebugEvent.cs b/QSB/Utility/Events/DebugEvent.cs new file mode 100644 index 00000000..0cde719a --- /dev/null +++ b/QSB/Utility/Events/DebugEvent.cs @@ -0,0 +1,36 @@ +using QSB.Events; +using QSB.Messaging; + +namespace QSB.Utility.Events +{ + public class DebugEvent : QSBEvent> + { + public override EventType Type => EventType.DebugEvent; + + public override void SetupListener() => GlobalMessenger.AddListener(EventNames.QSBDebugEvent, Handler); + public override void CloseListener() => GlobalMessenger.RemoveListener(EventNames.QSBDebugEvent, Handler); + + private void Handler(DebugEventEnum type) => SendEvent(CreateMessage(type)); + + private EnumMessage CreateMessage(DebugEventEnum type) => new EnumMessage + { + AboutId = LocalPlayerId, + EnumValue = type + }; + + public override void OnReceiveLocal(bool isHost, EnumMessage message) + { + OnReceiveRemote(isHost, message); + } + + public override void OnReceiveRemote(bool isHost, EnumMessage message) + { + switch (message.EnumValue) + { + case DebugEventEnum.TriggerSupernova: + TimeLoop.SetSecondsRemaining(0f); + break; + } + } + } +} diff --git a/QSB/Utility/Events/DebugEventEnum.cs b/QSB/Utility/Events/DebugEventEnum.cs new file mode 100644 index 00000000..1f74bc9c --- /dev/null +++ b/QSB/Utility/Events/DebugEventEnum.cs @@ -0,0 +1,7 @@ +namespace QSB.Utility.Events +{ + public enum DebugEventEnum + { + TriggerSupernova + } +} \ No newline at end of file From 9d684b354076582b1020d512732ae6dc20372bf7 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 09:21:26 +0100 Subject: [PATCH 04/18] disable quantum vis if not in debug mode --- .../WorldObjects/QSBQuantumObject.cs | 47 ++++++++++--------- 1 file changed, 25 insertions(+), 22 deletions(-) diff --git a/QSB/QuantumSync/WorldObjects/QSBQuantumObject.cs b/QSB/QuantumSync/WorldObjects/QSBQuantumObject.cs index c0f700c3..38920856 100644 --- a/QSB/QuantumSync/WorldObjects/QSBQuantumObject.cs +++ b/QSB/QuantumSync/WorldObjects/QSBQuantumObject.cs @@ -64,29 +64,32 @@ namespace QSB.QuantumSync.WorldObjects shape.OnShapeDeactivated += (Shape s) => QSBCore.UnityEvents.FireOnNextUpdate(() => OnDisable(s)); - if (shape is BoxShape boxShape) + if (QSBCore.DebugMode) { - var newCube = UnityEngine.Object.Instantiate(cube); - newCube.transform.parent = shape.transform; - newCube.transform.localPosition = Vector3.zero; - newCube.transform.localRotation = Quaternion.Euler(0, 0, 0); - newCube.transform.localScale = boxShape.size; - } - else if (shape is SphereShape sphereShape) - { - var newSphere = UnityEngine.Object.Instantiate(sphere); - newSphere.transform.parent = shape.transform; - newSphere.transform.localPosition = Vector3.zero; - newSphere.transform.localRotation = Quaternion.Euler(0, 0, 0); - newSphere.transform.localScale = Vector3.one * (sphereShape.radius * 2); - } - else if (shape is CapsuleShape capsuleShape) - { - var newCapsule = Object.Instantiate(capsule); - newCapsule.transform.parent = shape.transform; - newCapsule.transform.localPosition = Vector3.zero; - newCapsule.transform.localRotation = Quaternion.Euler(0, 0, 0); - newCapsule.transform.localScale = new Vector3(capsuleShape.radius * 2, capsuleShape.height, capsuleShape.radius * 2); + if (shape is BoxShape boxShape) + { + var newCube = UnityEngine.Object.Instantiate(cube); + newCube.transform.parent = shape.transform; + newCube.transform.localPosition = Vector3.zero; + newCube.transform.localRotation = Quaternion.Euler(0, 0, 0); + newCube.transform.localScale = boxShape.size; + } + else if (shape is SphereShape sphereShape) + { + var newSphere = UnityEngine.Object.Instantiate(sphere); + newSphere.transform.parent = shape.transform; + newSphere.transform.localPosition = Vector3.zero; + newSphere.transform.localRotation = Quaternion.Euler(0, 0, 0); + newSphere.transform.localScale = Vector3.one * (sphereShape.radius * 2); + } + else if (shape is CapsuleShape capsuleShape) + { + var newCapsule = Object.Instantiate(capsule); + newCapsule.transform.parent = shape.transform; + newCapsule.transform.localPosition = Vector3.zero; + newCapsule.transform.localRotation = Quaternion.Euler(0, 0, 0); + newCapsule.transform.localScale = new Vector3(capsuleShape.radius * 2, capsuleShape.height, capsuleShape.radius * 2); + } } } From 049b82a483e061b69ddaba80037f8f248b8720d8 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 17:29:49 +0100 Subject: [PATCH 05/18] fix orb issue again --- .../TransformSync/NomaiOrbTransformSync.cs | 27 +++++++++---------- QSB/Syncs/SyncBase.cs | 2 +- 2 files changed, 14 insertions(+), 15 deletions(-) diff --git a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs index aaeb19c7..60521afe 100644 --- a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs +++ b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs @@ -1,7 +1,7 @@ -using QSB.Syncs.Unsectored.Transforms; +using OWML.Common; +using QSB.Syncs.Unsectored.Transforms; using QSB.Utility; using QSB.WorldSync; -using QuantumUNET; using System.Collections.Generic; using UnityEngine; @@ -27,15 +27,9 @@ namespace QSB.OrbSync.TransformSync var originalParent = AttachedObject.GetAttachedOWRigidbody().GetOrigParent(); if (originalParent == Locator.GetRootTransform()) { - DebugLog.DebugWrite($"{_logName} with AttachedObject {AttachedObject.name} had it's original parent as SolarSystemRoot - Destroying..."); - if (QSBCore.IsHost) - { - QNetworkServer.Destroy(gameObject); - } - else - { - DebugLog.ToConsole($"Error - Parent mismatch when not running on host?! A client should never be spawning the orbs.", OWML.Common.MessageType.Error); - } + DebugLog.DebugWrite($"{_logName} with AttachedObject {AttachedObject.name} had it's original parent as SolarSystemRoot - Disabling..."); + enabled = false; + OrbTransformSyncs[_index] = null; } SetReferenceTransform(originalParent); @@ -45,22 +39,27 @@ namespace QSB.OrbSync.TransformSync { if (_index == -1) { - DebugLog.ToConsole($"Error - Index cannot be found.", OWML.Common.MessageType.Error); + DebugLog.ToConsole($"Error - Index cannot be found.", MessageType.Error); return null; } if (QSBWorldSync.OldOrbList == null || QSBWorldSync.OldOrbList.Count <= _index) { - DebugLog.ToConsole($"Error - OldOrbList is null or does not contain index {_index}.", OWML.Common.MessageType.Error); + DebugLog.ToConsole($"Error - OldOrbList is null or does not contain index {_index}.", MessageType.Error); return null; } if (QSBWorldSync.OldOrbList[_index] == null) { - DebugLog.ToConsole($"Error - OldOrbList index {_index} is null.", OWML.Common.MessageType.Error); + DebugLog.ToConsole($"Error - OldOrbList index {_index} is null.", MessageType.Error); return null; } + if (QSBWorldSync.OldOrbList.Count != OrbTransformSyncs.Count) + { + DebugLog.ToConsole($"Warning - OldOrbList count ({QSBWorldSync.OldOrbList.Count}) does not equal OrbTransformSyncs count ({OrbTransformSyncs.Count})!", MessageType.Warning); + } + return QSBWorldSync.OldOrbList[_index].transform; } diff --git a/QSB/Syncs/SyncBase.cs b/QSB/Syncs/SyncBase.cs index 5171b2cf..558b4cf2 100644 --- a/QSB/Syncs/SyncBase.cs +++ b/QSB/Syncs/SyncBase.cs @@ -86,7 +86,7 @@ namespace QSB.Syncs public Component AttachedObject { get; set; } public Transform ReferenceTransform { get; set; } - protected string _logName => $"{PlayerId}.{GetType().Name}"; + protected string _logName => $"{PlayerId}.{NetId.Value}:{GetType().Name}"; protected virtual float DistanceLeeway { get; } = 5f; private float _previousDistance; protected const float SmoothTime = 0.1f; From fea1d20fc429b2e2b692e673943d8f4cd264a4a4 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 17:41:03 +0100 Subject: [PATCH 06/18] fix server state issue? fixes #277 ? --- QSB/ClientServerStateSync/ServerStateManager.cs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/QSB/ClientServerStateSync/ServerStateManager.cs b/QSB/ClientServerStateSync/ServerStateManager.cs index 70722429..12f7ed6e 100644 --- a/QSB/ClientServerStateSync/ServerStateManager.cs +++ b/QSB/ClientServerStateSync/ServerStateManager.cs @@ -125,7 +125,8 @@ namespace QSB.ClientServerStateSync if (_currentState == ServerState.WaitingForAllPlayersToReady) { - if (QSBPlayerManager.PlayerList.All(x => x.State == ClientState.WaitingForOthersToReadyInSolarSystem)) + if (QSBPlayerManager.PlayerList.All(x => x.State == ClientState.WaitingForOthersToReadyInSolarSystem) + || QSBPlayerManager.PlayerList.All(x => x.State == ClientState.AliveInSolarSystem)) { DebugLog.DebugWrite($"All ready!!"); QSBEventManager.FireEvent(EventNames.QSBStartLoop); From 44237e9dd0793927a89d20df3500ee66cf63c6f6 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 20:46:32 +0100 Subject: [PATCH 07/18] fix #318 --- QSB/DeathSync/RespawnManager.cs | 1 + 1 file changed, 1 insertion(+) diff --git a/QSB/DeathSync/RespawnManager.cs b/QSB/DeathSync/RespawnManager.cs index de9ae658..7b104e2e 100644 --- a/QSB/DeathSync/RespawnManager.cs +++ b/QSB/DeathSync/RespawnManager.cs @@ -26,6 +26,7 @@ namespace QSB.DeathSync private void OnSceneLoaded(OWScene oldScene, OWScene newScene, bool inUniverse) { + QSBPlayerManager.ShowAllPlayers(); QSBPlayerManager.PlayerList.ForEach(x => x.IsDead = false); _playersPendingRespawn.Clear(); } From ab6a356d5afe75e63df54ac376ddb6198e7eced8 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Wed, 20 Oct 2021 20:54:34 +0100 Subject: [PATCH 08/18] add visible to debug gui --- QSB/Utility/DebugGUI.cs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/QSB/Utility/DebugGUI.cs b/QSB/Utility/DebugGUI.cs index 812b157c..355c8445 100644 --- a/QSB/Utility/DebugGUI.cs +++ b/QSB/Utility/DebugGUI.cs @@ -76,6 +76,8 @@ namespace QSB.Utility offset2 += _debugLineSpacing; GUI.Label(new Rect(420, offset2, 400f, 20f), $"Dead : {player.IsDead}", guiStyle); offset2 += _debugLineSpacing; + GUI.Label(new Rect(420, offset2, 400f, 20f), $"Visible : {player.Visible}", guiStyle); + offset2 += _debugLineSpacing; if (player.PlayerStates.IsReady && QSBCore.WorldObjectsReady) { From 2ae0751aa721743f9928bc0ca8c06b712a6a2456 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Thu, 21 Oct 2021 17:21:54 +0100 Subject: [PATCH 09/18] stuff --- QSB/ClientServerStateSync/ServerStateManager.cs | 8 ++++++++ QSB/Menus/MenuManager.cs | 3 +++ QSB/OrbSync/OrbManager.cs | 9 +++++++-- QSB/Player/Events/PlayerJoinEvent.cs | 14 ++++++++++++-- QSB/Player/Events/PlayerJoinMessage.cs | 3 +++ QSB/Player/GamePlatform.cs | 9 +++++++++ QSB/Player/KickReason.cs | 3 ++- QSB/QSB.csproj | 1 + QSB/QSBCore.cs | 4 ++++ QSB/default-config.json | 2 +- 10 files changed, 50 insertions(+), 6 deletions(-) create mode 100644 QSB/Player/GamePlatform.cs diff --git a/QSB/ClientServerStateSync/ServerStateManager.cs b/QSB/ClientServerStateSync/ServerStateManager.cs index 12f7ed6e..42e93e1b 100644 --- a/QSB/ClientServerStateSync/ServerStateManager.cs +++ b/QSB/ClientServerStateSync/ServerStateManager.cs @@ -15,6 +15,7 @@ namespace QSB.ClientServerStateSync public delegate void ChangeStateEvent(ServerState newState); private ServerState _currentState; + private bool _blockNextCheck; private void Awake() => Instance = this; @@ -123,6 +124,12 @@ namespace QSB.ClientServerStateSync return; } + if (_blockNextCheck) + { + _blockNextCheck = false; + return; + } + if (_currentState == ServerState.WaitingForAllPlayersToReady) { if (QSBPlayerManager.PlayerList.All(x => x.State == ClientState.WaitingForOthersToReadyInSolarSystem) @@ -131,6 +138,7 @@ namespace QSB.ClientServerStateSync DebugLog.DebugWrite($"All ready!!"); QSBEventManager.FireEvent(EventNames.QSBStartLoop); QSBEventManager.FireEvent(EventNames.QSBServerState, ServerState.InSolarSystem); + _blockNextCheck = true; } } } diff --git a/QSB/Menus/MenuManager.cs b/QSB/Menus/MenuManager.cs index cccdfb0d..b2077ad5 100644 --- a/QSB/Menus/MenuManager.cs +++ b/QSB/Menus/MenuManager.cs @@ -183,6 +183,9 @@ namespace QSB.Menus case KickReason.GameVersionNotMatching: text = "Server refused connection as Outer Wilds version does not match."; break; + case KickReason.GamePlatformNotMatching: + text = "Server refused connection as Outer Wilds platform does not match. (Steam/Epic)"; + break; case KickReason.None: text = "Kicked from server. No reason given."; break; diff --git a/QSB/OrbSync/OrbManager.cs b/QSB/OrbSync/OrbManager.cs index f2c7767b..3e283563 100644 --- a/QSB/OrbSync/OrbManager.cs +++ b/QSB/OrbSync/OrbManager.cs @@ -4,6 +4,7 @@ using QSB.OrbSync.WorldObjects; using QSB.Utility; using QSB.WorldSync; using QuantumUNET; +using System.Collections.Generic; using System.Linq; using UnityEngine; @@ -11,6 +12,8 @@ namespace QSB.OrbSync { public class OrbManager : WorldObjectManager { + private List _orbs = new List(); + protected override void RebuildWorldObjects(OWScene scene) { QSBWorldSync.Init(); @@ -24,11 +27,13 @@ namespace QSB.OrbSync QSBWorldSync.OldOrbList = Resources.FindObjectsOfTypeAll().ToList(); if (QSBCore.IsHost) { - NomaiOrbTransformSync.OrbTransformSyncs.ForEach(x => QNetworkServer.Destroy(x.gameObject)); + _orbs.ForEach(x => QNetworkServer.Destroy(x)); + _orbs.Clear(); NomaiOrbTransformSync.OrbTransformSyncs.Clear(); foreach (var orb in QSBWorldSync.OldOrbList) { - Instantiate(QSBNetworkManager.Instance.OrbPrefab).SpawnWithServerAuthority(); + var newOrb = Instantiate(QSBNetworkManager.Instance.OrbPrefab); + newOrb.SpawnWithServerAuthority(); } } diff --git a/QSB/Player/Events/PlayerJoinEvent.cs b/QSB/Player/Events/PlayerJoinEvent.cs index b5d6ee1a..7a3f0149 100644 --- a/QSB/Player/Events/PlayerJoinEvent.cs +++ b/QSB/Player/Events/PlayerJoinEvent.cs @@ -18,7 +18,8 @@ namespace QSB.Player.Events AboutId = LocalPlayerId, PlayerName = name, QSBVersion = QSBCore.QSBVersion, - GameVersion = QSBCore.GameVersion + GameVersion = QSBCore.GameVersion, + Platform = QSBCore.Platform }; public override void OnReceiveRemote(bool server, PlayerJoinMessage message) @@ -45,10 +46,19 @@ namespace QSB.Player.Events return; } + if (message.Platform != QSBCore.Platform) + { + if (server) + { + DebugLog.ToConsole($"Error - Client {message.PlayerName} connecting with wrong game platform. (Client:{message.Platform}, Server:{QSBCore.Platform})", MessageType.Error); + QSBEventManager.FireEvent(EventNames.QSBPlayerKick, message.AboutId, KickReason.GamePlatformNotMatching); + } + } + var player = QSBPlayerManager.GetPlayer(message.AboutId); player.Name = message.PlayerName; DebugLog.ToAll($"{player.Name} joined!", MessageType.Info); - DebugLog.DebugWrite($"{player.Name} joined. id:{player.PlayerId}, qsbVersion:{message.QSBVersion}, gameVersion:{message.GameVersion}", MessageType.Info); + DebugLog.DebugWrite($"{player.Name} joined. id:{player.PlayerId}, qsbVersion:{message.QSBVersion}, gameVersion:{message.GameVersion}, platform:{message.Platform}", MessageType.Info); } public override void OnReceiveLocal(bool server, PlayerJoinMessage message) diff --git a/QSB/Player/Events/PlayerJoinMessage.cs b/QSB/Player/Events/PlayerJoinMessage.cs index 1dab8bda..a07f5f4d 100644 --- a/QSB/Player/Events/PlayerJoinMessage.cs +++ b/QSB/Player/Events/PlayerJoinMessage.cs @@ -8,6 +8,7 @@ namespace QSB.Player.Events public string PlayerName { get; set; } public string QSBVersion { get; set; } public string GameVersion { get; set; } + public GamePlatform Platform { get; set; } public override void Deserialize(QNetworkReader reader) { @@ -15,6 +16,7 @@ namespace QSB.Player.Events PlayerName = reader.ReadString(); QSBVersion = reader.ReadString(); GameVersion = reader.ReadString(); + Platform = (GamePlatform)reader.ReadInt32(); } public override void Serialize(QNetworkWriter writer) @@ -23,6 +25,7 @@ namespace QSB.Player.Events writer.Write(PlayerName); writer.Write(QSBVersion); writer.Write(GameVersion); + writer.Write((int)Platform); } } } \ No newline at end of file diff --git a/QSB/Player/GamePlatform.cs b/QSB/Player/GamePlatform.cs new file mode 100644 index 00000000..6aedb3f1 --- /dev/null +++ b/QSB/Player/GamePlatform.cs @@ -0,0 +1,9 @@ +namespace QSB.Player +{ + public enum GamePlatform + { + None, + Steam, + Epic + } +} diff --git a/QSB/Player/KickReason.cs b/QSB/Player/KickReason.cs index 4e911581..d02b4159 100644 --- a/QSB/Player/KickReason.cs +++ b/QSB/Player/KickReason.cs @@ -4,6 +4,7 @@ { None, QSBVersionNotMatching, - GameVersionNotMatching + GameVersionNotMatching, + GamePlatformNotMatching } } diff --git a/QSB/QSB.csproj b/QSB/QSB.csproj index c191550b..294f9217 100644 --- a/QSB/QSB.csproj +++ b/QSB/QSB.csproj @@ -109,6 +109,7 @@ + diff --git a/QSB/QSBCore.cs b/QSB/QSBCore.cs index 784c7f49..3b361975 100644 --- a/QSB/QSBCore.cs +++ b/QSB/QSBCore.cs @@ -26,6 +26,7 @@ using QSB.Utility; using QSB.WorldSync; using QuantumUNET; using QuantumUNET.Components; +using System.Linq; using UnityEngine; /* @@ -65,6 +66,9 @@ namespace QSB public static bool IsInMultiplayer => QNetworkManager.singleton.isNetworkActive; public static string QSBVersion => Helper.Manifest.Version; public static string GameVersion => Application.version; + public static GamePlatform Platform => typeof(Achievements).Assembly.GetTypes().Any(x => x.Name == "EpicEntitlementRetriever") + ? GamePlatform.Epic + : GamePlatform.Steam; public static IMenuAPI MenuApi { get; private set; } public void Awake() diff --git a/QSB/default-config.json b/QSB/default-config.json index fedee1d0..ffe88285 100644 --- a/QSB/default-config.json +++ b/QSB/default-config.json @@ -3,7 +3,7 @@ "settings": { "defaultServerIP": "localhost", "port": 7777, - "debugMode": true, + "debugMode": false, "showLinesInDebug": false } } \ No newline at end of file From 6146a5300df3d3a0099c6dc23d4b43044540bd25 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Sat, 23 Oct 2021 20:06:43 +0100 Subject: [PATCH 10/18] Update manifest.json --- QSB/manifest.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/QSB/manifest.json b/QSB/manifest.json index 32918373..fd9f720f 100644 --- a/QSB/manifest.json +++ b/QSB/manifest.json @@ -9,6 +9,6 @@ }, "uniqueName": "Raicuparta.QuantumSpaceBuddies", "version": "0.12.0-pr4", - "owmlVersion": "2.0.0", + "owmlVersion": "2.1.0", "dependencies": [ "_nebula.MenuFramework" ] } \ No newline at end of file From 54b2cca481284946f7b16fad7212e508a5895f6f Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Sat, 23 Oct 2021 21:17:49 +0100 Subject: [PATCH 11/18] closes #324 --- QSB/Syncs/Sectored/BaseSectoredSync.cs | 6 ++++++ QSB/Syncs/SyncBase.cs | 8 ++++++++ 2 files changed, 14 insertions(+) diff --git a/QSB/Syncs/Sectored/BaseSectoredSync.cs b/QSB/Syncs/Sectored/BaseSectoredSync.cs index f52a6239..5d645415 100644 --- a/QSB/Syncs/Sectored/BaseSectoredSync.cs +++ b/QSB/Syncs/Sectored/BaseSectoredSync.cs @@ -67,6 +67,12 @@ namespace QSB.Syncs.Sectored { if (_sectorIdWaitingSlot == int.MinValue) { + if (ReferenceSector != null && ReferenceSector.Transform != ReferenceTransform) + { + DebugLog.ToConsole($"Warning - {_logName} : ReferenceSector.Transform was different to ReferenceTransform. Correcting...", OWML.Common.MessageType.Warning); + SetReferenceTransform(ReferenceSector.Transform); + } + base.Update(); return; } diff --git a/QSB/Syncs/SyncBase.cs b/QSB/Syncs/SyncBase.cs index 558b4cf2..1c98238c 100644 --- a/QSB/Syncs/SyncBase.cs +++ b/QSB/Syncs/SyncBase.cs @@ -223,6 +223,14 @@ namespace QSB.Syncs return; } + if (ShouldReparentAttachedObject + && !HasAuthority + && AttachedObject.transform.parent != ReferenceTransform) + { + DebugLog.ToConsole($"Warning : {_logName} : AttachedObject's parent is different to ReferenceTransform. Correcting...", MessageType.Warning); + ReparentAttachedObject(ReferenceTransform); + } + UpdateTransform(); base.Update(); From bccc4e18738d792de106d8a61f7c97a669013244 Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Sun, 24 Oct 2021 10:47:25 +0100 Subject: [PATCH 12/18] fix some logs --- .../Events/ClientStateEvent.cs | 2 +- .../TransformSync/NomaiOrbTransformSync.cs | 8 +++++++- QSB/Patches/QSBPatchManager.cs | 2 +- QSB/Player/PlayerHUDMarker.cs | 2 +- QSB/Player/QSBPlayerManager.cs | 9 ++++++++- QSB/ProbeSync/QSBProbe.cs | 2 +- QSB/QuantumSync/Patches/QuantumPatches.cs | 2 +- QSB/SectorSync/SectorSync.cs | 13 ++++++++++++- QSB/Syncs/IntermediaryTransform.cs | 8 ++++---- QSB/TimeSync/WakeUpSync.cs | 2 +- QSB/WorldSync/QSBWorldSync.cs | 16 ++++++++++++++-- 11 files changed, 51 insertions(+), 15 deletions(-) diff --git a/QSB/ClientServerStateSync/Events/ClientStateEvent.cs b/QSB/ClientServerStateSync/Events/ClientStateEvent.cs index 3e9b0890..b664a3e1 100644 --- a/QSB/ClientServerStateSync/Events/ClientStateEvent.cs +++ b/QSB/ClientServerStateSync/Events/ClientStateEvent.cs @@ -30,7 +30,7 @@ namespace QSB.ClientServerStateSync.Events { if (message.AboutId == uint.MaxValue) { - DebugLog.DebugWrite($"Error - ID is uint.MaxValue!", OWML.Common.MessageType.Error); + DebugLog.ToConsole($"Error - ID is uint.MaxValue!", OWML.Common.MessageType.Error); return; } diff --git a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs index 60521afe..915705b2 100644 --- a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs +++ b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs @@ -24,6 +24,12 @@ namespace QSB.OrbSync.TransformSync protected override void Init() { base.Init(); + + if (AttachedObject == null) + { + DebugLog.ToConsole($"Error - Trying to init orb with null AttachedObject.", MessageType.Error); + } + var originalParent = AttachedObject.GetAttachedOWRigidbody().GetOrigParent(); if (originalParent == Locator.GetRootTransform()) { @@ -39,7 +45,7 @@ namespace QSB.OrbSync.TransformSync { if (_index == -1) { - DebugLog.ToConsole($"Error - Index cannot be found.", MessageType.Error); + DebugLog.ToConsole($"Error - Index cannot be found. OrbTransformSyncs count : {OrbTransformSyncs.Count}", MessageType.Error); return null; } diff --git a/QSB/Patches/QSBPatchManager.cs b/QSB/Patches/QSBPatchManager.cs index 508c31a7..c0bb40f6 100644 --- a/QSB/Patches/QSBPatchManager.cs +++ b/QSB/Patches/QSBPatchManager.cs @@ -94,7 +94,7 @@ namespace QSB.Patches } catch (Exception ex) { - DebugLog.DebugWrite($"Error while patching {patch.GetType().Name} :\r\n{ex}", MessageType.Error); + DebugLog.ToConsole($"Error while patching {patch.GetType().Name} :\r\n{ex}", MessageType.Error); } } } diff --git a/QSB/Player/PlayerHUDMarker.cs b/QSB/Player/PlayerHUDMarker.cs index 9fdf8047..9835b3da 100644 --- a/QSB/Player/PlayerHUDMarker.cs +++ b/QSB/Player/PlayerHUDMarker.cs @@ -50,7 +50,7 @@ namespace QSB.Player } else { - DebugLog.DebugWrite($"Warning - _canvasMarker for {_player.PlayerId} is null!", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - _canvasMarker for {_player.PlayerId} is null!", OWML.Common.MessageType.Warning); } } diff --git a/QSB/Player/QSBPlayerManager.cs b/QSB/Player/QSBPlayerManager.cs index 7cfc2560..377b1ef4 100644 --- a/QSB/Player/QSBPlayerManager.cs +++ b/QSB/Player/QSBPlayerManager.cs @@ -120,7 +120,8 @@ namespace QSB.Player return cameraList; } - DebugLog.DebugWrite($"Error - LocalPlayer.Camera is null.", MessageType.Error); + DebugLog.ToConsole($"Error - LocalPlayer.Camera is null.", MessageType.Error); + LocalPlayer.Camera = Locator.GetPlayerCamera(); } return cameraList; @@ -158,6 +159,12 @@ namespace QSB.Player public static PlayerInfo GetClosestPlayerToWorldPoint(List playerList, Vector3 worldPoint) { + if (playerList == null) + { + DebugLog.ToConsole($"Error - Cannot get closest player from null player list.", MessageType.Error); + return null; + } + if (playerList.Count == 0) { DebugLog.ToConsole($"Error - Cannot get closest player from empty player list.", MessageType.Error); diff --git a/QSB/ProbeSync/QSBProbe.cs b/QSB/ProbeSync/QSBProbe.cs index aad3382c..198645fb 100644 --- a/QSB/ProbeSync/QSBProbe.cs +++ b/QSB/ProbeSync/QSBProbe.cs @@ -111,7 +111,7 @@ namespace QSB.ProbeSync break; case ProbeEvent.Invalid: default: - DebugLog.DebugWrite($"Warning - Unknown/Invalid probe event.", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - Unknown/Invalid probe event.", OWML.Common.MessageType.Warning); break; } } diff --git a/QSB/QuantumSync/Patches/QuantumPatches.cs b/QSB/QuantumSync/Patches/QuantumPatches.cs index aef42d5e..0ebd1e96 100644 --- a/QSB/QuantumSync/Patches/QuantumPatches.cs +++ b/QSB/QuantumSync/Patches/QuantumPatches.cs @@ -295,7 +295,7 @@ namespace QSB.QuantumSync.Patches var owner = allMultiStates.FirstOrDefault(x => x.QuantumStates.Contains(stateObject)); if (owner == default) { - DebugLog.DebugWrite($"Error - Could not find QSBMultiStateQuantumObject for state {__instance.name}", MessageType.Error); + DebugLog.ToConsole($"Error - Could not find QSBMultiStateQuantumObject for state {__instance.name}", MessageType.Error); return; } diff --git a/QSB/SectorSync/SectorSync.cs b/QSB/SectorSync/SectorSync.cs index 457e6421..2b998c98 100644 --- a/QSB/SectorSync/SectorSync.cs +++ b/QSB/SectorSync/SectorSync.cs @@ -131,7 +131,18 @@ namespace QSB.SectorSync return null; } - var numSectorsCurrentlyIn = SectorList.Count(x => x.ShouldSyncTo(_targetType)); + bool ShouldSyncTo(QSBSector sector, TargetType type) + { + if (sector == null) + { + DebugLog.ToConsole($"Warning - Tried to check if we should sync to null sector!", MessageType.Warning); + return false; + } + + return sector.ShouldSyncTo(type); + } + + var numSectorsCurrentlyIn = SectorList.Count(x => ShouldSyncTo(x, _targetType)); var listToCheck = numSectorsCurrentlyIn == 0 ? QSBWorldSync.GetWorldObjects().Where(x => !x.IsFakeSector && x.Type != Sector.Name.Unnamed) diff --git a/QSB/Syncs/IntermediaryTransform.cs b/QSB/Syncs/IntermediaryTransform.cs index ea5f95de..f4ec1ae8 100644 --- a/QSB/Syncs/IntermediaryTransform.cs +++ b/QSB/Syncs/IntermediaryTransform.cs @@ -58,7 +58,7 @@ namespace QSB.Syncs { if (_referenceTransform == null) { - DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name} \r\n{Environment.StackTrace}", MessageType.Error); + DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name}", MessageType.Error); return; } @@ -73,7 +73,7 @@ namespace QSB.Syncs { if (_referenceTransform == null) { - DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name} \r\n{Environment.StackTrace}", MessageType.Error); + DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name}", MessageType.Error); return; } @@ -99,7 +99,7 @@ namespace QSB.Syncs { if (_referenceTransform == null) { - DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name} \r\n{Environment.StackTrace}", MessageType.Error); + DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name}", MessageType.Error); return Vector3.zero; } @@ -113,7 +113,7 @@ namespace QSB.Syncs { if (_referenceTransform == null) { - DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name} \r\n{Environment.StackTrace}", MessageType.Error); + DebugLog.ToConsole($"Error - _referenceTransform has not been set for {_attachedTransform.name}", MessageType.Error); return Quaternion.identity; } diff --git a/QSB/TimeSync/WakeUpSync.cs b/QSB/TimeSync/WakeUpSync.cs index 06cdc885..489cad8f 100644 --- a/QSB/TimeSync/WakeUpSync.cs +++ b/QSB/TimeSync/WakeUpSync.cs @@ -293,7 +293,7 @@ namespace QSB.TimeSync if (CurrentState != State.Loaded && CurrentState != State.NotLoaded && CurrentReason == null) { - DebugLog.DebugWrite($"Warning - CurrentReason is null.", MessageType.Warning); + DebugLog.ToConsole($"Warning - CurrentReason is null.", MessageType.Warning); } // Checks to pause/fastforward diff --git a/QSB/WorldSync/QSBWorldSync.cs b/QSB/WorldSync/QSBWorldSync.cs index a61f9fa5..0d7a31de 100644 --- a/QSB/WorldSync/QSBWorldSync.cs +++ b/QSB/WorldSync/QSBWorldSync.cs @@ -90,17 +90,29 @@ namespace QSB.WorldSync public static void RemoveWorldObjects() { + if (WorldObjects == null || WorldObjects.Count == 0) + { + DebugLog.ToConsole($"Warning - Trying to remove WorldObjects of type {typeof(TWorldObject).Name}, but there are no WorldObjects!"); + } + var itemsToRemove = WorldObjects.Where(x => x is TWorldObject); + foreach (var item in itemsToRemove) { - WorldObjectsToUnityObjects.Remove(item.ReturnObject()); + if (item is null) + { + DebugLog.ToConsole($"Error - Trying to remove a null WorldObject of type {typeof(TWorldObject).Name}.", MessageType.Error); + continue; + } + try { + WorldObjectsToUnityObjects.Remove(item.ReturnObject()); item.OnRemoval(); } catch (Exception e) { - DebugLog.ToConsole($"Error - Exception in OnRemoval() for {item.GetType()}. Message : {e.InnerException.Message}, Stack trace : {e.InnerException.StackTrace}", MessageType.Error); + DebugLog.ToConsole($"Error - Exception in OnRemoval() for {item.GetType()}. Message : {e.Message}, Stack trace : {e.StackTrace}", MessageType.Error); } } From 7dd79678347760483a13cdc0ea572cc437a2e1be Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 10:42:25 +0100 Subject: [PATCH 13/18] more fixes goddamn --- QSB/OrbSync/OrbManager.cs | 1 + QSB/Player/PlayerInfo.cs | 55 +++++++++++++++++++++--- QSB/SectorSync/WorldObjects/QSBSector.cs | 15 ++++++- QSB/Syncs/Sectored/BaseSectoredSync.cs | 6 +++ QSB/Utility/DebugGUI.cs | 20 +++++++-- 5 files changed, 86 insertions(+), 11 deletions(-) diff --git a/QSB/OrbSync/OrbManager.cs b/QSB/OrbSync/OrbManager.cs index 3e283563..135ed560 100644 --- a/QSB/OrbSync/OrbManager.cs +++ b/QSB/OrbSync/OrbManager.cs @@ -34,6 +34,7 @@ namespace QSB.OrbSync { var newOrb = Instantiate(QSBNetworkManager.Instance.OrbPrefab); newOrb.SpawnWithServerAuthority(); + _orbs.Add(newOrb); } } diff --git a/QSB/Player/PlayerInfo.cs b/QSB/Player/PlayerInfo.cs index 01a28795..9d8430a9 100644 --- a/QSB/Player/PlayerInfo.cs +++ b/QSB/Player/PlayerInfo.cs @@ -1,4 +1,5 @@ -using QSB.Animation.Player; +using OWML.Common; +using QSB.Animation.Player; using QSB.Animation.Player.Thrusters; using QSB.CampfireSync.WorldObjects; using QSB.ClientServerStateSync; @@ -23,9 +24,49 @@ namespace QSB.Player public PlayerTransformSync TransformSync { get; set; } // Body Objects - public OWCamera Camera { get; set; } + public OWCamera Camera + { + get + { + if (_camera == null && PlayerStates.IsReady) + { + DebugLog.ToConsole($"Warning - {PlayerId}.Camera is null!", MessageType.Warning); + } + return _camera; + } + set + { + if (value == null) + { + DebugLog.ToConsole($"Warning - Setting {PlayerId}.Camera to null.", MessageType.Warning); + } + _camera = value; + } + } + private OWCamera _camera; + public GameObject CameraBody { get; set; } - public GameObject Body { get; set; } + public GameObject Body + { + get + { + if (_body == null && PlayerStates.IsReady) + { + DebugLog.ToConsole($"Warning - {PlayerId}.Body is null!", MessageType.Warning); + } + return _body; + } + set + { + if (value == null) + { + DebugLog.ToConsole($"Warning - Setting {PlayerId}.Body to null.", MessageType.Warning); + } + _body = value; + } + } + private GameObject _body; + public GameObject RoastingStick { get; set; } public bool Visible { get; set; } = true; @@ -79,7 +120,7 @@ namespace QSB.Player { if (QSBPlayerManager.LocalPlayer != this) { - DebugLog.ToConsole($"Warning - Tried to access local-only property LocalProbeLauncher in PlayerInfo for non local player!", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - Tried to access local-only property LocalProbeLauncher in PlayerInfo for non local player!", MessageType.Warning); return null; } @@ -93,7 +134,7 @@ namespace QSB.Player { if (QSBPlayerManager.LocalPlayer != this) { - DebugLog.ToConsole($"Warning - Tried to access local-only property LocalFlashlight in PlayerInfo for non local player!", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - Tried to access local-only property LocalFlashlight in PlayerInfo for non local player!", MessageType.Warning); return null; } @@ -107,7 +148,7 @@ namespace QSB.Player { if (QSBPlayerManager.LocalPlayer != this) { - DebugLog.ToConsole($"Warning - Tried to access local-only property LocalSignalscope in PlayerInfo for non local player!", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - Tried to access local-only property LocalSignalscope in PlayerInfo for non local player!", MessageType.Warning); return null; } @@ -121,7 +162,7 @@ namespace QSB.Player { if (QSBPlayerManager.LocalPlayer != this) { - DebugLog.ToConsole($"Warning - Tried to access local-only property LocalTranslator in PlayerInfo for non local player!", OWML.Common.MessageType.Warning); + DebugLog.ToConsole($"Warning - Tried to access local-only property LocalTranslator in PlayerInfo for non local player!", MessageType.Warning); return null; } diff --git a/QSB/SectorSync/WorldObjects/QSBSector.cs b/QSB/SectorSync/WorldObjects/QSBSector.cs index c0be4c60..dbd76ccf 100644 --- a/QSB/SectorSync/WorldObjects/QSBSector.cs +++ b/QSB/SectorSync/WorldObjects/QSBSector.cs @@ -2,6 +2,7 @@ using OWML.Utils; using QSB.Utility; using QSB.WorldSync; +using System; using System.Linq; using UnityEngine; @@ -10,7 +11,19 @@ namespace QSB.SectorSync.WorldObjects public class QSBSector : WorldObject { public Sector.Name Type => AttachedObject.GetName(); - public Transform Transform => AttachedObject.transform; + public Transform Transform + { + get + { + if (AttachedObject == null) + { + DebugLog.ToConsole($"Error - Tried to get Transform from QSBSector {ObjectId} with null AttachedObject!\r\n{Environment.StackTrace}", MessageType.Error); + return null; + } + + return AttachedObject.transform; + } + } public Vector3 Position => Transform.position; public bool IsFakeSector => AttachedObject.GetType() == typeof(FakeSector); diff --git a/QSB/Syncs/Sectored/BaseSectoredSync.cs b/QSB/Syncs/Sectored/BaseSectoredSync.cs index 5d645415..36064dab 100644 --- a/QSB/Syncs/Sectored/BaseSectoredSync.cs +++ b/QSB/Syncs/Sectored/BaseSectoredSync.cs @@ -34,6 +34,12 @@ namespace QSB.Syncs.Sectored } } + protected override void OnSceneLoaded(OWScene oldScene, OWScene newScene, bool isInUniverse) + { + base.OnSceneLoaded(oldScene, newScene, isInUniverse); + SetReferenceSector(null); + } + protected override void Init() { base.Init(); diff --git a/QSB/Utility/DebugGUI.cs b/QSB/Utility/DebugGUI.cs index 355c8445..d09d0baf 100644 --- a/QSB/Utility/DebugGUI.cs +++ b/QSB/Utility/DebugGUI.cs @@ -1,4 +1,5 @@ -using QSB.ClientServerStateSync; +using OWML.Utils; +using QSB.ClientServerStateSync; using QSB.OrbSync.TransformSync; using QSB.Player; using QSB.ProbeSync.TransformSync; @@ -82,12 +83,24 @@ namespace QSB.Utility if (player.PlayerStates.IsReady && QSBCore.WorldObjectsReady) { var networkTransform = player.TransformSync; - var sector = networkTransform.ReferenceSector; + var referenceSector = networkTransform.ReferenceSector; + var referenceTransform = networkTransform.ReferenceTransform; + var parent = networkTransform.AttachedObject?.transform.parent; + var intermediary = networkTransform.GetValue("_intermediaryTransform"); + var interTransform = intermediary.GetReferenceTransform(); GUI.Label(new Rect(420, offset2, 400f, 20f), $" - L.Pos : {networkTransform.transform.localPosition}", guiStyle); offset2 += _debugLineSpacing; - GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Sector : {(sector == null ? "NULL" : sector.Name)}", guiStyle); + GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Ref. Sector : {(referenceSector == null ? "NULL" : referenceSector.Name)}", guiStyle); offset2 += _debugLineSpacing; + GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Ref. Transform : {(referenceTransform == null ? "NULL" : referenceTransform.name)}", guiStyle); + offset2 += _debugLineSpacing; + GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Inter. Ref. Transform : {(interTransform == null ? "NULL" : interTransform.name)}", guiStyle); + offset2 += _debugLineSpacing; + GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Parent : {(parent == null ? "NULL" : parent.name)}", guiStyle); + offset2 += _debugLineSpacing; + + /* var probeSync = SyncBase.GetPlayers(player); if (probeSync != default) { @@ -95,6 +108,7 @@ namespace QSB.Utility GUI.Label(new Rect(420, offset2, 400f, 20f), $" - Probe Sector : {(probeSector == null ? "NULL" : probeSector.Name)}", guiStyle); offset2 += _debugLineSpacing; } + */ } } } From 5ffaccc4dd2639c28c509c0e0829c5edbba55ead Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 11:07:09 +0100 Subject: [PATCH 14/18] skip null orbs when checking ownership --- QSB/QSBNetworkManager.cs | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/QSB/QSBNetworkManager.cs b/QSB/QSBNetworkManager.cs index 62d23dc4..49ef38d9 100644 --- a/QSB/QSBNetworkManager.cs +++ b/QSB/QSBNetworkManager.cs @@ -234,6 +234,11 @@ namespace QSB foreach (var item in NomaiOrbTransformSync.OrbTransformSyncs) { + if (item is null) + { + continue; + } + var identity = item.GetComponent(); if (identity.ClientAuthorityOwner == connection) { From 6eccc40f3e9b858bfed669abd41ba4e8b24fdf0c Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 15:00:27 +0100 Subject: [PATCH 15/18] fix issue when joining game from pause menu --- QSB/QSBCore.cs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/QSB/QSBCore.cs b/QSB/QSBCore.cs index 3b361975..c23caf2e 100644 --- a/QSB/QSBCore.cs +++ b/QSB/QSBCore.cs @@ -131,6 +131,10 @@ namespace QSB if (type == QSBPatchTypes.OnClientConnect) { Application.runInBackground = true; + if (Locator.GetSceneMenuManager().pauseMenu.IsOpen()) + { + Locator.GetSceneMenuManager().pauseMenu._pauseMenu.EnableMenu(false); + } } } From 01d87df8043573d606f6af50b25ce720532b422e Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 15:16:03 +0100 Subject: [PATCH 16/18] fix nre in menu --- QSB/QSBCore.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/QSB/QSBCore.cs b/QSB/QSBCore.cs index c23caf2e..ef1c7bc0 100644 --- a/QSB/QSBCore.cs +++ b/QSB/QSBCore.cs @@ -131,7 +131,7 @@ namespace QSB if (type == QSBPatchTypes.OnClientConnect) { Application.runInBackground = true; - if (Locator.GetSceneMenuManager().pauseMenu.IsOpen()) + if (Locator.GetSceneMenuManager() != null && Locator.GetSceneMenuManager().pauseMenu.IsOpen()) { Locator.GetSceneMenuManager().pauseMenu._pauseMenu.EnableMenu(false); } From 8943dc76b5b724b0205e054f6032a3ff5e79d05f Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 16:31:15 +0100 Subject: [PATCH 17/18] more fixes, my god --- QSB/OrbSync/OrbManager.cs | 2 +- QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs | 11 ++++++----- QSB/TimeSync/WakeUpSync.cs | 10 ++++++++++ 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/QSB/OrbSync/OrbManager.cs b/QSB/OrbSync/OrbManager.cs index 135ed560..50c842fb 100644 --- a/QSB/OrbSync/OrbManager.cs +++ b/QSB/OrbSync/OrbManager.cs @@ -24,12 +24,12 @@ namespace QSB.OrbSync private void BuildOrbs() { QSBWorldSync.OldOrbList.Clear(); + NomaiOrbTransformSync.OrbTransformSyncs.Clear(); QSBWorldSync.OldOrbList = Resources.FindObjectsOfTypeAll().ToList(); if (QSBCore.IsHost) { _orbs.ForEach(x => QNetworkServer.Destroy(x)); _orbs.Clear(); - NomaiOrbTransformSync.OrbTransformSyncs.Clear(); foreach (var orb in QSBWorldSync.OldOrbList) { var newOrb = Instantiate(QSBNetworkManager.Instance.OrbPrefab); diff --git a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs index 915705b2..a2060a79 100644 --- a/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs +++ b/QSB/OrbSync/TransformSync/NomaiOrbTransformSync.cs @@ -23,11 +23,17 @@ namespace QSB.OrbSync.TransformSync protected override void Init() { + if (!OrbTransformSyncs.Contains(this)) + { + OrbTransformSyncs.Add(this); + } + base.Init(); if (AttachedObject == null) { DebugLog.ToConsole($"Error - Trying to init orb with null AttachedObject.", MessageType.Error); + return; } var originalParent = AttachedObject.GetAttachedOWRigidbody().GetOrigParent(); @@ -61,11 +67,6 @@ namespace QSB.OrbSync.TransformSync return null; } - if (QSBWorldSync.OldOrbList.Count != OrbTransformSyncs.Count) - { - DebugLog.ToConsole($"Warning - OldOrbList count ({QSBWorldSync.OldOrbList.Count}) does not equal OrbTransformSyncs count ({OrbTransformSyncs.Count})!", MessageType.Warning); - } - return QSBWorldSync.OldOrbList[_index].transform; } diff --git a/QSB/TimeSync/WakeUpSync.cs b/QSB/TimeSync/WakeUpSync.cs index 489cad8f..e3a8d806 100644 --- a/QSB/TimeSync/WakeUpSync.cs +++ b/QSB/TimeSync/WakeUpSync.cs @@ -255,6 +255,16 @@ namespace QSB.TimeSync } } + if (serverState == ServerState.WaitingForAllPlayersToDie && clientState == ClientState.WaitingForOthersToReadyInSolarSystem) + { + if (CurrentState == State.Pausing && (PauseReason)CurrentReason == PauseReason.WaitingForAllPlayersToBeReady) + { + //? + DebugLog.ToConsole($"Warning - Server waiting for players to die, but players waiting for ready signal! Assume players correct.", MessageType.Warning); + QSBEventManager.FireEvent(EventNames.QSBServerState, ServerState.WaitingForAllPlayersToReady); + } + } + if (CurrentState != State.Loaded) { return; From 51149fc70071990009c3a89981efe395abb9b29a Mon Sep 17 00:00:00 2001 From: Mister_Nebula <41904486+misternebula@users.noreply.github.com> Date: Mon, 25 Oct 2021 16:35:16 +0100 Subject: [PATCH 18/18] catch error if profile doesnt exist --- QSB/QSBNetworkManager.cs | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/QSB/QSBNetworkManager.cs b/QSB/QSBNetworkManager.cs index 49ef38d9..65254a34 100644 --- a/QSB/QSBNetworkManager.cs +++ b/QSB/QSBNetworkManager.cs @@ -87,11 +87,19 @@ namespace QSB private string GetPlayerName() { - var profileManager = StandaloneProfileManager.SharedInstance; - profileManager.Initialize(); - var profile = profileManager.GetValue("_currentProfile"); - var profileName = profile.profileName; - return profileName; + try + { + var profileManager = StandaloneProfileManager.SharedInstance; + profileManager.Initialize(); + var profile = profileManager._currentProfile; + var profileName = profile.profileName; + return profileName; + } + catch (Exception ex) + { + DebugLog.ToConsole($"Error - Exception when getting player name : {ex}", MessageType.Error); + return "Player"; + } } private void SetupNetworkId(GameObject go, int assetId)