Skip to content

Commit

Permalink
Support removing the actor, light, or model from the root (#1492)
Browse files Browse the repository at this point in the history
* Support removing the actor, light, or model from the root

Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

* Update src/Root_TEST.cc

Co-authored-by: Steve Peters <[email protected]>
Signed-off-by: Nate Koenig <[email protected]>

---------

Signed-off-by: Nate Koenig <[email protected]>
Co-authored-by: Steve Peters <[email protected]>
  • Loading branch information
nkoenig and scpeters authored Nov 12, 2024
1 parent 91d9029 commit d0bcd40
Show file tree
Hide file tree
Showing 5 changed files with 85 additions and 0 deletions.
5 changes: 5 additions & 0 deletions include/sdf/Root.hh
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,11 @@ namespace sdf
public: sdf::ElementPtr ToElement(
const OutputConfig &_config = OutputConfig::GlobalConfig()) const;

/// \brief Remove the actor, light, or model if one of them exists.
/// The SDF Root object can only hold one, or none, from the set
/// [Actor, Light, Model].
public: void ClearActorLightModel();

/// \brief Private data pointer
GZ_UTILS_IMPL_PTR(dataPtr)
};
Expand Down
4 changes: 4 additions & 0 deletions python/src/sdf/pyRoot.cc
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,10 @@ void defineRoot(pybind11::object module)
.def("set_light", &sdf::Root::SetLight,
"Set the light object. This will override any existing model, "
"actor, and light object.")
.def("clear_actor_light_model", &sdf::Root::ClearActorLightModel,
"Remove the actor, light, or model if one of them exists."
"The SDF Root object can only hold one, or none, from the set"
"[Actor, Light, Model].")
.def("add_world", [](Root &self, const World &_world)
{
ThrowIfErrors(self.AddWorld(_world));
Expand Down
28 changes: 28 additions & 0 deletions python/test/pyRoot_TEST.py
Original file line number Diff line number Diff line change
Expand Up @@ -358,5 +358,33 @@ def test_resolve_auto_inertials_with_save_calculation_configuration(self):
self.assertEqual(len(inertialErr), 0)
self.assertTrue(link.auto_inertia_saved())

def test_clear_actor_light_model(self):
root = Root()

# \TODO(anyone) Wrap the Actor class.
# self.assertEqual(None, root.actor())
# actor1 = Actor()
# actor1.set_name("actor1")
# root.set_actor(actor1)
# self.assertNotEqual(None, root.actor())
# root.clear_actor_light_model()
# self.assertEqual(None, root.actor())

self.assertEqual(None, root.light())
light1 = Light()
light1.set_name("light1")
root.set_light(light1)
self.assertNotEqual(None, root.light())
root.clear_actor_light_model()
self.assertEqual(None, root.light())

self.assertEqual(None, root.model())
model1 = Model()
model1.set_name("model1")
root.set_model(model1)
self.assertNotEqual(None, root.model())
root.clear_actor_light_model()
self.assertEqual(None, root.model())

if __name__ == '__main__':
unittest.main()
6 changes: 6 additions & 0 deletions src/Root.cc
Original file line number Diff line number Diff line change
Expand Up @@ -644,3 +644,9 @@ sdf::ElementPtr Root::ToElement(const OutputConfig &_config) const

return elem;
}

/////////////////////////////////////////////////
void Root::ClearActorLightModel()
{
this->dataPtr->modelLightOrActor = std::monostate{};
}
42 changes: 42 additions & 0 deletions src/Root_TEST.cc
Original file line number Diff line number Diff line change
Expand Up @@ -670,3 +670,45 @@ TEST(DOMRoot, WorldByName)
ASSERT_TRUE(root.WorldNameExists("world2"));
EXPECT_EQ("world2", root.WorldByName("world2")->Name());
}

/////////////////////////////////////////////////
TEST(DOMRoot, ClearActorLightModel)
{
sdf::Root root;
EXPECT_EQ(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());

sdf::Actor actor1;
actor1.SetName("actor1");
root.SetActor(actor1);
EXPECT_NE(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());
root.ClearActorLightModel();
EXPECT_EQ(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());

sdf::Light light1;
light1.SetName("light1");
root.SetLight(light1);
EXPECT_EQ(nullptr, root.Actor());
EXPECT_NE(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());
root.ClearActorLightModel();
EXPECT_EQ(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());

sdf::Model model1;
model1.SetName("model1");
root.SetModel(model1);
EXPECT_EQ(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_NE(nullptr, root.Model());
root.ClearActorLightModel();
EXPECT_EQ(nullptr, root.Actor());
EXPECT_EQ(nullptr, root.Light());
EXPECT_EQ(nullptr, root.Model());
}

0 comments on commit d0bcd40

Please sign in to comment.