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");
1388 (*fMethod).fClass =
this;
1400 ::Fatal(
"TClass::Init",
"gInterpreter not initialized");
1403 bool invalid = !
gInterpreter->ClassInfo_IsValid(givenInfo);
1404 bool notloaded = !
gInterpreter->ClassInfo_IsLoaded(givenInfo);
1405 auto property =
gInterpreter->ClassInfo_Property(givenInfo);
1407 if (invalid || (notloaded && (property &
kIsNamespace)) ||
1474 ::Error(
"TClass::Init",
"no interpreter information for class %s is available even though it has a TClass "
1475 "initialization routine.",
1493 if (!givenInfo && strchr (
name,
'<')) {
1505 if (resolvedThis !=
name) {
1529 if (resolvedThis !=
fName) {
1530 oldcl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(resolvedThis);
1531 if (oldcl && oldcl !=
this) {
1538 if (resolvedThis != htmp->String())
continue;
1539 oldcl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(htmp->fOrigName);
1540 if (oldcl && oldcl !=
this) {
1558 if (persistentRef) {
1565 if ( isStl || !strncmp(
GetName(),
"stdext::hash_",13) || !strncmp(
GetName(),
"__gnu_cxx::hash_",16) ) {
1576 }
else if (!silent) {
1577 Warning(
"Init",
"Collection proxy for %s was not properly initialized!",
GetName());
1583 }
else if (!strncmp(
GetName(),
"std::pair<",10) || !strncmp(
GetName(),
"pair<",5) ) {
1603 if (resolvedThis == htmp->String() && htmp->fOrigName ==
GetName()) {
1670 std::map<std::string, TObjArray*>::iterator it;
1671 std::map<std::string, TObjArray*>::iterator end = (*fConversionStreamerInfo).end();
1672 for( it = (*fConversionStreamerInfo).begin(); it != end; ++it ) {
1682 Int_t ReadRulesContent(FILE *
f)
1694 while ((
c = fgetc(
f)) != EOF) {
1700 if (rule.Length() > 0) {
1752 static const char *suffix =
"class.rules";
1758 FILE *
f = fopen(sname,
"r");
1760 res = ReadRulesContent(
f);
1763 ::Error(
"TClass::ReadRules()",
"Cannot find rules file %s", sname.
Data());
1776 if (!filename || !filename[0]) {
1777 ::Error(
"TClass::ReadRules",
"no file name specified");
1781 FILE *
f = fopen(filename,
"r");
1783 ::Error(
"TClass::ReadRules",
"Failed to open %s\n",filename);
1786 Int_t count = ReadRulesContent(
f);
1839 ::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).",
1900 TAutoInspector insp(
b);
1901 obj->ShowMembers(insp);
1922 }
else if (actual !=
this) {
1923 return actual->
Browse(obj,
b);
1929 TAutoInspector insp(
b);
1972 isTransient =
kTRUE;
1977 TMmallocDescTemp setreset;
1988 static TClassRef clRefString(
"std::string");
1989 if (clRefString ==
this) {
1998 && strncmp(
GetName(),
"pair<", 5) != 0) {
1999 Error(
"BuildRealData",
"Inspection for %s not supported!",
GetName());
2005 TBuildRealData brd(pointer,
this);
2011 if ( isTransient ) {
2019 Error(
"BuildRealData",
"Cannot find any ShowMembers function for %s!",
GetName());
2034 c->BuildRealData(0, isTransient);
2054 Error(
"BuildEmulatedRealData",
"Missing StreamerInfo for %s",
GetName());
2120 TMmallocDescTemp setreset;
2147 if (strcmp(
GetName(),
"string") == 0) {
2155 gInterpreter->InspectMembers(insp, obj,
this, isTransient);
2159 sinfo->CallShowMembers(obj, insp, isTransient);
2174 return gInterpreter->InspectMembers(insp, obj,
this, isTransient);
2238 }
else if (!
c->CanSplitBaseAllow()) {
2282 static TClassRef stdStringClass(
"std::string");
2347 if (new_name == 0 || new_name[0]==
'\0' ||
fName == new_name) {
2348 Error(
"Clone",
"The name of the class must be changed when cloning a TClass object.");
2378 copy->
fName = new_name;
2433 if (!padsav || !opt.
Contains(
"same")) {
2436 gROOT->ProcessLine(
"new TCanvas(\"R__class\",\"class\",20,20,1000,750);");
2442 if (
gPad)
gPad->DrawClassObject(
this,option);
2444 if (padsav) padsav->
cd();
2485 if (
sizeof(
this) == 4)
2488 Printf(
"==> Dumping object at: 0x%016lx, name=%s, class=%s\n",prObj,tobj->
GetName(),
GetName());
2491 if (
sizeof(
this) == 4)
2492 Printf(
"==> Dumping object at: 0x%08lx, class=%s\n",prObj,
GetName());
2494 Printf(
"==> Dumping object at: 0x%016lx, class=%s\n",prObj,
GetName());
2497 TDumpMembers dm(noAddr);
2499 Info(
"Dump",
"No ShowMembers function, dumping disabled");
2509 static const UInt_t maxsize = 255;
2510 static char name[maxsize+2];
2514 for (
UInt_t i = 0; i < nch && icur < maxsize; ++i, ++icur) {
2515 if (
text[i] ==
'\"' ||
text[i] ==
'[' ||
text[i] ==
'~' ||
2518 text[i] ==
'?' ||
text[i] ==
'>') {
2548 if (
object==0)
return (
TClass*)
this;
2550 return (*
fIsA)(object);
2561 return realTObject->IsA();
2578 return (*
fIsA)(object);
2596 if (strcmp(
GetName(), classname) == 0)
return this;
2615 if (cl ==
this)
return this;
2627 if (cl ==
c)
return c;
2628 c1 =
c->GetBaseClass(cl);
2646 if (cl ==
this)
return 0;
2648 if (!
fBase.load()) {
2655 if (!sinfo)
return -1;
2661 for(
Int_t i=0; i<size; i++) {
2667 if (!baseclass)
return -1;
2669 if (subOffset == -2)
return -2;
2670 if (subOffset != -1)
return offset+subOffset;
2671 offset += baseclass->
Size();
2675 if (!baseclass)
return -1;
2677 if (subOffset == -2)
return -2;
2678 if (subOffset != -1)
return offset+subOffset;
2679 offset += baseclass->
Size();
2682 Error(
"GetBaseClassOffsetRecurse",
"Unexpected element type for base class: %s\n",element->IsA()->
GetName());
2694 if (
fBase.load() == 0)
2697 lnk =
fBase.load()->FirstLink();
2713 off =
c->GetBaseClassOffsetRecurse(cl);
2714 if (off == -2)
return -2;
2733 if (
this == toBase)
return 0;
2749 if(derived && base) {
2771 if (dm)
return this;
2779 TClass *cdm =
c->GetBaseDataMember(datamember);
2780 if (cdm)
return cdm;
2791 struct TClassLocalStorage {
2792 TClassLocalStorage() : fCollectionProxy(0), fStreamer(0) {};
2797 static TClassLocalStorage *GetStorage(
const TClass *cl)
2803 if (*thread_ptr==0) *thread_ptr =
new TExMap();
2810 local = (
ULong_t)
new TClassLocalStorage();
2813 return (TClassLocalStorage*)local;
2841 TClassLocalStorage *local = TClassLocalStorage::GetStorage(
this);
2844 return local->fCollectionProxy;
2855 TClassLocalStorage *local = TClassLocalStorage::GetStorage(
this);
2857 if (local->fStreamer==0) {
2859 const std::type_info &orig = (
typeid(*fStreamer) );
2860 if (!local->fStreamer) {
2861 Warning(
"GetStreamer",
"For %s, the TClassStreamer (%s) passed's call to Generate failed!",
GetName(),orig.name());
2863 const std::type_info © = (
typeid(*local->fStreamer) );
2864 if (strcmp(orig.name(),copy.name())!=0) {
2865 Warning(
"GetStreamer",
"For %s, the TClassStreamer passed does not properly implement the Generate method (%s vs %s)\n",
GetName(),orig.name(),copy.name());
2869 return local->fStreamer;
2910 if (strstr(
name,
"(anonymous)"))
return 0;
2911 if (strncmp(
name,
"class ",6)==0)
name += 6;
2912 if (strncmp(
name,
"struct ",7)==0)
name += 7;
2914 if (!
gROOT->GetListOfClasses())
return 0;
2960 if (!cl && !load)
return 0;
2962 TClass *loadedcl = (dict)();
2972 std::string normalizedName;
2981 if (normalizedName !=
name) {
2982 cl = (
TClass*)
gROOT->GetListOfClasses()->FindObject(normalizedName.c_str());
2993 normalizedName = cl->
GetName();
2994 checkTable = load && (normalizedName !=
name);
2997 if (!load)
return 0;
3023 if (
TDataType* theDataType =
gROOT->GetType(normalizedName.c_str())){
3025 auto underlyingTypeName = theDataType->GetTypeName();
3028 if (underlyingTypeDict){
3029 loadedcl = underlyingTypeDict();
3035 if (loadedcl)
return loadedcl;
3039 if (loadedcl)
return loadedcl;
3052 std::string::size_type posLess = normalizedName.find(
'<');
3053 if (posLess != std::string::npos) {
3060 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());
3062 if (normalizedName.length()) {
3072 auto ci =
gInterpreter->ClassInfo_Factory(normalizedName.c_str());
3074 auto method =
gInterpreter->MethodInfo_Factory(funcDecl);
3080 funcPtr(0, 0,
nullptr, &res);
3092 std::string alternative;
3093 gInterpreter->GetInterpreterTypeName(normalizedName.c_str(), alternative,
kTRUE);
3094 const char *altname = alternative.c_str();
3095 if (strncmp(altname,
"std::", 5) == 0) {
3100 if (altname != normalizedName && strcmp(altname,
name) != 0) {
3127 if (!
gROOT->GetListOfClasses())
3135 if (cl && cl->
IsLoaded())
return cl;
3142 cl =
GetIdMap()->Find(typeinfo.name());
3161 if (!load)
return 0;
3171 TIter next(
gROOT->GetListOfClassGenerators());
3183 if (!autoload_old) {
3214 if (!
gROOT->GetListOfClasses())
return 0;
3235 if (!load)
return 0;
3238 if (cl) loadedcl =
gROOT->LoadClass(cl->
GetName(),silent);
3239 else loadedcl =
gROOT->LoadClass(
name,silent);
3241 if (loadedcl)
return loadedcl;
3266 if (!
gROOT->GetListOfClasses())
return 0;
3270 DeclIdMap_t::equal_range iter = map->Find(
id);
3271 if (iter.first == iter.second)
return false;
3272 std::vector<TClass*>::iterator vectIt = classes.begin();
3273 for (DeclIdMap_t::const_iterator it = iter.first; it != iter.second; ++it)
3274 vectIt = classes.insert(vectIt, it->second);
3302 || datamember == 0)
return 0;
3305 const char *start_name = datamember;
3306 while (*start_name ==
'*') ++start_name;
3311 if (
const char *
s = strchr(start_name,
'[')){
3341 if (strchr(
name,
'[')==0) {
3383 std::string givenName(
name);
3386 std::string::size_type firstBracket = givenName.find_first_of(
"[");
3387 if (firstBracket != std::string::npos) {
3389 std::string nameNoDim(givenName.substr(0, firstBracket));
3393 std::string objName(obj->
GetName());
3394 std::string::size_type pos = objName.find_first_of(
"[");
3396 if (pos != std::string::npos) {
3398 if (objName == nameNoDim) {
3407 std::ostringstream ptrname;
3408 ptrname <<
"*" << givenName;
3415 std::string::size_type firstDot = givenName.find_first_of(
".");
3416 if (firstDot == std::string::npos) {
3427 std::string::size_type lastDot = givenName.find_last_of(
".");
3428 std::ostringstream starname;
3429 starname << givenName.substr(0, lastDot) <<
".*" << givenName.substr(lastDot + 1);
3445 std::string::size_type bracket = starname.str().find_first_of(
"[");
3446 if (bracket != std::string::npos) {
3455 std::string firstDotName(givenName.substr(firstDot + 1));
3498 if (!
fBase.load()) {
3523 Fatal(
"GetListOfBases",
"gInterpreter not initialized");
3526 if (!
fBase.load()) {
3552 auto temp =
fEnums.load();
3554 if (requestListLoading) {
3569 if (!requestListLoading) {
3576 static bool fromRootCling = dlsym(RTLD_DEFAULT,
"usedToIdentifyRootClingByDlSym");
3661 if (
gDebug>0)
Info(
"GetListOfMethods",
"Header Parsing - Asking for all the methods of class %s: this can involve parsing.",
GetName());
3694 if (
gDebug>0)
Info(
"GetListOfAllPublicMethods",
"Header Parsing - Asking for all the methods of class %s: this can involve parsing.",
GetName());
3724 while ((baseClass = (
TBaseClass *) nextBase())) {
3732 while ((method = (
TMethod*)next())) {
3738 if (
m &&
m->GetNargs() == method->
GetNargs())
3763 return cl->IsLoaded();
3791 TIter nextMemb(ldm);
3822 for (
int i = 0; i < 2; i++) {
3838 if (
this == sCIString)
return;
3850 auto checkDicts = [&](
const string &clName){
3857 if (cl && !cl->HasDictionary()) {
3858 cl->GetMissingDictionariesWithRecursionCheck(result, visited, recurse);
3862 const auto &elements = splitType.
fElements;
3863 const auto &templName = elements[0];
3866 if (templName ==
"pair") {
3874 if (templName ==
"unique_ptr" || templName ==
"array") {
3875 checkDicts(elements[1]);
3882 if (templName ==
"tuple") {
3885 const auto nTemplArgs = elements.size() - 1;
3887 for (
auto iTemplArg = 1U; iTemplArg < nTemplArgs; ++iTemplArg) {
3888 checkDicts(elements[iTemplArg]);
3937 if (
this == sCIString)
return;
3941 if (strncmp(
fName,
"pair<", 5) == 0) {
3995 while ((acl = (
TClass*)nextClass())) {
3996 if (acl == newcl)
continue;
4001 info->
Update(
this, newcl);
4005 TIter delIter( &tobedeleted );
4006 while ((acl = (
TClass*)delIter())) {
4017 Warning(
"ResetClassInfo(Long_t tagnum)",
"Call to deprecated interface (does nothing)");
4068 (*fMethod).Unload();
4102 if (options==0 || options[0]==0)
return;
4104 if (strstr(options,
"streamerinfo")!=0) {
4108 std::map<std::string, TObjArray*>::iterator it;
4109 std::map<std::string, TObjArray*>::iterator end = (*fConversionStreamerInfo).end();
4110 for( it = (*fConversionStreamerInfo).begin(); it != end; ++it ) {
4111 it->second->ls(options);
4138 TIter next(methodList);
4140 while ((method = (
TMethod*) next())) {
4142 if (classPtr != method->
GetClass()) {
4150 TIter nextarg(margsList);
4151 while ((methodArg = (
TMethodArg*)nextarg())) {
4201 if(
fMethod.compare_exchange_strong(expected, temp.get()) ) {
4237 m =
c->GetMethodAllAny(method);
4259 Fatal(
"GetMethod",
"gInterpreter not initialized");
4265 if (!decl)
return 0;
4272 "\nDid not find matching TMethod <%s> with \"%s\" %sfor %s",
4273 method,params,objectIsConst ?
"const " :
"",
GetName());
4283 return static_cast<TMethod *
>(method);
4287 if (
TFunction* method = base->FindClassOrBaseMethodWithId(declId))
4288 return static_cast<TMethod *
>(method);
4305 Fatal(
"GetMethodWithPrototype",
"gInterpreter not initialized");
4309 objectIsConst, mode);
4311 if (!decl)
return 0;
4314 Error(
"GetMethodWithPrototype",
4315 "\nDid not find matching TMethod <%s> with \"%s\" %sfor %s",
4316 method,
proto,objectIsConst ?
"const " :
"",
GetName());
4331 if (faddr == (
Long_t)
m->InterfaceMethod())
4350 Fatal(
"GetClassMethod",
"gInterpreter not initialized");
4356 if (!decl)
return 0;
4376 Fatal(
"GetClassMethodWithPrototype",
"gInterpreter not initialized");
4383 if (!decl)
return 0;
4475 Error(
"GetStreamerInfo",
"class: %s, attempting to access a wrong version: %d",
GetName(), version);
4494 TMmallocDescTemp setreset;
4548 newname +=
"@@emulated";
4573 for (
Int_t i = -1; sinfo == 0 && i < ninfos; ++i)
4586 Error(
"GetStreamerInfoAbstractEmulated",
"could not create TVirtualStreamerInfo");
4611 newname +=
"@@emulated";
4626 if (!sinfo && (checksum !=
fCheckSum)) {
4636 for (
Int_t i = -1; sinfo == 0 && i < ninfos; ++i)
4649 Error(
"GetStreamerInfoAbstractEmulated",
"could not create TVirtualStreamerInfo");
4696 Error(
"IgnoreTObjectStreamer",
"Must be called before the creation of StreamerInfo");
4722 if (cl ==
this)
return kTRUE;
4732 if (!clbase)
return kFALSE;
4751 if (cl ==
this)
return obj;
4758 return (
void*)((
Long_t)obj+off);
4760 return (
void*)((
Long_t)obj-off);
4826 Error(
"New",
"cannot create object of class %s",
GetName());
4842 Error(
"New",
"cannot create object of class %s",
GetName());
4853 Error(
"New",
"cannot create object of class %s",
GetName());
4874 if (!sinfo && !quiet) {
4893 Error(
"New",
"Failed to construct class '%s' using streamer info",
GetName());
4896 Fatal(
"New",
"This cannot happen!");
4920 Error(
"New with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
4935 Error(
"New with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
4963 Error(
"New with placement",
"Cannot construct class '%s' version %d at address %p, no streamer info available!",
GetName(),
fClassVersion, arena);
4968 p = sinfo->
New(arena);
4982 Error(
"New with placement",
"This cannot happen!");
5069 Error(
"NewArray",
"This cannot happen!");
5093 Error(
"NewArray with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
5108 Error(
"NewArray with placement",
"cannot create object of class %s version %d at address %p",
GetName(),
fClassVersion, arena);
5136 Error(
"NewArray with placement",
"Cannot construct class '%s' version %d at address %p, no streamer info available!",
GetName(),
fClassVersion, arena);
5141 p = sinfo->
NewArray(nElements, arena);
5160 Error(
"NewArray with placement",
"This cannot happen!");
5172 if (obj == 0)
return;
5179 }
else if ((!dtorOnly) &&
fDelete) {
5211 std::multiset<Version_t> knownVersions;
5224 knownVersions.insert(ver);
5232 if (!inRepo || verFound) {
5239 Error(
"Destructor",
"No streamer info available for class '%s' version %d at address %p, cannot destruct emulated object!",
GetName(),
fClassVersion, p);
5245 Error(
"Destructor",
"Doing Dump() ...");
5260 Error(
"Destructor2",
"No streamer info available for class '%s' version %d, cannot destruct object at addr: %p",
GetName(), objVer, p);
5267 Error(
"Destructor2",
"Doing Dump() ...");
5275 if (inRepo && verFound && p) {
5279 Error(
"Destructor",
"This cannot happen! (class %s)",
GetName());
5289 if (ary == 0)
return;
5296 Error(
"DeleteArray",
"Destructor only is not supported!");
5325 std::multiset<Version_t> knownVersions;
5336 knownVersions.insert(ver);
5344 if (!inRepo || verFound) {
5351 Error(
"DeleteArray",
"No streamer info available for class '%s' version %d at address %p, cannot destruct object!",
GetName(),
fClassVersion, ary);
5357 Error(
"DeleteArray",
"Doing Dump() ...");
5366 Error(
"DeleteArray",
"Loaded class version %d is not registered for addr %p",
fClassVersion, p);
5375 Error(
"DeleteArray",
"No streamer info available for class '%s' version %d at address %p, cannot destruct object!",
GetName(), objVer, ary);
5382 Error(
"DeleteArray",
"Doing Dump() ...");
5393 if (inRepo && verFound && p) {
5397 Error(
"DeleteArray",
"This cannot happen! (class '%s')",
GetName());
5468 char *
s =
new char[maxsize];
5472 b.ReadString(
s, maxsize);
5473 while (strlen(
s) == (maxsize - 1)) {
5475 b.SetBufferOffset(pos);
5476 maxsize = 2*maxsize;
5478 s =
new char[maxsize];
5479 b.ReadString(
s, maxsize);
5484 ::Error(
"TClass::Load",
"dictionary of class %s not found",
s);
5508 if (result)
return result;
5556 TIter next(
gROOT->GetListOfClassGenerators());
5583 bool autoParse = !
gInterpreter->IsAutoParsingSuspended();
5597 ::Error(
"TClass::LoadClassInfo",
"no interpreter information for class %s is available"
5598 " even though it has a TClass initialization routine.",
5621 const char *dfil,
const char *ifil,
5626 TMmallocDescTemp setreset;
5627 return new TClass(cname,
id, info, isa, dfil, ifil, dl, il);
5635 const char *dfil,
const char *ifil,
5640 TMmallocDescTemp setreset;
5641 return new TClass(cname,
id, dfil, ifil, dl, il);
5745 The class %s transitioned from not having a specified class version\n\
5746 to having a specified class version (the current class version is %d).\n\
5747 However too many different non-versioned layouts of the class have\n\
5748 already been loaded so far. To work around this problem you can\n\
5749 load fewer 'old' file in the same ROOT session or load the C++ library\n\
5750 describing the class %s before opening the files or increase the version\n\
5751 number of the class for example ClassDef(%s,%d).\n\
5752 Do not try to write objects with the current class definition,\n\
5753 the files might not be readable.\n",
5757 The StreamerInfo version %d for the class %s which was read\n\
5758 from a file previously opened has the same version as the active class\n\
5759 but a different checksum. You should update the version to ClassDef(%s,%d).\n\
5760 Do not try to write objects with the current class definition,\n\
5761 the files will not be readable.\n"
5806 TMmallocDescTemp setreset;
6021 Fatal(
"SetUnloaded",
"The TClass for %s is being unloaded when in state %d\n",
6045 (*fMethod).Unload();
6054 if (fState <= kForwardDeclared && fStreamerInfo->GetEntries() != 0) {
6147 //info is empty. Let's build the default Streamer descriptor
6149 char *temp = new char[10000];
6153 //add list of base classes
6154 TIter nextb(GetListOfBases());
6156 while ((base = (TBaseClass*) nextb())) {
6157 snprintf(local,100,"%s;",base->GetName());
6158 strlcat(temp,local,10000);
6161 //add list of data members and types
6162 TIter nextd(GetListOfDataMembers());
6163 while ((dm = (TDataMember *) nextd())) {
6164 if (dm->IsEnum()) continue;
6165 if (!dm->IsPersistent()) continue;
6166 Long_t property = dm->Property();
6167 if (property & kIsStatic) continue;
6168 TClass *acl = TClass::GetClass(dm->GetTypeName(),update);
6171 if (acl->GetClassVersion() == 0) continue;
6174 // dm->GetArrayIndex() returns an empty string if it does not
6176 const char * index = dm->GetArrayIndex();
6177 if (strlen(index)==0)
6178 snprintf(local,100,"%s %s;",dm->GetFullTypeName(),dm->GetName());
6180 snprintf(local,100,"%s %s[%s];",dm->GetFullTypeName(),dm->GetName(),index);
6181 strlcat(temp,local,10000);
6183 //fStreamerInfo = temp;
6272 for (
int i=0; i<il; i++)
id =
id*3+
name[i];
6281 TIter nextBase(tlb);
6290 for (
int i=0; i<il; i++)
id =
id*3+
name[i];
6293 Error(
"GetCheckSum",
"Calculating the checksum for (%s) requires the base class (%s) meta information to be available!",
6302 TList *tlm = ((
TClass*)
this)->GetListOfDataMembers();
6304 TIter nextMemb(tlm);
6320 for (i=0; i<il; i++)
id =
id*3+
name[i];
6332 type.ReplaceAll(
"ULong64_t",
"unsigned long long");
6333 type.ReplaceAll(
"Long64_t",
"long long");
6334 type.ReplaceAll(
"<signed char",
"<char");
6335 type.ReplaceAll(
",signed char",
",char");
6336 if (
type==
"signed char")
type =
"char";
6348 for (i=0; i<il; i++)
id =
id*3+
type[i];
6352 for (
int ii=0;ii<dim;ii++)
id =
id*3+tdm->
GetMaxIndex(ii);
6359 left = strstr(tdm->
GetTitle(),
"[");
6361 const char *right = strstr(left,
"]");
6364 while (left != right) {
6456 return b.ReadClassBuffer(
this,pointer,version,start,count);
6465 return b.ReadClassBuffer(
this,pointer);
6477 b.WriteClassBuffer(
this,pointer);
6490 streamer->
Stream(
b,
object,onfile_class);
6522 if (
b.IsReading()) {
6523 b.ReadClassEmulated(pThis,
object, onfile_class);
6525 b.WriteClassBuffer(pThis,
object);
6556 if (
b.IsReading()) {
6557 b.ReadClassBuffer(pThis,
object, onfile_class);
6561 b.WriteClassBuffer(pThis,
object);
6580 pThis->
Fatal(
"StreamerDefault",
"fStreamerImpl not properly initialized (%d)", pThis->
fStreamerType);
6742 for (
Int_t i=-1;i<ninfos;++i) {
6764 for (
Int_t i=-1;i<ninfos;i++) {
6768 if (!info)
continue;
6809 std::map<std::string, TObjArray*>::iterator it;
6812 it = (*fConversionStreamerInfo).find( cl->
GetName() );
6814 if( it != (*fConversionStreamerInfo).end() ) {
6818 if( arr && version > -1 && version < arr->GetSize() && arr->
At( version ) )
6830 if( version >= -1 && version < clSI->GetSize() )
6868 (*fConversionStreamerInfo)[cl->
GetName()] = arr;
6907 std::map<std::string, TObjArray*>::iterator it;
6911 it = (*fConversionStreamerInfo).find( cl->
GetName() );
6913 if( it != (*fConversionStreamerInfo).end() ) {
6962 (*fConversionStreamerInfo)[cl->
GetName()] = arr;
6981 Error(
"RegisterStreamerInfo",
6982 "Register StreamerInfo for %s on non-empty slot (%d).",
7022 static const char *handVerified[] = {
7023 "TEnvRec",
"TDataType",
"TObjArray",
"TList",
"THashList",
7024 "TClass",
"TCling",
"TInterpreter",
"TMethod",
"ROOT::Internal::TCheckHashRecursiveRemoveConsistency",
7025 "TCheckHashRecursiveRemoveConsistency",
"TGWindow",
7026 "TDirectory",
"TDirectoryFile",
"TObject",
"TH1",
7027 "TQClass",
"TGlobal" };
7029 if (cname && cname[0]) {
7030 for (
auto cursor : handVerified) {
7031 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.
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