X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_Tools.cpp;h=b52be827ea67d9ce23d0112942fb36c1b75eeab2;hb=0cd070a0e4106dd57c5679d5bac26a0d0afd40b5;hp=9a7556e403aa431d18eebfc168d3cde9ae186717;hpb=88e6607f0b144ea77928192796a18f64fc75ee09;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_Tools.cpp b/src/XGUI/XGUI_Tools.cpp index 9a7556e40..b52be827e 100644 --- a/src/XGUI/XGUI_Tools.cpp +++ b/src/XGUI/XGUI_Tools.cpp @@ -1,4 +1,22 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> +// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// +// This library 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. +// +// This library 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 this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or +// email : webmaster.salome@opencascade.com +// #include "XGUI_Tools.h" @@ -6,6 +24,7 @@ #include "XGUI_Workshop.h" #include "ModuleBase_IWorkshop.h" +#include "ModuleBase_Tools.h" #include #include @@ -17,7 +36,7 @@ #include #include #include -#include +#include #include @@ -26,6 +45,7 @@ #include #include +#include namespace XGUI_Tools { //****************************************************************** @@ -42,7 +62,8 @@ QString dir(const QString& path, bool isAbs) QString file(const QString& path, bool withExt) { QString fPath = path; - while (!fPath.isEmpty() && (fPath[fPath.length() - 1] == '\\' || fPath[fPath.length() - 1] == '/')) + while (!fPath.isEmpty() && (fPath[fPath.length() - 1] == '\\' || + fPath[fPath.length() - 1] == '/')) fPath.remove(fPath.length() - 1, 1); if (withExt) @@ -102,23 +123,19 @@ std::string featureInfo(FeaturePtr theFeature) } }*/ + //****************************************************************** -bool canRemoveOrRename(QWidget* theParent, const QObjectPtrList& theObjects) +bool canRemoveOrRename(QWidget* theParent, const std::set& theFeatures) { bool aResult = true; - QString aNotActivatedNames; - if (!XGUI_Tools::allDocumentsActivated(aNotActivatedNames)) { - DocumentPtr aModuleDoc = ModelAPI_Session::get()->moduleDocument(); - bool aFoundPartSetObject = false; - foreach (ObjectPtr aObj, theObjects) { - if (aObj->groupName() == ModelAPI_ResultPart::group()) - continue; - aFoundPartSetObject = aObj->document() == aModuleDoc; - } + std::string aNotActivatedNames; + if (!ModelAPI_Tools::allDocumentsActivated(aNotActivatedNames)) { + bool aFoundPartSetObject = ModuleBase_Tools::hasModuleDocumentFeature(theFeatures); if (aFoundPartSetObject) { + const char* aKeyStr = "Selected objects can be used in Part documents which are not loaded: " + "%1. Whould you like to continue?"; QMessageBox::StandardButton aRes = QMessageBox::warning(theParent, QObject::tr("Warning"), - QObject::tr("Selected objects can be used in Part documents which are not loaded: \ -%1. Whould you like to continue?").arg(aNotActivatedNames), + QObject::tr(aKeyStr).arg(aNotActivatedNames.c_str()), QMessageBox::No | QMessageBox::Yes, QMessageBox::No); aResult = aRes == QMessageBox::Yes; } @@ -132,12 +149,14 @@ bool canRename(const ObjectPtr& theObject, const QString& theName) if (std::dynamic_pointer_cast(theObject).get()) { double aValue; ResultParameterPtr aParam; - if (ModelAPI_Tools::findVariable(theObject->document(), + if (ModelAPI_Tools::findVariable(theObject->document(), FeaturePtr(), qPrintable(theName), aValue, aParam)) { - QString aErrMsg(QObject::tr("Selected parameter can not be renamed to: %1. \ - There is a parameter with the same name. Its value is: %2.").arg(qPrintable(theName)).arg(aValue)); - // We can not use here a dialog box for message - it will crash editing process in ObjectBrowser - Events_Error::send(aErrMsg.toStdString()); + const char* aKeyStr = "Selected parameter can not be renamed to: %1. " + "There is a parameter with the same name. Its value is: %2."; + QString aErrMsg(QObject::tr(aKeyStr).arg(qPrintable(theName)).arg(aValue)); + // We can not use here a dialog box for message - + // it will crash editing process in ObjectBrowser + Events_InfoMessage("XGUI_Tools", aErrMsg.toStdString()).send(); return false; } } @@ -145,32 +164,12 @@ bool canRename(const ObjectPtr& theObject, const QString& theName) return true; } -//****************************************************************** -bool allDocumentsActivated(QString& theNotActivatedNames) -{ - bool anAllPartActivated = true; - QStringList aRefNames; - - DocumentPtr aRootDoc = ModelAPI_Session::get()->moduleDocument(); - int aSize = aRootDoc->size(ModelAPI_ResultPart::group()); - for (int i = 0; i < aSize; i++) { - ObjectPtr aObject = aRootDoc->object(ModelAPI_ResultPart::group(), i); - ResultPartPtr aPart = std::dynamic_pointer_cast(aObject); - if (!aPart->isActivated()) { - anAllPartActivated = false; - aRefNames.append(aObject->data()->name().c_str()); - } - } - theNotActivatedNames = aRefNames.join(", "); - return anAllPartActivated; -} - //************************************************************** XGUI_Workshop* workshop(ModuleBase_IWorkshop* theWorkshop) { XGUI_ModuleConnector* aConnector = dynamic_cast(theWorkshop); - return aConnector->workshop(); + return aConnector ? aConnector->workshop() : 0; } }