Merge pull request #17265 from wwmayer/issue_17250
Core: Add convenience class ModuleIO to open files
This commit is contained in:
@@ -28,8 +28,8 @@
|
||||
# include <QActionGroup>
|
||||
# include <QApplication>
|
||||
# include <QEvent>
|
||||
# include <QFileInfo>
|
||||
# include <QMenu>
|
||||
# include <QMessageBox>
|
||||
# include <QRegularExpression>
|
||||
# include <QScreen>
|
||||
# include <QTimer>
|
||||
@@ -50,8 +50,8 @@
|
||||
#include "PreferencePages/DlgSettingsWorkbenchesImp.h"
|
||||
#include "Document.h"
|
||||
#include "EditorView.h"
|
||||
#include "FileDialog.h"
|
||||
#include "Macro.h"
|
||||
#include "ModuleIO.h"
|
||||
#include "MainWindow.h"
|
||||
#include "PythonEditor.h"
|
||||
#include "WhatsThis.h"
|
||||
@@ -902,20 +902,13 @@ void RecentFilesAction::activateFile(int id)
|
||||
}
|
||||
|
||||
QString filename = files[id];
|
||||
QFileInfo fi(filename);
|
||||
if (!fi.exists() || !fi.isFile()) {
|
||||
QMessageBox::critical(getMainWindow(), tr("File not found"), tr("The file '%1' cannot be opened.").arg(filename));
|
||||
if (!ModuleIO::verifyFile(filename)) {
|
||||
files.removeAll(filename);
|
||||
setFiles(files);
|
||||
save();
|
||||
}
|
||||
else {
|
||||
// invokes appendFile()
|
||||
SelectModule::Dict dict = SelectModule::importHandler(filename);
|
||||
for (SelectModule::Dict::iterator it = dict.begin(); it != dict.end(); ++it) {
|
||||
Application::Instance->open(it.key().toUtf8(), it.value().toLatin1());
|
||||
break;
|
||||
}
|
||||
ModuleIO::openFile(filename);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1102,8 +1095,7 @@ void RecentMacrosAction::activateFile(int id)
|
||||
|
||||
QString filename = files[id];
|
||||
QFileInfo fi(filename);
|
||||
if (!fi.exists() || !fi.isFile()) {
|
||||
QMessageBox::critical(getMainWindow(), tr("File not found"), tr("The file '%1' cannot be opened.").arg(filename));
|
||||
if (!ModuleIO::verifyFile(filename)) {
|
||||
files.removeAll(filename);
|
||||
setFiles(files);
|
||||
}
|
||||
|
||||
@@ -1231,6 +1231,7 @@ SET(FreeCADGui_CPP_SRCS
|
||||
GuiConsole.cpp
|
||||
Macro.cpp
|
||||
MergeDocuments.cpp
|
||||
ModuleIO.cpp
|
||||
Namespace.h
|
||||
resource.cpp
|
||||
Control.cpp
|
||||
@@ -1266,6 +1267,7 @@ SET(FreeCADGui_SRCS
|
||||
Macro.h
|
||||
MergeDocuments.h
|
||||
MetaTypes.h
|
||||
ModuleIO.h
|
||||
Notifications.h
|
||||
PreCompiled.cpp
|
||||
PreCompiled.h
|
||||
|
||||
@@ -91,6 +91,7 @@
|
||||
#include "DownloadManager.h"
|
||||
#include "FileDialog.h"
|
||||
#include "MenuManager.h"
|
||||
#include "ModuleIO.h"
|
||||
#include "NotificationArea.h"
|
||||
#include "OverlayManager.h"
|
||||
#include "ProgressBar.h"
|
||||
@@ -2411,12 +2412,7 @@ void MainWindow::loadUrls(App::Document* doc, const QList<QUrl>& urls)
|
||||
}
|
||||
|
||||
QByteArray docName = doc ? QByteArray(doc->getName()) : qApp->translate("StdCmdNew","Unnamed").toUtf8();
|
||||
SelectModule::Dict dict = SelectModule::importHandler(files);
|
||||
// load the files with the associated modules
|
||||
for (SelectModule::Dict::iterator it = dict.begin(); it != dict.end(); ++it) {
|
||||
// if the passed document name doesn't exist the module should create it, if needed
|
||||
Application::Instance->importFrom(it.key().toUtf8(), docName, it.value().toLatin1());
|
||||
}
|
||||
ModuleIO::importFiles(files, docName);
|
||||
}
|
||||
|
||||
void MainWindow::changeEvent(QEvent *e)
|
||||
|
||||
79
src/Gui/ModuleIO.cpp
Normal file
79
src/Gui/ModuleIO.cpp
Normal file
@@ -0,0 +1,79 @@
|
||||
// SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
/***************************************************************************
|
||||
* Copyright (c) 2024 Werner Mayer <wmayer[at]users.sourceforge.net> *
|
||||
* *
|
||||
* This file is part of FreeCAD. *
|
||||
* *
|
||||
* FreeCAD is free software: you can redistribute it and/or modify it *
|
||||
* under the terms of the GNU Lesser General Public License as *
|
||||
* published by the Free Software Foundation, either version 2.1 of the *
|
||||
* License, or (at your option) any later version. *
|
||||
* *
|
||||
* FreeCAD is distributed in the hope that it will be useful, but *
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
|
||||
* Lesser General Public License for more details. *
|
||||
* *
|
||||
* You should have received a copy of the GNU Lesser General Public *
|
||||
* License along with FreeCAD. If not, see *
|
||||
* <https://www.gnu.org/licenses/>. *
|
||||
* *
|
||||
**************************************************************************/
|
||||
|
||||
#include "PreCompiled.h"
|
||||
#ifndef _PreComp_
|
||||
#include <QFileInfo>
|
||||
#include <QMessageBox>
|
||||
#endif
|
||||
|
||||
|
||||
#include "ModuleIO.h"
|
||||
#include "Application.h"
|
||||
#include "FileDialog.h"
|
||||
#include "MainWindow.h"
|
||||
|
||||
|
||||
using namespace Gui;
|
||||
|
||||
/* TRANSLATOR Gui::ModuleIO */
|
||||
|
||||
bool ModuleIO::verifyFile(const QString& filename)
|
||||
{
|
||||
QFileInfo fi(filename);
|
||||
if (!fi.exists() || !fi.isFile()) {
|
||||
QMessageBox::critical(Gui::getMainWindow(),
|
||||
tr("File not found"),
|
||||
tr("The file '%1' cannot be opened.").arg(filename));
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void ModuleIO::openFile(const QString& filename)
|
||||
{
|
||||
// invokes appendFile()
|
||||
Gui::SelectModule::Dict dict = Gui::SelectModule::importHandler(filename);
|
||||
for (Gui::SelectModule::Dict::iterator it = dict.begin(); it != dict.end(); ++it) {
|
||||
Gui::Application::Instance->open(it.key().toUtf8(), it.value().toLatin1());
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void ModuleIO::verifyAndOpenFile(const QString& filename)
|
||||
{
|
||||
if (verifyFile(filename)) {
|
||||
openFile(filename);
|
||||
}
|
||||
}
|
||||
|
||||
void ModuleIO::importFiles(const QStringList& filenames, const char* document)
|
||||
{
|
||||
SelectModule::Dict dict = SelectModule::importHandler(filenames);
|
||||
// load the files with the associated modules
|
||||
for (SelectModule::Dict::iterator it = dict.begin(); it != dict.end(); ++it) {
|
||||
// if the passed document name doesn't exist the module should create it, if needed
|
||||
Application::Instance->importFrom(it.key().toUtf8(), document, it.value().toLatin1());
|
||||
}
|
||||
}
|
||||
72
src/Gui/ModuleIO.h
Normal file
72
src/Gui/ModuleIO.h
Normal file
@@ -0,0 +1,72 @@
|
||||
// SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
|
||||
/***************************************************************************
|
||||
* Copyright (c) 2024 Werner Mayer <wmayer[at]users.sourceforge.net> *
|
||||
* *
|
||||
* This file is part of FreeCAD. *
|
||||
* *
|
||||
* FreeCAD is free software: you can redistribute it and/or modify it *
|
||||
* under the terms of the GNU Lesser General Public License as *
|
||||
* published by the Free Software Foundation, either version 2.1 of the *
|
||||
* License, or (at your option) any later version. *
|
||||
* *
|
||||
* FreeCAD is distributed in the hope that it will be useful, but *
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
|
||||
* Lesser General Public License for more details. *
|
||||
* *
|
||||
* You should have received a copy of the GNU Lesser General Public *
|
||||
* License along with FreeCAD. If not, see *
|
||||
* <https://www.gnu.org/licenses/>. *
|
||||
* *
|
||||
**************************************************************************/
|
||||
|
||||
#ifndef GUI_MODULE_IO_H
|
||||
#define GUI_MODULE_IO_H
|
||||
|
||||
#include <QCoreApplication>
|
||||
#include <FCGlobal.h>
|
||||
|
||||
namespace Gui {
|
||||
|
||||
class GuiExport ModuleIO
|
||||
{
|
||||
Q_DECLARE_TR_FUNCTIONS(Gui::ModuleIO)
|
||||
|
||||
public:
|
||||
/*!
|
||||
* \brief verifyFile
|
||||
* Verifies the existence of the file. If it doesn't exist an error dialog
|
||||
* pops up and false is returned, otherwise true is returned.
|
||||
* \param filename
|
||||
* \return
|
||||
*/
|
||||
static bool verifyFile(const QString& filename);
|
||||
/*!
|
||||
* \brief openFile
|
||||
* Opens the file.
|
||||
* The handling module is supposed to create a new document.
|
||||
* \param filename
|
||||
*/
|
||||
static void openFile(const QString& filename);
|
||||
/*!
|
||||
* \brief verifyAndOpenFile
|
||||
* Verifies the existence of the file and opens it.
|
||||
* The handling module is supposed to create a new document.
|
||||
* \param filename
|
||||
*/
|
||||
static void verifyAndOpenFile(const QString& filename);
|
||||
/*!
|
||||
* \brief importFile
|
||||
* Imports the files into the given document.
|
||||
* The handling module is supposed to create a new document if the passed
|
||||
* document doesn't exist.
|
||||
* \param filename
|
||||
* \param document
|
||||
*/
|
||||
static void importFiles(const QStringList& filenames, const char* document);
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif // GUI_MODULE_IO_H
|
||||
@@ -48,10 +48,8 @@
|
||||
#include <Base/Tools.h>
|
||||
#include <Gui/Application.h>
|
||||
#include <Gui/Command.h>
|
||||
#include <Gui/MainWindow.h>
|
||||
#include <Gui/Document.h>
|
||||
#include <Gui/Workbench.h>
|
||||
#include <Gui/FileDialog.h>
|
||||
#include <Gui/ModuleIO.h>
|
||||
#include <Gui/View3DInventor.h>
|
||||
#include <Gui/View3DInventorViewer.h>
|
||||
#include <gsl/pointers>
|
||||
@@ -435,25 +433,10 @@ void StartView::postStart(PostStartBehavior behavior) const
|
||||
|
||||
void StartView::fileCardSelected(const QModelIndex& index)
|
||||
{
|
||||
auto file = index.data(static_cast<int>(Start::DisplayedFilesModelRoles::path)).toString();
|
||||
std::string escapedstr = Base::Tools::escapedUnicodeFromUtf8(file.toStdString().c_str());
|
||||
escapedstr = Base::Tools::escapeEncodeFilename(escapedstr);
|
||||
try {
|
||||
QString filename = QString::fromStdString(escapedstr);
|
||||
QFileInfo fi(filename);
|
||||
if (!fi.exists() || !fi.isFile()) {
|
||||
QMessageBox::critical(Gui::getMainWindow(),
|
||||
tr("File not found"),
|
||||
tr("The file '%1' cannot be opened.").arg(filename));
|
||||
}
|
||||
else {
|
||||
// invokes appendFile()
|
||||
Gui::SelectModule::Dict dict = Gui::SelectModule::importHandler(filename);
|
||||
for (Gui::SelectModule::Dict::iterator it = dict.begin(); it != dict.end(); ++it) {
|
||||
Gui::Application::Instance->open(it.key().toUtf8(), it.value().toLatin1());
|
||||
break;
|
||||
}
|
||||
}
|
||||
auto filename =
|
||||
index.data(static_cast<int>(Start::DisplayedFilesModelRoles::path)).toString();
|
||||
Gui::ModuleIO::verifyAndOpenFile(filename);
|
||||
}
|
||||
catch (Base::PyException& e) {
|
||||
Base::Console().Error(e.getMessage().c_str());
|
||||
|
||||
Reference in New Issue
Block a user