According to Elvis Angelaccio over at Bug 400093, "There is an abort() in kxmlgui if the xml file has a wrong syntax." As a result, Dolphin crashes upon startup if its config has become messed up, and is unable to perform any actions such as informing the user of what went wrong, loading a default configurations instead, etc. If both my understanding and Elvis's analysis of kxmlgui correct, then this means ANY application using kxmlgui is doomed to the same crash behaviour, with no option for graceful handling. What is needed is a mechanism, possibly opt-in, for an application using kxmlgui to be told of an error in the XML, leaving it up to the application to determine how to proceed.
This seems reasonable to me.
My point was we shouldn't handle this from the dolphin side or on a per-app basis. Of course we can improve kxmlgui to better handle invalid input. But I think our time would be best spent to prevent invalid input in the first place.
*** Bug 414392 has been marked as a duplicate of this bug. ***
*** Bug 400093 has been marked as a duplicate of this bug. ***
Preventing the situation from happening would be ideal, but KXMLGui should also be more robust when it does happen. Crashing is a really bad user experience. We could at the minimum remove the malformed file so that the app at least launches.
*** Bug 428659 has been marked as a duplicate of this bug. ***
Created attachment 133267 [details] Invalid XML in dolphinui.rc I see 2 problems here: 1. Something has broken this file. I don't know if it was a Debian APT script during an update, or Dolphin itself, or what. 2. Most definitely, no program should crash when reading wrong XML. I guess the latter point is what this bug is about. I would like to help, but I have never installed sources of any KDE app for such purpose. Could you give me some hints or point me to some tutorial so that I could debug it myself?
Here is some documentation for how to build our software from source: https://community.kde.org/Get_Involved/development Feel free to give it a try!