#include "BasicBlockWidget.hxx"
+#include "gui/Mainwindow.hxx"
-BasicBlockWidget::BasicBlockWidget(const QString& name, BasicBlock * block)
+BasicBlockWidget::BasicBlockWidget(const QString& name, BasicBlock * block,
+ Mainwindow * mainwindow)
: width(270), height(45)
- , name(name), block(block)
- , _proxy(this) {
+ , _widget("", this)
+ , _table(NULL), name(name)
+ , block(block), mainwindow(mainwindow) {
next[0] = NULL; next[1] = NULL;
- _proxy.setWidget(&_widget);
- _widget.setTextInteractionFlags(Qt::TextSelectableByMouse|Qt::LinksAccessibleByMouse);
- _widget.setStyleSheet("QLabel { background-color : #ddddff; }");
- _proxy.setPos(5, 20);
+ _widget.setTextInteractionFlags(Qt::TextSelectableByMouse|
+ Qt::LinksAccessibleByMouse);
- if (width < 270) width = 270;
+ _widget.setPos(5, 20);
+
+ if (width < 250) width = 250;
}
void BasicBlockWidget::addItem(uint8_t* bytes, size_t num_bytes,
QString line, const QString& href) {
QString bytestring;
+ int row;
+
+ if (_table) {
+ row = _table->rows();
+ _table->appendRows(1);
+ } else {
+ row = 0;
+ QTextTableFormat format;
+ format.setBorderStyle(QTextFrameFormat::BorderStyle_None);
+ format.setBorder(0);
+ _table = _widget.textCursor().insertTable(1, 3, format);
+ }
for (size_t i(0); i < num_bytes; ++i) {
const char * hexdigits = "0123456789ABCDEF";
bytestring += ' ';
}
- QString old_text = _widget.text();
- if (old_text == "") {
- old_text = "<table>";
- }
+ _table->cellAt(row, 0).firstCursorPosition().insertText(bytestring);
- line = line.toHtmlEscaped();
+ line = line.replace('\t', ' ').toHtmlEscaped();
if (href != "") {
line = "<a href=\"" + href + "\">" + line + "</a>";
}
- QString new_text =
- old_text.remove("</table>") +
- "<tr><td>" + bytestring +
- "</td><td>" + line +
- "</td><td>" + "" +
- "</td></tr></table>";
+ _table->cellAt(row, 1).firstCursorPosition().insertHtml(line);
+
+ QObject::connect(&_widget, &QGraphicsTextItem::linkActivated,
+ [=](QString str) {
+ if (str.startsWith("function:")) {
+ QString address = str.remove("function:");
+ mainwindow->switchMainPlaneToAddress(address.toInt(NULL, 16));
+ }
+ });
- _widget.setText(new_text);
- width = 12 + _widget.sizeHint().width();
- height = 25 + _widget.sizeHint().height();
+ width = 10 + _widget.boundingRect().width();
+ height = 25 + _widget.boundingRect().height();
if (width < 250) width = 250;
- _widget.resize(width - 12, height - 25);
}