]> sigrok.org Git - pulseview.git/blobdiff - pv/views/decoder_output/view.hpp
Fix #1505 by always updating the DecodeTrace height when needed
[pulseview.git] / pv / views / decoder_output / view.hpp
index 9f86cfae24b114756aed7d21744f633ff0a3b444..16d35e82e2823af56cfe83cd5738798360667e6c 100644 (file)
 #ifndef PULSEVIEW_PV_VIEWS_DECODEROUTPUT_VIEW_HPP
 #define PULSEVIEW_PV_VIEWS_DECODEROUTPUT_VIEW_HPP
 
+#include <QAction>
 #include <QComboBox>
 #include <QStackedWidget>
+#include <QToolButton>
 
 #include <pv/views/viewbase.hpp>
 #include <pv/data/decodesignal.hpp>
@@ -36,6 +38,18 @@ namespace views {
 
 namespace decoder_output {
 
+// When adding an entry here, don't forget to update SaveTypeNames as well
+enum SaveType {
+       SaveTypeBinary,
+       SaveTypeHexDumpPlain,
+       SaveTypeHexDumpWithOffset,
+       SaveTypeHexDumpComplete,
+       SaveTypeCount  // Indicates how many save types there are, must always be last
+};
+
+extern const char* SaveTypeNames[SaveTypeCount];
+
+
 class View : public ViewBase
 {
        Q_OBJECT
@@ -43,8 +57,6 @@ class View : public ViewBase
 public:
        explicit View(Session &session, bool is_main_view=false, QMainWindow *parent = nullptr);
 
-       ~View();
-
        virtual ViewType get_type() const;
 
        /**
@@ -53,8 +65,6 @@ public:
         */
        virtual void reset_view_state();
 
-       virtual void clear_signals();
-
        virtual void clear_decode_signals();
        virtual void add_decode_signal(shared_ptr<data::DecodeSignal> signal);
        virtual void remove_decode_signal(shared_ptr<data::DecodeSignal> signal);
@@ -63,21 +73,39 @@ public:
        virtual void restore_settings(QSettings &settings);
 
 private:
+       void reset_data();
        void update_data();
 
+       void save_data() const;
+       void save_data_as_hex_dump(bool with_offset=false, bool with_ascii=false) const;
+
 private Q_SLOTS:
-       void on_selected_signal_changed(int index);
+       void on_selected_decoder_changed(int index);
+       void on_selected_class_changed(int index);
        void on_signal_name_changed(const QString &name);
-       void on_new_binary_data(unsigned int segment_id);
+       void on_new_binary_data(unsigned int segment_id, void* decoder, unsigned int bin_class_id);
+
+       void on_decoder_stacked(void* decoder);
+       void on_decoder_removed(void* decoder);
+
+       void on_actionSave_triggered(QAction* action = nullptr);
+
+       virtual void perform_delayed_view_update();
 
 private:
-       QComboBox *signal_selector_, *format_selector_;
+       QWidget* parent_;
+
+       QComboBox *decoder_selector_, *format_selector_, *class_selector_;
        QStackedWidget *stacked_widget_;
        QHexView *hex_view_;
 
-       data::DecodeSignal *signal_;
+       QToolButton* save_button_;
+       QAction* save_action_;
 
-       QByteArray *merged_data_;
+       data::DecodeSignal *signal_;
+       const data::decode::Decoder *decoder_;
+       uint32_t bin_class_id_;
+       bool binary_data_exists_;
 };
 
 } // namespace decoder_output