summaryrefslogtreecommitdiffstats
path: root/utils/regtools/qeditor/regtab.h
blob: b56747f4d16c271be3adeba89a8e4f21a0c340f3 (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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/***************************************************************************
 *             __________               __   ___.
 *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 *                     \/            \/     \/    \/            \/
 * $Id$
 *
 * Copyright (C) 2014 by Amaury Pouly
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 * KIND, either express or implied.
 *
 ****************************************************************************/
#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();
    virtual QWidget *GetWidget();

protected:
    QTreeWidgetItem *MakeNode(const soc_desc::node_inst_t& inst, const QString& s);
    soc_desc::node_inst_t NodeInst(QTreeWidgetItem *item);
    void FillSubTree(QTreeWidgetItem *item);
    void FillRegTree();
    void FillAnalyserList();
    void UpdateSocList();
    void DisplayNode(const soc_desc::node_inst_t& ref);
    void SetDataSocName(const QString& socname);
    void SetPanel(RegTabPanel *panel);
    void UpdateSocFilename();
    void UpdateTabName();
    int SetMessage(MessageWidget::MessageType type, const QString& msg);
    void HideMessage(int id);

    QComboBox *m_soc_selector;
    BackendSelector *m_backend_selector;
    Backend *m_backend;
    QTreeWidget *m_reg_tree;
    soc_desc::soc_ref_t 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;
    MessageWidget *m_msg;
    int m_msg_select_id;
    int m_msg_error_id;

private slots:
    void SetReadOnlyIndicator();
    void OnSocChanged(int index);
    void OnSocAdded(const SocFileRef& ref);
    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 */