1
0
Fork 0
mirror of https://github.com/transmission/transmission synced 2024-12-26 09:37:56 +00:00
transmission/gtk/SorterBase.hh
Mike Gelfand fa091495d6
Refactor sorting and filtering compatibility code (GTK client) (#4558)
* Refactor sorting and filtering compatibility code

Factor out parts of `TorrentFilter` and `TorrentSorter` classes into
reusable `FilterBase<>` and `SorterBase<>` templates.

Factor out filter and sort models setup from `FilterBar` and `Session`
classes into reusable `FilterListModel<>` and `SortListModel<>`
templates.

* Remove unused lambda capture (Clang build failure)
2023-01-08 15:31:03 +00:00

49 lines
1.3 KiB
C++

// This file Copyright © 2022-2023 Mnemosyne LLC.
// It may be used under GPLv2 (SPDX: GPL-2.0-only), GPLv3 (SPDX: GPL-3.0-only),
// or any future license endorsed by Mnemosyne LLC.
// License text can be found in the licenses/ folder.
#pragma once
#include "SorterBase.h"
#if GTKMM_CHECK_VERSION(4, 0, 0)
template<typename T>
Gtk::Ordering SorterBase<T>::compare_vfunc(gpointer lhs, gpointer rhs)
{
auto const* const concrete_lhs = dynamic_cast<T const*>(Glib::wrap_auto(static_cast<GObject*>(lhs)));
auto const* const concrete_rhs = dynamic_cast<T const*>(Glib::wrap_auto(static_cast<GObject*>(rhs)));
if (concrete_lhs == nullptr && concrete_lhs == nullptr)
{
g_return_val_if_reached(Gtk::Ordering::EQUAL);
}
g_return_val_if_fail(concrete_lhs != nullptr, Gtk::Ordering::SMALLER);
g_return_val_if_fail(concrete_rhs != nullptr, Gtk::Ordering::LARGER);
return Gtk::Ordering{ compare(*concrete_lhs, *concrete_rhs) };
}
template<typename T>
Gtk::Sorter::Order SorterBase<T>::get_order_vfunc()
{
return Gtk::Sorter::Order::PARTIAL;
}
#else
template<typename T>
sigc::signal<void(typename SorterBase<T>::Change)>& SorterBase<T>::signal_changed()
{
return signal_changed_;
}
template<typename T>
void SorterBase<T>::changed(Change change)
{
signal_changed_.emit(change);
}
#endif