Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
RFieldVisitor.cxx
Go to the documentation of this file.
1/// \file RFieldVisitor.cxx
2/// \ingroup NTuple ROOT7
3/// \author Simon Leisibach <simon.leisibach@gmail.com>
4/// \date 2019-06-11
5/// \warning This is part of the ROOT 7 prototype! It will change without notice. It might trigger earthquakes. Feedback
6/// is welcome!
7
8/*************************************************************************
9 * Copyright (C) 1995-2019, Rene Brun and Fons Rademakers. *
10 * All rights reserved. *
11 * *
12 * For the licensing terms see $ROOTSYS/LICENSE. *
13 * For the list of contributors see $ROOTSYS/README/CREDITS. *
14 *************************************************************************/
15
16#include <ROOT/RField.hxx>
18#include <ROOT/RNTupleUtil.hxx>
19#include <ROOT/RNTupleView.hxx>
20
21#include <cassert>
22#include <iomanip>
23#include <iostream>
24#include <sstream>
25#include <string>
26#include <vector>
27
28
29//----------------------------- RPrepareVisitor --------------------------------
30
32{
33 auto subFields = field.GetSubFields();
34 for (auto f : subFields) {
35 RPrepareVisitor visitor;
36 f->AcceptVisitor(visitor);
37 fNumFields += visitor.fNumFields;
38 fDeepestLevel = std::max(fDeepestLevel, 1 + visitor.fDeepestLevel);
39 }
40}
41
42
44{
45 VisitField(field);
46 fNumFields--;
47 fDeepestLevel--;
48}
49
50
51//---------------------------- RPrintSchemaVisitor -----------------------------
52
53
55{
56 fDeepestLevel = d;
57}
58
60{
61 fNumFields = n;
62 SetAvailableSpaceForStrings();
63}
64
66{
67 fOutput << fFrameSymbol << ' ';
68
69 std::string key = fTreePrefix;
70 key += "Field " + fFieldNoPrefix + std::to_string(fFieldNo);
71 fOutput << RNTupleFormatter::FitString(key, fAvailableSpaceKeyString);
72 fOutput << " : ";
73
74 std::string value = field.GetFieldName();
75 if (!field.GetTypeName().empty())
76 value += " (" + field.GetTypeName() + ")";
77 fOutput << RNTupleFormatter::FitString(value, fAvailableSpaceValueString);
78 fOutput << fFrameSymbol << std::endl;
79
80 auto subFields = field.GetSubFields();
81 auto fieldNo = 1;
82 for (auto iField = subFields.begin(); iField != subFields.end(); ) {
83 RPrintSchemaVisitor visitor(*this);
84 visitor.fFieldNo = fieldNo++;
85 visitor.fFieldNoPrefix += std::to_string(fFieldNo) + ".";
86
87 auto f = *iField;
88 ++iField;
89 // TODO(jblomer): implement tree drawing
90 visitor.fTreePrefix += " ";
91 f->AcceptVisitor(visitor);
92 }
93}
94
95
97{
98 auto fieldNo = 1;
99 for (auto f : fieldZero.GetSubFields()) {
100 RPrintSchemaVisitor visitor(*this);
101 visitor.fFieldNo = fieldNo++;
102 f->AcceptVisitor(visitor);
103 }
104}
105
106
107//--------------------------- RPrintValueVisitor -------------------------------
108
110{
111 if (fPrintOptions.fPrintSingleLine)
112 return;
113
114 for (unsigned int i = 0; i < fLevel; ++i)
115 fOutput << " ";
116}
117
119{
120 if (fPrintOptions.fPrintName)
121 fOutput << "\"" << field.GetFieldName() << "\": ";
122}
123
125{
126 PrintIndent();
127 PrintName(field);
128 fOutput << "[";
129 auto elems = field.SplitValue(fValue);
130 for (auto iValue = elems.begin(); iValue != elems.end(); ) {
131 RPrintOptions options;
132 options.fPrintSingleLine = true;
133 options.fPrintName = false;
134 RPrintValueVisitor elemVisitor(*iValue, fOutput, 0 /* level */, options);
135 iValue->GetField().AcceptVisitor(elemVisitor);
136
137 if (++iValue == elems.end())
138 break;
139 else
140 fOutput << ", ";
141 }
142 fOutput << "]";
143}
144
146{
147 PrintIndent();
148 PrintName(field);
149 fOutput << "{";
150 auto elems = field.SplitValue(fValue);
151 for (auto iValue = elems.begin(); iValue != elems.end();) {
152 if (!fPrintOptions.fPrintSingleLine)
153 fOutput << std::endl;
154
155 RPrintOptions options;
156 options.fPrintSingleLine = fPrintOptions.fPrintSingleLine;
157 RPrintValueVisitor visitor(*iValue, fOutput, fLevel + 1, options);
158 iValue->GetField().AcceptVisitor(visitor);
159
160 if (++iValue == elems.end()) {
161 if (!fPrintOptions.fPrintSingleLine)
162 fOutput << std::endl;
163 break;
164 } else {
165 fOutput << ",";
166 if (fPrintOptions.fPrintSingleLine)
167 fOutput << " ";
168 }
169 }
170 PrintIndent();
171 fOutput << "}";
172}
173
175{
176 PrintIndent();
177 PrintName(field);
178 fOutput << "\"<unsupported type: " << field.GetTypeName() << ">\"";
179}
180
181
183{
184 PrintIndent();
185 PrintName(field);
186 if (fValue.GetRef<bool>())
187 fOutput << "true";
188 else
189 fOutput << "false";
190}
191
192
194{
195 PrintIndent();
196 PrintName(field);
197 fOutput << fValue.GetRef<double>();
198}
199
200
202{
203 PrintIndent();
204 PrintName(field);
205 fOutput << fValue.GetRef<float>();
206}
207
209{
210 PrintIndent();
211 PrintName(field);
212 char prev = std::cout.fill();
213 fOutput << "0x" << std::setw(2) << std::setfill('0') << std::hex << (fValue.GetRef<unsigned char>() & 0xff);
214 fOutput << std::resetiosflags(std::ios_base::basefield);
215 std::cout.fill(prev);
216}
217
219{
220 PrintIndent();
221 PrintName(field);
222 fOutput << fValue.GetRef<char>();
223}
224
226{
227 PrintIndent();
228 PrintName(field);
229 fOutput << fValue.GetRef<std::int8_t>();
230}
231
233{
234 PrintIndent();
235 PrintName(field);
236 fOutput << fValue.GetRef<std::int16_t>();
237}
238
240{
241 PrintIndent();
242 PrintName(field);
243 fOutput << fValue.GetRef<int>();
244}
245
247{
248 PrintIndent();
249 PrintName(field);
250 fOutput << fValue.GetRef<std::int64_t>();
251}
252
254{
255 PrintIndent();
256 PrintName(field);
257 // TODO(jblomer): escape double quotes
258 fOutput << "\"" << fValue.GetRef<std::string>() << "\"";
259}
260
262{
263 PrintIndent();
264 PrintName(field);
265 fOutput << static_cast<int>(fValue.GetRef<std::uint8_t>());
266}
267
269{
270 PrintIndent();
271 PrintName(field);
272 fOutput << fValue.GetRef<std::uint16_t>();
273}
274
276{
277 PrintIndent();
278 PrintName(field);
279 fOutput << fValue.GetRef<std::uint32_t>();
280}
281
282
284{
285 PrintIndent();
286 PrintName(field);
287 fOutput << fValue.GetRef<std::uint64_t>();
288}
289
291{
292 PrintIndent();
293 PrintName(field);
294 if (field.As32Bit()) {
295 fOutput << fValue.GetRef<std::uint32_t>();
296 return;
297 }
298 if (field.As64Bit()) {
299 fOutput << fValue.GetRef<std::uint64_t>();
300 return;
301 }
302 R__ASSERT(false && "unsupported cardinality size type");
303}
304
306{
307 constexpr auto nBitsULong = sizeof(unsigned long) * 8;
308 const auto *asULongArray = fValue.GetPtr<unsigned long>().get();
309
310 PrintIndent();
311 PrintName(field);
312 fOutput << "\"";
313 std::size_t i = 0;
314 std::string str;
315 for (std::size_t word = 0; word < (field.GetN() + nBitsULong - 1) / nBitsULong; ++word) {
316 for (std::size_t mask = 0; (mask < nBitsULong) && (i < field.GetN()); ++mask, ++i) {
317 bool isSet = (asULongArray[word] & (static_cast<unsigned long>(1) << mask)) != 0;
318 str = std::to_string(isSet) + str;
319 }
320 }
321 fOutput << str << "\"";
322}
323
325{
326 PrintCollection(field);
327}
328
330{
331 PrintCollection(field);
332}
333
335{
336 PrintRecord(field);
337}
338
340{
341 PrintRecord(field);
342}
343
345{
346 PrintRecord(field);
347}
348
350{
351 PrintIndent();
352 PrintName(field);
353 auto elems = field.SplitValue(fValue);
354 if (elems.empty()) {
355 fOutput << "null";
356 } else {
357 RPrintOptions options;
358 options.fPrintSingleLine = true;
359 options.fPrintName = false;
360 RPrintValueVisitor visitor(elems[0], fOutput, fLevel, options);
361 elems[0].GetField().AcceptVisitor(visitor);
362 }
363}
364
366{
367 PrintIndent();
368 PrintName(field);
369 auto intValue = field.SplitValue(fValue)[0];
370 RPrintOptions options;
371 options.fPrintSingleLine = true;
372 options.fPrintName = false;
373 RPrintValueVisitor visitor(intValue, fOutput, fLevel, options);
374 intValue.GetField().AcceptVisitor(visitor);
375}
376
378{
379 PrintIndent();
380 PrintName(field);
381 auto itemValue = field.SplitValue(fValue)[0];
382 RPrintOptions options;
383 options.fPrintSingleLine = true;
384 options.fPrintName = false;
385 RPrintValueVisitor visitor(itemValue, fOutput, fLevel, options);
386 itemValue.GetField().AcceptVisitor(visitor);
387}
388
390{
391 PrintCollection(field);
392}
393
395{
396 PrintCollection(field);
397}
398
400{
401 PrintCollection(field);
402}
403
405{
406 PrintCollection(field);
407}
408
409//---------------------------- RNTupleFormatter --------------------------------
410
411
412std::string ROOT::Experimental::RNTupleFormatter::FitString(const std::string &str, int availableSpace)
413{
414 int strSize{static_cast<int>(str.size())};
415 if (strSize <= availableSpace)
416 return str + std::string(availableSpace - strSize, ' ');
417 else if (availableSpace < 3)
418 return std::string(availableSpace, '.');
419 return std::string(str, 0, availableSpace - 3) + "...";
420}
#define d(i)
Definition RSha256.hxx:102
#define f(i)
Definition RSha256.hxx:104
#define R__ASSERT(e)
Definition TError.h:118
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t mask
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
A field for fixed-size arrays that are represented as RVecs in memory.
Definition RField.hxx:1237
The generic field for fixed size arrays, which do not need an offset column.
Definition RField.hxx:1185
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given a value for this field.
Definition RField.cxx:3633
The generic field an std::bitset<N>.
Definition RField.hxx:1280
std::size_t GetN() const
Get the number of bits in the bitset, i.e. the N in std::bitset<N>
Definition RField.hxx:1311
An artificial field that transforms an RNTuple column that contains the offset of collections into co...
Definition RField.hxx:1715
const RField< RNTupleCardinality< std::uint32_t > > * As32Bit() const
Definition RField.cxx:1147
const RField< RNTupleCardinality< std::uint64_t > > * As64Bit() const
Definition RField.cxx:1153
The field for a class with dictionary.
Definition RField.hxx:760
The field for an unscoped or scoped enum with dictionary.
Definition RField.hxx:821
std::vector< RValue > SplitValue(const RValue &value) const final
Creates the list of direct child values given a value for this field.
Definition RField.cxx:1917
A field translates read and write calls from/to underlying columns to/from tree values.
Definition RField.hxx:95
std::string GetFieldName() const
Definition RField.hxx:665
std::vector< RFieldBase * > GetSubFields()
Definition RField.cxx:876
std::string GetTypeName() const
Definition RField.hxx:668
virtual std::vector< RValue > SplitValue(const RValue &value) const
Creates the list of direct child values given a value for this field.
Definition RField.cxx:848
The container field for an ntuple model, which itself has no physical representation.
Definition RField.hxx:717
Classes with dictionaries that can be inspected by TClass.
Definition RField.hxx:1506
static std::string FitString(const std::string &str, int availableSpace)
The field for values that may or may not be present in an entry.
Definition RField.hxx:1411
Visitor used for a pre-processing run to collect information needed by another visitor class.
void VisitField(const RFieldBase &field) final
void VisitFieldZero(const RFieldZero &field) final
Contains settings for printing and prints a summary of an RField instance.
void VisitField(const RFieldBase &field) final
Prints summary of Field.
void VisitFieldZero(const RFieldZero &fieldZero) final
Renders a JSON value corresponding to the field.
void VisitVectorBoolField(const RField< std::vector< bool > > &field) final
void VisitDoubleField(const RField< double > &field) final
void VisitUInt16Field(const RField< std::uint16_t > &field) final
void VisitArrayField(const RArrayField &field) final
void VisitFloatField(const RField< float > &field) final
void VisitRecordField(const RRecordField &field) final
void VisitStringField(const RField< std::string > &field) final
void VisitInt8Field(const RField< std::int8_t > &field) final
void PrintName(const RFieldBase &field)
void VisitNullableField(const RNullableField &field) final
void VisitUInt8Field(const RField< std::uint8_t > &field) final
void VisitBitsetField(const RBitsetField &field) final
void VisitCardinalityField(const RCardinalityField &field) final
void VisitTObjectField(const RField< TObject > &field) final
void VisitAtomicField(const RAtomicField &field) final
void VisitRVecField(const RRVecField &field) final
void VisitUInt64Field(const RField< std::uint64_t > &field) final
void VisitEnumField(const REnumField &field) final
void VisitBoolField(const RField< bool > &field) final
void VisitField(const RFieldBase &field) final
void VisitProxiedCollectionField(const RProxiedCollectionField &field) final
void VisitInt16Field(const RField< std::int16_t > &field) final
void VisitArrayAsRVecField(const RArrayAsRVecField &field) final
void VisitByteField(const RField< std::byte > &field) final
void PrintCollection(const RFieldBase &field)
void VisitVectorField(const RVectorField &field) final
void VisitCharField(const RField< char > &field) final
void VisitInt64Field(const RField< std::int64_t > &field) final
void VisitClassField(const RClassField &field) final
void PrintRecord(const RFieldBase &field)
void VisitIntField(const RField< int > &field) final
void VisitUInt32Field(const RField< std::uint32_t > &field) final
The field for a class representing a collection of elements via TVirtualCollectionProxy.
Definition RField.hxx:858
The type-erased field for a RVec<Type>
Definition RField.hxx:1123
The field for an untyped record.
Definition RField.hxx:1001
The generic field for a (nested) std::vector<Type> except for std::vector<bool>
Definition RField.hxx:1068
const Int_t n
Definition legend1.C:16