]> git.siccegge.de Git - frida/frida.git/blobdiff - src/gui/widgets/BasicBlockWidget.cxx
Use QGraphicsProxyWidget
[frida/frida.git] / src / gui / widgets / BasicBlockWidget.cxx
index faaa2a6aad7b797de6faa6d8c3d42aa1be380a60..2003458d8733a2deb3e7e15d4b5a426209833c0c 100644 (file)
@@ -2,27 +2,31 @@
 
 BasicBlockWidget::BasicBlockWidget(const QString& name, BasicBlock * block)
        : width(270), height(45)
-       , name(name), block(block) {
+       , name(name), block(block)
+       , _proxy(this) {
        next[0] = NULL; next[1] = NULL;
-    _widget.move(5, 20);
+       _proxy.setWidget(&_widget);
+       _widget.setTextInteractionFlags(Qt::TextSelectableByMouse|Qt::LinksAccessibleByMouse);
 
-    if (width < 270) width = 270;
+       _proxy.setPos(5, 20);
+
+       if (width < 270) width = 270;
 }
 
 void BasicBlockWidget::addItem(uint8_t* bytes, size_t num_bytes,
                                const QString& line) {
-    QString bytestring;
+       QString bytestring;
 
-    for (size_t i(0); i < num_bytes; ++i) {
-        const char * hexdigits = "0123456789ABCDEF";
-        bytestring += hexdigits[(bytes[i] >> 4) & 0xF];
-        bytestring += hexdigits[bytes[i] & 0xF];
-        bytestring += ' ';
-    }
+       for (size_t i(0); i < num_bytes; ++i) {
+               const char * hexdigits = "0123456789ABCDEF";
+               bytestring += hexdigits[(bytes[i] >> 4) & 0xF];
+               bytestring += hexdigits[bytes[i] & 0xF];
+               bytestring += ' ';
+       }
 
        QString old_text = _widget.text();
        if (old_text == "") {
-               old_text = "<table style=\"background-color: #ccccff;\">";
+               old_text = "<table style=\"background-color: #ddddff;\">";
        }
        QString new_text =
                old_text.remove("</table>") +
@@ -32,8 +36,9 @@ void BasicBlockWidget::addItem(uint8_t* bytes, size_t num_bytes,
                "</td></tr></table>";
 
        _widget.setText(new_text);
+       _widget.resize(_widget.sizeHint().width(), _widget.sizeHint().height());
        width = 12 + _widget.sizeHint().width();
        height = 25 + _widget.sizeHint().height();
 
-    if (width < 250) width = 250;
+       if (width < 250) width = 250;
 }