FeaturesAPI_BooleanFuse::FeaturesAPI_BooleanFuse(
const std::shared_ptr<ModelAPI_Feature>& theFeature,
const std::list<ModelHighAPI_Selection>& theMainObjects,
- const bool theRemoveEdges,
- const int theVersion)
+ const bool theRemoveEdges)
: ModelHighAPI_Interface(theFeature)
{
if (initialize()) {
fillAttribute(FeaturesPlugin_BooleanFuse::CREATION_METHOD_SIMPLE(), mycreationMethod);
- fillAttribute(theVersion, theFeature->integer(FeaturesPlugin_Boolean::VERSION_ID()));
fillAttribute(theMainObjects, mymainObjects);
fillAttribute(theRemoveEdges, myremoveEdges);
const std::shared_ptr<ModelAPI_Feature>& theFeature,
const std::list<ModelHighAPI_Selection>& theMainObjects,
const std::list<ModelHighAPI_Selection>& theToolObjects,
- const bool theRemoveEdges,
- const int theVersion)
+ const bool theRemoveEdges)
: ModelHighAPI_Interface(theFeature)
{
if(initialize()) {
fillAttribute(FeaturesPlugin_BooleanFuse::CREATION_METHOD_ADVANCED(), mycreationMethod);
- fillAttribute(theVersion, theFeature->integer(FeaturesPlugin_Boolean::VERSION_ID()));
fillAttribute(theMainObjects, mymainObjects);
fillAttribute(theToolObjects, mytoolObjects);
fillAttribute(theRemoveEdges, myremoveEdges);
aBase->selectionList(FeaturesPlugin_BooleanFuse::TOOL_LIST_ID());
AttributeBooleanPtr aRemoveEdges =
aBase->boolean(FeaturesPlugin_BooleanFuse::REMOVE_INTERSECTION_EDGES_ID());
- AttributeIntegerPtr aVersion =
- aBase->integer(FeaturesPlugin_BooleanFuse::VERSION_ID());
theDumper << "(" << aDocName << ", " << anObjects;
theDumper << ", " << aTools;
}
- bool hasVersion = aVersion && aVersion->isInitialized();
- if (aRemoveEdges->value() || hasVersion) {
- theDumper << ", " << aRemoveEdges->value();
+ if (aRemoveEdges->value()) {
+ theDumper << ", removeEdges = True";
}
- if (hasVersion) {
- theDumper << ", " << aVersion->value();
- }
+ if (!aBase->data()->version().empty())
+ theDumper << ", keepSubResults = True";
theDumper << ")" << std::endl;
}
//==================================================================================================
BooleanFusePtr addFuse(const std::shared_ptr<ModelAPI_Document>& thePart,
- const std::list<ModelHighAPI_Selection>& theObjects,
+ const std::list<ModelHighAPI_Selection>& theMainObjects,
+ const std::pair<std::list<ModelHighAPI_Selection>, bool>& theToolObjects,
const bool theRemoveEdges,
- const int theVersion)
-{
- std::shared_ptr<ModelAPI_Feature> aFeature = thePart->addFeature(FeaturesAPI_BooleanFuse::ID());
- return BooleanFusePtr(new FeaturesAPI_BooleanFuse(aFeature,
- theObjects,
- theRemoveEdges,
- theVersion));
-}
-
-//==================================================================================================
-BooleanFusePtr addFuse(const std::shared_ptr<ModelAPI_Document>& thePart,
- const std::list<ModelHighAPI_Selection>& theMainObjects,
- const std::list<ModelHighAPI_Selection>& theToolObjects,
- const bool theRemoveEdges,
- const int theVersion)
+ const bool keepSubResults)
{
std::shared_ptr<ModelAPI_Feature> aFeature = thePart->addFeature(FeaturesAPI_BooleanFuse::ID());
- return BooleanFusePtr(new FeaturesAPI_BooleanFuse(aFeature,
- theMainObjects,
- theToolObjects,
- theRemoveEdges,
- theVersion));
+ if (!keepSubResults)
+ aFeature->data()->setVersion("");
+
+ bool aRemoveEdges = theRemoveEdges;
+ if (theToolObjects.first.empty())
+ aRemoveEdges = aRemoveEdges || theToolObjects.second;
+
+ BooleanFusePtr aFuse;
+ if (theToolObjects.first.empty())
+ aFuse.reset(new FeaturesAPI_BooleanFuse(aFeature, theMainObjects, aRemoveEdges));
+ else {
+ aFuse.reset(new FeaturesAPI_BooleanFuse(aFeature, theMainObjects, theToolObjects.first,
+ aRemoveEdges));
+ }
+ return aFuse;
}