- Debugging Exaile
- What’s an easy way to test stuff without wrecking my actual collection?
- Debugging options for Exaile
- Where can I find log files?
- Viewing stack traces when Exaile hangs
- GStreamer Debugging Techniques
- Using GDB to diagnose issues
- Other thoughts
If you use the
--all-data-dir option to Exaile, it will store all data
for that execution of Exaile in that directory (collections, playlists, logs):
--help for more details, but there are a few useful options:
--debug- Shows debug log messages
--eventdebug- Enable debugging of xl.event. Generates lots of output
--eventdebug-full- Enable debugging of xl.event. Generates LOTS of output
--threaddebug- Adds the thread name to logging messages
On Exaile 4, you can click the ‘Open error logs’ button in the ‘Help’ menu and it will open the directory where logs are stored.
~/.local/share/exaile/logs/for Exaile 3.x+ releases
On Linux/OSX if you send SIGUSR2 to Exaile it will dump stacktraces of all current Python threads to stderr.
When tracking down GST issues, a useful thing to do is the following:
$ GST_DEBUG=3 ./exaile $ GST_DEBUG="cat:5;cat2:3" .. etc. $ GST_DEBUG="GST_STATES:4" ./exaile
GST_DEBUG_NO_COLOR=1 is good if you’re running exaile inside of pydev on eclipse.
Additional help about GStreamer debugging variables can be found in its Documentation
This is pretty cool, shows you the entire GST pipeline:
Gst.debug_bin_to_dot_file(some_gst_element, Gst.DebugGraphDetails.ALL, "filename")
Then if you run exaile like so:
It will dump a dot file that you can turn into an image:
dot -Tpng -oimage.png graph_lowlevel.dot
Please make sure that you have installed debug symbols for all essential non-python packages listed in Installation dependencies. Python packages do not need debug symbols, because they ship both binary and source files already. Depending on the distribution you are using, you may obtain debug symbols in different ways.
GDB can be used to diagnose segfaults and other issues. To run GDB:
gdb --args python3 exaile.py --startgui <other arguments here>
Refer to the Python Documentation, but especially useful here are:
(gdb) py-btis similar to
(gdb) bt, but it lists the python stack instead
(gdb) info threads
On GLib >= 2.46 you might want to set the
variable to show deprecation warnings. They are disabled by default since 2.46
and sometimes on older versions. See
- run gdb with
G_DEBUG=fatal-warnings gdb --args python3 exaile --startgui
- run exaile from gdb with
- do whatever causes Gtk-WARNING. This will lead to a crash in exaile.
- debug this crash with gdb
WARNING: On Linux, this will freeze your X server if the crash happens in a menu. This is due to X grabbing all input on open menus. When gdb stops exaile inside a menu it can’t leave the input grab.
Some recommend starting exaile on another X server or on a Wayland backend. One way to workaround this is to run exaile on a nested X server inside weston:
- install weston
weston --modules=xwayland.so(note: from now on all your Gtk+ 3.x applications will try to start inside weston due to preferring Wayland over X)
- inside weston, run
env | grep DISPLAYto figure out which X11 display to start exaile on
- before running gdb, add
GDK_BACKEND=x11` and `DISPLAY=:1(or whatever you got the step before) to its environment
To make Gtk+ 3.x applications not run inside weston but use your current X11
desktop session, run them with
GDK_BACKEND=x11 environment variable set.
- Open a terminal.
- Use the
cdcommand to change to the directory where you put Exaile source code or to its installation directory.
- In gdb, run
set logging on exaile-segfault.txtto enable logging to that file.
- In gdb, run
run ./exaile.py --startgui. You might append other arguments if you need them.
- Use Exaile as you did before and try to reproduce the problem. At some point, exaile might freeze. This is when gdb catched the segmentation fault.
- In gdb, run
t a a py-btand
t a a bt full. The first one will get python backtraces from all threads, the second one will get native (C/C++) stacktraces. You might need to type the return key a few times after each of these two commands to make gdb print all lines of the stack traces. This might take a while.
- In gdb, type
quitand press the enter key.
- Please attach the file
exaile-segfault.txtto a bug report at Github after you checked that it does not contain any private data. If you prefer to send the data encrypted, please feel free to encrypt them to the PGP key ID 0x545B42FB8713DA3B and send it to one of its Email addresses.
If Exaile freezes, follow the steps above for debugging segfaults but attach to the running instance instead.
- Get the PID of Exaile. You may want to use
htop, KSysGuard or GNOME System Monitor or a similar tool.
- Follow the steps above, with one change: Instead of starting
run ./exaile.py --startgui, run the
attach [pid]command inside gdb to attach to the exaile instance with the PID you retrieved in the previous step.
Sometimes, especially when shutting down, Exaile may print a message like this:
Exception TypeError: "'NoneType' object is not callable" in <object repr() failed> ignored
You may see this output when the python runtime ran into an exception when calling __del__ on an object or during garbage collection.
This output is generated by
PyErr_WriteUnraisable in python’s
errors.c. To debug it, attach gdb to Exaile or start Exaile in gdb and run
break PyErr_WriteUnraisable. Instead of writing the above message, gdb should break at the specified function and you should be able to get a backtrace.
Exaile is written using Gtk+, GStreamer, and Python. Any generally useful debugging tips that apply to those environments will often apply to Exaile also. Quod Libet is another audio player uses Gtk/GStreamer and Python, their development documentation also has useful debugging information: