diff options
Diffstat (limited to 'qtmips_gui/coreview/memory.h')
-rw-r--r-- | qtmips_gui/coreview/memory.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/qtmips_gui/coreview/memory.h b/qtmips_gui/coreview/memory.h new file mode 100644 index 0000000..0f0d40d --- /dev/null +++ b/qtmips_gui/coreview/memory.h @@ -0,0 +1,41 @@ +#ifndef COREVIEW_MEMORY_H +#define COREVIEW_MEMORY_H + +#include <QGraphicsObject> +#include <QPainter> +#include <qtmipsmachine.h> +#include "../coreview.h" +#include "connection.h" + +namespace coreview{ + +class Memory : public QGraphicsObject { + Q_OBJECT +public: + Memory(machine::QtMipsMachine *machine); + + QRectF boundingRect() const; + void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget); + + void setPos(qreal x, qreal y); + const Connector *connector_in(bool program) const; + const Connector *connector_out(bool program) const; + const Connector *connector_read(bool program) const; + const Connector *connector_write(bool program) const; + // TODO integrate cache + +private: + struct { + Connector *in, *out, *read, *write; + } con_program, con_data; +}; + +} + +#else + +namespace coreview { + class Memory; +} + +#endif // MEMORY_H |