Merge pull request #580 from GriffinRichards/open-proj

Fix minor issues with project opening
This commit is contained in:
GriffinR 2024-01-08 21:29:03 -05:00 committed by GitHub
commit c67835d350
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 52 additions and 50 deletions

View file

@ -347,7 +347,8 @@ private:
void sortMapList(); void sortMapList();
void openSubWindow(QWidget * window); void openSubWindow(QWidget * window);
QString getExistingDirectory(QString); QString getExistingDirectory(QString);
bool openProject(QString dir); bool openProject(const QString &dir, bool initial = false);
void showProjectOpenFailure();
bool setInitialMap(); bool setInitialMap();
void setRecentMap(QString map_name); void setRecentMap(QString map_name);
QStandardItem* createMapItem(QString mapName, int groupNum, int inGroupNum); QStandardItem* createMapItem(QString mapName, int groupNum, int inGroupNum);
@ -377,7 +378,6 @@ private:
void applyMapListFilter(QString filterText); void applyMapListFilter(QString filterText);
void restoreWindowState(); void restoreWindowState();
void setTheme(QString); void setTheme(QString);
bool openRecentProject();
void updateTilesetEditor(); void updateTilesetEditor();
Event::Group getEventGroupFromTabWidget(QWidget *tab); Event::Group getEventGroupFromTabWidget(QWidget *tab);
void closeSupplementaryWindows(); void closeSupplementaryWindows();

View file

