#include <ModuleBase_OperationFeature.h>
#include <ModuleBase_ViewerPrs.h>
+#include <GeomDataAPI_Point2D.h>
+#include <GeomAPI_Pnt2d.h>
+
#include <Events_InfoMessage.h>
#include <ModelAPI_AttributeRefAttr.h>
#include <ModelAPI_AttributeSelectionList.h>
#include <ModelAPI_AttributeRefList.h>
#include <ModelAPI_Object.h>
-#include <ModelAPI_ResultCompSolid.h>
+#include <ModelAPI_ResultBody.h>
#include <ModelAPI_Session.h>
#include <ModelAPI_Tools.h>
#include <SketchPlugin_Sketch.h>
#include <SketchPlugin_ConstraintCoincidence.h>
#include <SketchPlugin_Arc.h>
+#include <SketchPlugin_Point.h>
#include <GeomAPI_Edge.h>
#include <list>
}
}
+bool PartSet_IntersectionSelection::isValid(const ModuleBase_ISelection* theSelection,
+ ModuleBase_Operation* theOperation) const
+{
+ if (theSelection->getSelected(ModuleBase_ISelection::Viewer).size() == 0) {
+ return isEmptySelectionValid(theOperation);
+ } else {
+ int aCount = shapesNbLines(theSelection);
+ return aCount == 0;
+ }
+}
+
std::string PartSet_DifferentObjectsValidator::errorMessage(
const PartSet_DifferentObjectsValidator::ErrorType& theType,
AttributeSelectionPtr anAttr =
std::dynamic_pointer_cast<ModelAPI_AttributeSelection>(theAttribute);
ResultPtr aContext = anAttr->context();
+ FeaturePtr aContextFeature = anAttr->contextFeature();
GeomShapePtr aShape = anAttr->value();
// Check selection attributes
return false;
}
}
+ // check the whole selected feature contains the result
+ if (aContextFeature.get()) {
+ if (aRef->contextFeature().get()) {
+ if (aContextFeature == aRef->contextFeature()) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRef->id());
+ return false;
+ }
+ } else if (aRef->context().get() &&
+ aRef->context()->document()->feature(aRef->context()) == aContextFeature) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRef->id());
+ return false;
+ }
+ } else if (aRef->contextFeature().get() && aContext.get()) {
+ if (aContext->document()->feature(aContext) == aRef->contextFeature()) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRef->id());
+ return false;
+ }
+ }
}
}
}
for(int i = 0; i < aCurSelList->size(); i++) {
std::shared_ptr<ModelAPI_AttributeSelection> aCurSel = aCurSelList->value(i);
ResultPtr aCurSelContext = aCurSel->context();
- ResultCompSolidPtr aCurSelCompSolidPtr = ModelAPI_Tools::compSolidOwner(aCurSelContext);
+ FeaturePtr aCurSelFeature = aCurSel->contextFeature();
+ ResultBodyPtr aCurSelCompSolidPtr = ModelAPI_Tools::bodyOwner(aCurSelContext);
std::shared_ptr<GeomAPI_Shape> aCurSelCompSolid;
if(aCurSelCompSolidPtr.get()) {
aCurSelCompSolid = aCurSelCompSolidPtr->shape();
for(int j = 0; j < aRefSelList->size(); j++) {
std::shared_ptr<ModelAPI_AttributeSelection> aRefSel = aRefSelList->value(j);
ResultPtr aRefSelContext = aRefSel->context();
- ResultCompSolidPtr aRefSelCompSolidPtr =
- ModelAPI_Tools::compSolidOwner(aRefSelContext);
+ FeaturePtr aRefSelFeature = aRefSel->contextFeature();
+ ResultBodyPtr aRefSelCompSolidPtr =
+ ModelAPI_Tools::bodyOwner(aRefSelContext);
std::shared_ptr<GeomAPI_Shape> aRefSelCompSolid;
- if(aRefSelCompSolidPtr.get()) {
+ if (aRefSelCompSolidPtr.get()) {
aRefSelCompSolid = aRefSelCompSolidPtr->shape();
}
if ((aCurSelCompSolid.get() && aCurSelCompSolid->isEqual(aRefSel->value()))
|| (aRefSelCompSolid.get() && aRefSelCompSolid->isEqual(aCurSel->value()))) {
- theError = errorMessage(EqualShapes, "", theAttribute->id(),
- aRefSel->id());
- return false;
+ theError = errorMessage(EqualShapes, "", theAttribute->id(),
+ aRefSel->id());
+ return false;
}
- if(aCurSelContext == aRefSelContext) {
+ if (aCurSelContext == aRefSelContext) {
if (aCurSel->value().get() == NULL || aRefSel->value().get() == NULL) {
- theError = errorMessage(EmptyShapes, "", theAttribute->id(),
- aRefSel->id());
+ theError = errorMessage(EmptyShapes, "", theAttribute->id(), aRefSel->id());
return false;
}
if (aCurSel->value()->isEqual(aRefSel->value())) {
- theError = errorMessage(EqualShapes, "", theAttribute->id(),
- aRefSel->id());
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRefSel->id());
+ return false;
+ }
+ }
+
+ // check the whole selected feature contains the result
+ if (aCurSelFeature.get()) {
+ if (aRefSelFeature.get()) {
+ if (aCurSelFeature == aRefSelFeature) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRefSel->id());
+ return false;
+ }
+ }
+ else if (aRefSelContext.get() &&
+ aRefSelContext->document()->feature(aRefSelContext) == aCurSelFeature) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRefSel->id());
+ return false;
+ }
+ }
+ else if (aRefSelFeature.get() && aCurSelContext.get()) {
+ if (aCurSelContext->document()->feature(aCurSelContext) == aRefSelFeature) {
+ theError = errorMessage(EqualShapes, "", theAttribute->id(), aRefSel->id());
return false;
}
}
return true;
}
+bool PartSet_DifferentPointsValidator::isValid(const AttributePtr& theAttribute,
+ const std::list<std::string>& theArguments,
+ Events_InfoMessage& theError) const
+{
+ FeaturePtr aFeature = std::dynamic_pointer_cast<ModelAPI_Feature>(theAttribute->owner());
+
+ // the type of validated attributes should be equal, attributes with
+ // different types are not validated
+ // Check RefAttr attributes
+ std::string anAttrType = theAttribute->attributeType();
+ std::list<std::shared_ptr<ModelAPI_Attribute> > anAttrs;
+ if (anAttrType != ModelAPI_AttributeRefAttr::typeId())
+ return true;
+
+ // obtain point of the given attribute
+ AttributePoint2DPtr anAttributePoint = getRefPointAttribute(theAttribute);
+ if (!anAttributePoint.get() || !anAttributePoint->isInitialized())
+ return true;
+
+ // obtain point of the parameter attribute
+ AttributePoint2DPtr anArgumentPoint = getRefPointAttribute
+ (aFeature->attribute(theArguments.front()));
+
+ if (!anArgumentPoint.get() || !anArgumentPoint->isInitialized())
+ return true;
+
+ return !anAttributePoint->pnt()->isEqual(anArgumentPoint->pnt());
+}
+
+AttributePoint2DPtr PartSet_DifferentPointsValidator::getRefPointAttribute
+ (const AttributePtr& theAttribute) const
+{
+ AttributeRefAttrPtr anAttr = std::dynamic_pointer_cast<ModelAPI_AttributeRefAttr>(theAttribute);
+
+ AttributePoint2DPtr aPointAttribute;
+ if (anAttr->isObject()) {
+ ObjectPtr anObject = anAttr->object();
+ if (anObject.get()) {
+ FeaturePtr aFeature = ModelAPI_Feature::feature(anObject);
+ if (aFeature->getKind() == SketchPlugin_Point::ID())
+ aPointAttribute = std::dynamic_pointer_cast<GeomDataAPI_Point2D>
+ (aFeature->attribute(SketchPlugin_Point::COORD_ID()));
+ }
+ }
+ else {
+ aPointAttribute = std::dynamic_pointer_cast<GeomDataAPI_Point2D>(anAttr->attr());
+ }
+ return aPointAttribute;
+}
+
bool PartSet_CoincidentAttr::isValid(const AttributePtr& theAttribute,
const std::list<std::string>& theArguments,
Events_InfoMessage& theError) const