Feature request: Better TreeNode management #547
Replies: 3 comments
-
I think it's reasonable to define the deallocation order of On the other hand, I'm assuming you're building a custom model by DynamicModelPipeline. Defining another set of TreeNodes and the desired destruction behavior in your derived Simulator class might also work out. Just replace the strings :) |
Beta Was this translation helpful? Give feedback.
-
I have a related complaint that I'd like to share with you. Maybe you can come up with a suggestion on how to handle it.
Sparta relies on the |
Beta Was this translation helpful? Give feedback.
-
I totally agree with everything you said. I also agree and strongly suggest (if you haven't already) adding to discussion #509 that exact requirement. In addition, I have come across implementations of With that being said, the Now, onto @kathlenemagnus-mips rightful complaint. 😄 The original concept of factory/tree node creation pairing was to use the following pattern in Simulation:
In a nutshell, you register factories with the Simulation class and then use the protected member
Then, when simulation ends, alllll just works. In theory. 😆 These are things I wouldn't mind changing for map_v3. |
Beta Was this translation helpful? Give feedback.
-
I'm thinking about working on a replacement for the
std::vector<std::unique_ptr<sparta::TreeNode>> to_delete_;
member inside of thesparta::app::Simulation
base class. I don't like the existing mechanism because modelers who have requirements that the destructor of one TreeNode is called before the destructor of another TreeNode seem to be getting the habit of shuffling their TreeNodes into this vector into a particular order, and then relying on the fact that GNU libstdc++'sstd::~vector()
happens to destruct its elements from front to back. The example code in this repo already demonstrates this fragile pattern:map/sparta/example/DynamicModelPipeline/src/ExampleSimulation.cpp
Line 693 in e736f0d
I have two reasons not to like this pattern:
Models that work on GNU libstdc++ may break when linked against LLVM's libc++, where std::vector destructs elements back-to-front (consistent with the behavior the C++ standard imposes for raw arrays): https://godbolt.org/z/h3Pon4oT9
I suggest keeping
to_delete_;
(there's too much model code out there that uses it) while introducing a replacement API that registers TreeNodes to be managed by sparta::app::Simulation base class by storing them in some private member and ensuring the destructor destructs them in a well-specified order. Maybe in MAPv3 we can formally deprecate to_delete_ but I wonder if it's okay to go ahead and introduce a new solution now within the MAPv2 series.Beta Was this translation helpful? Give feedback.
All reactions