diff options
Diffstat (limited to 'gui')
-rw-r--r-- | gui/mainwindow.cc | 69 | ||||
-rw-r--r-- | gui/mainwindow.h | 7 | ||||
-rw-r--r-- | gui/mainwindow.ui | 34 |
3 files changed, 48 insertions, 62 deletions
diff --git a/gui/mainwindow.cc b/gui/mainwindow.cc index 285a9250..4bf6be1e 100644 --- a/gui/mainwindow.cc +++ b/gui/mainwindow.cc @@ -83,12 +83,25 @@ MainWindow::MainWindow(Design *_design, QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow), design(_design) { ui->setupUi(this); + PyImport_ImportModule("emb"); + + write = [this](std::string s) { + plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->insertPlainText(s.c_str()); + plainTextEdit->moveCursor(QTextCursor::End); + }; + emb::set_stdout(write); + std::string title = "nextpnr-ice40 - " + design->chip.getChipName(); + setWindowTitle(title.c_str()); + + // Add tree view ui->treeWidget->setColumnCount(1); ui->treeWidget->setHeaderLabel(QString("Items")); ui->treeWidget->setContextMenuPolicy(Qt::CustomContextMenu); connect(ui->treeWidget, &QTreeWidget::customContextMenuRequested, this, &MainWindow::prepareMenu); + // Add bels to tree QTreeWidgetItem *bel_root = new QTreeWidgetItem(ui->treeWidget); bel_root->setText(0, QString("Bels")); ui->treeWidget->insertTopLevelItem(0, bel_root); @@ -100,6 +113,7 @@ MainWindow::MainWindow(Design *_design, QWidget *parent) } bel_root->addChildren(bel_items); + // Add wires to tree QTreeWidgetItem *wire_root = new QTreeWidgetItem(ui->treeWidget); QList<QTreeWidgetItem *> wire_items; wire_root->setText(0, QString("Wires")); @@ -111,6 +125,7 @@ MainWindow::MainWindow(Design *_design, QWidget *parent) } wire_root->addChildren(wire_items); + // Add pips to tree QTreeWidgetItem *pip_root = new QTreeWidgetItem(ui->treeWidget); QList<QTreeWidgetItem *> pip_items; pip_root->setText(0, QString("Pips")); @@ -122,21 +137,9 @@ MainWindow::MainWindow(Design *_design, QWidget *parent) } pip_root->addChildren(pip_items); - PyImport_ImportModule("emb"); - - write = [this](std::string s) { - ui->plainTextEdit->moveCursor(QTextCursor::End); - ui->plainTextEdit->insertPlainText(s.c_str()); - ui->plainTextEdit->moveCursor(QTextCursor::End); - }; - emb::set_stdout(write); - std::string title = "nextpnr-ice40 - " + design->chip.getChipName(); - setWindowTitle(title.c_str()); - + // Add property view variantManager = new QtVariantPropertyManager(); - variantFactory = new QtVariantEditorFactory(); - propertyEditor = new QtTreePropertyBrowser(); propertyEditor->setFactoryForManager(variantManager, variantFactory); propertyEditor->setPropertiesWithoutValueMarked(true); @@ -146,6 +149,19 @@ MainWindow::MainWindow(Design *_design, QWidget *parent) connect(ui->treeWidget, SIGNAL(itemClicked(QTreeWidgetItem *, int)), SLOT(onItemClicked(QTreeWidgetItem *, int))); + + // Add text area for Python output and input line + plainTextEdit = new QPlainTextEdit(); + plainTextEdit->setReadOnly(true); + plainTextEdit->setMinimumHeight(50); + plainTextEdit->setMaximumHeight(200); + ui->splitter->addWidget(plainTextEdit); + lineEdit = new QLineEdit(); + lineEdit->setMinimumHeight(30); + lineEdit->setMaximumHeight(30); + ui->splitter->addWidget(lineEdit); + connect(lineEdit, SIGNAL(returnPressed()), this, + SLOT(editLineReturnPressed())); } MainWindow::~MainWindow() @@ -221,12 +237,12 @@ void MainWindow::prepareMenu(const QPoint &pos) void MainWindow::selectObject() { - ui->plainTextEdit->moveCursor(QTextCursor::End); - ui->plainTextEdit->insertPlainText( + plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->insertPlainText( std::string("selected " + itemContextMenu->text(0).toStdString() + "\n") .c_str()); - ui->plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->moveCursor(QTextCursor::End); } void handle_system_exit() { exit(-1); } @@ -263,9 +279,9 @@ int MainWindow::executePython(std::string command) PyObject *objectsRepresentation = PyObject_Str(v); std::string errorStr = PyUnicode_AsUTF8(objectsRepresentation) + std::string("\n"); - ui->plainTextEdit->moveCursor(QTextCursor::End); - ui->plainTextEdit->insertPlainText(errorStr.c_str()); - ui->plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->insertPlainText(errorStr.c_str()); + plainTextEdit->moveCursor(QTextCursor::End); Py_DECREF(objectsRepresentation); Py_XDECREF(exception); Py_XDECREF(v); @@ -276,14 +292,13 @@ int MainWindow::executePython(std::string command) return 0; } -void MainWindow::on_lineEdit_returnPressed() +void MainWindow::editLineReturnPressed() { - std::string input = ui->lineEdit->text().toStdString(); - ui->plainTextEdit->moveCursor(QTextCursor::End); - ui->plainTextEdit->insertPlainText( - std::string(">>> " + input + "\n").c_str()); - ui->plainTextEdit->moveCursor(QTextCursor::End); - ui->plainTextEdit->update(); - ui->lineEdit->clear(); + std::string input = lineEdit->text().toStdString(); + plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->insertPlainText(std::string(">>> " + input + "\n").c_str()); + plainTextEdit->moveCursor(QTextCursor::End); + plainTextEdit->update(); + lineEdit->clear(); int error = executePython(input); } diff --git a/gui/mainwindow.h b/gui/mainwindow.h index b528f6b7..e9645619 100644 --- a/gui/mainwindow.h +++ b/gui/mainwindow.h @@ -7,7 +7,9 @@ #include "qttreepropertybrowser.h" #include "qtvariantproperty.h" +#include <QLineEdit> #include <QMainWindow> +#include <QPlainTextEdit> // FIXME USING_NEXTPNR_NAMESPACE @@ -30,7 +32,7 @@ class MainWindow : public QMainWindow void addProperty(QtVariantProperty *property, const QString &id); private Q_SLOTS: - void on_lineEdit_returnPressed(); + void editLineReturnPressed(); void prepareMenu(const QPoint &pos); void selectObject(); void onItemClicked(QTreeWidgetItem *item, int); @@ -46,6 +48,9 @@ class MainWindow : public QMainWindow QMap<QtProperty *, QString> propertyToId; QMap<QString, QtVariantProperty *> idToProperty; + + QPlainTextEdit *plainTextEdit; + QLineEdit *lineEdit; }; #endif // MAINWINDOW_H diff --git a/gui/mainwindow.ui b/gui/mainwindow.ui index 7352af1f..aed4b47f 100644 --- a/gui/mainwindow.ui +++ b/gui/mainwindow.ui @@ -25,40 +25,6 @@ <enum>Qt::Vertical</enum> </property> <widget class="FPGAViewWidget" name="openGLWidget" native="true"/> - <widget class="QPlainTextEdit" name="plainTextEdit"> - <property name="enabled"> - <bool>true</bool> - </property> - <property name="minimumSize"> - <size> - <width>0</width> - <height>50</height> - </size> - </property> - <property name="maximumSize"> - <size> - <width>16777215</width> - <height>200</height> - </size> - </property> - <property name="readOnly"> - <bool>true</bool> - </property> - </widget> - <widget class="QLineEdit" name="lineEdit"> - <property name="minimumSize"> - <size> - <width>0</width> - <height>30</height> - </size> - </property> - <property name="maximumSize"> - <size> - <width>16777215</width> - <height>30</height> - </size> - </property> - </widget> </widget> <widget class="QSplitter" name="splitter_2"> <property name="orientation"> |