36 if (ob->
IsEqual(obj))
return idx;
57 if (a == 0 && b == 0)
return 0;
59 if (b == 0)
return -1;
77 while (last - first > 1) {
81 while (++i < last &&
ObjCompare(a[i], a[first]) < 0)
83 while (--j > first &&
ObjCompare(a[j], a[first]) > 0)
99 if (j - first < last - (j + 1)) {
103 QSort(a, j + 1, last);
125 static int depth = 0;
126 if (depth == 0 && nBs > 0) tmp2 =
new TObject*[nBs];
129 while (last - first > 1) {
133 while (++i < last &&
ObjCompare(a[i], a[first]) < 0) {}
134 while (--j > first &&
ObjCompare(a[j], a[first]) > 0) {}
137 tmp1 = a[i];
for(k=0;k<nBs;k++) tmp2[k] = b[k][i];
138 a[i] = a[j];
for(k=0;k<nBs;k++) b[k][i] = b[k][j];
139 a[j] = tmp1;
for(k=0;k<nBs;k++) b[k][j] = tmp2[k];
145 tmp1 = a[first];
for(k=0;k<nBs;k++) tmp2[k] = b[k][first];
146 a[first] = a[j];
for(k=0;k<nBs;k++) b[k][first] = b[k][j];
147 a[j] = tmp1;
for(k=0;k<nBs;k++) b[k][j] = tmp2[k];
148 if (j - first < last - (j + 1)) {
149 QSort(a, nBs, b, first, j);
152 QSort(a, nBs, b, j + 1, last);
158 if (depth == 0 && nBs > 0)
delete [] tmp2;
188 Warning(
"Merge",
"list is empty - nothing to merge");
192 Warning(
"Merge",
"input list is empty - nothing to merge with");
195 TIter nextobject(
this);
196 TIter nextlist(list);
205 while ((
object = nextobject())) {
208 if (!object->IsA()) {
223 while ((collcrt = nextlist())) {
225 Error(
"Merge",
"some objects in the input list are not collections - merging aborted");
233 Warning(
"Merge",
"object of type %s (position %d in list) not found in list %d. Continuing...",
246 if (object->IsA() != objtomerge->IsA()) {
247 Error(
"Merge",
"object of type %s at index %d not matching object of type %s in input list",
254 templist->
Add(objtomerge);
258 if (!notmergeable &&
IsA())
261 notmergeable->
Add(objtomerge);
263 Warning(
"Merge",
"temp list for non mergeable objects not created!");
276 if (notmergeable && notmergeable->
GetSize() > 0) {
277 TIter nxnm(notmergeable);
279 while ((onm = nxnm())) {
Add(onm->
Clone()); }
virtual void Add(TObject *obj)
R__EXTERN TVirtualMutex * gCollectionMutex
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
ClassImp(TSeqCollection) Int_t TSeqCollection TIter next(this)
Return index of object in collection.
virtual Bool_t IsEqual(const TObject *obj) const
Default equal comparison (objects are equal if they have the same address in memory).
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
Sequenceable collection abstract base class.
virtual Bool_t IsEmpty() const
UChar_t mod R__LOCKGUARD2(gSrvAuthenticateMutex)
void * New(ENewType defConstructor=kClassNew, Bool_t quiet=kFALSE) const
Return a pointer to a newly allocated object of this class.
Method or function calling interface.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
Collection abstract base class.
static void QSort(TObject **a, Int_t first, Int_t last)
Sort array of TObject pointers using a quicksort algorithm.
void InitWithPrototype(TClass *cl, const char *method, const char *proto, Bool_t objectIsConst=kFALSE, ROOT::EFunctionMatchMode mode=ROOT::kConversionMatch)
Initialize the method invocation environment.
virtual Int_t GetLast() const
Returns index of last object in collection.
virtual Int_t GetSize() const
Mother of all ROOT objects.
void Execute(const char *, const char *, int *=0)
Execute method on this object with the given parameter string, e.g.
void SetParam(Long_t l)
Add a long method parameter.
virtual Int_t Compare(const TObject *obj) const
Compare abstract method.
virtual Int_t IndexOf(const TObject *obj) const
static Int_t ObjCompare(TObject *a, TObject *b)
Compare to objects in the collection. Use member Compare() of object a.
Bool_t IsValid() const
Return true if the method call has been properly initialized and is usable.
Long64_t Merge(TCollection *list)
Merge this collection with all collections coming in the input list.
virtual TObject * Last() const =0
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.