private void Deinit() { LoadPassengersPatch.Undo(); UnloadPassengersPatch.Undo(); DepotAIPatch.Undo(); NetManagerPatch.Undo(); VehicleManagerPatch.Undo(); PublicTransportLineVehicleModelSelectorRefreshPatch.Undo(); Redirector <TramAIDetour> .Revert(); Redirector <PassengerTrainAIDetour> .Revert(); Redirector <PassengerShipAIDetour> .Revert(); Redirector <PassengerPlaneAIDetour> .Revert(); Redirector <PassengerFerryAIDetour> .Revert(); Redirector <PassengerBlimpAIDetour> .Revert(); Redirector <BusAIDetour> .Revert(); Redirector <CommonBuildingAIReverseDetour> .Revert(); Redirector <PublicTransportStopButtonDetour> .Revert(); Redirector <PublicTransportVehicleButtonDetour> .Revert(); Redirector <PublicTransportWorldInfoPanelDetour> .Revert(); Redirector <TrolleybusAIDetour> .Revert(); Redirector <PassengerHelicopterAIDetour> .Revert(); Redirector <TransportLineDetour> .Revert(); TransportLineSimulationStepPatch.Undo(); TransportLineGetLineVehiclePatch.Undo(); CachedTransportLineData.Deinit(); BuildingExtension.Deinit(); CachedNodeData.Deinit(); CachedVehicleData.Deinit(); VehiclePrefabs.Deinit(); SerializableDataExtension.instance.Loaded = false; LocaleModifier.Deinit(); if ((UnityEngine.Object) this._iptGameObject != (UnityEngine.Object)null) { UnityEngine.Object.Destroy((UnityEngine.Object) this._iptGameObject); } if (!((UnityEngine.Object) this._worldInfoPanel != (UnityEngine.Object)null)) { return; } UnityEngine.Object.Destroy((UnityEngine.Object) this._worldInfoPanel); }
public override void OnLevelLoaded(LoadMode mode) { base.OnLevelLoaded(mode); if (mode != LoadMode.LoadGame && mode != LoadMode.NewGame && mode != LoadMode.NewGameFromScenario) { return; } inGame = true; try { Utils.Log((object)$"Begin init version: {version}"); this.ReleaseUnusedCitizenUnits(); UIView objectOfType = UnityEngine.Object.FindObjectOfType <UIView>(); if ((UnityEngine.Object)objectOfType != (UnityEngine.Object)null) { this._iptGameObject = new GameObject("IptGameObject"); this._iptGameObject.transform.parent = objectOfType.transform; this._iptGameObject.AddComponent <SimHelper>(); this._iptGameObject.AddComponent <LineWatcher>(); this._worldInfoPanel = new GameObject("PublicTransportStopWorldInfoPanel"); this._worldInfoPanel.transform.parent = objectOfType.transform; this._worldInfoPanel.AddComponent <PublicTransportStopWorldInfoPanel>(); CachedNodeData.Init(); Patch(typeof(DepotAI), nameof(DepotAI.StartTransfer), DepotAIPatch.GetPrefix(), null); Patch(typeof(NetManager), nameof(NetManager.ReleaseNode), null, typeof(NetManagerPatch).GetMethod(nameof(NetManagerPatch.ReleaseNode))); //TODO: think, whether it should be pre or post CachedVehicleData.Init(); Patch(typeof(VehicleManager), "ReleaseWaterSource", null, typeof(VehicleManagerPatch).GetMethod(nameof(VehicleManagerPatch.ReleaseWaterSource))); //TODO: think, whether it should be pre or post Redirector <BusAIDetour> .Deploy(); PatchCountPassengers(typeof(BusAI)); Redirector <TrolleybusAIDetour> .Deploy(); PatchCountPassengers(typeof(TrolleybusAI)); Redirector <PassengerTrainAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerTrainAI)); Redirector <PassengerShipAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerShipAI)); Redirector <PassengerPlaneAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerPlaneAI)); Redirector <PassengerFerryAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerFerryAI)); Redirector <PassengerBlimpAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerBlimpAI)); Redirector <PassengerHelicopterAIDetour> .Deploy(); PatchCountPassengers(typeof(PassengerHelicopterAI)); Redirector <TramAIDetour> .Deploy(); PatchCountPassengers(typeof(TramAI)); Redirector <CommonBuildingAIReverseDetour> .Deploy(); Redirector <PublicTransportStopButtonDetour> .Deploy(); Redirector <PublicTransportVehicleButtonDetour> .Deploy(); Redirector <PublicTransportWorldInfoPanelDetour> .Deploy(); BuildingExtension.Init(); LineWatcher.instance.Init(); CachedTransportLineData.Init(); Redirector <TransportLineDetour> .Deploy(); VehiclePrefabs.Init(); SerializableDataExtension.instance.Loaded = true; LocaleModifier.Init(); this._iptGameObject.AddComponent <VehicleEditor>(); this._iptGameObject.AddComponent <PanelExtenderLine>(); this._iptGameObject.AddComponent <PanelExtenderVehicle>(); this._iptGameObject.AddComponent <PanelExtenderCityService>(); Utils.Log((object)"Loading done!"); } else { Utils.LogError((object)"UIView not found, aborting!"); } } catch (Exception ex) { Utils.LogError((object)("Error during initialization, IPT disables itself." + System.Environment.NewLine + "Please try again without any other mod." + System.Environment.NewLine + "Please upload your log file and post the link here if that didn't help:" + System.Environment.NewLine + "http://steamcommunity.com/workshop/filedetails/discussion/424106600/615086038663282271/" + System.Environment.NewLine + ex.Message + System.Environment.NewLine + (object)ex.InnerException + System.Environment.NewLine + ex.StackTrace)); this.Deinit(); } }
public override void OnLevelLoaded(LoadMode mode) { base.OnLevelLoaded(mode); if (mode != LoadMode.LoadGame && mode != LoadMode.NewGame && mode != LoadMode.NewGameFromScenario) { return; } inGame = true; try { Utils.Log((object)$"IPT2: Begin init version: {version}"); this.ReleaseUnusedCitizenUnits(); UIView objectOfType = UnityEngine.Object.FindObjectOfType <UIView>(); if ((UnityEngine.Object)objectOfType != (UnityEngine.Object)null) { this._iptGameObject = new GameObject("IptGameObject"); this._iptGameObject.transform.parent = objectOfType.transform; this._iptGameObject.AddComponent <SimHelper>(); this._iptGameObject.AddComponent <LineWatcher>(); this._worldInfoPanel = new GameObject("PublicTransportStopWorldInfoPanel"); this._worldInfoPanel.transform.parent = objectOfType.transform; this._worldInfoPanel.AddComponent <PublicTransportStopWorldInfoPanel>(); CachedNodeData.Init(); int maxVehicleCount; if (Utils.IsModActive(1764208250)) { UnityEngine.Debug.LogWarning("IPT2: More Vehicles is enabled, applying compatibility workaround"); maxVehicleCount = ushort.MaxValue + 1; } else { UnityEngine.Debug.Log("IPT2: More Vehicles is not enabled"); maxVehicleCount = VehicleManager.MAX_VEHICLE_COUNT; } CachedVehicleData.Init(maxVehicleCount); LoadPassengersPatch.Apply(); UnloadPassengersPatch.Apply(); DepotAIPatch.Apply(); NetManagerPatch.Apply(); VehicleManagerPatch.Apply(); PublicTransportLineVehicleModelSelectorRefreshPatch.Apply(); Redirector <BusAIDetour> .Deploy(); Redirector <TrolleybusAIDetour> .Deploy(); Redirector <PassengerTrainAIDetour> .Deploy(); Redirector <PassengerShipAIDetour> .Deploy(); Redirector <PassengerPlaneAIDetour> .Deploy(); Redirector <PassengerFerryAIDetour> .Deploy(); Redirector <PassengerBlimpAIDetour> .Deploy(); Redirector <PassengerHelicopterAIDetour> .Deploy(); Redirector <TramAIDetour> .Deploy(); Redirector <CommonBuildingAIReverseDetour> .Deploy(); Redirector <PublicTransportStopButtonDetour> .Deploy(); Redirector <PublicTransportVehicleButtonDetour> .Deploy(); Redirector <PublicTransportWorldInfoPanelDetour> .Deploy(); BuildingExtension.Init(); LineWatcher.instance.Init(); CachedTransportLineData.Init(); Redirector <TransportLineDetour> .Deploy(); TransportLineSimulationStepPatch.Apply(); TransportLineGetLineVehiclePatch.Apply(); VehiclePrefabs.Init(); SerializableDataExtension.instance.Loaded = true; LocaleModifier.Init(); this._iptGameObject.AddComponent <VehicleEditor>(); this._iptGameObject.AddComponent <PanelExtenderLine>(); this._iptGameObject.AddComponent <PanelExtenderVehicle>(); this._iptGameObject.AddComponent <PanelExtenderCityService>(); Utils.Log((object)"Loading done!"); } else { Utils.LogError((object)"UIView not found, aborting!"); } } catch (Exception ex) { Utils.LogError((object)("IPT2: Error during initialization, IPT disables itself." + System.Environment.NewLine + "Please try again without any other mod." + System.Environment.NewLine + "Please upload your log file and post the link here if that didn't help:" + System.Environment.NewLine + "http://steamcommunity.com/workshop/filedetails/discussion/424106600/615086038663282271/" + System.Environment.NewLine + ex.Message + System.Environment.NewLine + (object)ex.InnerException + System.Environment.NewLine + ex.StackTrace)); this.Deinit(); } }