File indexing completed on 2025-09-15 09:11:42
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014 #ifndef ROOT_RFieldVisitor
0015 #define ROOT_RFieldVisitor
0016
0017 #include <ROOT/RField.hxx>
0018 #include <ROOT/RNTupleUtil.hxx>
0019
0020 #include <algorithm>
0021 #include <iostream>
0022 #include <sstream>
0023 #include <string>
0024 #include <vector>
0025
0026 namespace ROOT {
0027 namespace Detail {
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038
0039
0040
0041
0042
0043
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058 class RFieldVisitor {
0059 public:
0060 virtual void VisitField(const ROOT::RFieldBase &field) = 0;
0061 virtual void VisitFieldZero(const ROOT::RFieldZero &field) { VisitField(field); }
0062 virtual void VisitArrayField(const ROOT::RArrayField &field) { VisitField(field); }
0063 virtual void VisitArrayAsRVecField(const ROOT::RArrayAsRVecField &field) { VisitField(field); }
0064 virtual void VisitAtomicField(const ROOT::RAtomicField &field) { VisitField(field); }
0065 virtual void VisitBitsetField(const ROOT::RBitsetField &field) { VisitField(field); }
0066 virtual void VisitBoolField(const ROOT::RField<bool> &field) { VisitField(field); }
0067 virtual void VisitClassField(const ROOT::RClassField &field) { VisitField(field); }
0068 virtual void VisitTObjectField(const ROOT::RField<TObject> &field) { VisitField(field); }
0069 virtual void VisitStreamerField(const ROOT::RStreamerField &field) { VisitField(field); }
0070 virtual void VisitProxiedCollectionField(const ROOT::RProxiedCollectionField &field) { VisitField(field); }
0071 virtual void VisitRecordField(const ROOT::RRecordField &field) { VisitField(field); }
0072 virtual void VisitCardinalityField(const ROOT::RCardinalityField &field) { VisitField(field); }
0073 virtual void VisitDoubleField(const ROOT::RField<double> &field) { VisitField(field); }
0074 virtual void VisitEnumField(const ROOT::REnumField &field) { VisitField(field); }
0075 virtual void VisitFloatField(const ROOT::RField<float> &field) { VisitField(field); }
0076 virtual void VisitByteField(const ROOT::RField<std::byte> &field) { VisitField(field); }
0077 virtual void VisitCharField(const ROOT::RField<char> &field) { VisitField(field); }
0078
0079
0080 virtual void VisitInt8Field(const ROOT::RIntegralField<std::int8_t> &field) { VisitField(field); }
0081 virtual void VisitInt16Field(const ROOT::RIntegralField<std::int16_t> &field) { VisitField(field); }
0082 virtual void VisitInt32Field(const ROOT::RIntegralField<std::int32_t> &field) { VisitField(field); }
0083 virtual void VisitInt64Field(const ROOT::RIntegralField<std::int64_t> &field) { VisitField(field); }
0084 virtual void VisitNullableField(const ROOT::RNullableField &field) { VisitField(field); }
0085 virtual void VisitStringField(const ROOT::RField<std::string> &field) { VisitField(field); }
0086 virtual void VisitUInt8Field(const ROOT::RIntegralField<std::uint8_t> &field) { VisitField(field); }
0087 virtual void VisitUInt16Field(const ROOT::RIntegralField<std::uint16_t> &field) { VisitField(field); }
0088 virtual void VisitUInt32Field(const ROOT::RIntegralField<std::uint32_t> &field) { VisitField(field); }
0089 virtual void VisitUInt64Field(const ROOT::RIntegralField<std::uint64_t> &field) { VisitField(field); }
0090 virtual void VisitVectorField(const ROOT::RVectorField &field) { VisitField(field); }
0091 virtual void VisitVectorBoolField(const ROOT::RField<std::vector<bool>> &field) { VisitField(field); }
0092 virtual void VisitRVecField(const ROOT::RRVecField &field) { VisitField(field); }
0093 };
0094
0095 }
0096
0097 namespace Internal {
0098
0099
0100
0101
0102
0103
0104
0105
0106
0107
0108 class RPrepareVisitor : public Detail::RFieldVisitor {
0109 private:
0110 unsigned int fDeepestLevel = 1;
0111 unsigned int fNumFields = 1;
0112
0113 public:
0114 RPrepareVisitor() = default;
0115 void VisitField(const ROOT::RFieldBase &field) final;
0116 void VisitFieldZero(const ROOT::RFieldZero &field) final;
0117
0118 unsigned int GetDeepestLevel() const { return fDeepestLevel; }
0119 unsigned int GetNumFields() const { return fNumFields; }
0120 };
0121
0122
0123
0124
0125
0126
0127
0128
0129
0130
0131 class RPrintSchemaVisitor : public Detail::RFieldVisitor {
0132 private:
0133
0134 std::ostream &fOutput;
0135
0136 char fFrameSymbol;
0137
0138 int fWidth;
0139 int fDeepestLevel;
0140 int fNumFields;
0141 int fAvailableSpaceKeyString;
0142 int fAvailableSpaceValueString;
0143 int fFieldNo = 1;
0144 std::string fTreePrefix;
0145 std::string fFieldNoPrefix;
0146
0147 public:
0148 RPrintSchemaVisitor(std::ostream &out = std::cout, char frameSymbol = '*', int width = 80, int deepestLevel = 1,
0149 int numFields = 1)
0150 : fOutput{out}, fFrameSymbol{frameSymbol}, fWidth{width}, fDeepestLevel{deepestLevel}, fNumFields{numFields}
0151 {
0152 SetAvailableSpaceForStrings();
0153 }
0154
0155 void VisitField(const ROOT::RFieldBase &field) final;
0156 void VisitFieldZero(const ROOT::RFieldZero &fieldZero) final;
0157 void SetFrameSymbol(char s) { fFrameSymbol = s; }
0158 void SetWidth(int w) { fWidth = w; }
0159 void SetDeepestLevel(int d);
0160 void SetNumFields(int n);
0161
0162
0163
0164
0165
0166
0167
0168
0169
0170
0171
0172
0173
0174
0175 void SetAvailableSpaceForStrings()
0176 {
0177 fAvailableSpaceKeyString =
0178 std::min(4 * fDeepestLevel + 4 + static_cast<int>(std::to_string(fNumFields).size()), fWidth - 15);
0179 fAvailableSpaceValueString = fWidth - 6 - fAvailableSpaceKeyString;
0180 }
0181 };
0182
0183
0184
0185
0186
0187
0188
0189
0190 class RPrintValueVisitor : public Detail::RFieldVisitor {
0191 public:
0192 struct RPrintOptions {
0193 bool fPrintSingleLine;
0194 bool fPrintName;
0195
0196 RPrintOptions() : fPrintSingleLine(false), fPrintName(true) {}
0197 };
0198
0199 private:
0200 ROOT::RFieldBase::RValue fValue;
0201
0202 std::ostream &fOutput;
0203 unsigned int fLevel;
0204 RPrintOptions fPrintOptions;
0205
0206 void PrintIndent();
0207 void PrintName(const ROOT::RFieldBase &field);
0208 void PrintCollection(const ROOT::RFieldBase &field);
0209 void PrintRecord(const ROOT::RFieldBase &field);
0210
0211 public:
0212 RPrintValueVisitor(ROOT::RFieldBase::RValue value, std::ostream &output, unsigned int level = 0,
0213 RPrintOptions options = RPrintOptions())
0214 : fValue(value), fOutput{output}, fLevel(level), fPrintOptions(options)
0215 {
0216 }
0217
0218 void VisitField(const ROOT::RFieldBase &field) final;
0219
0220 void VisitBoolField(const ROOT::RField<bool> &field) final;
0221 void VisitDoubleField(const ROOT::RField<double> &field) final;
0222 void VisitFloatField(const ROOT::RField<float> &field) final;
0223 void VisitByteField(const ROOT::RField<std::byte> &field) final;
0224 void VisitCharField(const ROOT::RField<char> &field) final;
0225 void VisitInt8Field(const ROOT::RIntegralField<std::int8_t> &field) final;
0226 void VisitInt16Field(const ROOT::RIntegralField<std::int16_t> &field) final;
0227 void VisitInt32Field(const ROOT::RIntegralField<std::int32_t> &field) final;
0228 void VisitInt64Field(const ROOT::RIntegralField<std::int64_t> &field) final;
0229 void VisitStringField(const ROOT::RField<std::string> &field) final;
0230 void VisitUInt8Field(const ROOT::RIntegralField<std::uint8_t> &field) final;
0231 void VisitUInt16Field(const ROOT::RIntegralField<std::uint16_t> &field) final;
0232 void VisitUInt32Field(const ROOT::RIntegralField<std::uint32_t> &field) final;
0233 void VisitUInt64Field(const ROOT::RIntegralField<std::uint64_t> &field) final;
0234
0235 void VisitCardinalityField(const ROOT::RCardinalityField &field) final;
0236 void VisitArrayField(const ROOT::RArrayField &field) final;
0237 void VisitArrayAsRVecField(const ROOT::RArrayAsRVecField &field) final;
0238 void VisitClassField(const ROOT::RClassField &field) final;
0239 void VisitTObjectField(const ROOT::RField<TObject> &field) final;
0240 void VisitStreamerField(const ROOT::RStreamerField &field) final;
0241 void VisitRecordField(const ROOT::RRecordField &field) final;
0242 void VisitProxiedCollectionField(const ROOT::RProxiedCollectionField &field) final;
0243 void VisitVectorField(const ROOT::RVectorField &field) final;
0244 void VisitVectorBoolField(const ROOT::RField<std::vector<bool>> &field) final;
0245 void VisitRVecField(const ROOT::RRVecField &field) final;
0246 void VisitBitsetField(const ROOT::RBitsetField &field) final;
0247 void VisitNullableField(const ROOT::RNullableField &field) final;
0248 void VisitEnumField(const ROOT::REnumField &field) final;
0249 void VisitAtomicField(const ROOT::RAtomicField &field) final;
0250 };
0251
0252
0253
0254
0255
0256
0257
0258
0259
0260
0261 class RNTupleFormatter {
0262 public:
0263
0264 static std::string FitString(const std::string &str, int availableSpace);
0265 };
0266
0267 }
0268 }
0269
0270 #endif