X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fgui%2Fwidgets%2FBasicBlockWidget.hxx;h=10ea402267f5fc1dd1aa0088e3dc533b28644e0e;hp=6ea927b3e4706965447c0adc633f4226637691cd;hb=78942350b02f0b23d8152d3f5b06a8d500fedaab;hpb=2a014774e29e324bc5b5f26143d0384351738ca1 diff --git a/src/gui/widgets/BasicBlockWidget.hxx b/src/gui/widgets/BasicBlockWidget.hxx index 6ea927b..10ea402 100644 --- a/src/gui/widgets/BasicBlockWidget.hxx +++ b/src/gui/widgets/BasicBlockWidget.hxx @@ -1,36 +1,34 @@ #include "gui/qt.hxx" +#include "disassembler/BasicBlock.hxx" class BasicBlockWidget : public QGraphicsItem { public: - BasicBlockWidget() { - x = -5; - y = -20; - dx = 250; - dy = 270; - _widget.addItem("THIS"); - _widget.addItem("IS"); - _widget.addItem("A"); - _widget.addItem("TEST"); - } + BasicBlockWidget(const QString& name); + + void addItem(uint8_t* bytes, size_t num_bytes, const QString& line); - QRectF boundingRect() const - { + QRectF boundingRect() const { qreal penWidth = 1; return QRectF(x - penWidth / 2, y - penWidth / 2, dx + penWidth, dy + penWidth); } + QPointF getEntry() const { + return QPointF(x + dx/2, y); + } + void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, - QWidget *widget) - { + 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, "BLOCK"); + painter->drawText(0, -5, name); _widget.render(painter); } private: int x, y, dx, dy; - QListWidget _widget; + QTableWidget _widget; + QString name; + BasicBlock * block; };