Replies: 21 comments
-
Irony is deleting and verifying that files in the patch match the latest data. Checking whether that things like file hashes match, files exist and is dumping files that are "auto" resolved. Basically lots of going on in the irony patch directory. Since Irony is not crashing there will be no logs and only way is to setup a system using the configuration you mentioned to see why this is happening. Given that I've tested already Irony (including conflict solver) on 4-5 various distros now testing on another one is too much for me. I know it's not what you wanted to hear but I have no time to debug another distro. |
Beta Was this translation helpful? Give feedback.
-
What is it using to check file hashes? |
Beta Was this translation helpful? Give feedback.
-
Also, just fyi -- If you read my post I've made it clear that I'm looking for log information. Not really asking you to do anything on your part (like test on a distro), because as a break fix engineer I know it's going to be next to impossible to duplicate the conditions, which is why I said what I said in the issue post. I'd really like to fix this myself. But for that, I do need log information. As break fix engineers we rely on log info to debug and fix things all the time, but it's difficult to do with an application that does not log itself. But very few applications do not log themselves; they are in the minority; probably because in the real world no break fix engineers or software devs can debug the app without knowing what it is doing. So my ask is this; I need this app to log itself. That's so we can fix it and you don't have to. I realize this is the only bug post on the site so far and it's not a shiny feature request, but as the only bug post so far on this project is it possible to get a log. |
Beta Was this translation helpful? Give feedback.
-
Irony is using MetroHash (/~https://github.com/jandrewrogers/MetroHash) which is a .NET Core native library. No external dependencies are needed as the app itself is self contained and was compiled as such so you don't even need net core installed on Linux. The only dependency that might be needed in Linux is maybe xdg as it asks it to resolve environment variables and launch external processes. And as I already told you if there are no crashes Irony does not log in depth anything (as many windows apps do actually). What I do log are actual exception logs and I rely on these to fix bug reports. There have been a couple of reported freezes in some Linux distros and all problems with them are tied to upstream issues related to Avalonia and underlying library that Avalonia uses (which you most likely cannot fix yourself). If you really want its trace info you can check the nlog config and set debug info to trace or info which will then make Irony write its output to logs folder. As for Irony logging it will not dump its info via trace as I never implemented an interceptor which dumps trace or info to the logs only exceptions as I mentioned. Anyway for more info as to what is happening is that Irony is finishing the Syncing Patches in the service layer IronyModManager/src/IronyModManager.Services/ModPatchCollectionService.cs Lines 1191 to 1206 in 495ae10 and ViewModel thread awaiter is signaling via MessageBus that it's done and Irony can skip to the next step which is to pretty much switch the view which in your case is not happening IronyModManager/src/IronyModManager/ViewModels/MainWindowViewModel.cs Lines 229 to 248 in 495ae10 The problem for you lies somewhere in the upstream which does not trigger when I'm asking Avalonia to show the next view. |
Beta Was this translation helpful? Give feedback.
-
What's the name of the Avalonia library that the freeze is attributed to? |
Beta Was this translation helpful? Give feedback.
-
Don't remember. The speculation that Avalonia is to blame here is merely a speculation; until I get around to it sometime to check it out. Don't know when that will be but I will keep this ticket open. |
Beta Was this translation helpful? Give feedback.
-
bcssov, here is the nlog config file. How do we set debug info to "trace" or "info"? |
Beta Was this translation helpful? Give feedback.
-
/~https://github.com/NLog/NLog/wiki/Configuration-file#log-levels Though if nothing is logged let me know in another ticket, I might have broken something in recent updates. Haven't tested trace\info logging in months in release build configuration. |
Beta Was this translation helpful? Give feedback.
-
Hey bcssov, thanks for the nlog info. I need to let you know that the Merge function works; I'm using the mod it created currently with no problems. The mod size that it created was 1020 mb. Before I move on to nlog activity, I have some strace output for you. The following output was during a 100% message with the window hung. The command was run as follows: "strace -f --status=failed ./IronyModManager | uniq" Uniq eliminates duplicates. In this case, with the above qualifiers, strace only outputs system calls that have failed. This is a small sample grab; fyi, there was a very large number of futex errors: [pid 141] futex(0x7f26b8002970, FUTEX_WAIT_PRIVATE, 2, NULL) = -1 EAGAIN (Resource temporarily unavailable) I also ran an error summary with strace which reports the total number of errors per call after the program is terminated. Note the large number of recvmsg errors in this summary. Also 18000+ read errors: adm0@steam0:~/bin/irony> strace -c --summary-columns=error ./IronyModManager
|
Beta Was this translation helpful? Give feedback.
-
Nlog report -- the nlog.config that I have is identical to the one you posted, however I am getting no log files generated in ~/bin/irony (which I assume is the basedir if ironymodmanager is launched from there). If the logger name rules are set to "Error" as they seem to be, we should be getting something. |
Beta Was this translation helpful? Give feedback.
-
It could still be anything from a managed C# code coming from either Irony or Avalonia; or an Avalonia wrapper code in C# around native C++ code.
No they are not the same. I linked the log levels Nlog configuration to you to study to see which error log level you want and a development version of Irony nlog conflg (which is different than the release version of Irony). |
Beta Was this translation helpful? Give feedback.
-
How much RAM do you have exactly? On what kind of hardware is Irony running? Had a friend with some spare time who quickly setup a clean bare bones build with latest updates applied with I believe OpenSUSE Tumbleweed + KDE Plasma in an effort to reproduce the problem. To see whether there's something in .NET Core that does not agree (or Avalonia) with this specific build. His quick test passed with no issues (though I guess that should not surprise you). |
Beta Was this translation helpful? Give feedback.
-
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Beta Was this translation helpful? Give feedback.
-
Hey bcssov memory is not the problem. The hardware is an Acer Swift 3 with AMD Ryzen 7 2700U and RX540 graphics. Your app is running by itself and consumes no more than 15% memory while running Conflict Solver. I am including a screenshot of top with the memory consumption: https://imagebin.ca/v/5nDh5SFWKKsK I'm running more diagnostics to trace library calls. |
Beta Was this translation helpful? Give feedback.
-
Btw thanks for the upgrade to the application. I'm running tests on that now. Also, thank you for the tests you and friend conducted on a fresh install of Tumbleweed; that effort is much appreciated. I will figure this out. It might take a while but having you as occasional consult is invaluable. |
Beta Was this translation helpful? Give feedback.
-
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Beta Was this translation helpful? Give feedback.
-
I plan on converting this ticket into a discussion but cannot at the moment as that function is unavailable. It's some kind of GitHub bug so the feature was disabled at the moment. |
Beta Was this translation helpful? Give feedback.
-
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Beta Was this translation helpful? Give feedback.
-
Thanks bcssov for trying to get this converted into a discussion, that would be helpful |
Beta Was this translation helpful? Give feedback.
-
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Beta Was this translation helpful? Give feedback.
-
This has been resolved with the Imm version v1.14.37 and the addition of mscorefonts installation to tumbleweed distro. The rpm I used was a noarch rpm from openSUSE Leap 42.3, the rpm is: msttcorefonts-2.0-11.1.noarch.rpm I hope this information is useful to other IronyModManager Linux users. |
Beta Was this translation helpful? Give feedback.
-
Describe the bug
IMM passes all processing steps after Conflict Resolver button is hit, but never makes it off the shaded 100% progress screen. Otherwise it loads Stellaris normally/successfully and will load the mods as expected. Everything works OK except end of Conflict Resolver process.
To Reproduce
Need Tumbleweed installation with working Steam and Stellaris, then run IMM. For proper problem replication you would need this system I am working from.
Expected behavior
Just need to make it past the 100% screen to conflict resolution panes.
Screenshots
If applicable, add screenshots to help explain your problem.
http://www.enlightenment.org/ss/e-5fead80b079460.72421673.jpg
Logs
It does not crash, is very stable but I can't get clues on the 100% screen hang. I would be glad to examine the logs for this app if I knew the location of the logs. Wasn't able to find them when I looked
Version:
Additional context
I believe that Irony is attempting to finalize it's processing using a command normally available in Linux, but which might not be available in this minimalist install. It would be helpful to me to know what Irony is doing when it reaches the end of it's Conflict Resolver processing.
Compression? Copy? Parsing? Can we check logs to see what it is doing?
Beta Was this translation helpful? Give feedback.
All reactions