X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_FilterValidated.cpp;h=bb56ba1491318356fcf5f9d62a5ebfd7983c01ca;hb=f96e7958a6b68c45e722aea764ecc075d0797233;hp=08314d734cc3cf2793e3e601ac6a9a53d891551d;hpb=70122a4400ec112e9c2c071724d444fa40282076;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_FilterValidated.cpp b/src/ModuleBase/ModuleBase_FilterValidated.cpp index 08314d734..bb56ba149 100644 --- a/src/ModuleBase/ModuleBase_FilterValidated.cpp +++ b/src/ModuleBase/ModuleBase_FilterValidated.cpp @@ -12,26 +12,57 @@ #include #include #include +#include #include +#include IMPLEMENT_STANDARD_HANDLE(ModuleBase_FilterValidated, SelectMgr_Filter); IMPLEMENT_STANDARD_RTTIEXT(ModuleBase_FilterValidated, SelectMgr_Filter); +//#define DEBUG_CURRENT_SELECTION + Standard_Boolean ModuleBase_FilterValidated::IsOk(const Handle(SelectMgr_EntityOwner)& theOwner) const { bool aValid = true; ModuleBase_Operation* anOperation = myWorkshop->module()->currentOperation(); if (anOperation) { +#ifdef DEBUG_CURRENT_SELECTION + QString aPrefix = "ModuleBase_FilterValidated::IsOk: "; + QList aSelected = myWorkshop->selection()->getSelected(ModuleBase_ISelection::Viewer); + QList::const_iterator anIt = aSelected.begin(), aLast = aSelected.end(); + QStringList anInfo; + ModuleBase_ViewerPrsPtr aPrs; + for (; anIt != aLast; anIt++) { + aPrs = (*anIt); + if (!aPrs.get()) + continue; + + //GeomShapePtr aShape = aPrs->shape(); + ObjectPtr anObject = aPrs->object(); + QString anObjectInfo = anObject.get() ? ModuleBase_Tools::objectInfo(anObject) : ""; + anInfo.append(anObjectInfo); + } + QString anInfoStr = anInfo.join(";\t"); + qDebug(QString("%1: %2, %3").arg(aPrefix).arg(anInfo.size()).arg(anInfoStr).toStdString().c_str()); +#endif + ModuleBase_IPropertyPanel* aPanel = anOperation->propertyPanel(); ModuleBase_ModelWidget* aCurrentWidget = aPanel->preselectionWidget(); if (!aCurrentWidget) aCurrentWidget = myWorkshop->module()->activeWidget(); - ModuleBase_WidgetValidated* aWidgetValidated = dynamic_cast - (aCurrentWidget); - ModuleBase_ViewerPrs aPrs; - myWorkshop->selection()->fillPresentation(aPrs, theOwner); - - aValid = !aWidgetValidated || aWidgetValidated->isValidSelection(aPrs); + if (aCurrentWidget) { + ModuleBase_ViewerPrsPtr aPrs(new ModuleBase_ViewerPrs()); + myWorkshop->selection()->fillPresentation(aPrs, theOwner); + ModuleBase_WidgetValidated* aWidgetValidated = dynamic_cast + (aCurrentWidget); + if (aWidgetValidated) + aValid = !aWidgetValidated || aWidgetValidated->isValidSelection(aPrs); + else{ + ModuleBase_WidgetValidator* aWidgetValidator = aCurrentWidget->widgetValidator(); + if (aWidgetValidator) + aValid = aWidgetValidator->isValidSelection(aPrs); + } + } } #ifdef DEBUG_FILTERS