From 5c6b8a5f0473c6ec04dd045029eb0d87353558ab Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Wed, 30 Jun 2021 10:10:18 +0200 Subject: Preserve ArchArgs and reinit Context when applicable in GUI --- gui/basewindow.cc | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'gui') diff --git a/gui/basewindow.cc b/gui/basewindow.cc index 80785199..e93428cf 100644 --- a/gui/basewindow.cc +++ b/gui/basewindow.cc @@ -365,6 +365,11 @@ void BaseMainWindow::open_json() QString fileName = QFileDialog::getOpenFileName(this, QString("Open JSON"), QString(), QString("*.json")); if (!fileName.isEmpty()) { disableActions(); + if (ctx->settings.find(ctx->id("synth")) == ctx->settings.end()) { + ArchArgs chipArgs = ctx->getArchArgs(); + ctx = std::unique_ptr(new Context(chipArgs)); + Q_EMIT contextChanged(ctx.get()); + } handler->load_json(ctx.get(), fileName.toStdString()); Q_EMIT updateTreeView(); log("Loading design successful.\n"); @@ -523,7 +528,7 @@ void BaseMainWindow::place() { Q_EMIT task->place(timing_driven); } void BaseMainWindow::disableActions() { - actionLoadJSON->setEnabled(false); + actionLoadJSON->setEnabled(true); actionPack->setEnabled(false); actionAssignBudget->setEnabled(false); actionPlace->setEnabled(false); -- cgit v1.2.3