-
Notifications
You must be signed in to change notification settings - Fork 4.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove or replace OwnVector<SiStripMatchedRecHit2D>
#43987
Remove or replace OwnVector<SiStripMatchedRecHit2D>
#43987
Conversation
cms-bot internal usage |
+code-checks Logs: https://cmssdt.cern.ch/SDT/code-checks/cms-sw-PR-43987/38908
|
please test |
A new Pull Request was created by @wddgit (W. David Dagenhart) for master. It involves the following packages:
@subirsarkar, @makortel, @srimanob, @jfernan2, @Dr15Jones, @mdhildreth, @mandrenguyen, @civanch, @bsunanda can you please review it and eventually sign? Thanks. cms-bot commands are listed here |
+1 Summary: https://cmssdt.cern.ch/SDT/jenkins-artifacts/pull-request-integration/PR-144c09/37508/summary.html Comparison SummarySummary:
|
+1 |
Note that the part of this requiring upgrade and geometry signatures only deletes some comment lines (containing the deleted typedef) and removes one unused "#include "OwnVector.h". |
+1 |
+Upgrade |
This pull request is fully signed and it will be integrated in one of the next master IBs (tests are also fine). This pull request will now be reviewed by the release team before it's merged. @rappoccio, @antoniovilela, @sextonkennedy (and backports should be raised in the release meeting by the corresponding L2) |
+1 |
PR description:
This is part of a campaign to remove code related to OwnVector. This is in preparation for a possible move to RNTuple from TTree as a persistence mechanism. RNTuple does not support OwnVector because it allows polymorphism. Issue #42734 discusses this in more detail.
In this PR,
OwnVector<SiStripMatchedRecHit2D>
is removed or replaced. This is one of the classes on Matti's list in the issue.The dictionaries in classes_def.xml are removed and also an unused typedef.
The other usage in SiStripRecHitMatcher and SiStripRecHitConverterAlgorithm is replaced by a
std::vector<std::unique_ptr<SiStripMatchedRecHit2D>>
. As used in that part of the code, the object is not persistent so there aren't any backward compatibility issues and the replacement should work exactly the same as the OwnVector.It appears that the OwnVector dictionaries were originally introduced in 2006 and new DetSetVector containers replaced them in 2007. Probably the OwnVector code was kept for backward compatibility originally and no one ever had time or remembered to clean it up when backward compatibility to 2007 was no longer needed.
PR validation:
This relies on existing tests for the part that was converted to a
vector<unique_ptr>
. It should work identically to the way it worked before.To test the deletion of the dictionaries, I added this in OwnVector.h and built
This demonstrates nothing could be using this or writing this type persistently. I did that for a 14_1_X IB and also for 10_6_39. I suspect nothing has written products of this type since 2007, but didn't verify that with a test. 10_6_X is what we need for the legacy release work.
FYI @makortel