X-Git-Url: http://git.code-monkey.de/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fview.hpp;h=3e0a347142fb91b69b72301c4adeaa60e109e07b;hp=e4d0ebad1ab5237968b0e37ebf1f34c4faa6a877;hb=cf124e472f9b5be7f85ecf708fe5290d6a6d1c9e;hpb=6046c19df08472d69aa06216136ea7fafaf25492 diff --git a/pv/view/view.hpp b/pv/view/view.hpp index e4d0eba..3e0a347 100644 --- a/pv/view/view.hpp +++ b/pv/view/view.hpp @@ -39,6 +39,10 @@ #include "flag.hpp" #include "rowitemowner.hpp" +namespace sigrok { +class ChannelGroup; +} + namespace pv { class Session; @@ -48,6 +52,7 @@ namespace view { class CursorHeader; class Header; class Ruler; +class Trace; class Viewport; class View : public QAbstractScrollArea, public RowItemOwner { @@ -231,16 +236,17 @@ private: */ QRectF label_rect(const QRectF &rect); - static bool add_channels_to_owner( + RowItemOwner* find_prevalent_trace_group( + const std::shared_ptr &group, + const std::unordered_map, + std::shared_ptr > &signal_map); + + static std::vector< std::shared_ptr > + extract_new_traces_for_channels( const std::vector< std::shared_ptr > &channels, - RowItemOwner *owner, int &offset, - std::unordered_map, + const std::unordered_map, std::shared_ptr > &signal_map, - std::function)> filter_func = - std::function)>()); - - static void apply_offset( - std::shared_ptr row_item, int &offset); + std::set< std::shared_ptr > &add_list); private: bool eventFilter(QObject *object, QEvent *event);