diff options
author | M Stoeckl <code@mstoeckl.com> | 2024-10-31 09:23:26 -0400 |
---|---|---|
committer | M Stoeckl <code@mstoeckl.com> | 2024-10-31 09:30:09 -0400 |
commit | 260eaba88ec8f54fe2bdbe391b18fcd2db70836f (patch) | |
tree | 252ac7bfe70b464117dc9aba7eb6d6dc98ac2906 /render.c | |
parent | 12b8f83be447379eded03c6109fe944945cd48aa (diff) | |
download | wmenu-260eaba88ec8f54fe2bdbe391b18fcd2db70836f.tar.gz |
Optimize menu sorting
Sorting and deduplicating elements after all items have been registered
improves the time complexity of constructing the item list from O(n^2)
to O(n log n). On a system with about 4000 menu items, this reduces
startup time from about 0.21 seconds to 0.13 seconds.
Diffstat (limited to 'render.c')
-rw-r--r-- | render.c | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -28,7 +28,8 @@ void calc_widths(struct menu *menu) { menu->right_arrow = text_width(cairo, menu->font, ">") + 2 * menu->padding; // Calculate item widths and input area width - for (struct item *item = menu->items; item; item = item->next) { + for (size_t i = 0; i < menu->item_count; i++) { + struct item *item = &menu->items[i]; item->width = text_width(cairo, menu->font, item->text); if (item->width > menu->inputw) { menu->inputw = item->width; |