Merge pull request #17632 from wwmayer/issue_17553

Fixes #17553
This commit is contained in:
Yorik van Havre
2024-11-04 18:14:18 +01:00
committed by GitHub
6 changed files with 127 additions and 8 deletions

View File

@@ -3628,9 +3628,10 @@ void Document::_removeObject(DocumentObject* pcObject)
else {
// for a rollback delete the object
signalTransactionRemove(*pcObject, 0);
breakDependency(pcObject, true);
}
breakDependency(pcObject, true);
// remove from map
pcObject->setStatus(ObjectStatus::Remove, false); // Unset the bit to be on the safe side
d->objectIdMap.erase(pcObject->_Id);

View File

@@ -120,7 +120,14 @@ void Document::exportGraphviz(std::ostream& out) const
*/
std::string getId(const DocumentObject * docObj) {
return std::string((docObj)->getDocument()->getName()) + "#" + docObj->getNameInDocument();
std::string id;
if (docObj->isAttachedToDocument()) {
auto doc = docObj->getDocument();
id.append(doc->getName());
id.append("#");
id.append(docObj->getNameInDocument());
}
return id;
}
/**
@@ -437,11 +444,14 @@ void Document::exportGraphviz(std::ostream& out) const
if (obj) {
std::map<std::string,Vertex>::const_iterator item = GlobalVertexList.find(getId(obj));
if (item == GlobalVertexList.end())
add(obj,
std::string(obj->getDocument()->getName()) + "#" + obj->getNameInDocument(),
std::string(obj->getDocument()->getName()) + "#" + obj->Label.getValue(),
CSSubgraphs);
if (item == GlobalVertexList.end()) {
if (obj->isAttachedToDocument()) {
add(obj,
std::string(obj->getDocument()->getName()) + "#" + obj->getNameInDocument(),
std::string(obj->getDocument()->getName()) + "#" + obj->Label.getValue(),
CSSubgraphs);
}
}
}
}
}

View File

@@ -55,6 +55,7 @@ set(PartDesign_TestScripts
PartDesignTests/TestThickness.py
PartDesignTests/TestTopologicalNamingProblem.py
PartDesignTests/TestInvoluteGear.py
PartDesignTests/TestSketch.py
)
if(BUILD_GUI)

View File

@@ -618,8 +618,13 @@ private:
std::string FeatName = documentOfBody->getUniqueObjectName("Sketch");
std::string supportString = Gui::Command::getObjectCmd(plane,"(",",[''])");
App::Document* doc = partDesignBody->getDocument();
if (!doc->hasPendingTransaction()) {
doc->openTransaction(QT_TRANSLATE_NOOP("Command", "Create a new Sketch"));
}
FCMD_OBJ_CMD(partDesignBody,"newObject('Sketcher::SketchObject','" << FeatName << "')");
auto Feat = partDesignBody->getDocument()->getObject(FeatName.c_str());
auto Feat = doc->getObject(FeatName.c_str());
FCMD_OBJ_CMD(Feat,"AttachmentSupport = " << supportString);
FCMD_OBJ_CMD(Feat,"MapMode = '" << Attacher::AttachEngine::getModeName(Attacher::mmFlatFace)<<"'");
Gui::Command::updateActive(); // Make sure the AttachmentSupport's Placement property is updated

View File

@@ -0,0 +1,101 @@
#***************************************************************************
#* 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/>. *
#* *
#***************************************************************************
import unittest
import FreeCAD
""" Test transaction interaction """
class TestSketch(unittest.TestCase):
def setUp(self):
self.doc = FreeCAD.newDocument("PartDesignTestSketch")
self.doc.UndoMode = True
def testIssue17553(self):
self.doc.openTransaction("Create box")
box = self.doc.addObject("Part::Box", "Box")
self.doc.commitTransaction()
self.doc.recompute()
self.doc.openTransaction("Create sketch")
body = self.doc.addObject('PartDesign::Body', 'Body')
plane = self.doc.getObject('XY_Plane')
self.doc.commitTransaction()
self.doc.openTransaction("Rename object")
box.Label = "Object"
self.doc.commitTransaction()
sketch = body.newObject('Sketcher::SketchObject', 'Sketch')
sketch.AttachmentSupport = (plane, [''])
sketch.MapMode = 'FlatFace'
self.doc.recompute()
self.assertEqual(sketch.InList, [body])
self.assertEqual(sketch.OutList, [plane])
sketch.AttachmentSupport == [(plane, ("",))]
self.doc.undo() # undo renaming
self.doc.undo() # undo body creation
self.doc.undo() # undo box creation
self.doc.openTransaction("Remove sketch")
self.doc.removeObject(sketch.Name)
self.doc.commitTransaction()
self.doc.undo() # undo removal
self.assertEqual(sketch.InList, [])
self.assertEqual(sketch.OutList, [])
self.assertEqual(sketch.AttachmentSupport, [])
def testDependency(self):
self.doc.openTransaction("Create box")
box = self.doc.addObject("Part::Box", "Box")
self.doc.commitTransaction()
self.doc.recompute()
self.doc.openTransaction("Create sketch")
body = self.doc.addObject('PartDesign::Body', 'Body')
plane = self.doc.getObject('XY_Plane')
self.doc.commitTransaction()
self.doc.openTransaction("Rename object")
box.Label = "Object"
self.doc.commitTransaction()
sketch = body.newObject('Sketcher::SketchObject', 'Sketch')
sketch.AttachmentSupport = (plane, [''])
sketch.MapMode = 'FlatFace'
self.doc.recompute()
sketch.OutList
sketch.AttachmentSupport
self.doc.undo() # undo renaming
self.doc.undo() # undo body creation
self.doc.undo() # undo box creation
self.doc.DependencyGraph
def tearDown(self):
FreeCAD.closeDocument("PartDesignTestSketch")

View File

@@ -55,6 +55,7 @@ from PartDesignTests.TestThickness import TestThickness
# extras
from PartDesignTests.TestInvoluteGear import TestInvoluteGear
from PartDesignTests.TestSketch import TestSketch
# Topological naming problem
from PartDesignTests.TestTopologicalNamingProblem import TestTopologicalNamingProblem