103#define RTLD_DEFAULT ((void *)::GetModuleHandle(NULL))
104#define dlsym(library, function_name) ::GetProcAddress((HMODULE)library, function_name)
130 static constexpr const char kUndeterminedClassInfoName[] =
"<NOT YET DETERMINED FROM fClassInfo>";
132 class TMmallocDescTemp {
136 TMmallocDescTemp(
void *value = 0) :
163 auto strLen = strlen(
name);
164 if (strLen == 0)
return;
166 const char* endCharPtr = strchr(
name,
'<');
167 endCharPtr = !endCharPtr ? &
name[strLen] : endCharPtr;
169 const char* beginCharPtr = endCharPtr;
170 while (beginCharPtr!=
name){
171 if (*beginCharPtr==
':'){
177 beginCharPtr = beginCharPtr!=endCharPtr ? beginCharPtr :
name;
178 std::string
s(beginCharPtr, endCharPtr);
180 printf(
"TDeclNameRegistry::AddQualifiedName Adding key %s for class/namespace %s\n",
s.c_str(),
name);
182 fClassNamesSet.insert(
s);
192 found = fClassNamesSet.find(
name) != fClassNamesSet.end();
201 if (fVerbLevel > 1) {
202 printf(
"TDeclNameRegistry Destructor. List of %lu names:\n",
203 (
long unsigned int)fClassNamesSet.size());
204 for (
auto const & key: fClassNamesSet) {
205 printf(
" - %s\n", key.c_str());
237 ObjRepoValue(
const TClass *what,
Version_t version) : fClass(what),fVersion(version) {}
262 std::pair<RepoCont_t::iterator, Bool_t> tmp =
gObjectVersionRepository.insert(RepoCont_t::value_type>(location, RepoCont_t::mapped_type(what,version)));
264 Warning(where,
"Reregistering an object of class '%s' version %d at address %p", what->
GetName(), version, p);
268 Warning(where,
"Failed to reregister an object of class '%s' version %d at address %p", what->
GetName(), version, location);
281 RepoCont_t::iterator tmp = cur++;
282 if ((tmp->first == location) && (tmp->second.fVersion == what->
GetClassVersion())) {
298 size_t objsize = what->
Size();
299 long delta = (
char*)newadd - (
char*)oldadd;
303 RepoCont_t::iterator tmp = cur++;
304 if (oldadd <= tmp->
first && tmp->first < ( ((
char*)oldadd) + objsize) ) {
307 gObjectVersionRepository.insert(RepoCont_t::value_type(((
char*)tmp->first)+delta, RepoCont_t::mapped_type(tmp->second.fClass,tmp->second.fVersion)));
320#define R__USE_STD_MAP
321 class TMapTypeToTClass {
322#if defined R__USE_STD_MAP
326 typedef std::map<std::string,TClass*>
IdMap_t;
327 typedef IdMap_t::key_type key_type;
328 typedef IdMap_t::const_iterator const_iterator;
329 typedef IdMap_t::size_type size_type;
332 typedef TClass* mapped_type;
334 typedef IdMap_t::mapped_type mapped_type;
341 void Add(
const key_type &key, mapped_type &obj)
346 mapped_type
Find(
const key_type &key)
const
349 IdMap_t::const_iterator iter = fMap.find(key);
351 if (iter != fMap.end()) cl = iter->second;
354 void Remove(
const key_type &key) {
363#ifdef R__COMPLETE_MEM_TERMINATION
372 void Add(
const char *key,
TClass *&obj) {
374 fMap.Add(realkey, obj);
377 const TPair *
a = (
const TPair *)fMap.FindObject(key);
381 void Remove(
const char *key) {
383 TObject *actual = fMap.Remove(&realkey);
389 class TMapDeclIdToTClass {
392 typedef multimap<TDictionary::DeclId_t, TClass*>
DeclIdMap_t;
393 typedef DeclIdMap_t::key_type key_type;
394 typedef DeclIdMap_t::mapped_type mapped_type;
395 typedef DeclIdMap_t::const_iterator const_iterator;
396 typedef std::pair <const_iterator, const_iterator> equal_range;
397 typedef DeclIdMap_t::size_type size_type;
403 void Add(
const key_type &key, mapped_type obj)
406 std::pair<const key_type, mapped_type> pair = make_pair(key, obj);
409 size_type CountElementsWithKey(
const key_type &key)
411 return fMap.count(key);
413 equal_range
Find(
const key_type &key)
const
416 return fMap.equal_range(key);
418 void Remove(
const key_type &key) {
427#ifdef R__COMPLETE_MEM_TERMINATION
429 return &gIdMapObject;
438#ifdef R__COMPLETE_MEM_TERMINATION
440 return &gDeclIdMapObject;
455 gROOT->GetListOfClasses()->Add(cl);
469 if (!cl || !
id)
return;
481 gROOT->GetListOfClasses()->Remove(oldcl);
513 TDumpMembers(
bool noAddr): fNoAddr(noAddr) { }
530void TDumpMembers::Inspect(
TClass *cl,
const char *pname,
const char *mname,
const void *add,
Bool_t )
532 const Int_t kvalue = 30;
534 const Int_t ktitle = 50;
536 const Int_t ktitle = 42;
538 const Int_t kline = 1024;
546 const char *memberName;
547 const char *memberFullTypeName;
548 const char *memberTitle;
553 if (member->GetDataType()) {
554 memberDataType = (
EDataType)member->GetDataType()->GetType();
556 memberName = member->GetName();
557 memberFullTypeName = member->GetFullTypeName();
558 memberTitle = member->GetTitle();
559 isapointer = member->IsaPointer();
560 isbasic = member->IsBasic();
567 const char *cursor = mname;
568 while ( (*cursor)==
'*' ) ++cursor;
570 Ssiz_t pos = elname.Index(
"[");
571 if ( pos !=
kNPOS ) {
572 elname.Remove( pos );
575 if (!element)
return;
580 memberName = element->
GetName();
583 membertype =
gROOT->GetType(memberFullTypeName);
585 isbasic = membertype !=0;
592 if (strcmp(memberName,
"fDatime") == 0 && memberDataType ==
kUInt_t) {
596 if (strcmp(memberName,
"fBits") == 0 && memberDataType ==
kUInt_t) {
601 static TClassRef stdClass(
"std::string");
602 Bool_t isStdString = (dataClass == stdClass);
605 for (i = 0;i < kline; i++)
line[i] =
' ';
611 char *pointer = (
char*)add;
612 char **ppointer = (
char**)(pointer);
615 char **p3pointer = (
char**)(*ppointer);
622 }
else if (membertype) {
624 i = strlen(*ppointer);
625 if (kvalue+i > kline) i=kline-1-kvalue;
627 for (
Int_t j = 0; j < i; j++) {
628 if (!std::isprint((*ppointer)[j])) {
634 strncpy(
line + kvalue, *ppointer, i);
642 }
else if (!strcmp(memberFullTypeName,
"char*") ||
643 !strcmp(memberFullTypeName,
"const char*")) {
644 i = strlen(*ppointer);
645 if (kvalue+i >= kline) i=kline-1-kvalue;
647 for (
Int_t j = 0; j < i; j++) {
648 if (!std::isprint((*ppointer)[j])) {
654 strncpy(
line + kvalue, *ppointer, std::min( i, kline - kvalue));
664 }
else if (membertype) {
666 cdatime = (
UInt_t*)pointer;
668 snprintf(&
line[kvalue],kline-kvalue,
"%d/%d",cdate,ctime);
676 std::string *str = (std::string*)pointer;
678 }
else if (isTString) {
688 if (isdate ==
kFALSE && strcmp(memberFullTypeName,
"char*") && strcmp(memberFullTypeName,
"const char*")) {
689 i = strlen(&
line[0]);
line[i] =
' ';
690 assert(250 > ktitle);
691 strlcpy(&
line[ktitle],memberTitle,250-ktitle+1);
713 void *fRealDataObject;
717 TBuildRealData(
void *obj,
TClass *cl) {
719 fRealDataObject = obj;
730void TBuildRealData::Inspect(
TClass* cl,
const char* pname,
const char* mname,
const void* add,
Bool_t isTransient)
742 isTransientMember =
kTRUE;
749 if (cl != fRealDataClass) {
750 if (!fRealDataClass->InheritsFrom(cl)) {
751 Ssiz_t dot = rname.Index(
'.');
756 if (!fRealDataClass->GetDataMember(rname)) {
771 if (!fRealDataClass->GetBaseDataMember(rname)) {
786 fRealDataClass->GetListOfRealData()->Add(rd);
796 fRealDataClass->GetListOfRealData()->Add(rd);
841 void* addrForRecursion = 0;
842 if (GetObjectValidity() == kValidObjectGiven)
843 addrForRecursion =
const_cast<void*
>(add);
850 fRealDataClass->GetListOfRealData()->Add(rd);
867 fBrowser =
b; fCount = 0; }
868 virtual ~TAutoInspector() { }
871 virtual Bool_t IsTreatingNonAccessibleTypes() {
return kFALSE;}
877void TAutoInspector::Inspect(
TClass *cl,
const char *tit,
const char *
name,
878 const void *addr,
Bool_t )
880 if(tit && strchr(tit,
'.')) return ;
881 if (fCount && !fBrowser)
return;
888 int ln = strcspn(
name,
"[ ");
892 if (!classInfo)
return;
902 if ((found = (iname==mname)))
break;
914 if (mname ==
"G__virtualinfo")
return;
916 int size =
sizeof(
void*);
936 for(
int i=0; i<nmax; i++) {
938 char *ptr = (
char*)addr + i*size;
945 if (!fBrowser)
return;
953 bwname = actualClass->
GetName();
962 int l = strcspn(bwname.
Data(),
"[ ");
963 if (
l<bwname.
Length() && bwname[
l]==
'[') {
964 char cbuf[13];
snprintf(cbuf,13,
"[%02d]",i);
967 bwname = (
const char*)ts;
973 fBrowser->Add(obj,clm,bwname);
980 fBrowser->Add( obj, clm, bwname );
986 int sz = proxy->
Size();
988 char fmt[] = {
"#%09d"};
989 fmt[3] =
'0'+(int)
log10(
double(sz))+1;
991 for (
int ii=0;ii<sz;ii++) {
992 void *p = proxy->
At(ii);
1004 fBrowser->Add( p, actualCl, ts );
1043 TMmallocDescTemp setreset;
1060 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1061 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1062 fAllPubMethod(0), fClassMenuList(0),
1063 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1064 fInstanceCount(0), fOnHeap(0),
1065 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1066 fTypeInfo(0), fShowMembers(0),
1067 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1068 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1069 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1070 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1071 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1073 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1074 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1079 ::Fatal(
"TClass::TClass",
"ROOT system not initialized");
1082 TMmallocDescTemp setreset;
1089 ::Fatal(
"TClass::TClass",
"gInterpreter not initialized");
1093 ::Warning(
"TClass::TClass",
"no dictionary for class %s is available",
name);
1107 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1108 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1109 fAllPubMethod(0), fClassMenuList(0),
1110 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1111 fInstanceCount(0), fOnHeap(0),
1112 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1113 fTypeInfo(0), fShowMembers(0),
1114 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1115 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1116 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1117 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1118 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1120 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1121 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1124 Init(
name, cversion, 0, 0, 0, 0, -1, -1, 0, silent);
1134 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1135 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1136 fAllPubMethod(0), fClassMenuList(0),
1137 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1138 fInstanceCount(0), fOnHeap(0),
1139 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1140 fTypeInfo(0), fShowMembers(0),
1141 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1142 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1143 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1144 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1145 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1147 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1148 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1160 "A TClass entry cannot be initialized in a state different from kForwardDeclared or kEmulated.");
1161 Init(
name, cversion, 0, 0, 0, 0, -1, -1, 0, silent);
1178 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1179 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1180 fAllPubMethod(0), fClassMenuList(0),
1181 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1182 fInstanceCount(0), fOnHeap(0),
1183 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1184 fTypeInfo(0), fShowMembers(0),
1185 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1186 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1187 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1188 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1189 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1191 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1192 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1197 ::Fatal(
"TClass::TClass",
"ROOT system not initialized");
1203 ::Fatal(
"TClass::TClass",
"gInterpreter not initialized");
1205 if (!classInfo || !
gInterpreter->ClassInfo_IsValid(classInfo)) {
1212 Init(
fName, cversion, 0, 0, dfil, ifil, dl, il, classInfo, silent);
1228 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1229 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1230 fAllPubMethod(0), fClassMenuList(0),
1231 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1232 fInstanceCount(0), fOnHeap(0),
1233 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1234 fTypeInfo(0), fShowMembers(0),
1235 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1236 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1237 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1238 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1239 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1241 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1242 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1245 Init(
name,cversion, 0, 0, dfil, ifil, dl, il, 0, silent);
1254 const char *dfil,
const char *ifil,
Int_t dl,
Int_t il,
1258 fStreamerInfo(0), fConversionStreamerInfo(0), fRealData(0),
1259 fBase(0), fData(0), fEnums(0), fFuncTemplate(0), fMethod(0), fAllPubData(0),
1262 fDeclFileName(
""), fImplFileName(
""), fDeclFileLine(0), fImplFileLine(0),
1263 fInstanceCount(0), fOnHeap(0),
1264 fCheckSum(0), fCollectionProxy(0), fClassVersion(0), fClassInfo(0),
1265 fTypeInfo(0), fShowMembers(0),
1266 fStreamer(0), fIsA(0), fGlobalIsA(0), fIsAMethod(0),
1267 fMerge(0), fResetAfterMerge(0), fNew(0), fNewArray(0), fDelete(0), fDeleteArray(0),
1268 fDestructor(0), fDirAutoAdd(0), fStreamerFunc(0), fConvStreamerFunc(0), fSizeof(-1),
1269 fCanSplit(-1), fProperty(0), fClassProperty(0), fHasRootPcmInfo(
kFALSE), fCanLoadClassInfo(
kFALSE),
1270 fIsOffsetStreamerSet(
kFALSE), fVersionUsed(
kFALSE), fRuntimeProperties(0), fOffsetStreamer(0), fStreamerType(
TClass::
kDefault),
1271 fState(kHasTClassInit),
1272 fCurrentInfo(0), fLastReadInfo(0), fRefProxy(0),
1273 fSchemaRules(0), fStreamerImpl(&
TClass::StreamerDefault)
1277 Init(
name, cversion, &info, isa, dfil, ifil, dl, il, 0, silent);
1295 info->
Clear(
"build");
1311 const char *dfil,
const char *ifil,
Int_t dl,
Int_t il,
1312 ClassInfo_t *givenInfo,
1316 ::Fatal(
"TClass::TClass",
"ROOT system not initialized");
1318 ::Error(
"TClass::Init",
"The name parameter is invalid (null or empty)");
1352 TClass **persistentRef = 0;
1370 info->
Clear(
"build");
1389 ::Fatal(
"TClass::Init",
"gInterpreter not initialized");
1392 bool invalid = !
gInterpreter->ClassInfo_IsValid(givenInfo);
1393 bool notloaded = !
gInterpreter->ClassInfo_IsLoaded(givenInfo);
1394 auto property =
gInterpreter->ClassInfo_Property(givenInfo);
1396 if (invalid || (notloaded && (property &
kIsNamespace)) ||
1463 ::Error(
"TClass::Init",
"no interpreter information for class %s is available even though it has a TClass "
1464 "initialization routine.",
1482 if (!givenInfo && strchr (
name,
'<')) {
1494 if (resolvedThis !=
name) {
1518 if (resolvedThis !=
fName) {
1519 oldcl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(resolvedThis);
1520 if (oldcl && oldcl !=
this) {
1527 if (resolvedThis != htmp->String())
continue;
1528 oldcl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(htmp->fOrigName);
1529 if (oldcl && oldcl !=
this) {
1547 if (persistentRef) {
1554 if ( isStl || !strncmp(
GetName(),
"stdext::hash_",13) || !strncmp(
GetName(),
"__gnu_cxx::hash_",16) ) {
1565 }
else if (!silent) {
1566 Warning(
"Init",
"Collection proxy for %s was not properly initialized!",
GetName());
1572 }
else if (!strncmp(
GetName(),
"std::pair<",10) || !strncmp(
GetName(),
"pair<",5) ) {
1592 if (resolvedThis == htmp->String() && htmp->fOrigName ==
GetName()) {
1659 std::map<std::string, TObjArray*>::iterator it;
1660 std::map<std::string, TObjArray*>::iterator end = (*fConversionStreamerInfo).end();
1661 for( it = (*fConversionStreamerInfo).begin(); it != end; ++it ) {
1671 Int_t ReadRulesContent(FILE *
f)
1683 while ((
c = fgetc(
f)) != EOF) {
1689 if (rule.Length() > 0) {
1741 static const char *suffix =
"class.rules";
1747 FILE *
f = fopen(sname,
"r");
1749 res = ReadRulesContent(
f);
1752 ::Error(
"TClass::ReadRules()",
"Cannot find rules file %s", sname.
Data());
1765 if (!filename || !filename[0]) {
1766 ::Error(
"TClass::ReadRules",
"no file name specified");
1770 FILE *
f = fopen(filename,
"r");
1772 ::Error(
"TClass::ReadRules",
"Failed to open %s\n",filename);
1775 Int_t count = ReadRulesContent(
f);
1828 ::Warning(
"TClass::AddRule",
"The rule for class: \"%s\": version, \"%s\" and data members: \"%s\" has been skipped because it conflicts with one of the other rules (%s).",
1889 TAutoInspector insp(
b);
1890 obj->ShowMembers(insp);
1911 }
else if (actual !=
this) {
1912 return actual->
Browse(obj,
b);
1918 TAutoInspector insp(
b);
1961 isTransient =
kTRUE;
1966 TMmallocDescTemp setreset;
1977 static TClassRef clRefString(
"std::string");
1978 if (clRefString ==
this) {
1987 && strncmp(
GetName(),
"pair<", 5) != 0) {
1988 Error(
"BuildRealData",
"Inspection for %s not supported!",
GetName());
1994 TBuildRealData brd(pointer,
this);
2000 if ( isTransient ) {
2008 Error(
"BuildRealData",
"Cannot find any ShowMembers function for %s!",
GetName());
2023 c->BuildRealData(0, isTransient);
2043 Error(
"BuildEmulatedRealData",
"Missing StreamerInfo for %s",
GetName());
2109 TMmallocDescTemp setreset;
2136 if (strcmp(
GetName(),
"string") == 0) {
2144 gInterpreter->InspectMembers(insp, obj,
this, isTransient);
2148 sinfo->CallShowMembers(obj, insp, isTransient);
2163 return gInterpreter->InspectMembers(insp, obj,
this, isTransient);
2227 }
else if (!
c->CanSplitBaseAllow()) {
2271 static TClassRef stdStringClass(
"std::string");
2336 if (new_name == 0 || new_name[0]==
'\0' ||
fName == new_name) {
2337 Error(
"Clone",
"The name of the class must be changed when cloning a TClass object.");
2367 copy->
fName = new_name;
2422 if (!padsav || !opt.
Contains(
"same")) {
2425 gROOT->ProcessLine(
"new TCanvas(\"R__class\",\"class\",20,20,1000,750);");
2431 if (
gPad)
gPad->DrawClassObject(
this,option);
2433 if (padsav) padsav->
cd();
2474 if (
sizeof(
this) == 4)
2477 Printf(
"==> Dumping object at: 0x%016lx, name=%s, class=%s\n",prObj,tobj->
GetName(),
GetName());
2480 if (
sizeof(
this) == 4)
2481 Printf(
"==> Dumping object at: 0x%08lx, class=%s\n",prObj,
GetName());
2483 Printf(
"==> Dumping object at: 0x%016lx, class=%s\n",prObj,
GetName());
2486 TDumpMembers dm(noAddr);
2488 Info(
"Dump",
"No ShowMembers function, dumping disabled");
2498 static const UInt_t maxsize = 255;
2499 static char name[maxsize+2];
2503 for (
UInt_t i = 0; i < nch && icur < maxsize; ++i, ++icur) {
2504 if (
text[i] ==
'\"' ||
text[i] ==
'[' ||
text[i] ==
'~' ||
2507 text[i] ==
'?' ||
text[i] ==
'>') {
2537 if (
object==0)
return (
TClass*)
this;
2539 return (*
fIsA)(object);
2550 return realTObject->IsA();
2567 return (*
fIsA)(object);
2585 if (strcmp(
GetName(), classname) == 0)
return this;
2604 if (cl ==
this)
return this;
2616 if (cl ==
c)
return c;
2617 c1 =
c->GetBaseClass(cl);
2635 if (cl ==
this)
return 0;
2637 if (!
fBase.load()) {
2644 if (!sinfo)
return -1;
2650 for(
Int_t i=0; i<size; i++) {
2656 if (!baseclass)
return -1;
2658 if (subOffset == -2)
return -2;
2659 if (subOffset != -1)
return offset+subOffset;
2660 offset += baseclass->
Size();
2664 if (!baseclass)
return -1;
2666 if (subOffset == -2)
return -2;
2667 if (subOffset != -1)
return offset+subOffset;
2668 offset += baseclass->
Size();
2671 Error(
"GetBaseClassOffsetRecurse",
"Unexpected element type for base class: %s\n",element->IsA()->
GetName());
2683 if (
fBase.load() == 0)
2686 lnk =
fBase.load()->FirstLink();
2702 off =
c->GetBaseClassOffsetRecurse(cl);
2703 if (off == -2)
return -2;
2722 if (
this == toBase)
return 0;
2738 if(derived && base) {
2760 if (dm)
return this;
2768 TClass *cdm =
c->GetBaseDataMember(datamember);
2769 if (cdm)
return cdm;
2780 struct TClassLocalStorage {
2781 TClassLocalStorage() : fCollectionProxy(0), fStreamer(0) {};
2786 static TClassLocalStorage *GetStorage(
const TClass *cl)
2792 if (*thread_ptr==0) *thread_ptr =
new TExMap();
2799 local = (
ULong_t)
new TClassLocalStorage();
2802 return (TClassLocalStorage*)local;
2830 TClassLocalStorage *local = TClassLocalStorage::GetStorage(
this);
2833 return local->fCollectionProxy;
2844 TClassLocalStorage *local = TClassLocalStorage::GetStorage(
this);
2846 if (local->fStreamer==0) {
2848 const std::type_info &orig = (
typeid(*fStreamer) );
2849 if (!local->fStreamer) {
2850 Warning(
"GetStreamer",
"For %s, the TClassStreamer (%s) passed's call to Generate failed!",
GetName(),orig.name());
2852 const std::type_info © = (
typeid(*local->fStreamer) );
2853 if (strcmp(orig.name(),copy.name())!=0) {
2854 Warning(
"GetStreamer",
"For %s, the TClassStreamer passed does not properly implement the Generate method (%s vs %s)\n",
GetName(),orig.name(),copy.name());
2858 return local->fStreamer;
2899 if (strstr(
name,
"(anonymous)"))
return 0;
2900 if (strncmp(
name,
"class ",6)==0)
name += 6;
2901 if (strncmp(
name,
"struct ",7)==0)
name += 7;
2903 if (!
gROOT->GetListOfClasses())
return 0;
2949 if (!cl && !load)
return 0;
2951 TClass *loadedcl = (dict)();
2961 std::string normalizedName;
2970 if (normalizedName !=
name) {
2971 cl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(normalizedName.c_str());
2982 normalizedName = cl->
GetName();
2983 checkTable = load && (normalizedName !=
name);
2986 if (!load)
return 0;
3012 if (
TDataType* theDataType =
gROOT->GetType(normalizedName.c_str())){
3014 auto underlyingTypeName = theDataType->GetTypeName();
3017 if (underlyingTypeDict){
3018 loadedcl = underlyingTypeDict();
3024 if (loadedcl)
return loadedcl;
3028 if (loadedcl)
return loadedcl;
3041 std::string::size_type posLess = normalizedName.find(
'<');
3042 if (posLess != std::string::npos) {
3049 printf(
"TClass::GetClass: Header Parsing - The representation of %s was not found in the type system. A lookup in the interpreter is about to be tried: this can cause parsing. This can be avoided selecting %s in the linkdef/selection file.\n",normalizedName.c_str(), normalizedName.c_str());
3051 if (normalizedName.length()) {
3061 auto ci =
gInterpreter->ClassInfo_Factory(normalizedName.c_str());
3063 auto method =
gInterpreter->MethodInfo_Factory(funcDecl);
3069 funcPtr(0, 0,
nullptr, &res);
3081 std::string alternative;
3082 gInterpreter->GetInterpreterTypeName(normalizedName.c_str(), alternative,
kTRUE);
3083 const char *altname = alternative.c_str();
3084 if (strncmp(altname,
"std::", 5) == 0) {
3089 if (altname != normalizedName && strcmp(altname,
name) != 0) {
3116 if (!
gROOT->GetListOfClasses())
3124 if (cl && cl->
IsLoaded())
return cl;
3131 cl =
GetIdMap()->Find(typeinfo.name());
3150 if (!load)
return 0;
3160 TIter next(
gROOT->GetListOfClassGenerators());
3172 if (!autoload_old) {
3203 if (!
gROOT->GetListOfClasses())
return 0;
3224 if (!load)
return 0;
3227 if (cl) loadedcl =
gROOT->LoadClass(cl->
GetName(),silent);
3228 else loadedcl =
gROOT->LoadClass(
name,silent);
3230 if (loadedcl)
return loadedcl;
3255 if (!
gROOT->GetListOfClasses())
return 0;
3259 DeclIdMap_t::equal_range iter = map->Find(
id);
3260 if (iter.first == iter.second)
return false;
3261 std::vector<TClass*>::iterator vectIt = classes.begin();
3262 for (DeclIdMap_t::const_iterator it = iter.first; it != iter.second; ++it)
3263 vectIt = classes.insert(vectIt, it->second);
3291 || datamember == 0)
return 0;
3294 const char *start_name = datamember;
3295 while (*start_name ==
'*') ++start_name;
3300 if (
const char *
s = strchr(start_name,
'[')){
3330 if (strchr(
name,
'[')==0) {
3372 std::string givenName(
name);
3375 std::string::size_type firstBracket = givenName.find_first_of(
"[");
3376 if (firstBracket != std::string::npos) {
3378 std::string nameNoDim(givenName.substr(0, firstBracket));
3382 std::string objName(obj->
GetName());
3383 std::string::size_type pos = objName.find_first_of(
"[");
3385 if (pos != std::string::npos) {
3387 if (objName == nameNoDim) {
3396 std::ostringstream ptrname;
3397 ptrname <<
"*" << givenName;
3404 std::string::size_type firstDot = givenName.find_first_of(
".");
3405 if (firstDot == std::string::npos) {
3416 std::string::size_type lastDot = givenName.find_last_of(
".");
3417 std::ostringstream starname;
3418 starname << givenName.substr(0, lastDot) <<
".*" << givenName.substr(lastDot + 1);
3426 std::string firstDotName(givenName.substr(firstDot + 1));
3440 std::string::size_type firstDotBracket = firstDotName.find_first_of(
"[");
3441 if (firstDotBracket != std::string::npos) {
3443 std::string nameNoDim(firstDotName.substr(0, firstDotBracket));
3447 std::string objName(obj->
GetName());
3448 std::string::size_type pos = objName.find_first_of(
"[");
3450 if (pos != std::string::npos) {
3452 if (objName == nameNoDim) {
3465 ptrname <<
"*" << firstDotName;
3481 std::string::size_type bracket = starname.str().find_first_of(
"[");
3482 if (bracket == std::string::npos) {
3527 if (!
fBase.load()) {
3552 Fatal(
"GetListOfBases",
"gInterpreter not initialized");
3555 if (!
fBase.load()) {
3581 auto temp =
fEnums.load();
3583 if (requestListLoading) {
3598 if (!requestListLoading) {
3605 static bool fromRootCling = dlsym(RTLD_DEFAULT,
"usedToIdentifyRootClingByDlSym");
3690 if (
gDebug>0)
Info(
"GetListOfMethods",
"Header Parsing - Asking for all the methods of class %s: this can involve parsing.",
GetName());
3723 if (
gDebug>0)
Info(
"GetListOfAllPublicMethods",
"Header Parsing - Asking for all the methods of class %s: this can involve parsing.",
GetName());
3753 while ((baseClass = (
TBaseClass *) nextBase())) {
3761 while ((method = (
TMethod*)next())) {
3767 if (
m &&
m->GetNargs() == method->
GetNargs())
3792 return cl->IsLoaded();
3820 TIter nextMemb(ldm);
3851 for (
int i = 0; i < 2; i++) {
3867 if (
this == sCIString)
return;
3879 auto checkDicts = [&](
const string &clName){
3886 if (cl && !cl->HasDictionary()) {
3887 cl->GetMissingDictionariesWithRecursionCheck(result, visited, recurse);
3891 const auto &elements = splitType.
fElements;
3892 const auto &templName = elements[0];
3895 if (templName ==
"pair") {
3903 if (templName ==
"unique_ptr" || templName ==
"array") {
3904 checkDicts(elements[1]);
3911 if (templName ==
"tuple") {
3914 const auto nTemplArgs = elements.size() - 1;
3916 for (
auto iTemplArg = 1U; iTemplArg < nTemplArgs; ++iTemplArg) {
3917 checkDicts(elements[iTemplArg]);
3966 if (
this == sCIString)
return;
3970 if (strncmp(
fName,
"pair<", 5) == 0) {
4024 while ((acl = (
TClass*)nextClass())) {
4025 if (acl == newcl)
continue;
4030 info->
Update(
this, newcl);
4034 TIter delIter( &tobedeleted );
4035 while ((acl = (
TClass*)delIter())) {
4046 Warning(
"ResetClassInfo(Long_t tagnum)",
"Call to deprecated interface (does nothing)");
4097 (*fMethod).Unload();
4131 if (options==0 || options[0]==0)
return;
4133 if (strstr(options,
"streamerinfo")!=0) {
4137 std::map<std::string, TObjArray*>::iterator it;
4138 std::map<std::string, TObjArray*>::iterator end = (*fConversionStreamerInfo).end();
4139 for( it = (*fConversionStreamerInfo).begin(); it != end; ++it ) {
4140 it->second->ls(options);
4167 TIter next(methodList);
4169 while ((method = (
TMethod*) next())) {
4171 if (classPtr != method->
GetClass()) {
4179 TIter nextarg(margsList);
4180 while ((methodArg = (
TMethodArg*)nextarg())) {
4230 if(
fMethod.compare_exchange_strong(expected, temp.get()) ) {
4266 m =
c->GetMethodAllAny(method);
4288 Fatal(
"GetMethod",
"gInterpreter not initialized");
4294 if (!decl)
return 0;
4301 "\nDid not find matching TMethod <%s> with \"%s\" %sfor %s",
4302 method,params,objectIsConst ?
"const " :
"",
GetName());
4312 return static_cast<TMethod *
>(method);
4316 if (
TFunction* method = base->FindClassOrBaseMethodWithId(declId))
4317 return static_cast<TMethod *
>(method);
4334 Fatal(
"GetMethodWithPrototype",
"gInterpreter not initialized");
4338 objectIsConst, mode);
4340 if (!decl)
return 0;
4343 Error(
"GetMethodWithPrototype",
4344 "\nDid not find matching TMethod <%s> with \"%s\" %sfor %s",
4345 method,
proto,objectIsConst ?
"const " :
"",
GetName());
4360 if (faddr == (
Long_t)
m->InterfaceMethod())
4379 Fatal(
"GetClassMethod",
"gInterpreter not initialized");
4385 if (!decl)
return 0;
4405 Fatal(
"GetClassMethodWithPrototype",
"gInterpreter not initialized");
4412 if (!decl)
return 0;
4504 Error(
"GetStreamerInfo",
"class: %s, attempting to access a wrong version: %d",
GetName(), version);
4523 TMmallocDescTemp setreset;
4577 newname +=
"@@emulated";
4602 for (
Int_t i = -1; sinfo == 0 && i < ninfos; ++i)
4615 Error(
"GetStreamerInfoAbstractEmulated",
"could not create TVirtualStreamerInfo");
4640 newname +=
"@@emulated";
4655 if (!sinfo && (checksum !=
fCheckSum)) {
4665 for (
Int_t i = -1; sinfo == 0 && i < ninfos; ++i)
4678 Error(
"GetStreamerInfoAbstractEmulated",
"could not create TVirtualStreamerInfo");
4725 Error(
"IgnoreTObjectStreamer",
"Must be called before the creation of StreamerInfo");
4751 if (cl ==
this)
return kTRUE;
4761 if (!clbase)
return kFALSE;
4780 if (cl ==
this)
return obj;
4787 return (
void*)((
Long_t)obj+off);
4789 return (
void*)((
Long_t)obj-off);
4855 Error(
"New",
"cannot create object of class %s",
GetName());
4871 Error(
"New",
"cannot create object of class %s",
GetName());
4882 Error(
"New",
"cannot create object of class %s",
GetName());
4903 if (!sinfo && !quiet) {
4922 Error(
"New",
"Failed to construct class '%s' using streamer info",
GetName());
4925 Fatal(
"New",
"This cannot happen!");
4949 Error(
"New with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
4964 Error(
"New with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
4992 Error(
"New with placement",
"Cannot construct class '%s' version %d at address %p, no streamer info available!",
GetName(),
fClassVersion, arena);
4997 p = sinfo->
New(arena);
5011 Error(
"New with placement",
"This cannot happen!");
5098 Error(
"NewArray",
"This cannot happen!");
5122 Error(
"NewArray with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
5137 Error(
"NewArray with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
5165 Error(
"NewArray with placement",
"Cannot construct class '%s' version %d at address %p, no streamer info available!",
GetName(),
fClassVersion, arena);
5170 p = sinfo->
NewArray(nElements, arena);
5189 Error(
"NewArray with placement",
"This cannot happen!");
5201 if (obj == 0)
return;
5208 }
else if ((!dtorOnly) &&
fDelete) {
5240 std::multiset<Version_t> knownVersions;
5253 knownVersions.insert(ver);
5261 if (!inRepo || verFound) {
5268 Error(
"Destructor",
"No streamer info available for class '%s' version %d at address %p, cannot destruct emulated object!",
GetName(),
fClassVersion, p);
5274 Error(
"Destructor",
"Doing Dump() ...");
5289 Error(
"Destructor2",
"No streamer info available for class '%s' version %d, cannot destruct object at addr: %p",
GetName(), objVer, p);
5296 Error(
"Destructor2",
"Doing Dump() ...");
5304 if (inRepo && verFound && p) {
5308 Error(
"Destructor",
"This cannot happen! (class %s)",
GetName());
5318 if (ary == 0)
return;
5325 Error(
"DeleteArray",
"Destructor only is not supported!");
5354 std::multiset<Version_t> knownVersions;
5365 knownVersions.insert(ver);
5373 if (!inRepo || verFound) {
5380 Error(
"DeleteArray",
"No streamer info available for class '%s' version %d at address %p, cannot destruct object!",
GetName(),
fClassVersion, ary);
5386 Error(
"DeleteArray",
"Doing Dump() ...");
5395 Error(
"DeleteArray",
"Loaded class version %d is not registered for addr %p",
fClassVersion, p);
5404 Error(
"DeleteArray",
"No streamer info available for class '%s' version %d at address %p, cannot destruct object!",
GetName(), objVer, ary);
5411 Error(
"DeleteArray",
"Doing Dump() ...");
5422 if (inRepo && verFound && p) {
5426 Error(
"DeleteArray",
"This cannot happen! (class '%s')",
GetName());
5497 char *
s =
new char[maxsize];
5501 b.ReadString(
s, maxsize);
5502 while (strlen(
s) == (maxsize - 1)) {
5504 b.SetBufferOffset(pos);
5505 maxsize = 2*maxsize;
5507 s =
new char[maxsize];
5508 b.ReadString(
s, maxsize);
5513 ::Error(
"TClass::Load",
"dictionary of class %s not found",
s);
5537 if (result)
return result;
5585 TIter next(
gROOT->GetListOfClassGenerators());
5612 bool autoParse = !
gInterpreter->IsAutoParsingSuspended();
5626 ::Error(
"TClass::LoadClassInfo",
"no interpreter information for class %s is available"
5627 " even though it has a TClass initialization routine.",
5650 const char *dfil,
const char *ifil,
5655 TMmallocDescTemp setreset;
5656 return new TClass(cname,
id, info, isa, dfil, ifil, dl, il);
5664 const char *dfil,
const char *ifil,
5669 TMmallocDescTemp setreset;
5670 return new TClass(cname,
id, dfil, ifil, dl, il);
5774 The class %s transitioned from not having a specified class version\n\
5775 to having a specified class version (the current class version is %d).\n\
5776 However too many different non-versioned layouts of the class have\n\
5777 already been loaded so far. To work around this problem you can\n\
5778 load fewer 'old' file in the same ROOT session or load the C++ library\n\
5779 describing the class %s before opening the files or increase the version\n\
5780 number of the class for example ClassDef(%s,%d).\n\
5781 Do not try to write objects with the current class definition,\n\
5782 the files might not be readable.\n",
5786 The StreamerInfo version %d for the class %s which was read\n\
5787 from a file previously opened has the same version as the active class\n\
5788 but a different checksum. You should update the version to ClassDef(%s,%d).\n\
5789 Do not try to write objects with the current class definition,\n\
5790 the files will not be readable.\n"
5835 TMmallocDescTemp setreset;
6050 Fatal(
"SetUnloaded",
"The TClass for %s is being unloaded when in state %d\n",
6074 (*fMethod).Unload();
6083 if (fState <= kForwardDeclared && fStreamerInfo->GetEntries() != 0) {
6176 //info is empty. Let's build the default Streamer descriptor
6178 char *temp = new char[10000];
6182 //add list of base classes
6183 TIter nextb(GetListOfBases());
6185 while ((base = (TBaseClass*) nextb())) {
6186 snprintf(local,100,"%s;",base->GetName());
6187 strlcat(temp,local,10000);
6190 //add list of data members and types
6191 TIter nextd(GetListOfDataMembers());
6192 while ((dm = (TDataMember *) nextd())) {
6193 if (dm->IsEnum()) continue;
6194 if (!dm->IsPersistent()) continue;
6195 Long_t property = dm->Property();
6196 if (property & kIsStatic) continue;
6197 TClass *acl = TClass::GetClass(dm->GetTypeName(),update);
6200 if (acl->GetClassVersion() == 0) continue;
6203 // dm->GetArrayIndex() returns an empty string if it does not
6205 const char * index = dm->GetArrayIndex();
6206 if (strlen(index)==0)
6207 snprintf(local,100,"%s %s;",dm->GetFullTypeName(),dm->GetName());
6209 snprintf(local,100,"%s %s[%s];",dm->GetFullTypeName(),dm->GetName(),index);
6210 strlcat(temp,local,10000);
6212 //fStreamerInfo = temp;
6301 for (
int i=0; i<il; i++)
id =
id*3+
name[i];
6310 TIter nextBase(tlb);
6319 for (
int i=0; i<il; i++)
id =
id*3+
name[i];
6322 Error(
"GetCheckSum",
"Calculating the checksum for (%s) requires the base class (%s) meta information to be available!",
6331 TList *tlm = ((
TClass*)
this)->GetListOfDataMembers();
6333 TIter nextMemb(tlm);
6349 for (i=0; i<il; i++)
id =
id*3+
name[i];
6361 type.ReplaceAll(
"ULong64_t",
"unsigned long long");
6362 type.ReplaceAll(
"Long64_t",
"long long");
6363 type.ReplaceAll(
"<signed char",
"<char");
6364 type.ReplaceAll(
",signed char",
",char");
6365 if (
type==
"signed char")
type =
"char";
6377 for (i=0; i<il; i++)
id =
id*3+
type[i];
6381 for (
int ii=0;ii<dim;ii++)
id =
id*3+tdm->
GetMaxIndex(ii);
6388 left = strstr(tdm->
GetTitle(),
"[");
6390 const char *right = strstr(left,
"]");
6393 while (left != right) {
6485 return b.ReadClassBuffer(
this,pointer,version,start,count);
6494 return b.ReadClassBuffer(
this,pointer);
6506 b.WriteClassBuffer(
this,pointer);
6519 streamer->
Stream(
b,
object,onfile_class);
6551 if (
b.IsReading()) {
6552 b.ReadClassEmulated(pThis,
object, onfile_class);
6554 b.WriteClassBuffer(pThis,
object);
6585 if (
b.IsReading()) {
6586 b.ReadClassBuffer(pThis,
object, onfile_class);
6590 b.WriteClassBuffer(pThis,
object);
6609 pThis->
Fatal(
"StreamerDefault",
"fStreamerImpl not properly initialized (%d)", pThis->
fStreamerType);
6771 for (
Int_t i=-1;i<ninfos;++i) {
6793 for (
Int_t i=-1;i<ninfos;i++) {
6797 if (!info)
continue;
6838 std::map<std::string, TObjArray*>::iterator it;
6841 it = (*fConversionStreamerInfo).find( cl->
GetName() );
6843 if( it != (*fConversionStreamerInfo).end() ) {
6847 if( arr && version > -1 && version < arr->GetSize() && arr->
At( version ) )
6859 if( version >= -1 && version < clSI->GetSize() )
6897 (*fConversionStreamerInfo)[cl->
GetName()] = arr;
6936 std::map<std::string, TObjArray*>::iterator it;
6940 it = (*fConversionStreamerInfo).find( cl->
GetName() );
6942 if( it != (*fConversionStreamerInfo).end() ) {
6991 (*fConversionStreamerInfo)[cl->
GetName()] = arr;
7010 Error(
"RegisterStreamerInfo",
7011 "Register StreamerInfo for %s on non-empty slot (%d).",
7051 static const char *handVerified[] = {
7052 "TEnvRec",
"TDataType",
"TObjArray",
"TList",
"THashList",
7053 "TClass",
"TCling",
"TInterpreter",
"TMethod",
"ROOT::Internal::TCheckHashRecursiveRemoveConsistency",
7054 "TCheckHashRecursiveRemoveConsistency",
"TGWindow",
7055 "TDirectory",
"TDirectoryFile",
"TObject",
"TH1",
7056 "TQClass",
"TGlobal" };
7058 if (cname && cname[0]) {
7059 for (
auto cursor : handVerified) {
7060 if (strcmp(cname, cursor) == 0)
TClass *(* DictFuncPtr_t)()
void(* MemberStreamerFunc_t)(TBuffer &, void *, Int_t)
TClass *(* IsAGlobalFunc_t)(const TClass *, const void *obj)
void(* ClassStreamerFunc_t)(TBuffer &, void *)
void(* ClassConvStreamerFunc_t)(TBuffer &, void *, const TClass *)
R__EXTERN TClassTable * gClassTable
TVirtualMutex * gInterpreterMutex
static TVirtualMutex * gOVRMutex
static void UnregisterAddressInRepository(const char *, void *location, const TClass *what)
static void RegisterAddressInRepository(const char *, void *location, const TClass *what)
TClass::ENewType & TClass__GetCallingNew()
std::multimap< void *, ObjRepoValue > RepoCont_t
static RepoCont_t gObjectVersionRepository
static void MoveAddressInRepository(const char *, void *oldadd, void *newadd, const TClass *what)
ROOT::TMapDeclIdToTClass DeclIdMap_t
ROOT::TMapTypeToTClass IdMap_t
void(* tcling_callfunc_Wrapper_t)(void *, int, void **, void *)
const Bool_t kIterBackward
R__EXTERN TInterpreter * gCling
R__EXTERN TVirtualMutex * gROOTMutex
void Printf(const char *fmt,...)
typedef void((*Func_t)())
R__EXTERN TSystem * gSystem
R__EXTERN void **(* gThreadTsd)(void *, Int_t)
#define R__LOCKGUARD2(mutex)
#define R__LOCKGUARD(mutex)
#define R__WRITE_LOCKGUARD(mutex)
#define R__READ_LOCKGUARD(mutex)
Bool_t AddRule(TSchemaRule *rule, EConsistencyCheck checkConsistency=kCheckAll, TString *errmsg=0)
The consistency check always fails if the TClass object was not set! if checkConsistency is: kNoCheck...
void SetClass(TClass *cls)
Set the TClass associated with this rule set.
static bool Check(TClass &classRef)
A spin mutex-as-code-guard class.
Bool_t SetFromRule(const char *rule)
Set the content fot this object from the rule See TClass::AddRule for details on the syntax.
const char * GetTargetString() const
Get the target data members of this rule as a simple string (i.e. the in memory data member).
const char * GetVersion() const
Get the version string.
const char * GetTargetClass() const
Get the targte class of this rule (i.e. the in memory class).
Each class (see TClass) has a linked list of its base class(es).
Int_t GetDelta()
Get offset from "this" to part of base class.
ROOT::ESTLType IsSTLContainer()
Return which type (if any) of STL container the data member is.
TClass * GetClassPointer(Bool_t load=kTRUE)
Get pointer to the base class TClass.
Long_t Property() const
Get property description word. For meaning of bits see EProperty.
Using a TBrowser one can browse all ROOT objects.
Buffer base class used for serializing objects.
Objects following this interface can be passed onto the TROOT object to implement a user customized w...
virtual TClass * GetClass(const char *classname, Bool_t load)=0
TClassRef is used to implement a permanent reference to a TClass object.
virtual void Stream(TBuffer &b, void *objp, const TClass *onfileClass)
virtual TClassStreamer * Generate() const
ClassStreamerFunc_t fStreamer
static DictFuncPtr_t GetDict(const char *cname)
Given the class name returns the Dictionary() function of a class (uses hash of name).
static TProtoClass * GetProtoNorm(const char *cname)
Given the class normalized name returns the TClassProto object for the class.
static DictFuncPtr_t GetDictNorm(const char *cname)
Given the normalized class name returns the Dictionary() function of a class (uses hash of name).
~InsertTClassInRegistryRAII()
InsertTClassInRegistryRAII(TClass::EState &state, const char *name, TDeclNameRegistry &emuRegistry)
Bool_t HasDeclName(const char *name) const
void AddQualifiedName(const char *name)
Extract this part of the name.
TDeclNameRegistry(Int_t verbLevel=0)
TDeclNameRegistry class constructor.
std::atomic_flag fSpinLock
TNameMapNode(const char *typedf, const char *orig)
TClass instances represent classes, structs and namespaces in the ROOT type system.
UInt_t GetCheckSum(ECheckSum code=kCurrentCheckSum) const
Call GetCheckSum with validity check.
ShowMembersFunc_t fShowMembers
TDataMember * GetDataMember(const char *datamember) const
Return pointer to datamember object with name "datamember".
void ForceReload(TClass *oldcl)
we found at least one equivalent.
TVirtualStreamerInfo * GetStreamerInfo(Int_t version=0) const
returns a pointer to the TVirtualStreamerInfo object for version If the object does not exist,...
ROOT::DelArrFunc_t fDeleteArray
Bool_t CanSplit() const
Return true if the data member of this TClass can be saved separately.
TClassStreamer * fStreamer
void SetDirectoryAutoAdd(ROOT::DirAutoAdd_t dirAutoAddFunc)
Install a new wrapper around the directory auto add function.
Bool_t IsFolder() const
Returns kTRUE in case object contains browsable objects (like containers or lists of other objects).
void * NewArray(Long_t nElements, ENewType defConstructor=kClassNew) const
Return a pointer to a newly allocated array of objects of this class.
static TDeclNameRegistry fNoInfoOrEmuOrFwdDeclNameRegistry
TListOfFunctionTemplates * fFuncTemplate
ClassStreamerFunc_t fStreamerFunc
void AdoptReferenceProxy(TVirtualRefProxy *proxy)
Adopt the Reference proxy pointer to indicate that this class represents a reference.
TVirtualStreamerInfo * DetermineCurrentStreamerInfo()
Determine and set pointer to current TVirtualStreamerInfo.
ROOT::ESTLType GetCollectionType() const
Return the 'type' of the STL the TClass is representing.
void AdoptMemberStreamer(const char *name, TMemberStreamer *strm)
Adopt the TMemberStreamer pointer to by p and use it to Stream non basic member name.
void ResetInstanceCount()
ClassStreamerFunc_t GetStreamerFunc() const
Get a wrapper/accessor function around this class custom streamer (member function).
void RemoveStreamerInfo(Int_t slot)
Remove and delete the StreamerInfo in the given slot.
void SetCanSplit(Int_t splitmode)
Set the splitability of this class:
TObject * Clone(const char *newname="") const
Create a Clone of this TClass object using a different name but using the same 'dictionary'.
TVirtualStreamerInfo * GetStreamerInfoAbstractEmulated(Int_t version=0) const
For the case where the requestor class is emulated and this class is abstract, returns a pointer to t...
void * New(ENewType defConstructor=kClassNew, Bool_t quiet=kFALSE) const
Return a pointer to a newly allocated object of this class.
void SetMerge(ROOT::MergeFunc_t mergeFunc)
Install a new wrapper around 'Merge'.
ConvSIMap_t fConversionStreamerInfo
ROOT::DirAutoAdd_t fDirAutoAdd
Bool_t HasDataMemberInfo() const
TVirtualRefProxy * fRefProxy
cached streamer info used in the last read.
TList * GetMenuList() const
Return the list of menu items associated with the class.
ROOT::MergeFunc_t fMerge
saved info to call a IsA member function
TMethod * GetMethod(const char *method, const char *params, Bool_t objectIsConst=kFALSE)
Find the best method (if there is one) matching the parameters.
virtual void Browse(TBrowser *b)
This method is called by a browser to get the class information.
static TClass * Load(TBuffer &b)
Load class description from I/O buffer and return class object.
EState fState
cached of the streaming method to use
ROOT::DesFunc_t GetDestructor() const
TMethod * GetMethodWithPrototype(const char *method, const char *proto, Bool_t objectIsConst=kFALSE, ROOT::EFunctionMatchMode mode=ROOT::kConversionMatch)
Find the method with a given prototype.
void CopyCollectionProxy(const TVirtualCollectionProxy &)
Copy the argument.
Int_t fStreamerType
saved info to call Streamer
void BuildRealData(void *pointer=0, Bool_t isTransient=kFALSE)
Build a full list of persistent data members.
std::atomic< TList * > fBase
Bool_t HasDictionary() const
Check whether a class has a dictionary or not.
Long_t GetDataMemberOffset(const char *membername) const
return offset for member name.
const TList * GetListOfAllPublicMethods(Bool_t load=kTRUE)
Returns a list of all public methods of this class and its base classes.
TMethod * GetClassMethod(Long_t faddr)
Look for a method in this class that has the interface function address faddr.
TList * GetListOfAllPublicDataMembers(Bool_t load=kTRUE)
Returns a list of all public data members of this class and its base classes.
void BuildEmulatedRealData(const char *name, Long_t offset, TClass *cl)
Build the list of real data for an emulated class.
static void AddClassToDeclIdMap(TDictionary::DeclId_t id, TClass *cl)
static: Add a TClass* to the map of classes.
virtual ~TClass()
TClass dtor. Deletes all list that might have been created.
void Destructor(void *obj, Bool_t dtorOnly=kFALSE)
Explicitly call destructor for object.
std::atomic< TVirtualStreamerInfo * > fCurrentInfo
Current 'state' of the class (Emulated,Interpreted,Loaded)
TList * GetListOfFunctionTemplates(Bool_t load=kTRUE)
Return list containing the TEnums of a class.
void * DynamicCast(const TClass *base, void *obj, Bool_t up=kTRUE)
Cast obj of this class type up to baseclass cl if up is true.
const char * fImplFileName
void RegisterStreamerInfo(TVirtualStreamerInfo *info)
Register the StreamerInfo in the given slot, change the State of the TClass as appropriate.
std::atomic< UInt_t > fCheckSum
std::atomic< TListOfFunctions * > fMethod
static void RemoveClassDeclId(TDictionary::DeclId_t id)
void SetNewArray(ROOT::NewArrFunc_t newArrayFunc)
Install a new wrapper around 'new []'.
Bool_t CallShowMembers(const void *obj, TMemberInspector &insp, Bool_t isTransient=kFALSE) const
Call ShowMembers() on the obj of this class type, passing insp and parent.
const char * fDeclFileName
void SetCollectionProxy(const ROOT::Detail::TCollectionProxyInfo &)
Create the collection proxy object (and the streamer object) from using the information in the TColle...
static Bool_t HasDictionarySelection(const char *clname)
Check whether a class has a dictionary or ROOT can load one.
void AdoptSchemaRules(ROOT::Detail::TSchemaRuleSet *rules)
Adopt a new set of Data Model Evolution rules.
static void StreamerInstrumented(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of instrumented class with a library.
TVirtualStreamerInfo * SetStreamerInfo(Int_t version, const char *info="")
Info is a string describing the names and types of attributes written by the class Streamer function.
static std::atomic< Int_t > fgClassCount
TVirtualStreamerInfo * GetCurrentStreamerInfo()
ROOT::DirAutoAdd_t GetDirectoryAutoAdd() const
void AddImplFile(const char *filename, int line)
TCollection * GetListOfMethodOverloads(const char *name) const
Return the collection of functions named "name".
std::atomic< TListOfEnums * > fEnums
static Bool_t HasNoInfoOrEmuOrFwdDeclaredDecl(const char *)
TList * GetListOfEnums(Bool_t load=kTRUE)
Return a list containing the TEnums of a class.
Bool_t IsStartingWithTObject() const
Returns true if this class inherits from TObject and if the start of the TObject parts is at the very...
TList * GetListOfMethods(Bool_t load=kTRUE)
Return list containing the TMethods of a class.
Int_t GetNmethods()
Return the number of methods of this class Note that in case the list of methods is not yet created,...
std::atomic< Bool_t > fIsOffsetStreamerSet
Indicates whether the ClassInfo is supposed to be available.
void IgnoreTObjectStreamer(Bool_t ignore=kTRUE)
When the class kIgnoreTObjectStreamer bit is set, the automatically generated Streamer will not call ...
TClassStreamer * GetStreamer() const
Return the Streamer Class allowing streaming (if any).
static IdMap_t * GetIdMap()
void SetDelete(ROOT::DelFunc_t deleteFunc)
Install a new wrapper around 'delete'.
static Int_t AutoBrowse(TObject *obj, TBrowser *browser)
Browse external object inherited from TObject.
ROOT::NewFunc_t GetNew() const
TClass * GetBaseClass(const char *classname)
Return pointer to the base class "classname".
Int_t GetNdata()
Return the number of data members of this class Note that in case the list of data members is not yet...
void SetDestructor(ROOT::DesFunc_t destructorFunc)
Install a new wrapper around the destructor.
Bool_t HasDefaultConstructor() const
virtual void PostLoadCheck()
Do the initialization that can only be done after the CINT dictionary has been fully populated and ca...
void LoadClassInfo() const
Try to load the ClassInfo if available.
void SetResetAfterMerge(ROOT::ResetAfterMergeFunc_t resetFunc)
Install a new wrapper around 'ResetAfterMerge'.
Bool_t MatchLegacyCheckSum(UInt_t checksum) const
Return true if the checksum passed as argument is one of the checksum value produced by the older che...
TViewPubFunctions * fAllPubMethod
Bool_t HasInterpreterInfo() const
static void AddClass(TClass *cl)
static: Add a class to the list and map of classes.
void GetMissingDictionariesForBaseClasses(TCollection &result, TCollection &visited, bool recurse)
Verify the base classes always.
ROOT::Detail::TSchemaRuleSet * fSchemaRules
Pointer to reference proxy if this class represents a reference.
std::atomic< Long_t > fProperty
Indicates whether this class can be split or not.
static void StreamerDefault(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Default streaming in cases where either we have no way to know what to do or if Property() has not ye...
void SetUnloaded()
Call this method to indicate that the shared library containing this class's code has been removed (u...
ROOT::DelArrFunc_t GetDeleteArray() const
Bool_t HasInterpreterInfoInMemory() const
ClassConvStreamerFunc_t fConvStreamerFunc
void SetRuntimeProperties()
Internal routine to set calculate the class properties that can only be known at run-time,...
static TClass * LoadClass(const char *requestedname, Bool_t silent)
Helper function used by TClass::GetClass().
const std::type_info * GetTypeInfo() const
TList * GetListOfDataMembers(Bool_t load=kTRUE)
Return list containing the TDataMembers of a class.
void Move(void *arenaFrom, void *arenaTo) const
Register the fact that an object was moved from the memory location 'arenaFrom' to the memory locatio...
static DeclIdMap_t * GetDeclIdMap()
Short_t GetDeclFileLine() const
void SetStreamerFunc(ClassStreamerFunc_t strm)
Set a wrapper/accessor function around this class custom streamer.
const char * GetImplFileName() const
TList * GetListOfRealData() const
Int_t Size() const
Return size of object of this class.
void SetCurrentStreamerInfo(TVirtualStreamerInfo *info)
Set pointer to current TVirtualStreamerInfo.
static DictFuncPtr_t GetDict(const char *cname)
Return a pointer to the dictionary loading function generated by rootcint.
ROOT::NewArrFunc_t GetNewArray() const
static void StreamerTObjectEmulated(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of TObjects when we do not have the library defining the class.
ROOT::ResetAfterMergeFunc_t GetResetAfterMerge() const
TMethod * GetClassMethodWithPrototype(const char *name, const char *proto, Bool_t objectIsConst=kFALSE, ROOT::EFunctionMatchMode mode=ROOT::kConversionMatch)
Find the method with a given prototype.
Bool_t CanIgnoreTObjectStreamer()
void SetGlobalIsA(IsAGlobalFunc_t)
This function installs a global IsA function for this class.
void GetMissingDictionariesForMembers(TCollection &result, TCollection &visited, bool recurse)
Verify the Data Members.
TObjArray * fStreamerInfo
const ROOT::Detail::TSchemaRuleSet * GetSchemaRules() const
Return the set of the schema rules if any.
TVirtualCollectionProxy * fCollectionProxy
static ENewType IsCallingNew()
Static method returning the defConstructor flag passed to TClass::New().
void ls(Option_t *opt="") const
The ls function lists the contents of a class on stdout.
TList * GetListOfBases()
Return list containing the TBaseClass(es) of a class.
void Store(TBuffer &b) const
Store class description on I/O buffer.
void InterpretedShowMembers(void *obj, TMemberInspector &insp, Bool_t isTransient)
Do a ShowMembers() traversal of all members and base classes' members using the reflection informatio...
static THashTable * fgClassTypedefHash
void Init(const char *name, Version_t cversion, const std::type_info *info, TVirtualIsAProxy *isa, const char *dfil, const char *ifil, Int_t dl, Int_t il, ClassInfo_t *classInfo, Bool_t silent)
Initialize a TClass object.
static void StreamerStreamerInfo(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of where we should directly use the StreamerInfo.
const TObjArray * GetStreamerInfos() const
void SetClassVersion(Version_t version)
Private function.
char * EscapeChars(const char *text) const
Introduce an escape character (@) in front of a special chars.
const std::type_info * fTypeInfo
std::atomic< TVirtualStreamerInfo * > fLastReadInfo
cached current streamer info.
static void StreamerTObject(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of TObjects.
Bool_t IsLoaded() const
Return true if the shared library of this class is currently in the a process's memory.
static Bool_t AddRule(const char *rule)
Add a schema evolution customization rule.
Bool_t IsTObject() const
Return kTRUE is the class inherits from TObject.
static void RemoveClass(TClass *cl)
static: Remove a class from the list and map of classes
Bool_t HasLocalHashMember() const
void DeleteArray(void *ary, Bool_t dtorOnly=kFALSE)
Explicitly call operator delete[] for an array.
ClassConvStreamerFunc_t GetConvStreamerFunc() const
Get a wrapper/accessor function around this class custom conversion streamer (member function).
Bool_t IsForeign() const
Return kTRUE is the class is Foreign (the class does not have a Streamer method).
ClassInfo_t * GetClassInfo() const
TViewPubDataMembers * fAllPubData
Int_t GetBaseClassOffset(const TClass *toBase, void *address=0, bool isDerivedObject=true)
void Dump() const
Dump contents of object on stdout.
Bool_t HasConsistentHashMember()
Return 'true' if we can guarantee that if this class (or any class in this class inheritance hierarch...
void AdoptStreamer(TClassStreamer *strm)
Adopt a TClassStreamer object.
TClass * GetBaseDataMember(const char *datamember)
Return pointer to (base) class that contains datamember.
Long_t Property() const
Set TObject::fBits and fStreamerType to cache information about the class.
Long_t fOffsetStreamer
Properties that can only be evaluated at run-time.
TVirtualCollectionProxy * GetCollectionProxy() const
Return the proxy describing the collection (if any).
void ResetCaches()
To clean out all caches.
std::atomic< Bool_t > fVersionUsed
saved remember if fOffsetStreamer has been set.
Long_t ClassProperty() const
Return the C++ property of this class, eg.
void SetStreamerImpl()
Internal routine to set fStreamerImpl based on the value of fStreamerType.
const char * GetSharedLibs()
Get the list of shared libraries containing the code for class cls.
void CalculateStreamerOffset() const
Calculate the offset between an object of this class to its base class TObject.
void GetMissingDictionariesForPairElements(TCollection &result, TCollection &visited, bool recurse)
void ReplaceWith(TClass *newcl) const
void GetMenuItems(TList *listitems)
Returns list of methods accessible by context menu.
void SetNew(ROOT::NewFunc_t newFunc)
Install a new wrapper around 'new'.
void Draw(Option_t *option="")
Draw detailed class inheritance structure.
std::atomic< TMethodCall * > fIsAMethod
static Int_t ReadRules()
Read the class.rules files from the default location:.
Bool_t CanSplitBaseAllow()
Pointer to the function implementing streaming for this class.
std::atomic< StreamerImpl_t > fStreamerImpl
void SetContextMenuTitle(const char *title)
Change (i.e. set) the title of the TNamed.
void SetMemberStreamer(const char *name, MemberStreamerFunc_t strm)
Install a new member streamer (p will be copied).
std::atomic< TClass ** > fPersistentRef
IsAGlobalFunc_t fGlobalIsA
pointer to the class's IsA proxy.
TVirtualStreamerInfo * GetConversionStreamerInfo(const char *onfile_classname, Int_t version) const
Return a Conversion StreamerInfo from the class 'classname' for version number 'version' to this clas...
Short_t GetImplFileLine() const
TMethod * GetMethodAllAny(const char *method)
Return pointer to method without looking at parameters.
std::atomic< UChar_t > fRuntimeProperties
TVirtualStreamerInfo * FindConversionStreamerInfo(const char *onfile_classname, UInt_t checksum) const
Return a Conversion StreamerInfo from the class 'classname' for the layout represented by 'checksum' ...
Int_t GetBaseClassOffsetRecurse(const TClass *toBase)
Return data member offset to the base class "cl".
ROOT::DelFunc_t GetDelete() const
static TClass * LoadClassDefault(const char *requestedname, Bool_t silent)
Helper function used by TClass::GetClass().
void SetClassSize(Int_t sizof)
TMethod * FindClassOrBaseMethodWithId(DeclId_t faddr)
Find a method with decl id in this class or its bases.
static void StreamerExternal(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
There is special streamer for the class.
Long_t fClassProperty
Property.
TString fContextMenuTitle
static void StreamerTObjectInitialized(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of TObjects when fIsOffsetStreamerSet is known to have been set.
static void ConvStreamerInstrumented(const TClass *pThis, void *object, TBuffer &b, const TClass *onfile_class)
Case of instrumented class with a library.
TListOfDataMembers * fData
std::atomic< Bool_t > fCanLoadClassInfo
Whether info was loaded from a root pcm.
void SetConvStreamerFunc(ClassConvStreamerFunc_t strm)
Set a wrapper/accessor function around this class custom conversion streamer.
TVirtualStreamerInfo * FindStreamerInfo(TObjArray *arr, UInt_t checksum) const
Find the TVirtualStreamerInfo in the StreamerInfos corresponding to checksum.
void GetMissingDictionaries(THashTable &result, bool recurse=false)
Get the classes that have a missing dictionary starting from this one.
void MakeCustomMenuList()
Makes a customizable version of the popup menu list, i.e.
TVirtualStreamerInfo * FindStreamerInfoAbstractEmulated(UInt_t checksum) const
For the case where the requestor class is emulated and this class is abstract, returns a pointer to t...
TMethod * GetMethodAny(const char *method)
Return pointer to method without looking at parameters.
TVirtualIsAProxy * GetIsAProxy() const
Return the proxy implementing the IsA functionality.
Version_t GetClassVersion() const
ROOT::MergeFunc_t GetMerge() const
ROOT::ResetAfterMergeFunc_t fResetAfterMerge
std::atomic< Bool_t > fHasRootPcmInfo
C++ Property of the class (is abstract, has virtual table, etc.)
Bool_t InheritsFrom(const char *cl) const
Return kTRUE if this class inherits from a class with name "classname".
TClass * GetActualClass(const void *object) const
Return a pointer the the real class of the object.
ROOT::DesFunc_t fDestructor
const char * GetDeclFileName() const
Return name of the file containing the declaration of this class.
TRealData * GetRealData(const char *name) const
Return pointer to TRealData element with name "name".
void SetDeleteArray(ROOT::DelArrFunc_t deleteArrayFunc)
Install a new wrapper around 'delete []'.
TFunctionTemplate * GetFunctionTemplate(const char *name)
void ResetClassInfo()
Make sure that the current ClassInfo is up to date.
ROOT::NewArrFunc_t fNewArray
Int_t ReadBuffer(TBuffer &b, void *pointer, Int_t version, UInt_t start, UInt_t count)
Function called by the Streamer functions to deserialize information from buffer b into object at p.
void GetMissingDictionariesWithRecursionCheck(TCollection &result, TCollection &visited, bool recurse)
From the second level of recursion onwards it is different state check.
@ kHasCustomStreamerMember
TListOfFunctions * GetMethodList()
Return (create an empty one if needed) the list of functions.
void ResetMenuList()
Resets the menu list to it's standard value.
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
Int_t WriteBuffer(TBuffer &b, void *pointer, const char *info="")
Function called by the Streamer functions to serialize object at p to buffer b.
static TClass * LoadClassCustom(const char *requestedname, Bool_t silent)
Helper function used by TClass::GetClass().
Collection abstract base class.
virtual void ls(Option_t *option="") const
List (ls) all objects in this collection.
virtual TObject * FindObject(const char *name) const
Find an object in this collection using its name.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual void Add(TObject *obj)=0
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
All ROOT classes may have RTTI (run time type identification) support added.
Int_t GetMaxIndex(Int_t dim) const
Return maximum index for array dimension "dim".
const char * GetTrueTypeName() const
Get full type description of data member, e,g.: "class TDirectory*".
Bool_t IsPersistent() const
Int_t GetArrayDim() const
Return number of array dimensions.
Bool_t IsBasic() const
Return true if data member is a basic type, e.g. char, int, long...
Bool_t IsaPointer() const
Return true if data member is a pointer.
TDataType * GetDataType() const
const char * GetTypeName() const
Get type of data member, e,g.: "class TDirectory*" -> "TDirectory".
const char * GetFullTypeName() const
Get full type description of data member, e,g.: "class TDirectory*".
Long_t Property() const
Get property description word. For meaning of bits see EProperty.
Basic data type descriptor (datatype information is obtained from CINT).
Long_t Property() const
Get property description word. For meaning of bits see EProperty.
const char * AsString(void *buf) const
Return string containing value in buffer formatted according to the basic data type.
TString GetTypeName()
Get basic type of typedef, e,g.
static TDataType * GetDataType(EDataType type)
Given a EDataType type, get the TDataType* that represents it.
static void GetDateTime(UInt_t datetime, Int_t &date, Int_t &time)
Static function that returns the date and time.
This class defines an abstract interface that must be implemented by all classes that contain diction...
This class stores a (key,value) pair using an external hash.
Long64_t GetValue(ULong64_t hash, Long64_t key)
Return the value belonging to specified key and hash value.
void AddAt(UInt_t slot, ULong64_t hash, Long64_t key, Long64_t value)
Add an (key,value) pair to the table.
Dictionary for function template This class describes one single function template.
Global functions class (global functions are obtained from CINT).
Int_t GetNargs() const
Number of function arguments.
THashTable implements a hash table to store TObject's.
TObject * Remove(TObject *obj)
Remove object from the hashtable.
const TList * GetListForObject(const char *name) const
Return the TList corresponding to object's name based hash value.
void Add(TObject *obj)
Add object to the hash table.
TObject * FindObject(const char *name) const
Find object using its name.
virtual Bool_t ClassInfo_HasMethod(ClassInfo_t *, const char *) const
virtual const char * DataMemberInfo_Name(DataMemberInfo_t *) const
virtual const char * DataMemberInfo_TypeName(DataMemberInfo_t *) const
virtual int DataMemberInfo_TypeSize(DataMemberInfo_t *) const
virtual Long_t ClassInfo_GetBaseOffset(ClassInfo_t *, ClassInfo_t *, void *=0, bool=true) const
virtual void * ClassInfo_New(ClassInfo_t *) const
virtual Bool_t ClassInfo_IsValid(ClassInfo_t *) const
virtual Int_t AutoParse(const char *cls)=0
virtual int SetClassAutoloading(int) const
virtual void ClassInfo_Delete(ClassInfo_t *) const
virtual void ClassInfo_DeleteArray(ClassInfo_t *, void *, bool) const
virtual Long_t ClassInfo_Property(ClassInfo_t *) const
virtual Bool_t ClassInfo_HasDefaultConstructor(ClassInfo_t *) const
virtual DataMemberInfo_t * DataMemberInfo_Factory(ClassInfo_t *=0) const
virtual int ClassInfo_Size(ClassInfo_t *) const
virtual const char * ClassInfo_FullName(ClassInfo_t *) const
virtual const char * ClassInfo_Title(ClassInfo_t *) const
virtual Long_t DataMemberInfo_TypeProperty(DataMemberInfo_t *) const
virtual int DataMemberInfo_Next(DataMemberInfo_t *) const
virtual Long_t DataMemberInfo_Property(DataMemberInfo_t *) const
virtual int DataMemberInfo_ArrayDim(DataMemberInfo_t *) const
virtual void DataMemberInfo_Delete(DataMemberInfo_t *) const
virtual int DataMemberInfo_MaxIndex(DataMemberInfo_t *, Int_t) const
TDictionary::DeclId_t DeclId_t
virtual Long_t ClassInfo_ClassProperty(ClassInfo_t *) const
virtual void ClassInfo_Destruct(ClassInfo_t *, void *) const
TIsAProxy implementation class.
A collection of TDataMember objects designed for fast access given a DeclId_t and for keep track of T...
virtual void Delete(Option_t *option="")
Delete all TDataMember object files.
void Unload()
Mark 'all func' as being unloaded.
void Load()
Load all the DataMembers known to the interpreter for the scope 'fClass' into this collection.
A collection of TEnum objects designed for fast access given a DeclId_t and for keep track of TEnum t...
A collection of TEnum objects designed for fast access given a DeclId_t and for keep track of TEnum t...
A collection of TFunction objects designed for fast access given a DeclId_t and for keep track of TFu...
virtual TObject * FindObject(const char *name) const
Specialize FindObject to do search for the a function just by name or create it if its not already in...
void Load()
Load all the functions known to the interpreter for the scope 'fClass' into this collection.
virtual void Delete(Option_t *option="")
Delete all TFunction object files.
A collection of TFunction objects designed for fast access given a DeclId_t and for keep track of TFu...
TFunction * Get(DeclId_t id)
Return (after creating it if necessary) the TMethod or TFunction describing the function correspondin...
virtual TObject * FindObject(const TObject *obj) const
Find object using its hash value (returned by its Hash() member).
virtual TList * GetListForObject(const char *name) const
Return the set of overloads for this name, collecting all available ones.
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
virtual TObject * FindObject(const char *name) const
Find an object in this list using its name.
virtual TObjLink * FirstLink() const
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
virtual void AddLast(TObject *obj)
Add object at the end of the list.
TMap implements an associative array of (key,value) pairs using a THashTable for efficient retrieval ...
Abstract base class for accessing the data-members of a class.
virtual void Inspect(TClass *cl, const char *parent, const char *name, const void *addr)
Each ROOT method (see TMethod) has a linked list of its arguments.
const char * GetFullTypeName() const
Get full type description of method argument, e.g.: "class TDirectory*".
Each ROOT class (see TClass) has a linked list of methods.
TClass * GetClass() const
EMenuItemKind IsMenuItem() const
virtual TList * GetListOfMethodArgs()
Returns methodarg list and additionally updates fDataMember in TMethod by calling FindDataMember();.
virtual void ls(Option_t *option="") const
List TNamed name and title.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual const char * GetTitle() const
Returns title of object.
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
virtual const char * GetName() const
Returns name of object.
Int_t GetEntriesFast() const
virtual void AddAtAndExpand(TObject *obj, Int_t idx)
Add object at position idx.
Int_t GetEntries() const
Return the number of objects in array (i.e.
virtual void Clear(Option_t *option="")
Remove all objects from the array.
TObject * UncheckedAt(Int_t i) const
virtual void Delete(Option_t *option="")
Remove all objects from the array AND delete all heap based objects.
virtual TObject * FindObject(const char *name) const
Find an object in this collection using its name.
Int_t GetLast() const
Return index of last object in array.
virtual TObject * RemoveAt(Int_t idx)
Remove object at index idx.
TObject * At(Int_t idx) const
Wrapper around a TObject so it can be stored in a TList.
TObject * GetObject() const
Collectable string class.
Mother of all ROOT objects.
virtual void Inspect() const
Dump contents of this object in a graphics canvas.
static void SetObjectStat(Bool_t stat)
Turn on/off tracking of objects in the TObjectTable.
virtual const char * GetName() const
Returns name of object.
virtual void Browse(TBrowser *b)
Browse object. May be overridden for another default action.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual TObject * FindObject(const char *name) const
Must be redefined in derived classes.
R__ALWAYS_INLINE Bool_t IsZombie() const
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
static Bool_t GetObjectStat()
Get status of object stat flag.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
virtual void SetUniqueID(UInt_t uid)
Set the unique object id.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
Class used by TMap to store (key,value) pairs.
Persistent version of a TClass.
static const TString & GetEtcDir()
Get the sysconfig directory in the installation. Static utility function.
The TRealData class manages the effective list of all data members for a given class.
void AdoptStreamer(TMemberStreamer *p)
virtual const char * GetName() const
Returns name of object.
Long_t GetThisOffset() const
void SetIsObject(Bool_t isObject)
virtual TClass * GetClassPointer() const
Returns a pointer to the TClass of this element.
virtual const char * GetFullName() const
Return element name including dimensions, if any Note that this function stores the name into a stati...
virtual TClass * GetClassPointer() const
Returns a pointer to the TClass of this element.
virtual Bool_t IsaPointer() const
const char * GetTypeName() const
virtual Bool_t IsBase() const
Return kTRUE if the element represent a base class.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
Ssiz_t First(char c) const
Find first occurrence of a character c.
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
UInt_t Hash(ECaseCompare cmp=kExact) const
Return hash value.
TString & Remove(Ssiz_t pos)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual const char * PrependPathName(const char *dir, TString &name)
Concatenate a directory and a file name.
View implementing the TList interface and giving access all the TDictionary describing public data me...
void Load()
Load all the DataMembers known to the interpreter for the scope 'fClass' and all its bases classes.
void Delete(Option_t *option="")
Delete is not allowed in this class.
View implementing the TList interface and giving access all the TFunction describing public methods i...
void Load()
Load all the functions known to the interpreter for the scope 'fClass' and all its bases classes.
virtual Int_t GetProperties() const
virtual UInt_t Sizeof() const =0
virtual void Destructor(void *p, Bool_t dtorOnly=kFALSE) const
virtual void * New() const
virtual void DeleteArray(void *p, Bool_t dtorOnly=kFALSE) const
virtual TClass * GetValueClass() const =0
virtual void * At(UInt_t idx)=0
virtual Int_t GetCollectionType() const =0
virtual UInt_t Size() const =0
virtual void * NewArray(Int_t nElements) const
virtual TVirtualCollectionProxy * Generate() const =0
virtual Bool_t HasPointers() const =0
virtual void SetClass(TClass *cl)=0
This class implements a mutex interface.
TVirtualPad is an abstract base class for the Pad and Canvas classes.
virtual TVirtualPad * cd(Int_t subpadnumber=0)=0
virtual void SetClass(TClass *classptr)=0
virtual TVirtualRefProxy * Clone() const =0
Abstract Interface class describing Streamer information for one class.
virtual void DeleteArray(void *p, Bool_t dtorOnly=kFALSE)=0
virtual TClassStreamer * GenEmulatedClassStreamer(const char *class_name, Bool_t silent)=0
Bool_t IsCompiled() const
virtual void BuildCheck(TFile *file=0)=0
virtual TVirtualStreamerInfo * NewInfo(TClass *cl)=0
virtual TClass * GetActualClass(const void *obj) const =0
virtual UInt_t GetCheckSum() const =0
virtual Int_t GetOffset(const char *) const =0
static const char * GetElementCounterStart(const char *dmTitle)
Given a comment/title declaring an array counter, for example:
virtual Bool_t BuildFor(const TClass *cl)=0
virtual TVirtualCollectionProxy * GenExplicitProxy(const ::ROOT::Detail::TCollectionProxyInfo &info, TClass *cl)=0
virtual void Clear(Option_t *)=0
Set name and title to empty strings ("").
virtual TVirtualCollectionProxy * GenEmulatedProxy(const char *class_name, Bool_t silent)=0
virtual void SetClass(TClass *cl)=0
virtual void * NewArray(Long_t nElements, void *ary=0)=0
virtual TObjArray * GetElements() const =0
virtual Int_t GetSize() const =0
virtual void BuildOld()=0
static TVirtualStreamerInfo * Factory()
Static function returning a pointer to a new TVirtualStreamerInfo object.
virtual Version_t GetOldVersion() const =0
virtual void * New(void *obj=0)=0
virtual Int_t GetOnFileClassVersion() const =0
virtual void Destructor(void *p, Bool_t dtorOnly=kFALSE)=0
virtual Bool_t CompareContent(TClass *cl, TVirtualStreamerInfo *info, Bool_t warn, Bool_t complete, TFile *file)=0
virtual Int_t GetClassVersion() const =0
virtual void Update(const TClass *oldClass, TClass *newClass)=0
virtual TClass * GetClass() const =0
void Add(RHist< DIMENSIONS, PRECISION_TO, STAT_TO... > &to, const RHist< DIMENSIONS, PRECISION_FROM, STAT_FROM... > &from)
Add two histograms.
R__EXTERN void * gMmallocDesc
Bool_t HasConsistentHashMember(TClass &clRef)
Return true is the Hash/RecursiveRemove setup is consistent, i.e.
Namespace for new ROOT classes and functions.
void(* DirAutoAdd_t)(void *, TDirectory *)
R__EXTERN TVirtualRWMutex * gCoreMutex
void(* ResetAfterMergeFunc_t)(void *, TFileMergeInfo *)
void(* DesFunc_t)(void *)
TClass * CreateClass(const char *cname, Version_t id, const std::type_info &info, TVirtualIsAProxy *isa, const char *dfil, const char *ifil, Int_t dl, Int_t il)
Global function called by a class' static Dictionary() method (see the ClassDef macro).
void(* DelFunc_t)(void *)
void *(* NewArrFunc_t)(Long_t size, void *arena)
void Class_ShowMembers(TClass *cl, const void *obj, TMemberInspector &)
Indirect call to the implementation of ShowMember allowing [forward] declaration with out a full defi...
void(* DelArrFunc_t)(void *)
void *(* NewFunc_t)(void *)
Long64_t(* MergeFunc_t)(void *, TCollection *, TFileMergeInfo *)
std::string ResolveTypedef(const char *tname, bool resolveAll=false)
bool IsStdArray(std::string_view name)
bool IsStdClass(const char *type)
return true if the class belongs to the std namespace
bool IsInterpreterDetail(const char *type)
Return true if the type is one the interpreter details which are only forward declared (ClassInfo_t e...
ROOT::ESTLType IsSTLCont(std::string_view type)
type : type name: vector<list<classA,allocator>,allocator> result: 0 : not stl container code of cont...
std::string ShortType(const char *typeDesc, int mode)
Return the absolute type of typeDesc.
void GetNormalizedName(std::string &norm_name, std::string_view name)
Return the normalized name.
bool IsSTLBitset(const char *type)
Return true is the name is std::bitset<number> or bitset<number>
static constexpr double s
UInt_t Find(std::list< std::pair< const Node< T > *, Float_t > > &nlist, const Node< T > *node, const T &event, UInt_t nfind)
Short_t Min(Short_t a, Short_t b)
bool IsTemplate()
Check if the type is a template.
std::vector< std::string > fElements