-
Posts
7,369 -
Joined
-
Last visited
Content Type
Profiles
Forums
Developer Articles
KSP2 Release Notes
Everything posted by Lisias
-
Just to explain exactly what happened: you were bitten by the infamous KSP's Assembly Loader/Resolver bug. It's the thingy that keeps track of every DLL loaded, as well the Assemblies inside the DLL (C# DLLs are like zip files, a container for things, being that things the Assemblies, where Assemblies are a bunch of related code sewed together). What happens is that when something tries to load a DLL and it's not there, or the DLL it's there but it's corrupted somehow (as not being able to find dependencies), the Assembly Loader/Resolver enters into a inconsistent state and from that point, anyone trying to load a DLL or to use a thingy called Reflection from the C#'s runtime borks relentlessly. It happens that TweakScale makes heavy use of both thingies and, so, it's usually the whistle blower that yells about it. Had not this nasty Assembly Loader/Resolver bug be there, failing to load a DLL would only affect whatever was trying to load it (as, obviously, it was being loaded because it have something someone is willing to use). Since this RunSharp.dll one could be removed without consequences, it was probably copied by accident into the distribution package. KSP preloads all DLLs if finds in the GameData (unless they are inside a directory called PluginData), even if no one is going to use it. I'm guessing that this RunSharp thingy needs some dependency that was not there, and then borked being loaded, and then triggered the infamous bug on Assembly Loader/Resolver. Welcome to a very important class on Software Development: Configuration Management. Cheers!
- 581 replies
-
- totm april 2023
- kopernicus
-
(and 3 more)
Tagged with:
-
Things are going to be even better when the CKAN guys finally aprove my entry! It's a month already in the making!!! https://github.com/KSP-CKAN/NetKAN/pull/9536
-
I like boeings!! here, I fixed it to ya: Humm… digging around, I found two that I can publish here: The ERJ-145 is known around here as the "Windows 98 jet", because its electronics need to be restarted all the time. It's also known as "Brasilia Jet", in a allusion to the EMB 120 Brasilia, which it succeeded. "Problem", Brasilia is also the name of a old volkswagen car from the 70s that for being cheap, it was very used on user's customisations - not all of them with a good taste. Note the two exhausts in the back - you shove 2 more wings on it and you have a ERJ-145!!!
-
This is too good to let it pass unchecked!!
-
[1.4.3 <= KSP <= 1.12.5] KSP Recall - 0.5.0.2- 2024-0521
Lisias replied to Lisias's topic in KSP1 Mod Releases
Well.. So I removed the InterstellarFuelSwitch and added back WarpPlugin IFS is not needed by this part (so it was ruled out of the problem anyway), and the WarpPlugin have the PartModules needed by the part. Unsurprisingly, the problem is back. So, yeah, we have our suspect, WarpPlugin - more specifically, one of above mentioned PartModule. So I removed IntegratedThermalElectricPowerGenerator from the part and tried again to see what happens. Bull's eye! The problem is gone. So we found the culprit. But why this is affecting only IT? Follows the KSPIE parts also using it: ./WarpPlugin/Parts/BeamedPower/PhasedArray/phasedArray1/MunSeeker_ZZZ_RadioTelescope_Contracts.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/OversizeFoldingDishAluminium/SIGINT.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/OversizeFoldingDishAluminium/SIGINT_End.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/OversizeFoldingDishGold/SIGINT.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/OversizeFoldingDishGold/SIGINT_End.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/OversizeFoldingDishGold/SIGINTEnd.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/SolarPowerMoltenSalt/SolarPower_MoltenSalt.cfg ./WarpPlugin/Parts/BeamedPower/Thermal/InlineThermalReceiverPanel/MW_TR_DI.cfg ./WarpPlugin/Parts/Electrical/AntimatterCore/WarpCoreUnit2.cfg ./WarpPlugin/Parts/Electrical/AntimatterCore/WarpCoreUnit.cfg ./WarpPlugin/Parts/Electrical/FissionReactor/fissionreactor.cfg ./WarpPlugin/Parts/Electrical/QuantumSingularityReactor2/QuantumSingulaityReactor.cfg ./WarpPlugin/Parts/Electrical/IXSMainHull/IXSMainHull.cfg ./WarpPlugin/Parts/Electrical/MuonCatFusionReactor2/StnSciSpectro.cfg ./WarpPlugin/Parts/Engines/SURGE/OPT_SURGE.cfg So, why nobody complained about this problem before? Logic suggests that these parts are also affected. So I reinstalled things back and tried one of these parts too. I randomly choose "Antimatter Catalyzed Fusion Reactor", the kspiWarpCoreUnit2 on WarpCoreUnit2.cfg. I took the very same rbug.craft file, and replaced the Interstellar-Technologies-ICFSC-Reactor with the kspiWarpCoreUnit2 and then scaled it up to 5M. No problem detected, the refunding happened exactly as expected. @GoAHead, this settles the matter: Interstellar Technologies appears to be at fault here. The very same PartModule that is triggering the problem on IT parts works fine on KSPIE ones. There's something missing on their parts, perhaps? Or perhaps they are using something that is broken on the IntegratedThermalElectricPowerGenerator PartModule and by plain luck (or knowledge) it's not used on KSPIE. In a way or another, I suggest you reach the IT guys and talk about the problem. I can't further help on this by myself. Good luck!- 633 replies
-
- 1
-
- survivability
- ksp-recall
-
(and 1 more)
Tagged with:
-
totm march 2020 So what song is stuck in your head today?
Lisias replied to SmileyTRex's topic in The Lounge
Music for times of war: -
Hi!
I have some news for you on Recall's thread:
Not the news you would like, I still don't know whats happening - I could only confirm this is not a problem being caused by Recall neither TweakScale.
I'm trying to figure out what to do next.
- Show previous comments 2 more
-
Hi!
I concluded the report:
There's something fishy on the IT part config. Since I don't know the KSPIE PartModules, I can't say what, but hey… Now we know where and how.
You will need help from the IT guys, and probably from the KSPIE's maintainer too in order to identify exactly why only IT parts are borking.
-
Just to finish the report, as I had diagnosed things later and my last message here left implied that KSPIE and/or IT were at fault somehow:
- It's a KSP's limitation : the IPartCostModifier uses float , and so are prone to loss of precision with really expensive (or cheap) parts.
-
KSPIE had no role in the problem, other than triggering it.
- IT, ditto. It only happens that these parts are expensive enough to get screwed by the float squashing problem.
- A new PartModule were added on KSP-Recall to handle the situation.
- All the other problems detected were just noise, they didn't affected the outcome.
-
[1.4.3 <= KSP <= 1.12.5] KSP Recall - 0.5.0.2- 2024-0521
Lisias replied to Lisias's topic in KSP1 Mod Releases
I know. But I need to do the tests progressivelly, otherwise I would had a really harsh time diagnosing the problem. For starters, I detected that Interstellar Technologies 0.4.1 (the latest available on SpaceDock), has some outdated add'ons compared with KSPIe latest (1.29.6 on SpaceDock). If you just unzipped IT0.4.1 over KSPIE1.29.6, you downgraded the following add'ons: CommunityResourcePack CommunityTechTree InterstellarFuelSwitch KerbalEngineer WarpPlugin Waterfall What can be the source of your problems. Right now I'm firing up KSP 1.12.5 with KSPIE and IT installed in order to check your case. Outdated add'ons weren't installed, I'm using whatever KSPIE installed on my rig. I also didn't updated IFS to 3.30, as I have words that 3.30 somehow broke TS or something else that sou broke TS, and I will utilize this test session to check it too. I will update this post as soon as I have some results. — POST EDIT — Unsurprisingly, TweakScale wasn't able to check some parts due errors on them: [LOG 02:53:19.454] [TweakScale] "TweakScale warning" about check failures was displayed <...> [LOG 02:53:19.225] [TweakScale] ERROR: part=Interstellar-Technologies.AMCatGasdynamicMirror (KSPIT KR-342 AM Cat. Gasdynamic Mirror Cell Fusion Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.227] [TweakScale] ERROR: part=Interstellar-Technologies.AM-Catalyzed-ICFE (KSPIT KR-250 Antimatter Catalyzed Inertial Confinement Fusion Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.229] [TweakScale] ERROR: part=Interstellar-Technologies.AM-Catalyzed-MIFE (KSPIT KR-129 Antimatter Catalyzed Magneto Inertial Fusion engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.230] [TweakScale] ERROR: part=Interstellar-Technologies.AM-Catalyzed-ICFE-Afterburning (KSPIT KN-162 Afterburning AM Cat ICFE) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.232] [TweakScale] ERROR: part=Interstellar-Technologies.AM-Fusion-Engine ("Compression" Antimatter Catalyzed Fusion Engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.233] [TweakScale] ERROR: part=Interstellar-Technologies.Antiproton-Catalyzed-Microfission (KSPIT NK-52 Antiproton catalyzed microfission drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.235] [TweakScale] ERROR: part=Interstellar-Technologies.BeamCoreFusion (KSPIT KR-523 Beam Core Fusion Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.237] [TweakScale] ERROR: part=Interstellar-Technologies.Daedalus-ICF (KSP-IT Daedalus Fusion Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.238] [TweakScale] ERROR: part=Interstellar-Technologies-Kugelblitz-Drive (IT-547 Kugelblitz Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.240] [TweakScale] ERROR: part=Interstellar-Technologies.Laser-Core-Antimatter ("Pion" Laser core Antimatter Engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.241] [TweakScale] ERROR: part=Interstellar-Technologies.Multi-Mode-Fusion-Engine ("Pressure" Multi-Mode Fusion Engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.243] [TweakScale] ERROR: part=Interstellar-Technologies.Muon-Cat-Large (KSPIT MN-620 Muon Catalyzed Fusion Drive) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.245] [TweakScale] ERROR: part=Interstellar-Technologies.Muon-Catalyzed-Fusion-Drive (KSP-IT KN-142 "Flare" Muon Catalyzed Fusion engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 [LOG 02:53:19.246] [TweakScale] ERROR: part=Interstellar-Technologies.Multi-Mode-SSTO-Engine ("Hybrid" Multi-Mode SSTO Fusion Engine) Exception on Sanity Checks: System.NullReferenceException: Object reference not set to an instance of an object at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x00000] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CopyToRecursive (ConfigNode node, System.Boolean overwrite) [0x0014a] in <106570632fc343a784fad39e75e877bf>:0 at ConfigNode.CreateCopy () [0x00006] in <106570632fc343a784fad39e75e877bf>:0 at GameDatabase.GetConfigNode (System.String url) [0x0002f] in <106570632fc343a784fad39e75e877bf>:0 at TweakScale.PrefabDryCostWriter.GetMeThatConfigNode (Part p) [0x0002a] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter.checkForOverrules (Part p) [0x00000] in <62ab179107a144c5a3808f0cd36a9f76>:0 at TweakScale.PrefabDryCostWriter+<WriteDryCost>d__3.MoveNext () [0x00417] in <62ab179107a144c5a3808f0cd36a9f76>:0 at error:0 These parts will probably cause some problems to you, but the "Interstellar-Technologies-ICFSC-Reactor" the rbug.craft uses is not there, so you have yet another problem to cope with. Anyway, I redid the test using the rbug.craft and, yes, I detected an underrefunding on it. However, and we need to make things clear here, this is not a problem on TweakScale neither with KSP-Recall. This is something on the Interstellar Techonologies - these parts have the problem. TS and Recall are working fine with everything else. I'm now checking what's wrong on these parts. — — POST POST EDIT — — To avoid losing time, I redid the test using the "Antimater Initiated Micro Fusion Reactor" on the same savegame where the Interstellar-Technologies-ICFSC-Reactor part is borking. I need to know if this is something confined into IT parts only or if it infected everything else. Well, the KSPIE parts are still being refunded without problems. This settle the matter, whatever is wrong, is affecting IT parts only. — — POST POST POST EDIT — — Interesting. Apparently, something is messing up the chain of events that ends up calling the `Refunding`'s `IPastCostModifier` interface. The best way to check for it is to remove `Refunding` and see what happens. So I applied this patch: @PART[Interstellar-Technologies-ICFSC-Reactor]:FINAL { !MODULE[Refunding] { } } to remove `Refunding` from the part to see what happens - and, as expected, I started to get mis-refunded (the problem `Refunding` was intended to fix at first place). Digging around the config cache and the craft files, I realised that the affected part has Refunding installed before TweakScale, where the funcional parts have it after TweakScale. I really don't remember if this can do a difference or not (I have some faint remembrance of being worried about this issue, but really don't really remember now), so I injected back the thing on the same patch so it would shove `Refunding` later on the patching process: @PART[Interstellar-Technologies-ICFSC-Reactor]:FINAL { !MODULE[Refunding] { } } @PART[Interstellar-Technologies-ICFSC-Reactor]:FINAL { %MODULE[Refunding] { active = True } } And this patch gave me the intended result on the ConfigCache, the `Refunding` module is now after TweakScale's. But it didin't solved the problem, so the order of the `Refunding` module is not an issue. (need to take note of that somewhere). At the present time, I don't have an explanation for only the IT parts being affected by the problem. The only thing I can say for sure is that neither TweakScale neither KSP-Recall are the culprits for the problem. They are involved on it, for sure, but they are not causing it. Wondering what to do next. — POST POST POST POST EDIT — Updating IFS to 3.30 didn't changed anything. No new problems, no change on the current ones. I don't understand why rolling back IFS solved anything for another user. More interesting yet, I reinstalled everything from scratch, starting with KSPIE and then I just shoved the InterstellarTechnologies directory into the GameData, completely ignoring anything else from the IT's zip package. The problem happens the same... So whatever is happening on the IT parts, is something being triggered on the Config, as everything else is the same for KSPIE parts - that are working as expected. Oh, dear… I'm going to debug parts now. — POST POST POST POST POST EDIT — So… It's Part Config debugging time. Since it was already stablished that this is not being caused (directly) by a PartModule (being it TS, Recall, or whatever), it's something on the ICFSCReactor.cfg file. In order to simplify the number of variables on this equation, I removed a lot of things from the test bed, leaving installed only: 000_FilterExtensions 000_FilterExtensions_Configs 000_KSPe CommunityResourcePack InterstellarFuelSwitch Interstellar_Redist.dll ModuleManager ModuleManagerWatchDog MyPatches.cfg Squad SquadExpansion TweakScale __LOCAL A customized copy of the Interstellar-Technologies-ICFSC-Reactor part is here for debugging. 000_KSPe.dll 666_ModuleManagerWatchDog.dll 999_KSP-Recall 999_Scale_Redist.dll ModuleManager.dll Of course the part will be butchered on launch, as the following PartModules will not be there for it: InertialConfinementReactor IntegratedThermalElectricPowerGenerator IntegratedRadiator This will allow me to check if the problem still happens or not on this reduced setup and… Well, the problem didn't happened ANYMORE. So the problem must be being triggered by one of the PartModules listed above. Working on it.- 633 replies
-
- survivability
- ksp-recall
-
(and 1 more)
Tagged with:
-
This one I gave a close look. It was a Unity issue. FS was relying on a call from Unity 2017 that got removed on Unity 2019, and then the DLL failed to be loaded - triggering the infamous Assembly Loader/Resolver on KSP. This was fixed on the next FS release, but MJ2 retained a code yelling anything going wrong on FS as FS not being compatible with KSP - even when something else screws up the Assembly Loader/Resolver and FS ends up being hit by the splash damage.
-
Publishing your KSP.log on dropbox and posting the link here will be a great first step! Read this thread about how to get help: On the OP, on the Spoiler below the title "Support:", you will find additional information for modern KSP on Linux and MacOS.
- 4,054 replies
-
- tweakscale
- plugin
-
(and 1 more)
Tagged with:
-
Other FS PartModules are also used. Most of them can be replaced, of course, but since some of them are still really needed, there was no ral point on switching some of them if you are not going to switch all of them. Until now. Or soon™ - frankly, every I sit down to work on AP+ (or something fun as expanding the TweakScale Companion), some astral conjunction happens somewhere in the Universe, triggering an avalanche of bug reports that ended up eating most of my free time. I understand, and I agree. I have this concerning on KAX - avoiding cluttering it with things that would not "fit" the add'ons' "spirit". Of course, I will not do it - what would be the point at this time? - but I think that AP+ should be a "Franchise", with some "sub-modules" adding related parts into the mix. AP+ "Cold War Civil Aviation", "WW2 Military Aviation", "Jet Engine Dawn", etc. I once waved some contributions to KAX once because I didn't thought it would fit on it (it's essentially Pre WW1 era, and post WW2 era aviation parts - how a Boeing fuselage would fit on it?). It's still an idea I'm toying with, but how to implement it without disrupting the Scene? I don't think the cost/benefit of doing it now would be positive. I'm toying with the possibility of fixing Firespitter. I already had fixed some things on it on a personal fork, but gave up on pushing them into the mainstream as things are never merged. I don't want to rant publicly about, but FS is fixable. There's absolutely nothing preventing it from bring fully compatible (with all the original parts) into modern KSP. I decline to further comment about. That said, almost everything on FS is replaceable. What doesn't means it will got better with it - sometimes, you will get a worst experience by switching off from it. Yes! I replaced some FS modules from KAX on the helo parts, and let me tell you - I hated the result. Fixing Firespitter is the way to go, in a way or another - it's the reason I decided to work on it extra-officially. I think it's wiser to decline on further commenting about. Because not so many people really like to use B9PS (they love the parts using ot, and tolerate B9PS due them), and even fewer authors like to support it. Believe me on this one - B9PS is a nice idea, but far from being convenient to support and frankly way overbloated. Kraken knows how many man-months it took me to support this thing on TweakScale - and I still get problems nowadays due something misusing it now and then. I don't oppose people using B9PS if people it, but I don't plan to do the job myself - I will assist anyone willing to do it, though, as long this dude maintains the patches themselves.
-
[1.4.3 <= KSP <= 1.12.5] KSP Recall - 0.5.0.2- 2024-0521
Lisias replied to Lisias's topic in KSP1 Mod Releases
Moved from TweakScale thread: So, this is what I did: On a "standard" KSP 1.12.5 test bed with the following preinstalled addons, all at the latest versions at this time KSPe KSP-Recall DistantObject (I forgot to remove it) ModuleManager/L Module Manager Watch Dog TweakScale TweakScale Companion the ÜberPaket I downloaded the latest KSPIE from SpaceDock (1.29.6) and installed it on that rig (without overwriting anything that was already there). I forgot to remove all MiniAVC DLLs, but whatever - most people also does it so perhaps this was for the best. I loaded your "bug" savegame and checked for the problem you reported. And got busted, as the part Interstellar-Technologies-ICFSC-Reactor was not found on the GameData. Krap, booting KSP 1.12.5 is pain where the sun doesn't shine on this machine. So I tried to salvage the situation using another reactor, the Antimater Initiated Micro Fusion Reactor, scaling it up to 7.5M and launched it at a cost of 3,689,359 . I confirmed the Funds were deducted from the KSC's account, then I recovered it. And the money were refunded as expected. So everything is working fine on a "Stock" (or nearly) installation, and so we have something else screwing you on your rig. Now that I know where the problem is not, I will start to update things on this rig to match yours and find who is stealing money from your Agency. I'm working on it.- 633 replies
-
- survivability
- ksp-recall
-
(and 1 more)
Tagged with:
-
It's not TweakScale, it's KSP-Recall that somehow is failing (or being induced to fail) on the stunt I cooked for working around the major KSP screwup on the IPartCostModifier handling. I will pursue this problem on KSP-Recall thread. — — POST EDIT — — Current KSP-Recall and TweakScale were ruled out, it's something else screwing with KSP-Recall.
- 4,054 replies
-
- tweakscale
- plugin
-
(and 1 more)
Tagged with:
-
totm march 2020 So what song is stuck in your head today?
Lisias replied to SmileyTRex's topic in The Lounge
Guitar Hero moment: Joan Jett! -
The weird thing about this Assembly Loader/Resolver problem is that everybody and the kitchen's sink get royally screwed once it is triggered by someone. On saner systems, only the thingy that failed being loaded would had problems, but due this KSP's bug, once the first DLL fails to be loaded, everybody else in need of loading another DLL or to use another thingy called Reflection will be screwed by the problem. So it's not obvious what's cause and what's effect on this one - not to mention splash damage. Empirically, I had found that the first occurrence of a DLL loading error would pinpoint the cause of the problem, but when MJ2 is installed, the order of the log is messed (something about MJ2 doing it's own sanity checks, changing the chain of events - not a problem, just a different way of doing some things), and so it's yet more harsh to diagnose the problem! Well, now let's talk about this problem. KSPe.Light is the lightweight, "retargetable" version of KSPe. I did this way because KSPe's API was not stable at that time, but yet had a lot of features that made my life easier so embedding a custom version of it on Recall (and others) make sense - I can develop KSPe outside the development cycle of Recall et all, so I don't risk screwing up someone else's life due an ABI breakage (that happens every minor version change - i.e., 2.2 to 2.3, from 2.3 to 2.4, and now with KSP 2.4 to 2.5). The side effect of it is that is not uncommon that Recall (et all) gets tied to a specific version of KSPe.Light.<something>. What's should not be a problem, because each Release of Recall (et all) come with it embedded, and all of them works on almost all KSP releases, so the user is never locked out of the bug fixing cycle no matter the KSP he's playing on (with a few exceptions, of course). Things got royally screwed on the user's machine because somehow KSPe.Light.Recall v2.3.0.4 was installed with KSP Recall v0.2.0.6 . But it happens that on Recall v0.2.0.6 I used the KSPe.Light.Recall v2.4.0.0, not this older one! And do you remember that I break ABI (Application Binary Interface) when I raise the minor version of KSPe? (i remove deprecated things marked to be removed since 2 or 3 minors before, usually - on 2.4 I removed a lot of bad ideas from the 2.2 era that was hindering further development). So now we have the reason for the breakage - an older KSP-Recall was installed, but somehow with an even older KSPe.Light.Recall for it where an ABI call was different from the one Recall was compiled against. So we had a Dynamic Linking error, that it's a kind of Reflection Error that triggers the Assembly Loader/Resolver bug on KSP, that so starts to screw up the life of everybody else. Firespitter is only a problem when the TweakScale Companion for Firespitter is not installed. I'm trying to find time to write a "Sanity Check" on TweakScale to recommend installing Companions as needed - but, boy, I just can't win an argument with Real Life™. So, at this time, the TweakScale Companion ÜberPaket is almost a hard dependency for people not playing Stock. Good thing I had wrote conditional DLL loading tools on KSPe, so you can install a "hard" Companion (one that needs a dedicated DLL compiled against the targer add'on) on a rig without the target installed without risking getting screwed by the Assembly Loader/Resolver. Well… "vida que segue" (life goes on). Cheers! — — — English Translation of some terms — — — API Application Programming Interface A kind of "contract" where two different codes from two different sources agree in order to reuse each other's assets. Source Code level ABI Application Binary Interface It's the same contract, but on the binary level after compilation. It's related, but doesn't matches exactly the API used to generate it, Depending in how you compile something (and in which language), one API can generate different ABIs. Most of the time, as your libraries evolve, you want to keep the ABI intact to prevent a recompile fest on the field - what creates drag on the adoption of the newer versions. API changes are usually better tolerated if done on the long term (i.e., first you mark something as deprecated, then you pesky everybody for some versions about how that thingy is going to be removed futurelly, and then you remove the thing). But sometimes you draw yourself to a corner with C# - there're so many different ways to define a call, and because of it sometimes you just can't keep ABI compatibility while changing an API. It was was happened on KSPe 2.3, a bunch of bad ideas were preventing me from fixing some API calls to something saner due ABI conflicts.
-
Nope. KSPe is not installed. What we have on his GameData are the specialised Light version used by DOE, Recall and TweakScale - and they are not throwing exceptions. Curiously, I found this: [LOG 14:54:03.858] [CompatibilityChecker] Running checker version 5 from 'MechJeb2' [EXC 14:54:03.861] MissingMethodException: bool ModuleManagerWatchDog.SanityLib.IsEnforceable(int,int) UnityEngine.DebugLogHandler:LogException(Exception, Object) ModuleManager.UnityLogHandle.InterceptLogHandler:LogException(Exception, Object) UnityEngine.Debug:CallOverridenDebugHandler(Exception, Object) [EXC 14:54:03.862] MissingMethodException: bool ModuleManagerWatchDog.SanityLib.IsEnforceable(int,int) UnityEngine.DebugLogHandler:LogException(Exception, Object) ModuleManager.UnityLogHandle.InterceptLogHandler:LogException(Exception, Object) UnityEngine.Debug:CallOverridenDebugHandler(Exception, Object) [LOG 14:54:03.862] [WatchDog.InstallChecker] Version 1.1.0.3 /L It's curious, but apparently something is screwing with MMWD DLLs. MMWD does not use KSPe, being the Light or not, so KSPe is not a variable on this one. So this is something else triggering that Kraken damned KSP bug on the Assembly Loader/Resolver thingy. Then I found this: [EXC 15:09:19.206] MissingMethodException: KSPe.Util.Log.Logger KSPe.Util.Log.Logger.CreateForType<!0>(string,string,int) Rethrow as TypeInitializationException: The type initializer for 'KSP_Recall.AttachedOnEditor.AttachedOnEditor' threw an exception. UnityEngine.DebugLogHandler:LogException(Exception, Object) ModuleManager.UnityLogHandle.InterceptLogHandler:LogException(Exception, Object) UnityEngine.GameObject:AddComponent(Type) Suggesting that KSP-Recall is not being able to find it's specialised version of KSPe.Light. However, it was found on your rig: [LOG 14:54:02.325] [KSPe.Light.KSP-Recall] Version 2.3.0.4 /L <...> [LOG 14:54:02.328] [KSP_Recall] Version 0.2.0.6 /L running on KSP 1.12.5 HOWEVER… Somehow you have a VERY OLD Version of KSP-Recall installed on your machine! This release if from more than 18 months ago, a really huge amount of time given the number of bug fixes I did on the newer versions! The following is the logs I have from my Reference KSP installagion: [LOG 12:10:34.512] [KSPe.Light.Recall] Version 2.4.3.0 /L for KSP-Recall [LOG 12:10:34.521] [KSP-Recall] Version 0.3.0.9 /L running on KSP 1.12.5 This is reason enough to stop the diagnosing and suggest you to completely remove the KSP-Recall and reinstall it using the latest version found on CurseForge or SpaceDock. It's since Dec 2021 (when I launched Recall V0.2.1.3) that I don't even fire this old 0.2.0.6 release!!! @Rocket Science42, please update KSP-Recall to the latest version and then try again. If things still get screwed, publish a new KSP.log and I will keep digging. Additionally, you are also using a very old release of TweakScale too!: [LOG 14:54:08.266] [TweakScale] Version 2.4.6.2 /L And Kraken knows how many mistakes and bugs I had fixed on TweakScale since Oct 2021, when I launched this version! I never fired it again since Nov 2021 when I released a new one. @Rocket Science42, again, please install the latest TweakScale from CurseForge or SpaceDock. And, now, a somewhat serious warning. You are using the latest KSP: [LOG 14:50:53.555] ******* Log Initiated for Kerbal Space Program - 1.12.5.3190 (WindowsPlayer x64) en-us ******* Kerbal Space Program - 1.12.5.3190 (WindowsPlayer x64) en-us So there's absolutely no reason for you be using so older versions of KSP Recall and TweakScale. I go trough huge pains to make the newer releases compatible to any KSP version since at least 1.4.3 (some few add'ons of mine can be used downto 1.3.1!!!), so you can always be using the latest releases with the latest features and bug fixes no matter the KSP version you are using. But I don't test older releases of my add'ons on newer KSP ones! I don't know why you decided to install so older versions of these Add'Ons (and, frankly, perhaps it's better not to know after all), but I strongly suggest you don't do it anymore. Now and then I made a mistake, I know. But I had always fixed the real bad ones in a matter of days once they are detected, and it's some time since a healthy KSP installation had suffered due one of them. The latest major screw up of mine was on a code that was trying to survived royally screwed up KSP installations with multiple bad patching problems on it - people that keeps their GameData sane didn't noticed the problem! Anyway. Please update your KSP-Recall and TweakScale to the latest versions and try again. If anything bad keeps happening, publish a new KSP.log and I will dig on it,
-
Yep! I'm going to support Universal Storage. Soon™. It will be implemented on the TweakScale Companion Program. This guy is a bit tricky to support because it have a lot of PartModules to cope with... Do you know what? I will start to work on it this WeekEnd! Cheers!
- 4,054 replies
-
- 1
-
- tweakscale
- plugin
-
(and 1 more)
Tagged with:
-
Problems with quicksave
Lisias replied to xXTWINGGOXx's topic in KSP1 Technical Support (PC, modded installs)
The problem is caused by double patching. The TweakScale code that tries to survive the problem got a regression on 2.6.4.22 that leaded to this unfortunate problem. The latest TweakScale 2.4.6.23 fixed the problem. Be advised that only installations infected with the double patching problem were affected. Installations with sane patchings weren't affected (as the code that suffered the regressions are only triggered on faulty installations). -
So I did what I usually do: I don't guess, I measure. With this project https://github.com/net-lisias-ksp/ScrewMeUp/releases one can selectivelly induce the injection of NRE's on the different points of the Unity's and KSP's Life Cycles - and so measure the consequences on the current gaming. I don't really have to explain that this thing can royally screw you over, so don't even consider using it on anything that you would remotely like to use again after! The M.O. is simple: on any scene, open the PAW for the selected strutCube and activate the "Screwer" you are interested on checking (KSP or Unity). Then look into the KSP.log for situations where the "Screwed" PartModule doesn't logs an entry telling its is fine. Failing to log "it's fine" indicates a situation where the NRE had screwed the Life Cycle of the PartModule. Only the strutCube (Cubic Octagonal Strut) was patched with these PartModules. Only crafts using it will be subject to the problem, we would need to inject these Modules on more complex parts (including with 3rd parties modules as TweakScale) to completely appreciate the consequences - but, hey, this is a start. Additional very important info on spoiler: Not entirely true - at least, depending from what you call "major". At least some methods are screwing KSP when an uncaught Exception happens, on the very least we have the already known PartModule.OnSave that can halt the whole User Interface when happens. Interesting enough the "damage" is not permanent, if you disable the "Screwing" the game goes back to normal. Not a bad thing, not a bad thing at all. See above. I didn't mapped exactly what ones are screwing the game and where, this is Research in Progress (something to be done on a longer Week End to say the true), but it's enough to say that it can impede the part from being loaded on recent KSPs if the test is activated on the Loading Scene (by setting true on the patch that inject the Screwer module into the part) - on some older KSPs, it plain crash the game to CTD. Additionally, I didn't created a test for VesselModules. Yet. I will need a more refined Test Artefact in order to check about this one (see above). It's important to consider that failing to complete the OnDestroy() can leave not only memory left behind on the heap, but entire objects on GameEvents (as it happened in the past with B9PS, that ended up screwing TweakScale), what I called Zombies in the past. TweakScale is one thingy that really misbehaves when transformed into a Zombie.
- 315 replies
-
- 1
-
So the problems happen when the uncaugh exceptions happens on KSP overriden methods only? The OnSave for sure screws the whole game when it happens, preventing even the UI from working once it happens. On exactly what method this is happening? We have information that Unity's "callbacks" are caughthing exceptions and preventing the thread's murder, but I have empirical evidences that at least the PartModule.OnSave royally screws the whole game when an uncaught exceptions os thrown...
- 315 replies
-
Choose your poison! EVE beta is, well, beta. You know you are risking your savegames using it. And since the thing is being actively developed, such problems are really expected to happen. Parallax is a bit more hairy, because it's being used as stable nowadays. IMHO, someone should at least handle that exceptions in a graceful way to make sure this is not aborting any threads. A lot of weird issues may be related to it, not only here on DOE or even TweakScale, but on some others too. Including efforts to fix KSP internal problems. There's no way to keep the game healthy with threads being murdered by unhandled Exceptions. This may be one of the reasons so many people are getting screwed on KSP while gaming, with crafts suddenly being saved missing modules and when reloaded, missing the configurations. I have diagnosed at least one case in which some (but not all) satellites on a savegame lose all communications: by inspecting the savegame, the affected crafts had lose the ModuleDataTransmitter and the values were reinjected in a way that made them unuseable. This must had happened in a single gaming session, because some 2 or 3 crafts had the problem - the other ones probably had never be unrailled on the doomed gaming session, so they were preserved. Again, if you don't mind risking your savegames, it's your choice. But users need to have the same choice too - and users can't choose what they don't know about - and they are not skilled techinicians as both of us.
- 315 replies
-
That's something we can work on! Let's talk about it on the next WeekEnd! In the end, it's really simple: a list of bodies by name and the RGB colours you want their flare. Check this file: https://github.com/net-lisias-ksp/DistantObject/blob/master/GameData/DistantObject/PlanetColors.cfg
- 315 replies
-
- 1
-
Ouch, I forgot about! It was going to be needed for some customisations, but I ended up not implementing them (yet) and forgot the thing there! Thanks for the heads up! That's the problem with errors on KSP: they break the chain of events of the life cycle of some components. As an example, let's suppose we have a one part vessel with 3 modules: ModuleA, ModuleB, ModuleC. When KSP fires up the vessel, it does something more or less like this: Call VesselModule's OnStart Call the OnStart of every Module: ModuleA.OnStart() ModuleB.OnStart() ModuleC.OnStart() Release control to the GameEngine. And the GameEngine, so, loops more or less this way: For every vessel in the physics range: Call its FixedUpdate For every Part on the Vessel: Calls its FixedUpdate, i.e: ModuleA.FixedUpdate() ModuleB.FixedUpdate() ModuleC.FixedUpdate() Now imagine: each Module's OnStart initialises some data needed by its respective FixedUpdate, right? So, what's happens if there's an Exception while handling the ModuleB.OnStart()? Well, the ModuleC.OnStart() will not be called, because the thread was killed while calling ModuleB.OnStart()! So ModuleB.FixedUpdated will probably be screwed, and ModuleC.FIxedUpdate will surely be royally screwed - besides not being its fault ModuleB killed the thread on the OnStart phase. The same happens if ModuleB.FixedUpdate() throws an Exception - the thread is killed, and the ModuleC.FixedUpdate() is never called because of that. This is the reason we should not play KSP when there're exceptions being thrown on the KSP.log. Kraken knows what's not being called because of that.
- 315 replies
-
[How to] bypass the new Launcher added in update 1.12.4 [Steam]
Lisias replied to 4x4cheesecake's topic in KSP1 Tutorials
Please note that this will be reverted when Steam updates something, or when the user asks for verifying the game installation, the same way it happens with the KSSL, mentioned here. -
KSP Interstellar Extended Support Thread
Lisias replied to FreeThinker's topic in KSP1 Mods Discussions
Update to the latest TweakScale (2.4.6.23 at this moment). Your GameData is "infected" with a pretty old problem that I call "Rogue Duplicate", when less than ideally written parches shove multiple copies of the TweakScale module on a part. While fixing a weird bug on 2.4.6.21 (that I still didn't understood what happened to this day), I made a stupid mistake on the code that handles this Rogue Duplicate crap on 2.4.6.22. Your rig will still have that Rogue Duplicate thingies, but with 2.4.6.23 TweakScale is able to handle them again. Cheers.