60 #ifdef R__CHECK_COLLECTION_MULTI_ACCESS 62 void TCollection::TErrorLock::ConflictReport(
std::thread::id holder,
const char *accesstype,
63 const TCollection *collection,
const char *
function)
66 auto local = std::this_thread::get_id();
67 std::stringstream cur, loc;
71 cur <<
"0x" << std::hex << holder;
72 loc <<
"0x" << std::hex << local;
80 "Access (%s) to a collection (%s:%p) from multiple threads at a time. holder=%s readers=%lu intruder=%s",
81 accesstype, collection->IsA()->
GetName(), collection, cur.str().c_str(), fReadSet.size(), loc.str().c_str());
83 std::set<std::thread::id> tmp;
84 for (
auto r : fReadSet) tmp.insert(
r);
87 reader <<
"0x" << std::hex <<
r;
88 ::Error(
function,
" Readers includes %s", reader.str().c_str());
93 void TCollection::TErrorLock::Lock(
const TCollection *collection,
const char *
function)
95 auto local = std::this_thread::get_id();
99 if (fWriteCurrent.compare_exchange_strong(holder, local)) {
101 ++fWriteCurrentRecurse;
106 if (fReadCurrentRecurse) {
107 if (fReadSet.size() > 1 || fReadSet.find(local) != fReadSet.end()) {
108 ConflictReport(
std::thread::id(),
"WriteLock while ReadLock taken", collection,
function);
114 if (holder == local) {
120 ConflictReport(holder,
"WriteLock", collection,
function);
122 ++fWriteCurrentRecurse;
126 void TCollection::TErrorLock::Unlock()
128 auto local = std::this_thread::get_id();
131 --fWriteCurrentRecurse;
132 if (fWriteCurrentRecurse == 0) {
133 if (fWriteCurrent.compare_exchange_strong(local, none)) {
153 void TCollection::TErrorLock::ReadLock(
const TCollection *collection,
const char *
function)
155 auto local = std::this_thread::get_id();
159 fReadSet.insert(local);
161 ++fReadCurrentRecurse;
163 if (fWriteCurrentRecurse) {
164 auto holder = fWriteCurrent.load();
165 if (holder != local) ConflictReport(holder,
"ReadLock with WriteLock taken", collection,
function);
169 void TCollection::TErrorLock::ReadUnlock()
171 auto local = std::this_thread::get_id();
174 fReadSet.erase(local);
176 --fReadCurrentRecurse;
179 #endif // R__CHECK_COLLECTION_MULTI_ACCESS 198 while ((obj = next()))
209 va_start(ap,
va_(obj1));
213 while ((obj = va_arg(ap,
TObject *)))
228 Error(
"AssertClass",
"class == 0");
232 for (
int i = 0; (obj = next()); i++)
234 Error(
"AssertClass",
"element %d is not an instance of class %s (%s)",
252 while ((obj = next())) b->
Add(obj);
264 if (newname && strlen(newname)) new_collection->
SetName(newname);
265 return new_collection;
275 if (
this == obj)
return 0;
287 while ((
object = next())) {
288 object->Draw(option);
300 while ((
object = next())) {
315 while ((obj = next()))
316 if (!strcmp(name, obj->
GetName()))
return obj;
340 while ((ob = next()))
341 if (ob->
IsEqual(obj))
return ob;
361 Error(
"GrowBy",
"delta < 0");
383 std::cout <<
"OBJ: " << IsA()->GetName() <<
"\t" <<
GetName() <<
"\t" <<
GetTitle() <<
" : " 390 if (option) star = (
char*)strchr(option,
'*');
393 while ((
object = next())) {
396 if (s != option && s.
Index(re) ==
kNPOS)
continue;
408 for (
auto obj : *
this) success &= obj->Notify();
426 printf(
"Collection name='%s', class='%s', size=%d\n",
447 coll->
Print(option, recurse);
450 entry->
Print(option);
498 while ((
object = next())) {
521 if (!wildcard) wildcard =
"";
523 Int_t nch = strlen(wildcard);
528 while ((
object = next())) {
530 if (nch == 0 || s == wildcard || s.
Index(re) !=
kNPOS) {
558 while ((
object = next())) {
584 while ((
object = next())) {
597 while ((obj = next()))
604 void TCollection::Streamer(
TBuffer &
b)
613 TObject::Streamer(b);
617 for (
Int_t i = 0; i < nobjects; i++) {
624 TObject::Streamer(b);
631 while ((obj = next())) {
651 option &= ~kSingleKey;
655 while ((obj = next())) {
656 nbytes += obj->
Write(name, option, bsize);
672 return ((
const TCollection*)
this)->Write(name,option,bsize);
810 return TIter(static_cast<TIterator*>(
nullptr));
void Add(TObject *obj, const char *name=0, Int_t check=-1)
Add object with name to browser.
virtual const char * GetName() const
Returns name of object.
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
virtual TObject * Remove(TObject *obj)=0
static Int_t fgGarbageStack
static Int_t DecreaseDirLevel()
Decrease the indentation level for ls().
const TCollection * GetCollection() const
virtual void StackTrace()
Print a stack trace.
Bool_t MatchB(const TString &s, const TString &mods="", Int_t start=0, Int_t nMaxMatch=10)
void CallRecursiveRemoveIfNeeded(TObject &obj)
call RecursiveRemove for obj if gROOT is valid and obj.TestBit(kMustCleanup) is true.
virtual const char * GetCollectionEntryName(TObject *entry) const
For given collection entry return the string that is used to identify the object and, potentially, perform wildcard/regexp filtering on.
Int_t Compare(const TObject *obj) const
Compare two TCollection objects.
TIter & Begin()
Pointing to the first element of the container.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
Bool_t IsArgNull(const char *where, const TObject *obj) const
Returns true if object is a null pointer.
virtual void Draw(Option_t *option="")
Draw all objects in this collection.
virtual void AddAll(const TCollection *col)
Add all objects from collection col to this collection.
Buffer base class used for serializing objects.
Regular expression class.
This class implements a mutex interface.
bool ContaineeInheritsFrom(TClass *cl, TClass *base)
Return true if 'cl' inherits from 'base'.
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
TVirtualMutex * gCollectionMutex
virtual void Browse(TBrowser *b)
Browse object. May be overridden for another default action.
Short_t Range(Short_t lb, Short_t ub, Short_t x)
static TCollection * fgCurrentCollection
virtual void Print(Option_t *option="") const
This method must be overridden when a class wants to print itself.
virtual UInt_t WriteVersion(const TClass *cl, Bool_t useBcnt=kFALSE)=0
virtual TObject * Clone(const char *newname="") const
Make a clone of an collection using the Streamer facility.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
if object in a list can be deleted
virtual void RecursiveRemove(TObject *obj)
Recursively remove this object from a list.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
void AddVector(TObject *obj1,...)
Add all arguments to the collection.
virtual bool UseRWLock()
Set this collection to use a RW lock upon access, making it thread safe.
virtual void PrintCollectionEntry(TObject *entry, Option_t *option, Int_t recurse) const
Print the collection entry.
void Error(const char *location, const char *msgfmt,...)
object has not been deleted
virtual Bool_t IsEqual(const TObject *obj) const
Default equal comparison (objects are equal if they have the same address in memory).
Using a TBrowser one can browse all ROOT objects.
TIter & operator=(const TIter &rhs)
Assigning an TIter to another.
virtual void RecursiveRemove(TObject *obj)
Remove object from this collection and recursively remove the object from all other objects (and coll...
virtual Int_t GrowBy(Int_t delta) const
Increase the collection's capacity by delta slots.
R__EXTERN TSystem * gSystem
write collection with single key
static TCollection * GetCurrentCollection()
Return the globally accessible collection.
virtual TIterator * MakeIterator(Bool_t dir=kIterForward) const =0
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
Collection abstract base class.
virtual void Paint(Option_t *option="")
Paint all objects in this collection.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
static void IndentLevel()
Functions used by ls() to indent an object hierarchy.
The ROOT global object gROOT contains a list of all defined classes.
virtual void SetByteCount(UInt_t cntpos, Bool_t packInVersion=kFALSE)=0
static void StartGarbageCollection()
Set up for garbage collection.
Bool_t InheritsFrom(const char *cl) const
Return kTRUE if this class inherits from a class with name "classname".
This class registers all instances of TObject and its derived classes in a hash table.
virtual Bool_t Notify()
'Notify' all objects in this collection.
void SetName(const char *name)
void SetCurrentCollection()
Set this collection to be the globally accesible collection.
virtual void Dump() const
Dump all objects in this collection.
static Bool_t fgEmptyingGarbage
static TIter End()
Pointing to the element after the last - to a nullptr value in our case.
#define R__LOCKGUARD2(mutex)
static void GarbageCollect(TObject *obj)
Add to the list of things to be cleaned up.
const TCollection & EmptyCollection()
Return an empty collection for use with nullptr TRangeCast.
virtual void ls(Option_t *option="") const
List (ls) all objects in this collection.
virtual ~TCollection()
TNamed destructor.
void Add(TObject *obj)
Add an object to the object table.
static TObjectTable * fgGarbageCollection
static constexpr double s
void Browse(TBrowser *b)
Browse this collection (called by TBrowser).
virtual void Add(TObject *obj)=0
int CompareTo(const char *cs, ECaseCompare cmp=kExact) const
Compare a string to char *cs2.
static void EmptyGarbageCollection()
Do the garbage collection.
Mother of all ROOT objects.
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
static Int_t IncreaseDirLevel()
Increase the indentation level for ls().
virtual const char * GetTitle() const
Returns title of object.
virtual void PrintCollectionHeader(Option_t *option) const
Print the collection header.
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
virtual TObject * FindObject(const char *name) const
Find an object in this collection using its name.
Bool_t AssertClass(TClass *cl) const
Make sure all objects in this collection inherit from class cl.
virtual void Print(Option_t *option="") const
Default print for collections, calls Print(option, 1).
virtual const char * GetName() const
Returns name of object.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
void Delete(Option_t *opt="")
Delete all objects stored in the TObjectTable.
TObject * operator()(const char *name) const
Find an object in this collection by name.
#define R__FOR_EACH(type, proc)
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write all objects in this collection.
virtual const char * GetName() const
Return name of this collection.
virtual Version_t ReadVersion(UInt_t *start=0, UInt_t *bcnt=0, const TClass *cl=0)=0
A spin mutex-as-code-guard class.
const char * Data() const