@ -60,7 +60,7 @@ MainWindow::MainWindow(QWidget *parent) :
cleanupLargeLog(); cleanupLargeLog();
this->initWindow(); this->initWindow();
if (this->openRecentProject()) if (porymapConfig.getReopenOnLaunch() && this->openProject(porymapConfig.getRecentProject(), true))
on_toolButton_Paint_clicked(); on_toolButton_Paint_clicked();
// there is a bug affecting macOS users, where the trackpad deilveres a bad touch-release gesture // there is a bug affecting macOS users, where the trackpad deilveres a bad touch-release gesture
@ -477,35 +477,29 @@ void MainWindow::setTheme(QString theme) {
} }
} }
bool MainWindow::openRecentProject() { bool MainWindow::openProject(const QString &dir, bool initial) {
if (!porymapConfig.getReopenOnLaunch()) if (dir.isNull() || dir.length() <= 0) {
return false;
QString default_dir = porymapConfig.getRecentProject();
if (default_dir.isNull() || default_dir.length() <= 0)
return false;
if (!QDir(default_dir).exists()) {
QString message = QString("Recent project directory '%1' doesn't exist.").arg(QDir::toNativeSeparators(default_dir));
logWarn(message);
this->statusBar()->showMessage(message);
return false;
}
logInfo(QString("Opening recent project: '%1'").arg(default_dir));
return openProject(default_dir);
}
bool MainWindow::openProject(QString dir) {
if (dir.isNull()) {
projectOpenFailure = true; projectOpenFailure = true;
setWindowDisabled(true); if (!initial) setWindowDisabled(true);
return false; return false;
} }
QString nativeDir = QDir::toNativeSeparators(dir); const QString projectString = QString("%1project '%2'").arg(initial ? "recent " : "").arg(QDir::toNativeSeparators(dir));
this->statusBar()->showMessage(QString("Opening project %1").arg(nativeDir)); if (!QDir(dir).exists()) {
projectOpenFailure = true;
const QString errorMsg = QString("Failed to open %1: No such directory").arg(projectString);
this->statusBar()->showMessage(errorMsg);
if (initial) {
// Graceful startup if recent project directory is missing
logWarn(errorMsg);
} else {
logError(errorMsg);
showProjectOpenFailure();
}
return false;
}
this->statusBar()->showMessage(QString("Opening %1").arg(projectString));
userConfig.setProjectDir(dir); userConfig.setProjectDir(dir);
userConfig.load(); userConfig.load();
@ -515,7 +509,10 @@ bool MainWindow::openProject(QString dir) {
this->closeSupplementaryWindows(); this->closeSupplementaryWindows();
this->newMapDefaultsSet = false; this->newMapDefaultsSet = false;
if (isProjectOpen())
Scripting::cb_ProjectClosed(editor->project->root);
Scripting::init(this); Scripting::init(this);
bool already_open = isProjectOpen() && (editor->project->root == dir); bool already_open = isProjectOpen() && (editor->project->root == dir);
if (!already_open) { if (!already_open) {
editor->closeProject(); editor->closeProject();
@ -540,19 +537,16 @@ bool MainWindow::openProject(QString dir) {
&& setInitialMap()); && setInitialMap());
if (this->projectOpenFailure) { if (this->projectOpenFailure) {
this->statusBar()->showMessage(QString("Failed to open project %1").arg(nativeDir)); this->statusBar()->showMessage(QString("Failed to open %1").arg(projectString));
QMessageBox msgBox(this); showProjectOpenFailure();
QString errorMsg = QString("There was an error opening the project %1. Please see %2 for full error details.\n\n%3")
.arg(dir)
.arg(getLogPath())
.arg(getMostRecentError());
msgBox.critical(nullptr, "Error Opening Project", errorMsg);
setWindowDisabled(true);
return false; return false;
} }
showWindowTitle(); showWindowTitle();
this->statusBar()->showMessage(QString("Opened project %1").arg(nativeDir));
const QString successMessage = QString("Opened %1").arg(projectString);
this->statusBar()->showMessage(successMessage);
logInfo(successMessage);
porymapConfig.addRecentProject(dir); porymapConfig.addRecentProject(dir);
refreshRecentProjectsMenu(); refreshRecentProjectsMenu();
@ -567,6 +561,14 @@ bool MainWindow::openProject(QString dir) {
return true; return true;
} }
void MainWindow::showProjectOpenFailure() {
QString errorMsg = QString("There was an error opening the project. Please see %1 for full error details.").arg(getLogPath());
QMessageBox error(QMessageBox::Critical, "porymap", errorMsg, QMessageBox::Ok, this);
error.setDetailedText(getMostRecentError());
error.exec();
setWindowDisabled(true);
}
bool MainWindow::isProjectOpen() { bool MainWindow::isProjectOpen() {
return !projectOpenFailure && editor && editor->project; return !projectOpenFailure && editor && editor->project;
} }
@ -607,17 +609,22 @@ void MainWindow::refreshRecentProjectsMenu() {
recentProjects.removeOne(this->editor->project->root); recentProjects.removeOne(this->editor->project->root);
} }
// Add project paths to menu. Arbitrary limit of 10 items. // Add project paths to menu. Skip any paths to folders that don't exist
const int numItems = qMin(10, recentProjects.length()); for (int i = 0; i < recentProjects.length(); i++) {
for (int i = 0; i < numItems; i++) {
const QString path = recentProjects.at(i); const QString path = recentProjects.at(i);
if (QDir(path).exists()) {
ui->menuOpen_Recent_Project->addAction(path, [this, path](){ ui->menuOpen_Recent_Project->addAction(path, [this, path](){
this->openProject(path); this->openProject(path);
}); });
} }
// Arbitrary limit of 10 items.
if (ui->menuOpen_Recent_Project->actions().length() >= 10)
break;
}
// Add action to clear list of paths // Add action to clear list of paths
if (!recentProjects.isEmpty()) ui->menuOpen_Recent_Project->addSeparator(); if (!ui->menuOpen_Recent_Project->actions().isEmpty())
ui->menuOpen_Recent_Project->addSeparator();
QAction *clearAction = ui->menuOpen_Recent_Project->addAction("Clear Items", [this](){ QAction *clearAction = ui->menuOpen_Recent_Project->addAction("Clear Items", [this](){
QStringList paths = QStringList(); QStringList paths = QStringList();
if (isProjectOpen()) if (isProjectOpen())
@ -652,14 +659,9 @@ void MainWindow::on_action_Open_Project_triggered()
recent = userConfig.getRecentMap(); recent = userConfig.getRecentMap();
} }
QString dir = getExistingDirectory(recent); QString dir = getExistingDirectory(recent);
if (!dir.isEmpty()) { if (!dir.isEmpty())
if (this->editor && this->editor->project) {
Scripting::cb_ProjectClosed(this->editor->project->root);
this->ui->graphicsView_Map->clearOverlayMap();
}
openProject(dir); openProject(dir);
} }
}
void MainWindow::on_action_Reload_Project_triggered() { void MainWindow::on_action_Reload_Project_triggered() {
// TODO: when undo history is complete show only if has unsaved changes // TODO: when undo history is complete show only if has unsaved changes
@ -2792,7 +2794,6 @@ void MainWindow::initCustomScriptsEditor() {
void MainWindow::reloadScriptEngine() { void MainWindow::reloadScriptEngine() {
Scripting::init(this); Scripting::init(this);
this->ui->graphicsView_Map->clearOverlayMap();
Scripting::populateGlobalObject(this); Scripting::populateGlobalObject(this);
// Lying to the scripts here, simulating a project reload // Lying to the scripts here, simulating a project reload
Scripting::cb_ProjectOpened(projectConfig.getProjectDir()); Scripting::cb_ProjectOpened(projectConfig.getProjectDir());

View file

@ -23,6 +23,7 @@ QMap<CallbackType, QString> callbackFunctions = {
Scripting *instance = nullptr; Scripting *instance = nullptr;
void Scripting::init(MainWindow *mainWindow) { void Scripting::init(MainWindow *mainWindow) {
mainWindow->ui->graphicsView_Map->clearOverlayMap();
if (instance) { if (instance) {
instance->engine->setInterrupted(true); instance->engine->setInterrupted(true);
instance->scriptUtility->clearActions(); instance->scriptUtility->clearActions();