-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Mod loading error dialog is not showing under Linux #348
Comments
I found that when I yafc-ce/Yafc.Parser/LuaContext.cs Line 494 in f59daae
But when I throw the same exception after this, it is not caught (anymore) and the unhandled exception is shown on the console. I am not a C# developer/expert, @SWeini @Dorus do you have any experience with exceptions not being caught anymore? Maybe because C# 'switched' to Lua to execute some code that the exception handler is 'disabled/paused' and needs to be reinstate (for Linux)? Or maybe you have any similar experiences with exception handling? |
I have seen exceptions not being caught anymore in a ruby integration. the ruby runtime handles exceptions by somehow jumping out of the call stack. doing some protected call instead (similar to lua_pcallk here) did the trick to catch those in general the pcallk call looks a bit weird. I'm by no means a lua expert, but that but then, is this an issue with lua exceptions or .net exceptions? I haven't tried to reproduce the issue yet oh, and I also remember that the dotnet runtime was able to continue on windows, but it performed a hard crash on macos I'd start by investigating how exactly the lua_pcallk is supposed to work |
It is about .net exceptions not being caught (Lua errors are checked when pcall returns and thrown as a It feels like the pcall disabled the exception handler(s) (in Linux), causing the unhandled exception being shown in the terminal... But I do not know enough of .net and their exception handling processes to do a deep dive in it (a (not-so) quick Google search didn't show me anything usable) |
C# exceptions are usually caught in a Try {} Catch {} block. I dont see one of those around the code you linked, all i see is |
The yafc-ce/Yafc/Windows/WelcomeScreen.cs Line 402 in 6a8cd05
Here it starts loading the project mods, on Windows the catch block works, and on Linux it doesn't. My research found that after calling the |
Just to be clear: Any breakpoint on line 403 is not hit? (First line of the exception handler). That does sound like a .net bug, might be worth raising it on one of the Microsoft pages. |
breakpoint -> exception Yes, any exception that is thrown after line 403 is not caught anymore... I agree it feels like a .net bug, but I have no idea how to reproduce in a simple example (I doubt that the .net devs are willing to run YAFC to reproduce the actual issue...) So I was hoping that someone would know about this issue, and is able to provide a workaround |
Yeah true, some minimal testcase would be beneficial to reporting the bug, but even without one, easy steps to reproduce on the YaFC-CE project might be enough. Are there many external files needed? Since i'm not running linux, i'm limited in how far i can dive into this myself. |
When a mod fails to load and error dialog is suppose to show:
As reported by #346 this does not for for Linux.
Note the the error is logged in stdout/stderr, but this is less convenient compared to the dialog (and lacks the feature to disable the mod and retry).
The text was updated successfully, but these errors were encountered: