summaryrefslogtreecommitdiffstats
path: root/utils/regtools/qeditor/regtab.h
blob: f48b72e683f4c5456c85f57a23ec23ecec8daca3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#ifndef REGTAB_H
#define REGTAB_H

#include <QComboBox>
#include <QTreeWidget>
#include <QVBoxLayout>
#include <QTabWidget>
#include <QSplitter>
#include <QLineEdit>
#include <QPushButton>
#include <QLabel>
#include <QListWidget>
#include <QGroupBox>
#include <QToolButton>
#include <QMenu>
#include <QCheckBox>
#include "backend.h"
#include "settings.h"
#include "mainwindow.h"
#include "utils.h"

class RegTabPanel
{
public:
    RegTabPanel() {}
    virtual ~RegTabPanel() {}
    virtual void AllowWrite(bool en) = 0;
    virtual QWidget *GetWidget() = 0;
};

class EmptyRegTabPanel : public QWidget, public RegTabPanel
{
public:
    EmptyRegTabPanel(QWidget *parent = 0);
    void AllowWrite(bool en);
    QWidget *GetWidget();
};

class RegTab : public QSplitter, public DocumentTab
{
    Q_OBJECT
public:
    RegTab(Backend *backend, QWidget *parent = 0);
    ~RegTab();
    virtual bool Quit();

signals:
    void OnModified(bool modified);

protected:
    void FillDevSubTree(QTreeWidgetItem *item);
    void FillSocSubTree(QTreeWidgetItem *item);
    void FillRegTree();
    void FillAnalyserList();
    void UpdateSocList();
    void DisplayRegister(const SocRegRef& ref);
    void DisplayDevice(const SocDevRef& ref);
    void DisplaySoc(const SocRef& ref);
    void SetDataSocName(const QString& socname);
    void SetPanel(RegTabPanel *panel);
    void UpdateSocFilename();

    QComboBox *m_soc_selector;
    BackendSelector *m_backend_selector;
    Backend *m_backend;
    QTreeWidget *m_reg_tree;
    SocRef m_cur_soc;
    QVBoxLayout *m_right_panel;
    RegTabPanel *m_right_content;
    QCheckBox *m_readonly_check;
    QLabel *m_data_soc_label;
    QPushButton *m_data_sel_reload;
    QPushButton *m_dump;
    IoBackend *m_io_backend;
    QTabWidget *m_type_selector;
    QListWidget *m_analysers_list;

private slots:
    void SetReadOnlyIndicator();
    void OnSocChanged(int index);
    void OnSocListChanged();
    void OnRegItemClicked(QTreeWidgetItem *clicked, int col);
    void OnBackendSelect(IoBackend *backend);
    void OnDataChanged();
    void OnDataSocActivated(const QString&);
    void OnAnalyserClicked(QListWidgetItem *clicked);
    void OnReadOnlyClicked(bool);
    void OnDumpRegs(bool);
    void OnBackendReload(bool);
    void OnTypeChanged(int index);
};

#endif /* REGTAB_H */