- BasicBlockWidget(const QString& name)
- : x(-5), y(-20)
- , dx(250), dy(270)
- , name(name) {
- _widget.addItem("THIS");
- _widget.addItem("IS");
- _widget.addItem("A");
- _widget.addItem("TEST");
- _widget.resize(dx-20, dy-20);
- }
-
- QRectF boundingRect() const
- {
- qreal penWidth = 1;
- return QRectF(x - penWidth / 2, y - penWidth / 2,
- dx + penWidth, dy + penWidth);
- }
-
- void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,
- QWidget *widget)
- {
- painter->fillRect(x, y, dx, dy, QColor(0xcc, 0xcc, 0xff, 0xff));
- painter->setPen(QColor(0x00, 0x00, 0xff, 0xff));
- painter->drawRect(x, y, dx, dy);
- painter->drawText(0, -5, name);
- _widget.render(painter);
- }
+ BasicBlockWidget(const QString& name, BasicBlock * block, Mainwindow * mainwindow);
+
+ void addItem(uint8_t* bytes, size_t num_bytes, QString line, const QString& href);
+
+ QRectF boundingRect() const {
+ qreal penWidth = 1;
+ QRectF result(- penWidth / 2, - penWidth / 2,
+ width + penWidth, height + penWidth);
+ return result;
+ }
+
+ void mouseMoveEvent(QGraphicsSceneMouseEvent * event) {
+ QGraphicsItem::mouseMoveEvent(event);
+ scene()->update();
+ }
+
+ QPointF getEntry() const {
+ return mapToScene(QPointF(width/2, 0));
+ }
+
+ std::array<QPointF, 3> getExits() const {
+ return { { mapToScene(QPointF( width/3, height)),
+ mapToScene(QPointF( width/2, height)),
+ mapToScene(QPointF(2*width/3, height)) } };
+ }
+
+ void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,
+ QWidget *widget) {
+ painter->fillRect(0, 0, width, height, QColor(0xcc, 0xcc, 0xff, 0xff));
+ painter->setPen(QColor(0x00, 0x00, 0xff, 0xff));
+ painter->drawRect(0, 0, width, height);
+ painter->drawText(5, 15, name);
+ }
+
+ void addPrevious(BasicBlockWidget * widget) {
+ previous.push_back(widget);
+ }
+
+ void addNext(BasicBlockWidget * left, BasicBlockWidget * right) {
+ next[0] = left;
+ next[1] = right;
+ }
+
+ BasicBlockWidget ** getNext() {
+ return next;
+ }
+
+ QString getName() const {
+ return name;
+ }