Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TObject.cxx
Go to the documentation of this file.
1// @(#)root/base:$Id$
2// Author: Rene Brun 26/12/94
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12/** \class TObject
13\ingroup Base
14
15Mother of all ROOT objects.
16
17The TObject class provides default behaviour and protocol for all
18objects in the ROOT system. It provides protocol for object I/O,
19error handling, sorting, inspection, printing, drawing, etc.
20Every object which inherits from TObject can be stored in the
21ROOT collection classes.
22
23TObject's bits can be used as flags, bits 0 - 13 and 24-31 are
24reserved as global bits while bits 14 - 23 can be used in different
25class hierarchies (watch out for overlaps).
26*/
27
28#include <cstring>
29#if !defined(WIN32) && !defined(__MWERKS__) && !defined(R__SOLARIS)
30#include <strings.h>
31#endif
32#include <cstdlib>
33#include <cstdio>
34#include <sstream>
35#include <fstream>
36#include <iostream>
37
38#include "Varargs.h"
39#include "snprintf.h"
40#include "TObject.h"
41#include "TBuffer.h"
42#include "TClass.h"
43#include "TGuiFactory.h"
44#include "TMethod.h"
45#include "TROOT.h"
46#include "TError.h"
47#include "TObjectTable.h"
48#include "TVirtualPad.h"
49#include "TInterpreter.h"
50#include "TMemberInspector.h"
51#include "TRefTable.h"
52#include "TProcessID.h"
53
56
58
59#if defined(__clang__) || defined (__GNUC__)
60# define ATTRIBUTE_NO_SANITIZE_ADDRESS __attribute__((no_sanitize_address))
61#else
62# define ATTRIBUTE_NO_SANITIZE_ADDRESS
63#endif
64
65namespace ROOT {
66namespace Internal {
67
68// Return true if delete changes/poisons/taints the memory.
69//
70// Detect whether operator delete taints the memory. If it does, we can not rely
71// on TestBit(kNotDeleted) to check if the memory has been deleted (but in case,
72// like TClonesArray, where we know the destructor will be called but not operator
73// delete, we can still use it to detect the cases where the destructor was called.
74
77{
78 static constexpr UInt_t kGoldenUUID = 0x00000021;
79 static constexpr UInt_t kGoldenbits = 0x03000000;
80
81 TObject *o = new TObject;
82 o->SetUniqueID(kGoldenUUID);
83 UInt_t *o_fuid = &(o->fUniqueID);
84 UInt_t *o_fbits = &(o->fBits);
85
86 if (*o_fuid != kGoldenUUID) {
87 Error("CheckingDeleteSideEffects",
88 "fUniqueID is not as expected, we got 0x%.8x instead of 0x%.8x",
89 *o_fuid, kGoldenUUID);
90 }
91 if (*o_fbits != kGoldenbits) {
92 Error("CheckingDeleteSideEffects",
93 "fBits is not as expected, we got 0x%.8x instead of 0x%.8x",
94 *o_fbits, kGoldenbits);
95 }
96 if (gDebug >= 9) {
97 unsigned char *oc = reinterpret_cast<unsigned char *>(o); // for address calculations
98 unsigned char references[sizeof(TObject)];
99 memcpy(references, oc, sizeof(TObject));
100
101 // The effective part of this code (the else statement is just that without
102 // any of the debug statement)
103 delete o;
104
105 // Not using the error logger, as there routine is meant to be called
106 // during library initialization/loading.
107 fprintf(stderr,
108 "DEBUG: Checking before and after delete the content of a TObject with uniqueID 0x21\n");
109 for(size_t i = 0; i < sizeof(TObject); i += 4) {
110 fprintf(stderr, "DEBUG: 0x%.8x vs 0x%.8x\n", *(int*)(references +i), *(int*)(oc + i));
111 }
112 } else
113 delete o; // the 'if' part is that surrounded by the debug code.
114
115 // Intentionally accessing the deleted memory to check whether it has been changed as
116 // a consequence (side effect) of executing operator delete. If there no change, we
117 // can guess this is always the case and we can rely on the changes to fBits made
118 // by ~TObject to detect use-after-delete error (and print a message rather than
119 // stop the program with a segmentation fault)
120 if ( *o_fbits != 0x01000000 ) {
121 // operator delete tainted the memory, we can not rely on TestBit(kNotDeleted)
122 return true;
123 }
124 return false;
125}
126
128{
129 static const bool value = DeleteChangesMemoryImpl();
130 if (gDebug >= 9)
131 DeleteChangesMemoryImpl(); // To allow for printing the debug info
132 return value;
133}
134
135}} // ROOT::Detail
136
137////////////////////////////////////////////////////////////////////////////////
138/// Copy this to obj.
139
140void TObject::Copy(TObject &obj) const
141{
142 obj.fUniqueID = fUniqueID; // when really unique don't copy
143 if (obj.IsOnHeap()) { // test uses fBits so don't move next line
144 obj.fBits = fBits;
145 obj.fBits |= kIsOnHeap;
146 } else {
147 obj.fBits = fBits;
148 obj.fBits &= ~kIsOnHeap;
149 }
150 obj.fBits &= ~kIsReferenced;
151 obj.fBits &= ~kCanDelete;
152}
153
154////////////////////////////////////////////////////////////////////////////////
155/// TObject destructor. Removes object from all canvases and object browsers
156/// if observer bit is on and remove from the global object table.
157
160 // if (!TestBit(kNotDeleted))
161 // Fatal("~TObject", "object deleted twice");
162
164
165 fBits &= ~kNotDeleted;
166
168}
169
170////////////////////////////////////////////////////////////////////////////////
171/// Private helper function which will dispatch to
172/// TObjectTable::AddObj.
173/// Included here to avoid circular dependency between header files.
174
176{
178}
179
180////////////////////////////////////////////////////////////////////////////////
181/// Append graphics object to current pad. In case no current pad is set
182/// yet, create a default canvas with the name "c1".
183
185{
186 if (!gPad)
187 gROOT->MakeDefCanvas();
188
189 if (!gPad->IsEditable())
190 return;
191
192 gPad->Add(this, option);
193}
194
195////////////////////////////////////////////////////////////////////////////////
196/// Browse object. May be overridden for another default action
197
199{
200 //Inspect();
201 TClass::AutoBrowse(this,b);
202}
203
204////////////////////////////////////////////////////////////////////////////////
205/// Returns name of class to which the object belongs.
206
207const char *TObject::ClassName() const
208{
209 return IsA()->GetName();
210}
211
212////////////////////////////////////////////////////////////////////////////////
213/// Make a clone of an object using the Streamer facility.
214/// If the object derives from TNamed, this function is called
215/// by TNamed::Clone. TNamed::Clone uses the optional argument to set
216/// a new name to the newly created object.
217///
218/// If the object class has a DirectoryAutoAdd function, it will be
219/// called at the end of the function with the parameter gDirectory.
220/// This usually means that the object will be appended to the current
221/// ROOT directory.
222
223TObject *TObject::Clone(const char *) const
224{
225 if (gDirectory) {
226 return gDirectory->CloneObject(this);
227 } else {
228 // Some of the streamer (eg. roofit's) expect(ed?) a valid gDirectory during streaming.
229 return gROOT->CloneObject(this);
230 }
231}
232
233////////////////////////////////////////////////////////////////////////////////
234/// Compare abstract method. Must be overridden if a class wants to be able
235/// to compare itself with other objects. Must return -1 if this is smaller
236/// than obj, 0 if objects are equal and 1 if this is larger than obj.
237
239{
240 AbstractMethod("Compare");
241 return 0;
242}
243
244////////////////////////////////////////////////////////////////////////////////
245/// Delete this object. Typically called as a command via the interpreter.
246/// Normally use "delete" operator when object has been allocated on the heap.
247
249{
250 if (IsOnHeap()) {
251 // Delete object from CINT symbol table so it can not be used anymore.
252 // CINT object are always on the heap.
253 gInterpreter->DeleteGlobal(this);
254
255 delete this;
256 }
257}
258
259
260////////////////////////////////////////////////////////////////////////////////
261/// Computes distance from point (px,py) to the object.
262/// This member function must be implemented for each graphics primitive.
263/// This default function returns a big number (999999).
264
266{
267 // AbstractMethod("DistancetoPrimitive");
268 return 999999;
269}
270
271////////////////////////////////////////////////////////////////////////////////
272/// Default Draw method for all objects
273
275{
277}
278
279////////////////////////////////////////////////////////////////////////////////
280/// Draw class inheritance tree of the class to which this object belongs.
281/// If a class B inherits from a class A, description of B is drawn
282/// on the right side of description of A.
283/// Member functions overridden by B are shown in class A with a blue line
284/// crossing-out the corresponding member function.
285/// The following picture is the class inheritance tree of class TPaveLabel:
286///
287/// \image html base_object.png
288
290{
291 IsA()->Draw();
292}
293
294////////////////////////////////////////////////////////////////////////////////
295/// Draw a clone of this object in the current selected pad with:
296/// `gROOT->SetSelectedPad(c1)`.
297/// If pad was not selected - `gPad` will be used.
298
300{
301 TVirtualPad::TContext ctxt(true);
302 auto pad = gROOT->GetSelectedPad();
303 if (pad)
304 pad->cd();
305
306 TObject *newobj = Clone();
307 if (!newobj)
308 return nullptr;
309
310 if (!option || !*option)
312
313 if (pad) {
314 pad->Add(newobj, option);
315 pad->Update();
316 } else {
317 newobj->Draw(option);
318 }
319
320 return newobj;
321}
322
323////////////////////////////////////////////////////////////////////////////////
324/// Dump contents of object on stdout.
325/// Using the information in the object dictionary (class TClass)
326/// each data member is interpreted.
327/// If a data member is a pointer, the pointer value is printed
328///
329/// The following output is the Dump of a TArrow object:
330/// ~~~ {.cpp}
331/// fAngle 0 Arrow opening angle (degrees)
332/// fArrowSize 0.2 Arrow Size
333/// fOption.*fData
334/// fX1 0.1 X of 1st point
335/// fY1 0.15 Y of 1st point
336/// fX2 0.67 X of 2nd point
337/// fY2 0.83 Y of 2nd point
338/// fUniqueID 0 object unique identifier
339/// fBits 50331648 bit field status word
340/// fLineColor 1 line color
341/// fLineStyle 1 line style
342/// fLineWidth 1 line width
343/// fFillColor 19 fill area color
344/// fFillStyle 1001 fill area style
345/// ~~~
346
347void TObject::Dump() const
348{
349 // Get the actual address of the object.
350 const void *actual = IsA()->DynamicCast(TObject::Class(),this,kFALSE);
351 IsA()->Dump(actual);
352}
353
354////////////////////////////////////////////////////////////////////////////////
355/// Execute method on this object with the given parameter string, e.g.
356/// "3.14,1,\"text\"".
357
358void TObject::Execute(const char *method, const char *params, Int_t *error)
359{
360 if (!IsA()) return;
361
362 Bool_t must_cleanup = TestBit(kMustCleanup);
363
364 gInterpreter->Execute(this, IsA(), method, params, error);
365
366 if (gPad && must_cleanup) gPad->Modified();
367}
368
369////////////////////////////////////////////////////////////////////////////////
370/// Execute method on this object with parameters stored in the TObjArray.
371/// The TObjArray should contain an argv vector like:
372/// ~~~ {.cpp}
373/// argv[0] ... argv[n] = the list of TObjString parameters
374/// ~~~
375
376void TObject::Execute(TMethod *method, TObjArray *params, Int_t *error)
377{
378 if (!IsA()) return;
379
380 Bool_t must_cleanup = TestBit(kMustCleanup);
381
382 gInterpreter->Execute(this, IsA(), method, params, error);
383
384 if (gPad && must_cleanup) gPad->Modified();
385}
386
387
388////////////////////////////////////////////////////////////////////////////////
389/// Execute action corresponding to an event at (px,py). This method
390/// must be overridden if an object can react to graphics events.
391
393{
394 // AbstractMethod("ExecuteEvent");
395}
396
397////////////////////////////////////////////////////////////////////////////////
398/// Must be redefined in derived classes.
399/// This function is typically used with TCollections, but can also be used
400/// to find an object by name inside this object.
401
402TObject *TObject::FindObject(const char *) const
403{
404 return nullptr;
405}
406
407////////////////////////////////////////////////////////////////////////////////
408/// Must be redefined in derived classes.
409/// This function is typically used with TCollections, but can also be used
410/// to find an object inside this object.
411
413{
414 return nullptr;
415}
416
417////////////////////////////////////////////////////////////////////////////////
418/// Get option used by the graphics system to draw this object.
419/// Note that before calling object.GetDrawOption(), you must
420/// have called object.Draw(..) before in the current pad.
421
423{
424 if (!gPad) return "";
425
426 TListIter next(gPad->GetListOfPrimitives());
427 while (auto obj = next()) {
428 if (obj == this)
429 return next.GetOption();
430 }
431 return "";
432}
433
434////////////////////////////////////////////////////////////////////////////////
435/// Returns name of object. This default method returns the class name.
436/// Classes that give objects a name should override this method.
437
438const char *TObject::GetName() const
439{
440 return IsA()->GetName();
441}
442
443////////////////////////////////////////////////////////////////////////////////
444/// Returns mime type name of object. Used by the TBrowser (via TGMimeTypes
445/// class). Override for class of which you would like to have different
446/// icons for objects of the same class.
447
448const char *TObject::GetIconName() const
449{
450 return nullptr;
451}
452
453////////////////////////////////////////////////////////////////////////////////
454/// Return the unique object id.
455
457{
458 return fUniqueID;
459}
460
461////////////////////////////////////////////////////////////////////////////////
462/// Returns string containing info about the object at position (px,py).
463/// This method is typically overridden by classes of which the objects
464/// can report peculiarities for different positions.
465/// Returned string will be re-used (lock in MT environment).
466
468{
469 if (!gPad) return (char*)"";
470 static char info[64];
471 Float_t x = gPad->AbsPixeltoX(px);
472 Float_t y = gPad->AbsPixeltoY(py);
473 snprintf(info,64,"x=%g, y=%g",gPad->PadtoX(x),gPad->PadtoY(y));
474 return info;
475}
476
477////////////////////////////////////////////////////////////////////////////////
478/// Returns title of object. This default method returns the class title
479/// (i.e. description). Classes that give objects a title should override
480/// this method.
481
482const char *TObject::GetTitle() const
483{
484 return IsA()->GetTitle();
485}
486
487
488////////////////////////////////////////////////////////////////////////////////
489/// Execute action in response of a timer timing out. This method
490/// must be overridden if an object has to react to timers.
491
493{
494 return kFALSE;
495}
496
497////////////////////////////////////////////////////////////////////////////////
498/// Return hash value for this object.
499///
500/// Note: If this routine is overloaded in a derived class, this derived class
501/// should also add
502/// ~~~ {.cpp}
503/// ROOT::CallRecursiveRemoveIfNeeded(*this)
504/// ~~~
505/// Otherwise, when RecursiveRemove is called (by ~TObject or example) for this
506/// type of object, the transversal of THashList and THashTable containers will
507/// will have to be done without call Hash (and hence be linear rather than
508/// logarithmic complexity). You will also see warnings like
509/// ~~~
510/// Error in <ROOT::Internal::TCheckHashRecursiveRemoveConsistency::CheckRecursiveRemove>: The class SomeName overrides TObject::Hash but does not call TROOT::RecursiveRemove in its destructor.
511/// ~~~
512///
513
515{
516 //return (ULong_t) this >> 2;
517 const void *ptr = this;
518 return TString::Hash(&ptr, sizeof(void*));
519}
520
521////////////////////////////////////////////////////////////////////////////////
522/// Returns kTRUE if object inherits from class "classname".
523
524Bool_t TObject::InheritsFrom(const char *classname) const
525{
526 return IsA()->InheritsFrom(classname);
527}
528
529////////////////////////////////////////////////////////////////////////////////
530/// Returns kTRUE if object inherits from TClass cl.
531
533{
534 return IsA()->InheritsFrom(cl);
535}
536
537////////////////////////////////////////////////////////////////////////////////
538/// Dump contents of this object in a graphics canvas.
539/// Same action as Dump but in a graphical form.
540/// In addition pointers to other objects can be followed.
541///
542/// The following picture is the Inspect of a histogram object:
543/// \image html base_inspect.png
544
546{
547 gGuiFactory->CreateInspectorImp(this, 400, 200);
548}
549
550////////////////////////////////////////////////////////////////////////////////
551/// Returns kTRUE in case object contains browsable objects (like containers
552/// or lists of other objects).
553
555{
556 return kFALSE;
557}
558
559////////////////////////////////////////////////////////////////////////////////
560/// Default equal comparison (objects are equal if they have the same
561/// address in memory). More complicated classes might want to override
562/// this function.
563
565{
566 return obj == this;
567}
568
569////////////////////////////////////////////////////////////////////////////////
570/// The ls function lists the contents of a class on stdout. Ls output
571/// is typically much less verbose then Dump().
572
574{
576 std::cout <<"OBJ: " << IsA()->GetName() << "\t" << GetName() << "\t" << GetTitle() << " : ";
577 std::cout << Int_t(TestBit(kCanDelete));
578 if (option && strstr(option,"noaddr")==nullptr) {
579 std::cout <<" at: "<< this ;
580 }
581 std::cout << std::endl;
582}
583
584////////////////////////////////////////////////////////////////////////////////
585/// This method must be overridden to handle object notification (the base implementation is no-op).
586///
587/// Different objects in ROOT use the `Notify` method for different purposes, in coordination
588/// with other objects that call this method at the appropriate time.
589///
590/// For example, `TLeaf` uses it to load class information; `TBranchRef` to load contents of
591/// referenced branches `TBranchRef`; most notably, based on `Notify`, `TChain` implements a
592/// callback mechanism to inform interested parties when it switches to a new sub-tree.
594{
595 return kFALSE;
596}
597
598////////////////////////////////////////////////////////////////////////////////
599/// This method must be overridden if a class wants to paint itself.
600/// The difference between Paint() and Draw() is that when a object
601/// draws itself it is added to the display list of the pad in
602/// which it is drawn (and automatically redrawn whenever the pad is
603/// redrawn). While paint just draws the object without adding it to
604/// the pad display list.
605
607{
608 // AbstractMethod("Paint");
609}
610
611////////////////////////////////////////////////////////////////////////////////
612/// Pop on object drawn in a pad to the top of the display list. I.e. it
613/// will be drawn last and on top of all other primitives.
614
616{
617 if (!gPad || !gPad->GetListOfPrimitives())
618 return;
619
620 if (this == gPad->GetListOfPrimitives()->Last())
621 return;
622
623 TListIter next(gPad->GetListOfPrimitives());
624 while (auto obj = next())
625 if (obj == this) {
626 TString opt = next.GetOption();
627 gPad->Remove(this, kFALSE); // do not issue modified by remove
628 gPad->Add(this, opt.Data());
629 return;
630 }
631}
632
633////////////////////////////////////////////////////////////////////////////////
634/// This method must be overridden when a class wants to print itself.
635
637{
638 std::cout <<"OBJ: " << IsA()->GetName() << "\t" << GetName() << "\t" << GetTitle() << std::endl;
639}
640
641////////////////////////////////////////////////////////////////////////////////
642/// Read contents of object with specified name from the current directory.
643/// First the key with the given name is searched in the current directory,
644/// next the key buffer is deserialized into the object.
645/// The object must have been created before via the default constructor.
646/// See TObject::Write().
647
649{
650 if (gDirectory)
651 return gDirectory->ReadTObject(this,name);
652 return 0;
653}
654
655////////////////////////////////////////////////////////////////////////////////
656/// Recursively remove this object from a list. Typically implemented
657/// by classes that can contain multiple references to a same object.
658
660{
661}
662
663
664////////////////////////////////////////////////////////////////////////////////
665/// Save this object in the file specified by filename.
666///
667/// - if "filename" contains ".root" the object is saved in filename as root
668/// binary file.
669///
670/// - if "filename" contains ".xml" the object is saved in filename as a xml
671/// ascii file.
672///
673/// - if "filename" contains ".cc" the object is saved in filename as C code
674/// independant from ROOT. The code is generated via SavePrimitive().
675/// Specific code should be implemented in each object to handle this
676/// option. Like in TF1::SavePrimitive().
677///
678/// - otherwise the object is written to filename as a CINT/C++ script. The
679/// C++ code to rebuild this object is generated via SavePrimitive(). The
680/// "option" parameter is passed to SavePrimitive. By default it is an empty
681/// string. It can be used to specify the Draw option in the code generated
682/// by SavePrimitive.
683///
684/// The function is available via the object context menu.
685
686void TObject::SaveAs(const char *filename, Option_t *option) const
687{
688 //==============Save object as a root file===================================
689 if (filename && strstr(filename,".root")) {
690 if (gDirectory) gDirectory->SaveObjectAs(this,filename,"");
691 return;
692 }
693
694 //==============Save object as a XML file====================================
695 if (filename && strstr(filename,".xml")) {
696 if (gDirectory) gDirectory->SaveObjectAs(this,filename,"");
697 return;
698 }
699
700 //==============Save object as a JSON file================================
701 if (filename && strstr(filename,".json")) {
702 if (gDirectory) gDirectory->SaveObjectAs(this,filename,option);
703 return;
704 }
705
706 //==============Save object as a C, ROOT independant, file===================
707 if (filename && strstr(filename,".cc")) {
708 TString fname;
709 if (filename && strlen(filename) > 0) {
710 fname = filename;
711 } else {
712 fname.Form("%s.cc", GetName());
713 }
714 std::ofstream out;
715 out.open(fname.Data(), std::ios::out);
716 if (!out.good ()) {
717 Error("SaveAs", "cannot open file: %s", fname.Data());
718 return;
719 }
720 ((TObject*)this)->SavePrimitive(out,"cc");
721 out.close();
722 Info("SaveAs", "cc file: %s has been generated", fname.Data());
723 return;
724 }
725
726 //==============Save as a C++ CINT file======================================
727 TString fname;
728 if (filename && strlen(filename) > 0) {
729 fname = filename;
730 } else {
731 fname.Form("%s.C", GetName());
732 }
733 std::ofstream out;
734 out.open(fname.Data(), std::ios::out);
735 if (!out.good ()) {
736 Error("SaveAs", "cannot open file: %s", fname.Data());
737 return;
738 }
739 out <<"{"<<std::endl;
740 out <<"//========= Macro generated from object: "<<GetName()<<"/"<<GetTitle()<<std::endl;
741 out <<"//========= by ROOT version"<<gROOT->GetVersion()<<std::endl;
742 ((TObject*)this)->SavePrimitive(out,option);
743 out <<"}"<<std::endl;
744 out.close();
745 Info("SaveAs", "C++ Macro file: %s has been generated", fname.Data());
746}
747
748////////////////////////////////////////////////////////////////////////////////
749/// Save a primitive as a C++ statement(s) on output stream "out".
750
751void TObject::SavePrimitive(std::ostream &out, Option_t * /*= ""*/)
752{
753 out << "//Primitive: " << GetName() << "/" << GetTitle()
754 <<". You must implement " << ClassName() << "::SavePrimitive" << std::endl;
755}
756
757////////////////////////////////////////////////////////////////////////////////
758/// Set drawing option for object. This option only affects
759/// the drawing style and is stored in the option field of the
760/// TObjOptLink supporting a TPad's primitive list (TList).
761/// Note that it does not make sense to call object.SetDrawOption(option)
762/// before having called object.Draw().
763
765{
766 if (!gPad || !option) return;
767
768 TListIter next(gPad->GetListOfPrimitives());
769 delete gPad->FindObject("Tframe");
770 while (auto obj = next())
771 if (obj == this) {
772 next.SetOption(option);
773 return;
774 }
775}
776
777////////////////////////////////////////////////////////////////////////////////
778/// Set or unset the user status bits as specified in f.
779
781{
782 if (set)
783 SetBit(f);
784 else
785 ResetBit(f);
786}
787
788////////////////////////////////////////////////////////////////////////////////
789/// Set the unique object id.
790
792{
793 fUniqueID = uid;
794}
795
796////////////////////////////////////////////////////////////////////////////////
797/// Set current style settings in this object
798/// This function is called when either TCanvas::UseCurrentStyle
799/// or TROOT::ForceStyle have been invoked.
800
802{
803}
804
805////////////////////////////////////////////////////////////////////////////////
806/// Write this object to the current directory.
807/// The data structure corresponding to this object is serialized.
808/// The corresponding buffer is written to the current directory
809/// with an associated key with name "name".
810///
811/// Writing an object to a file involves the following steps:
812///
813/// - Creation of a support TKey object in the current directory.
814/// The TKey object creates a TBuffer object.
815///
816/// - The TBuffer object is filled via the class::Streamer function.
817///
818/// - If the file is compressed (default) a second buffer is created to
819/// hold the compressed buffer.
820///
821/// - Reservation of the corresponding space in the file by looking
822/// in the TFree list of free blocks of the file.
823///
824/// - The buffer is written to the file.
825///
826/// Bufsize can be given to force a given buffer size to write this object.
827/// By default, the buffersize will be taken from the average buffer size
828/// of all objects written to the current file so far.
829///
830/// If a name is specified, it will be the name of the key.
831/// If name is not given, the name of the key will be the name as returned
832/// by GetName().
833///
834/// The option can be a combination of: kSingleKey, kOverwrite or kWriteDelete
835/// Using the kOverwrite option a previous key with the same name is
836/// overwritten. The previous key is deleted before writing the new object.
837/// Using the kWriteDelete option a previous key with the same name is
838/// deleted only after the new object has been written. This option
839/// is safer than kOverwrite but it is slower.
840/// NOTE: Neither kOverwrite nor kWriteDelete reduces the size of a TFile--
841/// the space is simply freed up to be overwritten; in the case of a TTree,
842/// it is more complicated. If one opens a TTree, appends some entries,
843/// then writes it out, the behaviour is effectively the same. If, however,
844/// one creates a new TTree and writes it out in this way,
845/// only the metadata is replaced, effectively making the old data invisible
846/// without deleting it. TTree::Delete() can be used to mark all disk space
847/// occupied by a TTree as free before overwriting its metadata this way.
848/// The kSingleKey option is only used by TCollection::Write() to write
849/// a container with a single key instead of each object in the container
850/// with its own key.
851///
852/// An object is read from the file into memory via TKey::Read() or
853/// via TObject::Read().
854///
855/// The function returns the total number of bytes written to the file.
856/// It returns 0 if the object cannot be written.
857
858Int_t TObject::Write(const char *name, Int_t option, Int_t bufsize) const
859{
861 return 0;
862
863 TString opt = "";
864 if (option & kSingleKey) opt += "SingleKey";
865 if (option & kOverwrite) opt += "OverWrite";
866 if (option & kWriteDelete) opt += "WriteDelete";
867
868 if (gDirectory)
869 return gDirectory->WriteTObject(this,name,opt.Data(),bufsize);
870
871 const char *objname = name ? name : GetName();
872 Error("Write","The current directory (gDirectory) is null. The object (%s) has not been written.",objname);
873 return 0;
874}
875
876////////////////////////////////////////////////////////////////////////////////
877/// Write this object to the current directory. For more see the
878/// const version of this method.
879
881{
882 return ((const TObject*)this)->Write(name, option, bufsize);
883}
884
885////////////////////////////////////////////////////////////////////////////////
886/// Stream an object of class TObject.
887
889{
890 if (IsA()->CanIgnoreTObjectStreamer()) return;
891 UShort_t pidf;
892 if (R__b.IsReading()) {
893 R__b.SkipVersion(); // Version_t R__v = R__b.ReadVersion(); if (R__v) { }
894 R__b >> fUniqueID;
895 const UInt_t isonheap = fBits & kIsOnHeap; // Record how this instance was actually allocated.
896 R__b >> fBits;
897 fBits |= isonheap | kNotDeleted; // by definition de-serialized object are not yet deleted.
898 if (TestBit(kIsReferenced)) {
899 //if the object is referenced, we must read its old address
900 //and store it in the ProcessID map in gROOT
901 R__b >> pidf;
902 pidf += R__b.GetPidOffset();
903 TProcessID *pid = R__b.ReadProcessID(pidf);
904 if (pid) {
905 UInt_t gpid = pid->GetUniqueID();
906 if (gpid>=0xff) {
907 fUniqueID = fUniqueID | 0xff000000;
908 } else {
909 fUniqueID = ( fUniqueID & 0xffffff) + (gpid<<24);
910 }
911 pid->PutObjectWithID(this);
912 }
913 }
914 } else {
916 // Can not read TFile.h here and avoid going through the interpreter by
917 // simply hard-coding this value.
918 // This **must** be equal to TFile::k630forwardCompatibility
919 constexpr int TFile__k630forwardCompatibility = BIT(2);
920 const auto parent = R__b.GetParent();
921 if (!TestBit(kIsReferenced)) {
922 R__b << fUniqueID;
923 if (R__unlikely(parent && parent->TestBit(TFile__k630forwardCompatibility)))
924 R__b << fBits;
925 else
926 R__b << (fBits & (~kIsOnHeap & ~kNotDeleted));
927 } else {
928 //if the object is referenced, we must save its address/file_pid
929 UInt_t uid = fUniqueID & 0xffffff;
930 R__b << uid;
931 if (R__unlikely(parent && parent->TestBit(TFile__k630forwardCompatibility)))
932 R__b << fBits;
933 else
934 R__b << (fBits & (~kIsOnHeap & ~kNotDeleted));
936 //add uid to the TRefTable if there is one
938 if(table) table->Add(uid, pid);
939 pidf = R__b.WriteProcessID(pid);
940 R__b << pidf;
941 }
942 }
943}
944
945////////////////////////////////////////////////////////////////////////////////
946/// Interface to ErrorHandler (protected).
947
948void TObject::DoError(int level, const char *location, const char *fmt, va_list va) const
949{
950 const char *classname = "UnknownClass";
951 if (TROOT::Initialized())
952 classname = ClassName();
953
954 ::ErrorHandler(level, Form("%s::%s", classname, location), fmt, va);
955}
956
957////////////////////////////////////////////////////////////////////////////////
958/// Issue info message. Use "location" to specify the method where the
959/// warning occurred. Accepts standard printf formatting arguments.
960
961void TObject::Info(const char *location, const char *va_(fmt), ...) const
962{
963 va_list ap;
964 va_start(ap, va_(fmt));
965 DoError(kInfo, location, va_(fmt), ap);
966 va_end(ap);
967}
968
969////////////////////////////////////////////////////////////////////////////////
970/// Issue warning message. Use "location" to specify the method where the
971/// warning occurred. Accepts standard printf formatting arguments.
972
973void TObject::Warning(const char *location, const char *va_(fmt), ...) const
974{
975 va_list ap;
976 va_start(ap, va_(fmt));
977 DoError(kWarning, location, va_(fmt), ap);
978 va_end(ap);
979 if (TROOT::Initialized())
980 gROOT->Message(1001, this);
981}
982
983////////////////////////////////////////////////////////////////////////////////
984/// Issue error message. Use "location" to specify the method where the
985/// error occurred. Accepts standard printf formatting arguments.
986
987void TObject::Error(const char *location, const char *va_(fmt), ...) const
988{
989 va_list ap;
990 va_start(ap, va_(fmt));
991 DoError(kError, location, va_(fmt), ap);
992 va_end(ap);
993 if (TROOT::Initialized())
994 gROOT->Message(1002, this);
995}
996
997////////////////////////////////////////////////////////////////////////////////
998/// Issue system error message. Use "location" to specify the method where
999/// the system error occurred. Accepts standard printf formatting arguments.
1000
1001void TObject::SysError(const char *location, const char *va_(fmt), ...) const
1002{
1003 va_list ap;
1004 va_start(ap, va_(fmt));
1005 DoError(kSysError, location, va_(fmt), ap);
1006 va_end(ap);
1007 if (TROOT::Initialized())
1008 gROOT->Message(1003, this);
1009}
1010
1011////////////////////////////////////////////////////////////////////////////////
1012/// Issue fatal error message. Use "location" to specify the method where the
1013/// fatal error occurred. Accepts standard printf formatting arguments.
1014
1015void TObject::Fatal(const char *location, const char *va_(fmt), ...) const
1016{
1017 va_list ap;
1018 va_start(ap, va_(fmt));
1019 DoError(kFatal, location, va_(fmt), ap);
1020 va_end(ap);
1021 if (TROOT::Initialized())
1022 gROOT->Message(1004, this);
1023}
1024
1025////////////////////////////////////////////////////////////////////////////////
1026/// Use this method to implement an "abstract" method that you don't
1027/// want to leave purely abstract.
1028
1029void TObject::AbstractMethod(const char *method) const
1030{
1031 Warning(method, "this method must be overridden!");
1032}
1033
1034////////////////////////////////////////////////////////////////////////////////
1035/// Use this method to signal that a method (defined in a base class)
1036/// may not be called in a derived class (in principle against good
1037/// design since a child class should not provide less functionality
1038/// than its parent, however, sometimes it is necessary).
1039
1040void TObject::MayNotUse(const char *method) const
1041{
1042 Warning(method, "may not use this method");
1043}
1044
1045////////////////////////////////////////////////////////////////////////////////
1046/// Use this method to declare a method obsolete. Specify as of which version
1047/// the method is obsolete and as from which version it will be removed.
1048
1049void TObject::Obsolete(const char *method, const char *asOfVers, const char *removedFromVers) const
1050{
1051 const char *classname = "UnknownClass";
1052 if (TROOT::Initialized())
1053 classname = ClassName();
1054
1055 ::Obsolete(Form("%s::%s", classname, method), asOfVers, removedFromVers);
1056}
1057
1058////////////////////////////////////////////////////////////////////////////////
1059/// Get status of object stat flag.
1060
1062{
1063 return fgObjectStat;
1064}
1065////////////////////////////////////////////////////////////////////////////////
1066/// Turn on/off tracking of objects in the TObjectTable.
1067
1069{
1070 fgObjectStat = stat;
1071}
1072
1073////////////////////////////////////////////////////////////////////////////////
1074/// Return destructor only flag
1075
1077{
1078 return fgDtorOnly;
1079}
1080
1081////////////////////////////////////////////////////////////////////////////////
1082/// Set destructor only flag
1083
1085{
1086 fgDtorOnly = (Longptr_t) obj;
1087}
1088
1089////////////////////////////////////////////////////////////////////////////////
1090/// Operator delete
1091
1092void TObject::operator delete(void *ptr)
1093{
1094 if ((Longptr_t) ptr != fgDtorOnly)
1096 else
1097 fgDtorOnly = 0;
1098}
1099
1100////////////////////////////////////////////////////////////////////////////////
1101/// Operator delete []
1102
1103void TObject::operator delete[](void *ptr)
1104{
1105 if ((Longptr_t) ptr != fgDtorOnly)
1107 else
1108 fgDtorOnly = 0;
1109}
1110
1111#ifdef R__SIZEDDELETE
1112////////////////////////////////////////////////////////////////////////////////
1113/// Operator delete for sized deallocation.
1114
1115void TObject::operator delete(void *ptr, size_t size)
1116{
1117 if ((Longptr_t) ptr != fgDtorOnly)
1119 else
1120 fgDtorOnly = 0;
1121}
1122
1123////////////////////////////////////////////////////////////////////////////////
1124/// Operator delete [] for sized deallocation.
1125
1126void TObject::operator delete[](void *ptr, size_t size)
1127{
1128 if ((Longptr_t) ptr != fgDtorOnly)
1130 else
1131 fgDtorOnly = 0;
1132}
1133#endif
1134
1135////////////////////////////////////////////////////////////////////////////////
1136/// Print value overload
1137
1138std::string cling::printValue(TObject *val)
1139{
1140 std::ostringstream strm;
1141 strm << "Name: " << val->GetName() << " Title: " << val->GetTitle();
1142 return strm.str();
1143}
1144
1145////////////////////////////////////////////////////////////////////////////////
1146/// Only called by placement new when throwing an exception.
1147
1148void TObject::operator delete(void *ptr, void *vp)
1149{
1150 TStorage::ObjectDealloc(ptr, vp);
1151}
1152
1153////////////////////////////////////////////////////////////////////////////////
1154/// Only called by placement new[] when throwing an exception.
1155
1156void TObject::operator delete[](void *ptr, void *vp)
1157{
1158 TStorage::ObjectDealloc(ptr, vp);
1159}
#define R__unlikely(expr)
Definition RConfig.hxx:586
#define b(i)
Definition RSha256.hxx:100
#define f(i)
Definition RSha256.hxx:104
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
bool Bool_t
Definition RtypesCore.h:63
unsigned short UShort_t
Definition RtypesCore.h:40
int Int_t
Definition RtypesCore.h:45
long Longptr_t
Definition RtypesCore.h:75
unsigned long ULong_t
Definition RtypesCore.h:55
unsigned int UInt_t
Definition RtypesCore.h:46
float Float_t
Definition RtypesCore.h:57
constexpr Bool_t kFALSE
Definition RtypesCore.h:94
constexpr Bool_t kTRUE
Definition RtypesCore.h:93
const char Option_t
Definition RtypesCore.h:66
#define BIT(n)
Definition Rtypes.h:85
#define ClassImp(name)
Definition Rtypes.h:377
#define gDirectory
Definition TDirectory.h:384
constexpr Int_t kError
Definition TError.h:47
void ErrorHandler(int level, const char *location, const char *fmt, std::va_list va)
General error handler function. It calls the user set error handler.
Definition TError.cxx:109
constexpr Int_t kFatal
Definition TError.h:50
constexpr Int_t kWarning
Definition TError.h:46
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
Definition TError.cxx:185
constexpr Int_t kInfo
Definition TError.h:45
constexpr Int_t kSysError
Definition TError.h:49
Option_t Option_t option
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
char name[80]
Definition TGX11.cxx:110
R__EXTERN TGuiFactory * gGuiFactory
Definition TGuiFactory.h:66
#define gInterpreter
R__EXTERN TObjectTable * gObjectTable
#define ATTRIBUTE_NO_SANITIZE_ADDRESS
Definition TObject.cxx:62
Int_t gDebug
Definition TROOT.cxx:597
#define gROOT
Definition TROOT.h:406
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
Definition TString.cxx:2489
#define gPad
#define va_(arg)
Definition Varargs.h:35
#define snprintf
Definition civetweb.c:1540
Using a TBrowser one can browse all ROOT objects.
Definition TBrowser.h:37
Buffer base class used for serializing objects.
Definition TBuffer.h:43
virtual TProcessID * ReadProcessID(UShort_t pidf)=0
Return the current Process-ID.
Definition TBuffer.cxx:344
virtual UShort_t WriteProcessID(TProcessID *pid)=0
Always return 0 (current processID).
Definition TBuffer.cxx:353
TObject * GetParent() const
Return pointer to parent of this buffer.
Definition TBuffer.cxx:262
virtual UShort_t GetPidOffset() const =0
Bool_t IsReading() const
Definition TBuffer.h:86
virtual UInt_t WriteVersion(const TClass *cl, Bool_t useBcnt=kFALSE)=0
virtual void SkipVersion(const TClass *cl=nullptr)=0
TClass instances represent classes, structs and namespaces in the ROOT type system.
Definition TClass.h:81
void Draw(Option_t *option="") override
Draw detailed class inheritance structure.
Definition TClass.cxx:2487
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.
Definition TClass.cxx:4915
static Int_t AutoBrowse(TObject *obj, TBrowser *browser)
Browse external object inherited from TObject.
Definition TClass.cxx:1966
void Dump() const override
Dump contents of object on stdout.
Definition TClass.h:398
Bool_t InheritsFrom(const char *cl) const override
Return kTRUE if this class inherits from a class with name "classname".
Definition TClass.cxx:4874
virtual TInspectorImp * CreateInspectorImp(const TObject *obj, UInt_t width, UInt_t height)
Create a batch version of TInspectorImp.
Iterator of linked list.
Definition TList.h:193
Option_t * GetOption() const override
Returns the object option stored in the list.
Definition TList.cxx:1140
void SetOption(Option_t *option)
Sets the object option stored in the list.
Definition TList.cxx:1149
Each ROOT class (see TClass) has a linked list of methods.
Definition TMethod.h:38
const char * GetName() const override
Returns name of object.
Definition TNamed.h:47
const char * GetTitle() const override
Returns title of object.
Definition TNamed.h:48
An array of TObjects.
Definition TObjArray.h:31
static void AddObj(TObject *obj)
Add an object to the global object table gObjectTable.
void RemoveQuietly(TObject *obj)
Remove an object from the object table.
Mother of all ROOT objects.
Definition TObject.h:41
void AbstractMethod(const char *method) const
Use this method to implement an "abstract" method that you don't want to leave purely abstract.
Definition TObject.cxx:1029
virtual Bool_t IsFolder() const
Returns kTRUE in case object contains browsable objects (like containers or lists of other objects).
Definition TObject.cxx:554
virtual void Inspect() const
Dump contents of this object in a graphics canvas.
Definition TObject.cxx:545
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Computes distance from point (px,py) to the object.
Definition TObject.cxx:265
static void SetObjectStat(Bool_t stat)
Turn on/off tracking of objects in the TObjectTable.
Definition TObject.cxx:1068
virtual Bool_t Notify()
This method must be overridden to handle object notification (the base implementation is no-op).
Definition TObject.cxx:593
virtual Bool_t IsEqual(const TObject *obj) const
Default equal comparison (objects are equal if they have the same address in memory).
Definition TObject.cxx:564
@ kOverwrite
overwrite existing object with same name
Definition TObject.h:92
@ kSingleKey
write collection with single key
Definition TObject.h:91
@ kWriteDelete
write object, then delete previous key with same name
Definition TObject.h:93
virtual const char * GetName() const
Returns name of object.
Definition TObject.cxx:438
virtual void Browse(TBrowser *b)
Browse object. May be overridden for another default action.
Definition TObject.cxx:198
virtual void Dump() const
Dump contents of object on stdout.
Definition TObject.cxx:347
UInt_t fUniqueID
object unique identifier
Definition TObject.h:44
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
Definition TObject.h:199
virtual const char * GetIconName() const
Returns mime type name of object.
Definition TObject.cxx:448
virtual void RecursiveRemove(TObject *obj)
Recursively remove this object from a list.
Definition TObject.cxx:659
virtual void DoError(int level, const char *location, const char *fmt, va_list va) const
Interface to ErrorHandler (protected).
Definition TObject.cxx:948
virtual Bool_t HandleTimer(TTimer *timer)
Execute action in response of a timer timing out.
Definition TObject.cxx:492
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
Definition TObject.cxx:223
virtual UInt_t GetUniqueID() const
Return the unique object id.
Definition TObject.cxx:456
@ kIsOnHeap
object is on heap
Definition TObject.h:81
@ kNotDeleted
object has not been deleted
Definition TObject.h:82
UInt_t fBits
bit field status word
Definition TObject.h:45
static Longptr_t fgDtorOnly
object for which to call dtor only (i.e. no delete)
Definition TObject.h:47
virtual void Streamer(TBuffer &)
Stream an object of class TObject.
Definition TObject.cxx:888
virtual void SysError(const char *method, const char *msgfmt,...) const
Issue system error message.
Definition TObject.cxx:1001
R__ALWAYS_INLINE Bool_t IsOnHeap() const
Definition TObject.h:152
virtual const char * ClassName() const
Returns name of class to which the object belongs.
Definition TObject.cxx:207
virtual void UseCurrentStyle()
Set current style settings in this object This function is called when either TCanvas::UseCurrentStyl...
Definition TObject.cxx:801
virtual Option_t * GetDrawOption() const
Get option used by the graphics system to draw this object.
Definition TObject.cxx:422
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
Definition TObject.cxx:973
void MayNotUse(const char *method) const
Use this method to signal that a method (defined in a base class) may not be called in a derived clas...
Definition TObject.cxx:1040
virtual TObject * DrawClone(Option_t *option="") const
Draw a clone of this object in the current selected pad with: gROOT->SetSelectedPad(c1).
Definition TObject.cxx:299
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to an event at (px,py).
Definition TObject.cxx:392
virtual TObject * FindObject(const char *name) const
Must be redefined in derived classes.
Definition TObject.cxx:402
static TClass * Class()
virtual void Execute(const char *method, const char *params, Int_t *error=nullptr)
Execute method on this object with the given parameter string, e.g.
Definition TObject.cxx:358
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
Definition TObject.cxx:184
virtual char * GetObjectInfo(Int_t px, Int_t py) const
Returns string containing info about the object at position (px,py).
Definition TObject.cxx:467
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save a primitive as a C++ statement(s) on output stream "out".
Definition TObject.cxx:751
virtual Int_t Write(const char *name=nullptr, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
Definition TObject.cxx:880
@ kOnlyPrepStep
Used to request that the class specific implementation of TObject::Write just prepare the objects to ...
Definition TObject.h:106
virtual void SaveAs(const char *filename="", Option_t *option="") const
Save this object in the file specified by filename.
Definition TObject.cxx:686
virtual void Delete(Option_t *option="")
Delete this object.
Definition TObject.cxx:248
static Longptr_t GetDtorOnly()
Return destructor only flag.
Definition TObject.cxx:1076
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
Definition TObject.cxx:780
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
Definition TObject.cxx:524
static Bool_t GetObjectStat()
Get status of object stat flag.
Definition TObject.cxx:1061
virtual void Copy(TObject &object) const
Copy this to obj.
Definition TObject.cxx:140
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definition TObject.cxx:987
virtual void SetDrawOption(Option_t *option="")
Set drawing option for object.
Definition TObject.cxx:764
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
Definition TObject.cxx:1015
static void SetDtorOnly(void *obj)
Set destructor only flag.
Definition TObject.cxx:1084
virtual void SetUniqueID(UInt_t uid)
Set the unique object id.
Definition TObject.cxx:791
virtual const char * GetTitle() const
Returns title of object.
Definition TObject.cxx:482
virtual void DrawClass() const
Draw class inheritance tree of the class to which this object belongs.
Definition TObject.cxx:289
virtual TClass * IsA() const
Definition TObject.h:243
virtual Int_t Compare(const TObject *obj) const
Compare abstract method.
Definition TObject.cxx:238
virtual ~TObject()
TObject destructor.
Definition TObject.cxx:158
virtual void Draw(Option_t *option="")
Default Draw method for all objects.
Definition TObject.cxx:274
virtual void Paint(Option_t *option="")
This method must be overridden if a class wants to paint itself.
Definition TObject.cxx:606
virtual void Print(Option_t *option="") const
This method must be overridden when a class wants to print itself.
Definition TObject.cxx:636
virtual void Pop()
Pop on object drawn in a pad to the top of the display list.
Definition TObject.cxx:615
virtual ULong_t Hash() const
Return hash value for this object.
Definition TObject.cxx:514
virtual void ls(Option_t *option="") const
The ls function lists the contents of a class on stdout.
Definition TObject.cxx:573
static Bool_t fgObjectStat
if true keep track of objects in TObjectTable
Definition TObject.h:48
void ResetBit(UInt_t f)
Definition TObject.h:198
@ kCanDelete
if object in a list can be deleted
Definition TObject.h:62
@ kIsReferenced
if object is referenced by a TRef or TRefArray
Definition TObject.h:65
@ kMustCleanup
if object destructor must call RecursiveRemove()
Definition TObject.h:64
virtual Int_t Read(const char *name)
Read contents of object with specified name from the current directory.
Definition TObject.cxx:648
static void AddToTObjectTable(TObject *)
Private helper function which will dispatch to TObjectTable::AddObj.
Definition TObject.cxx:175
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
Definition TObject.cxx:961
void Obsolete(const char *method, const char *asOfVers, const char *removedFromVers) const
Use this method to declare a method obsolete.
Definition TObject.cxx:1049
A TProcessID identifies a ROOT job in a unique way in time and space.
Definition TProcessID.h:74
void PutObjectWithID(TObject *obj, UInt_t uid=0)
stores the object at the uid th slot in the table of objects The object uniqued is set as well as its...
static TProcessID * GetProcessWithUID(const TObject *obj)
static function returning a pointer to TProcessID with its pid encoded in the highest byte of obj->Ge...
static Bool_t Initialized()
Return kTRUE if the TROOT object has been initialized.
Definition TROOT.cxx:2910
static void IndentLevel()
Functions used by ls() to indent an object hierarchy.
Definition TROOT.cxx:2895
A TRefTable maintains the association between a referenced object and the parent object supporting th...
Definition TRefTable.h:35
static TRefTable * GetRefTable()
Static function returning the current TRefTable.
virtual Int_t Add(Int_t uid, TProcessID *context=nullptr)
Add a new uid to the table.
Definition TRefTable.cxx:88
static void ObjectDealloc(void *vp)
Used to deallocate a TObject on the heap (via TObject::operator delete()).
Definition TStorage.cxx:322
Basic string class.
Definition TString.h:139
const char * Data() const
Definition TString.h:376
UInt_t Hash(ECaseCompare cmp=kExact) const
Return hash value.
Definition TString.cxx:677
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Definition TString.cxx:2356
Handles synchronous and a-synchronous timer events.
Definition TTimer.h:51
small helper class to store/restore gPad context in TPad methods
Definition TVirtualPad.h:61
Double_t y[n]
Definition legend1.C:17
Double_t x[n]
Definition legend1.C:17
bool DeleteChangesMemory()
Definition TObject.cxx:127
bool DeleteChangesMemoryImpl()
Definition TObject.cxx:76
tbb::task_arena is an alias of tbb::interface7::task_arena, which doesn't allow to forward declare tb...
void CallRecursiveRemoveIfNeeded(TObject &obj)
call RecursiveRemove for obj if gROOT is valid and obj.TestBit(kMustCleanup) is true.
Definition TROOT.h:395