[boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
[boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Game crush when I save it or when autosave.
It happens only after I place rail signal on bridge of 'Cargo Ship' mod.
Saves was successfull many times in this game before.
Nothing strange happens at the moment of placing the signal, only in next saving (manual or autosave)
After crush the save file is corrupted
Error BuildCheckResult.cpp:94: Build check failed: 2, cant-build-reason.entity-in-the-way(entity-name.rail-signal), name=rail-signal, type=rail-signal, position={321.5000000000, 849.5000000000}, setup=true, owned-by-ghost=false, simulation=false.
It happens only after I place rail signal on bridge of 'Cargo Ship' mod.
Saves was successfull many times in this game before.
Nothing strange happens at the moment of placing the signal, only in next saving (manual or autosave)
After crush the save file is corrupted
Error BuildCheckResult.cpp:94: Build check failed: 2, cant-build-reason.entity-in-the-way(entity-name.rail-signal), name=rail-signal, type=rail-signal, position={321.5000000000, 849.5000000000}, setup=true, owned-by-ghost=false, simulation=false.
- Attachments
-
- _autosave3.tmp.zip
- (3.71 MiB) Downloaded 182 times
-
- factorio-current.log
- (16.17 KiB) Downloaded 191 times
Re: [0.18.34] Crash on saving, supposedly because of 'Cargo Ship' mod
The log does not show a crash.
Post the latest loadable save file. Can you reproduce the crash with that file?
Post the latest loadable save file. Can you reproduce the crash with that file?
Re: [0.18.34] Crash on saving, supposedly because of 'Cargo Ship' mod
Sorry, It was wrong log
Here is new one with error and good save
If you will add signal to any bridge and try to save - game will crush
Crash always recurs under these conditions
Here is new one with error and good save
If you will add signal to any bridge and try to save - game will crush
Crash always recurs under these conditions
- Attachments
-
- _autosave3.zip
- (6.23 MiB) Downloaded 175 times
-
- factorio-current.log
- (18.79 KiB) Downloaded 209 times
Re: [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
I just got an error which seems like the same issue, from my having just added rail chain signals as technical entities to add glow to plants (which worked in a testing save, no less):
It also corrupted the save, though it appears to have put the corruption in a "tmp" file instead, with the original zip remaining functional, which I attached.
It also corrupted the save, though it appears to have put the corruption in a "tmp" file instead, with the original zip remaining functional, which I attached.
Code: Select all
Factorio crashed. Generating symbolized stacktrace, please wait ...
c:\cygwin64\tmp\factorio-build-blwuai\src\entity\railsignalbase.cpp (381): RailSignalBase::checkConsistency
c:\cygwin64\tmp\factorio-build-blwuai\src\entity\railsignalbase.cpp (67): RailSignalBase::save
c:\cygwin64\tmp\factorio-build-blwuai\src\entity\railchainsignal.cpp (48): RailChainSignal::save
c:\cygwin64\tmp\factorio-build-blwuai\src\surface\chunk.cpp (93): Chunk::save
c:\cygwin64\tmp\factorio-build-blwuai\src\surface\surface.cpp (907): Surface::save
c:\cygwin64\tmp\factorio-build-blwuai\src\map\map.cpp (1520): Map::save
c:\cygwin64\tmp\factorio-build-blwuai\src\scenario\scenario.cpp (1005): Scenario::saveMap
c:\cygwin64\tmp\factorio-build-blwuai\src\scenario\scenario.cpp (901): Scenario::saveAs
c:\cygwin64\tmp\factorio-build-blwuai\src\scenario\parallelscenariosaver.cpp (99): ParallelScenarioSaver::doSave
c:\program files (x86)\microsoft visual studio\2017\buildtools\vc\tools\msvc\14.15.26726\include\thr\xthread (230): std::_LaunchPad<std::unique_ptr<std::tuple<void (__cdecl RazerChromaController::*)(void),RazerChromaController *>,std::default_delete<std::tuple<void (__cdecl RazerChromaController::*)(void),RazerChromaController *> > > >::_Go
c:\program files (x86)\microsoft visual studio\2017\buildtools\vc\tools\msvc\14.15.26726\include\thr\xthread (209): std::_Pad::_Call_func
minkernel\crts\ucrt\src\appcrt\startup\thread.cpp (115): thread_start<unsigned int (__cdecl*)(void * __ptr64)>
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 0000000076CD556D)
0000000076CD556D (kernel32): (filename not available): BaseThreadInitThunk
ERROR: SymGetLineFromAddr64, GetLastError: 487 (Address: 0000000076E3385D)
0000000076E3385D (ntdll): (filename not available): RtlUserThreadStart
Stack trace logging done
6088.949 Error RailSignalBase.cpp:381: connection.rail->segment->hasSignal(this) was not true
Logger::writeStacktrace skipped.
6088.949 Error CrashHandler.cpp:189: Map tick at moment of crash: 16290176
- Attachments
-
- factorio-current.log
- (218.25 KiB) Downloaded 174 times
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Ok its "fixed" for 1.1.0. Rails logic is not happy when there are multiple rail signals binding to the same rail end on the same side. I am just adding the check to prevent multiple rail signals from being defined that do not collide with each other.
Code: Select all
10.333 Error ModManager.cpp:1510: entity prototype "invisible_chain_signal" (rail-chain-signal) collision mask does not collide with entity "buoy" (rail-signal).
rail signal collision masks must collide with all other rail signals.
invisible_chain_signal modifications: Cargo Ships
buoy modifications: Cargo Ships
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Can they still be made to not collide with anything else? If not, this will break all these "technical lights".boskid wrote: Mon Oct 19, 2020 10:10 am Ok its "fixed" for 1.1.0. Rails logic is not happy when there are multiple rail signals binding to the same rail end on the same side. I am just adding the check to prevent multiple rail signals from being defined that do not collide with each other.
Code: Select all
10.333 Error ModManager.cpp:1510: entity prototype "invisible_chain_signal" (rail-chain-signal) collision mask does not collide with entity "buoy" (rail-signal). rail signal collision masks must collide with all other rail signals. invisible_chain_signal modifications: Cargo Ships buoy modifications: Cargo Ships
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Only restrictions are with rail signals themselves. They are still allowed to be made to not collide with other entities. I am reusing the same logic that is applied between rails (have to collide with other rails) and as for rolling stocks (have to collide with other rolling stocks).Reika wrote: Mon Oct 26, 2020 7:39 pm Can they still be made to not collide with anything else? If not, this will break all these "technical lights".
-- edit:
Just in case look also at other restrictions that will be new in 1.1: 82623
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
This does mean using one of those "unnamed" collision layers, though, and forcibly making every rail signal use that layer, while having your own technical signal only be that layer.boskid wrote: Mon Oct 26, 2020 7:44 pmOnly restrictions are with rail signals themselves. They are still allowed to be made to not collide with other entities. I am reusing the same logic that is applied between rails (have to collide with other rails) and as for rolling stocks (have to collide with other rolling stocks).Reika wrote: Mon Oct 26, 2020 7:39 pm Can they still be made to not collide with anything else? If not, this will break all these "technical lights".
-- edit:
Just in case look also at other restrictions that will be new in 1.1: 82623
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Yes, rail signals now have one extra layer added taken from those unnamed.Reika wrote: Tue Oct 27, 2020 4:11 pm This does mean using one of those "unnamed" collision layers, though, and forcibly making every rail signal use that layer, while having your own technical signal only be that layer.
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
I forsee exhausting those layers, or having a collision with another mod using it for another purpose.boskid wrote: Tue Oct 27, 2020 5:57 pmYes, rail signals now have one extra layer added taken from those unnamed.Reika wrote: Tue Oct 27, 2020 4:11 pm This does mean using one of those "unnamed" collision layers, though, and forcibly making every rail signal use that layer, while having your own technical signal only be that layer.
I only use the "fake" rail signals as light sources; is there another entity-based way you would recommend? LuaRendering is not an option because of how it chokes on large quantities of lights.
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
Nope:Reika wrote: Thu Oct 29, 2020 7:23 pm I forsee exhausting those layers, or having a collision with another mod using it for another purpose.
https://forums.factorio.com/viewtopic.php?p=518171#p518171 wrote:Changed collision mask 'layer-11' to 'rail-layer'. Increased the total number of collision masks from 14 to 55.
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
You can configure lamps to require no power and always be on.Reika wrote: Thu Oct 29, 2020 7:23 pm ... is there another entity-based way you would recommend? LuaRendering is not an option because of how it chokes on large quantities of lights.
If you want to get ahold of me I'm almost always on Discord.
Re: [boskid] [0.18.34] Crash on saving (Build check failed) after adding train signal to 'Cargo Ship' bridge
True, that is now a thing with the void power source.