GSoC 2023: Rust and GTK 4 Bustle Rewrite (Week 9 & 10)

  • 19th Aug 2023
  • 4 min read
  • Tags: 
  • GSoC 2023

Card

Progress Made

I am thrilled to announce that a lot of progress happened once again over the past few weeks! Starting with the most important thing, the diagram, a lot of bugs has been squashed and the rendering performance is now improved to a usable and merge-able state.

Diagram

Aside from that, it now has a header that doesn't overlay on the diagram, the drawings now properly adjust to text scale factor changes, the signal arrows are now drawn, and the rows are no longer clipped into the row titles.

My mentor, Bilal, also worked on adding tags, the colored circles in the diagram, so it is easier to determine the category of a message.

On the general UI side, there is now a proper loading page that is shown while waiting for the PCAP files to show.

Loading Page

However, that may not be as useful as we also landed a patch that speeds up loading by up to 32 times; that's from 16 seconds on average to 500 milliseconds, when loading a 2.2 MB file.

There is also now a waiting page that shows before the first message arrives while recording.

Waiting Page

We also landed statistics window which shows frequencies of messages, durations of method calls, and sizes information of each message.

Statistics Frequencies Page

Statistics Durations Page

Statistics Sizes Page

My mentor, Bilal, also worked on adding information on the details view including the body size and signature, and the response time from method return to its call.

Details View

There is also now a way to save the PCAP file as a DOT graph file, which can be used to generate a graph using Graphviz to visualize interactions between bus names like the following:

DOT Graph

On the plumbing side, saving to PCAP file is now asynchronous, avoiding blocking the UI. We also ported from using libpcap to a pure Rust library, removing unsafe code and simplifying the codebase. Furthermore, the timestamp computation is now more accurate.

As part of making debugging in Bustle easier, I have also submitted a patch to zbus to simplify the printing of bus names.

Finally, I started prototyping services filtering. It is still a proof of concept and does not look great, but it already functions and is a good starting point for next week.

Services Filtering

Plans for the Following Weeks

The following weeks will be the last days of GSoC and I will be focusing on finishing up the remaining tasks. With the most difficult part of this GSoC project done, most of the tasks left, aside from services filtering, are optimizing performance and cleaning up the codebase.

There are also a few more things to fix such as a proper name owner changed signal handling, drawing method call arc regardless if the row is not drawable, properly killing the dbus-monitor process, and propagating user-facing errors.

I would also like to add features such as adding a button that scroll to the method call message of a method return message or vice-versa, porting to use the new GskPath APIs, and adding a way to open multiple diagrams at once via tabs and multiple windows.


That's all for this week. Thanks for reading!