From e4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 10 Apr 2024 22:34:10 +0200 Subject: Adding upstream version 4.2.2. Signed-off-by: Daniel Baumann --- ui/qt/sequence_diagram.h | 80 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 ui/qt/sequence_diagram.h (limited to 'ui/qt/sequence_diagram.h') diff --git a/ui/qt/sequence_diagram.h b/ui/qt/sequence_diagram.h new file mode 100644 index 00000000..aa9a377a --- /dev/null +++ b/ui/qt/sequence_diagram.h @@ -0,0 +1,80 @@ +/** @file + * + * Wireshark - Network traffic analyzer + * By Gerald Combs + * Copyright 1998 Gerald Combs + * + * SPDX-License-Identifier: GPL-2.0-or-later + */ + +#ifndef SEQUENCE_DIAGRAM_H +#define SEQUENCE_DIAGRAM_H + +#include + +#include + +#include + +#include +#include +#include + +struct _seq_analysis_info; +struct _seq_analysis_item; + +// Some of this is probably unnecessary +class WSCPSeqData +{ +public: + WSCPSeqData(); + WSCPSeqData(double key, _seq_analysis_item *value); + double key; + struct _seq_analysis_item *value; +}; + +typedef QMultiMap WSCPSeqDataMap; + +class SequenceDiagram : public QCPAbstractPlottable +{ + Q_OBJECT +public: + explicit SequenceDiagram(QCPAxis *keyAxis, QCPAxis *valueAxis, QCPAxis *commentAxis); + virtual ~SequenceDiagram(); + + // getters: + // Next / previous packet. + int adjacentPacket(bool next); + + double selectedKey() { return selected_key_; } + + // setters: + void setData(struct _seq_analysis_info *sainfo); + + // non-property methods: + struct _seq_analysis_item *itemForPosY(int ypos); + + // reimplemented virtual methods: + virtual void clearData() { data_->clear(); } + virtual double selectTest(const QPointF &pos, bool onlySelectable, QVariant *details=0) const Q_DECL_OVERRIDE; + +public slots: + void setSelectedPacket(int selected_packet); + +protected: + virtual void draw(QCPPainter *painter) Q_DECL_OVERRIDE; + virtual void drawLegendIcon(QCPPainter *painter, const QRectF &rect) const Q_DECL_OVERRIDE; + virtual QCPRange getKeyRange(bool &validRange, QCP::SignDomain inSignDomain=QCP::sdBoth) const Q_DECL_OVERRIDE; + virtual QCPRange getValueRange(bool &validRange, QCP::SignDomain inSignDomain=QCP::sdBoth, const QCPRange &inKeyRange = QCPRange()) const Q_DECL_OVERRIDE; + +private: + QCPAxis *key_axis_; + QCPAxis *value_axis_; + QCPAxis *comment_axis_; + WSCPSeqDataMap *data_; + struct _seq_analysis_info *sainfo_; + guint32 selected_packet_; + double selected_key_; +}; + +#endif // SEQUENCE_DIAGRAM_H -- cgit v1.2.3