X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Fdecoder_output%2FQHexView.hpp;h=74b9da566fe9e7dd78eb99755109f36b72ff6659;hb=ac9494eff3ebc74ae7a87746a4d8668c68f32b52;hp=234abda64baf3b9ecb2b1f734280e36a72c0dadd;hpb=560f837745f9779417b6984d3e6c838ae8451838;p=pulseview.git diff --git a/pv/views/decoder_output/QHexView.hpp b/pv/views/decoder_output/QHexView.hpp index 234abda6..74b9da56 100644 --- a/pv/views/decoder_output/QHexView.hpp +++ b/pv/views/decoder_output/QHexView.hpp @@ -31,45 +31,36 @@ #define PULSEVIEW_PV_VIEWS_DECODEROUTPUT_QHEXVIEW_H #include -#include -#include -using std::size_t; +#include +using std::size_t; +using pv::data::DecodeBinaryClass; +using pv::data::DecodeBinaryDataChunk; -class DataStorage +class QHexView: public QAbstractScrollArea { -public: - virtual ~DataStorage() {}; - virtual QByteArray getData(size_t position, size_t length) = 0; - virtual size_t size() = 0; -}; + Q_OBJECT - -class DataStorageArray: public DataStorage -{ public: - DataStorageArray(const QByteArray &arr); - virtual QByteArray getData(size_t position, size_t length); - virtual size_t size(); + enum Mode { + ChunkedDataMode, ///< Displays all data chunks in succession + MemoryEmulationMode ///< Reconstructs memory contents from data chunks + }; -private: - QByteArray data_; -}; - - -class QHexView: public QAbstractScrollArea -{ public: QHexView(QWidget *parent = 0); - ~QHexView(); -public Q_SLOTS: - void setData(DataStorage *pData); + void setMode(Mode m); + void setData(const DecodeBinaryClass* data); + void clear(); void showFromOffset(size_t offset); protected: + void initialize_byte_iterator(size_t offset); + uint8_t get_next_byte(bool* is_next_chunk = nullptr); + void paintEvent(QPaintEvent *event); void keyPressEvent(QKeyEvent *event); void mouseMoveEvent(QMouseEvent *event); @@ -85,11 +76,18 @@ private: size_t cursorPosFromMousePos(const QPoint &position); private: - DataStorage *pdata_; + Mode mode_; + const DecodeBinaryClass* data_; + size_t data_size_; size_t posAddr_, posHex_, posAscii_; size_t charWidth_, charHeight_; size_t selectBegin_, selectEnd_, selectInit_, cursorPos_; + + size_t current_chunk_id_, current_chunk_offset_; + const DecodeBinaryDataChunk* current_chunk_; + + vector chunk_colors_; }; #endif /* PULSEVIEW_PV_VIEWS_DECODEROUTPUT_QHEXVIEW_H */