using OWML.Common; using OWML.ModHelper; using OWML.ModHelper.Events; using QSB.ConversationSync; using QSB.ElevatorSync; using QSB.GeyserSync; using QSB.OrbSync; using QSB.Patches; using QSB.SectorSync; using QSB.Utility; using UnityEngine; using UnityEngine.Networking; namespace QSB { public class QSB : ModBehaviour { public static IModBehaviour ModBehaviour { get; private set; } public static IModHelper Helper { get; private set; } public static string DefaultServerIP { get; private set; } public static int Port { get; private set; } public static bool DebugMode { get; private set; } public static AssetBundle NetworkAssetBundle { get; private set; } public static AssetBundle InstrumentAssetBundle { get; private set; } public static bool HasWokenUp { get; set; } private void Awake() { Application.runInBackground = true; var instance = TextTranslation.Get().GetValue("m_table"); instance.theUITable[(int)UITextType.PleaseUseController] = "Quantum Space Buddies is best experienced with friends..."; ModBehaviour = this; } private void Start() { Helper = ModHelper; DebugLog.ToConsole($"* Start of QSB version {Helper.Manifest.Version} - authored by {Helper.Manifest.Author}", MessageType.Info); NetworkAssetBundle = Helper.Assets.LoadBundle("assets/network"); InstrumentAssetBundle = Helper.Assets.LoadBundle("assets/instruments"); QSBPatchManager.Init(); QSBPatchManager.DoPatchType(QSBPatchTypes.OnModStart); // Turns out these are very finicky about what order they go. QSBNetworkManager seems to // want to go first-ish, otherwise the NetworkManager complains about the PlayerPrefab being // null (even though it isn't...) gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); gameObject.AddComponent(); Helper.Events.Unity.RunWhen(() => PlayerData.IsLoaded(), RebuildSettingsSave); } private void RebuildSettingsSave() { if (PlayerData.GetFreezeTimeWhileReadingConversations() || PlayerData.GetFreezeTimeWhileReadingTranslator() || PlayerData.GetFreezeTimeWhileReadingShipLog()) { DebugLog.DebugWrite("Rebuilding SettingsSave..."); var clonedData = PlayerData.CloneSettingsData(); clonedData.freezeTimeWhileReading = false; clonedData.freezeTimeWhileReadingConversations = false; clonedData.freezeTimeWhileReadingShipLog = false; PlayerData.SetSettingsData(clonedData); } } public override void Configure(IModConfig config) { DefaultServerIP = config.GetSettingsValue("defaultServerIP"); Port = config.GetSettingsValue("port"); if (QSBNetworkManager.Instance != null) { QSBNetworkManager.Instance.networkPort = Port; } DebugMode = config.GetSettingsValue("debugMode"); } } }