Skip to content
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

I/O Customizaton Rules: add support for changing the input type. #17347

Merged
merged 30 commits into from
Jan 19, 2025

Conversation

pcanal
Copy link
Member

@pcanal pcanal commented Jan 2, 2025

With these changes, one can request the schema evolution (usually implicit) of the input data members from the on-file type to a custom type. Example of the changes support in the test roottest/root/io/evolution/rules/execSourceTypes.cxx added by the companion roottest PR

This fixes #17346 17346

@pcanal pcanal requested a review from dpiparo as a code owner January 2, 2025 23:19
@pcanal pcanal requested review from jblomer and dpiparo and removed request for dpiparo January 2, 2025 23:19
@pcanal pcanal self-assigned this Jan 2, 2025
Copy link

github-actions bot commented Jan 3, 2025

Test Results

    18 files      18 suites   4d 1h 8m 31s ⏱️
 2 695 tests  2 695 ✅ 0 💤 0 ❌
46 780 runs  46 780 ✅ 0 💤 0 ❌

Results for commit 1965fb4.

♻️ This comment has been updated with latest results.

@pcanal pcanal marked this pull request as draft January 3, 2025 18:52
@pcanal pcanal force-pushed the io-rules-type-change branch from ba28c30 to 7b3edc4 Compare January 4, 2025 00:25
@pcanal pcanal closed this Jan 4, 2025
@pcanal pcanal reopened this Jan 4, 2025
@pcanal pcanal closed this Jan 5, 2025
@pcanal pcanal reopened this Jan 5, 2025
@dpiparo dpiparo closed this Jan 6, 2025
@dpiparo dpiparo reopened this Jan 6, 2025
@pcanal pcanal marked this pull request as ready for review January 6, 2025 17:39
@pcanal pcanal closed this Jan 6, 2025
@pcanal pcanal reopened this Jan 6, 2025
@dpiparo dpiparo closed this Jan 8, 2025
@dpiparo dpiparo reopened this Jan 8, 2025
core/meta/src/TClass.cxx Show resolved Hide resolved
core/meta/src/TClass.cxx Outdated Show resolved Hide resolved
tree/treeplayer/src/TBranchProxy.cxx Outdated Show resolved Hide resolved
tree/treeplayer/src/TBranchProxy.cxx Show resolved Hide resolved
io/io/src/TStreamerInfo.cxx Outdated Show resolved Hide resolved
io/io/src/TStreamerInfoReadBuffer.cxx Outdated Show resolved Hide resolved
io/io/src/TStreamerInfo.cxx Show resolved Hide resolved
@pcanal pcanal force-pushed the io-rules-type-change branch 2 times, most recently from 5144078 to 285bcf6 Compare January 14, 2025 13:11
@pcanal pcanal closed this Jan 14, 2025
@pcanal pcanal reopened this Jan 14, 2025
Previously the call to RemoveStreamerInfo was working only if the slot was the the slot of the current version.
(the actually removed StreamerInfo was hard-coded to be the current version
The data members are cached (because they are input of a rule) need to be read into the original type not
the 'current in memory type' so that the rule can properly function if the type has changed.

We should upgrade further for the in-memory type of the input of a rule to be the one specified in
the rule independently of the onfile type and the final in-memory type.
@pcanal pcanal force-pushed the io-rules-type-change branch from 73a13c5 to 2e3d281 Compare January 14, 2025 16:50
@pcanal pcanal closed this Jan 18, 2025
pcanal added 20 commits January 19, 2025 10:01
Return the underlying type and other piece and information separately
This reverts commit e900d32.

Bug fix: I/O customization rules which missing input are no
longer (inappropriately) run.

We now properly warn if a rule is requesting an input that is not
present in the StreamerInfo that the rule is being applied to.

To avoid the warning in some cases (in particular the cases used
to support `HepMC` and are located in `$ROOTSYS/etc/class.rules`)
we introduce a new "attribute" for I/O customization rules:

   `CanIgnore:`

    When using this attribute the rule will be ignored if the input is
    missing from the schema/class-layout they apply to instead of issue a `Warning`

wip: Revert "Don't warn when ..."
In TStreamerInfo's Build and BuildOld update the artificial StreamerElement's description of the
in memory type to be used to store the data.

This allows the rule to request an implicit transformation from onfile representation to in memory
representation before running the explicit customization rules
This allows to remove data member whose type is array of (sub)objects.
dim needs to be 0 for non-array
Previously the code in TStreamerElement assumed that GetClassPointer return the underlying type of the in memory representation.
This was true until recently as you could not change the representation in the 'current' StreamerInfo ( GetClassPointer was
matching the layout as decribed by the Clang AST ) and if the class was not loaded, the 'old/onfile' representation was the
only possible choice.   However we now can change the representation on file (i.e. GetClassPointer) for the current StreamerInfo
of a loaded class (i.e. later using Write rule, now in the case of enum class and collection thereof) and in the case of
the synthetic/artifical class created to cache inputs of rules (they are named `classname@@versionNumber`), the rule now
dictates the representation in memory
This patch allows to register rules on a class which dictionary is in a different dictionary source file.

Introduce the internal functions:

ROOT::TMetaUtils::WriteStandaloneReadRules
ROOT::TMetaUtils::WriteRulesRegistration
TClass::GetReadRulesRegistry
TClass::RegisterReadRules
@pcanal pcanal force-pushed the io-rules-type-change branch 2 times, most recently from 6a3c4dc to d481d2c Compare January 19, 2025 16:35
@pcanal pcanal force-pushed the io-rules-type-change branch from d481d2c to 1965fb4 Compare January 19, 2025 16:44
@pcanal pcanal merged commit 34a8b14 into root-project:master Jan 19, 2025
20 of 21 checks passed
@smuzaffar
Copy link
Contributor

@pcanal , while testing this in cmssw , we get build error/warning like [a]. the classes_def.xml file is https://github.com/cms-sw/cmssw/blob/master/DataFormats/HcalIsolatedTrack/src/classes_def.xml . Do we need some cleanup in cmssw to avoid this warning?

[a] https://cmssdt.cern.ch/SDT/jenkins-artifacts/pull-request-integration/PR-276a04/43859/build-logs/DataFormats/HcalIsolatedTrack/log.html

>> Building LCG reflex dict from header file src/DataFormats/HcalIsolatedTrack/src/classes.h
/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/lcg/root/6.35.1-d947221dfef9ef0f4c58e17a5214a16a/bin/rootcling -reflex -f tmp/el8_amd64_gcc12/src/DataFormats/HcalIsolatedTrack/src/DataFormatsHcalIsolatedTrack/lcgdict/DataFormatsHcalIsolatedTrack_xr.cc -inlineInputHeader -failOnWarnings -rmf tmp/el8_amd64_gcc12/src/DataFormats/HcalIsolatedTrack/src/DataFormatsHcalIsolatedTrack/lcgdict/DataFormatsHcalIsolatedTrack_xr.rootmap -rml libDataFormatsHcalIsolatedTrack.so -m DataFormatsRecoCandidate_xr_rdict.pcm -m DataFormatsEgammaReco_xr_rdict.pcm -m DataFormatsGsfTrackReco_xr_rdict.pcm -m DataFormatsTrackReco_xr_rdict.pcm -m DataFormatsTrackCandidate_xr_rdict.pcm -m DataFormatsTrajectorySeed_xr_rdict.pcm -m DataFormatsL1Trigger_xr_rdict.pcm -m DataFormatsTrackingRecHit_xr_rdict.pcm -m DataFormatsL1TrackTrigger_xr_rdict.pcm -m DataFormatsTrackerCommon_xr_rdict.pcm -m DataFormatsBeamSpot_xr_rdict.pcm -m DataFormatsCaloTowers_xr_rdict.pcm -m DataFormatsEcalRecHit_xr_rdict.pcm -m DataFormatsGeometryCommonDetAlgo_xr_rdict.pcm -m DataFormatsSiStripCluster_xr_rdict.pcm -m DataFormatsCandidate_xr_rdict.pcm -m DataFormatsEcalDigi_xr_rdict.pcm -m DataFormatsGeometrySurface_xr_rdict.pcm -m DataFormatsL1GlobalCaloTrigger_xr_rdict.pcm -m DataFormatsTrajectoryState_xr_rdict.pcm -m DataFormatsCLHEP_xr_rdict.pcm -m DataFormatsCaloRecHit_xr_rdict.pcm -m DataFormatsEcalDetId_xr_rdict.pcm -m DataFormatsForwardDetId_xr_rdict.pcm -m DataFormatsGeometryVector_xr_rdict.pcm -m DataFormatsHcalDetId_xr_rdict.pcm -m DataFormatsL1CaloTrigger_xr_rdict.pcm -m DataFormatsMuonDetId_xr_rdict.pcm -m DataFormatsSiPixelDetId_xr_rdict.pcm -m DataFormatsSiStripDetId_xr_rdict.pcm -m DataFormatsDetId_xr_rdict.pcm -m DataFormatsL1GlobalMuonTrigger_xr_rdict.pcm -m DataFormatsMath_xr_rdict.pcm -m DataFormatsPhase2TrackerDigi_xr_rdict.pcm -m DataFormatsScouting_xr_rdict.pcm -m DataFormatsSiPixelCluster_xr_rdict.pcm -m DataFormatsSiStripDigi_xr_rdict.pcm -m DataFormatsCommon_xr_rdict.pcm -m DataFormatsProvenance_xr_rdict.pcm -DALPAKA_DEFAULT_HOST_MEMORY_ALIGNMENT=128 -DALPAKA_DISABLE_VENDOR_RNG -DCMS_DICT_IMPL -D_REENTRANT -DGNUSOURCE -D__STRICT_ANSI__ -DGNU_GCC -D_GNU_SOURCE -DTBB_USE_GLIBCXX_VERSION=120301 -DTBB_SUPPRESS_DEPRECATED_MESSAGES -DTBB_PREVIEW_RESUMABLE_TASKS=1 -DTBB_PREVIEW_TASK_GROUP_EXTENSIONS=1 -DBOOST_SPIRIT_THREADSAFE -DPHOENIX_THREADSAFE -DBOOST_MATH_DISABLE_STD_FPCLASSIFY -DBOOST_UUID_RANDOM_PROVIDER_FORCE_POSIX -DCMSSW_GIT_HASH="CMSSW_15_0_ROOT6_X_2025-01-19-2300" -DPROJECT_NAME="CMSSW" -DPROJECT_VERSION="CMSSW_15_0_ROOT6_X_2025-01-19-2300" -Isrc -Ipoison -I/cvmfs/cms-ib.cern.ch/sw/x86_64/nweek-02873/el8_amd64_gcc12/cms/cmssw/CMSSW_15_0_ROOT6_X_2025-01-19-2300/src -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/alpaka/1.1.0-8e7128ba865cc169d302ab17150849de/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/pcre/8.43-2d141998cfe5424b8f7aff48035cc2da/include -isystem/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/boost/1.80.0-24621bb5019ee7e7984682e0f80b5fcf/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/bz2lib/1.0.6-d065ccd79984efc6d4660f410e4c81de/include -isystem/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/clhep/2.4.7.1-d3a3e353d370e701238f7949a0d7909f/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/gsl/2.6-f7574c606b0ce57ff601d3ca9534cd01/include -isystem/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/hls/2019.08-e6beae7d560007d8bb20c2cf88bfde9a/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/libuuid/2.34-27ce4c3579b5b1de2808ea9c4cd8ed29/include -isystem/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/lcg/root/6.35.1-d947221dfef9ef0f4c58e17a5214a16a/include -isystem/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/tbb/v2021.9.0-573155027234b8f945d29403a2749d52/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/xz/5.2.5-6f3f49b07db84e10c9be594a1176c114/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/zlib/1.2.13-d217cdbdd8d586e845e05946de2796be/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/eigen/3bb6a48d8c171cf20b5f8e48bfb4e424fbd4f79e-e265b266d2b30c1bebdd883980d0f9d0/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/eigen/3bb6a48d8c171cf20b5f8e48bfb4e424fbd4f79e-e265b266d2b30c1bebdd883980d0f9d0/include/eigen3 -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/fmt/10.2.1-e35fd1db5eb3abc8ac0452e8ee427196/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/md5/1.0.0-5b594b264e04ae51e893b1d69a797ec6/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/OpenBLAS/0.3.27-70a9dd2c9f309171934f13e3003b0540/include -I/data/cmsbld/jenkins/workspace/ib-run-pr-tests/testBuildDir/el8_amd64_gcc12/external/tinyxml2/6.2.0-f99ae2781d074227d47e8a3e7c8ec87e/include -DCMSSW_REFLEX_DICT src/DataFormats/HcalIsolatedTrack/src/classes.h src/DataFormats/HcalIsolatedTrack/src/classes_def.xml
  Warning: 2 Rule(s) for target class reco::LeafParticle was not used!
   gmake: *** [tmp/el8_amd64_gcc12/src/DataFormats/HcalIsolatedTrack/src/DataFormatsHcalIsolatedTrack/lcgdict/DataFormatsHcalIsolatedTrack_xr.cc] Error 1

@pcanal
Copy link
Member Author

pcanal commented Jan 20, 2025

This indicates a 'real' error and the 2 rules whose targetClass is reco::LeafParticle are being ignored. The likely cause is that the dictionary generation that has DataFormats/HcalIsolatedTrack/src/classes_def.xml as argument is not seeing any header that declares reco::LeafParticle

Previously those rules were (likely) silently ignored.

To enable them add something like #include "reco/LeafParticle.h" to the dictionary generation steps.

@smuzaffar
Copy link
Contributor

To enable them add something like #include "reco/LeafParticle.h" to the dictionary generation steps.

thanks @pcanal , I will try this

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

I/O Customization rules fails in case of changes in the inputs types.
4 participants