aboutsummaryrefslogtreecommitdiff
path: root/qtmips_gui/coreview/registers.h
diff options
context:
space:
mode:
Diffstat (limited to 'qtmips_gui/coreview/registers.h')
-rw-r--r--qtmips_gui/coreview/registers.h44
1 files changed, 44 insertions, 0 deletions
diff --git a/qtmips_gui/coreview/registers.h b/qtmips_gui/coreview/registers.h
new file mode 100644
index 0000000..ece710d
--- /dev/null
+++ b/qtmips_gui/coreview/registers.h
@@ -0,0 +1,44 @@
+#ifndef COREVIEW_REGISTERS_H
+#define COREVIEW_REGISTERS_H
+
+#include <QGraphicsObject>
+#include <QPainter>
+#include <QGraphicsSimpleTextItem>
+#include "connection.h"
+
+namespace coreview {
+
+class Registers : public QGraphicsObject {
+ Q_OBJECT
+public:
+ Registers();
+ ~Registers();
+
+ QRectF boundingRect() const;
+ void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
+
+ void setPos(qreal x, qreal y);
+ const Connector *connector_read1() const;
+ const Connector *connector_read1_reg() const;
+ const Connector *connector_read2() const;
+ const Connector *connector_read2_reg() const;
+ const Connector *connector_write() const;
+ const Connector *connector_write_reg() const;
+ const Connector *connector_ctl_write() const;
+
+signals:
+ void open_registers();
+
+protected:
+ void mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event);
+
+private:
+ Connector *con_read1, *con_read1_reg, *con_read2, *con_read2_reg;
+ Connector *con_write, *con_write_reg, *con_ctl_write;
+
+ QGraphicsSimpleTextItem *name;
+};
+
+}
+
+#endif // COREVIEW_REGISTERS_H