205 gVirtualX->ShapeCombineMask(fId, 0, 0, fMask);
206 SetBackgroundPixmap(fPic);
212 gVirtualX->ChangeWindowAttributes(fId, &wattr);
241 if ((opt ==
"NEW") || (opt ==
"RECREATE"))
242 Start(filename, option);
336 if (delPreviousState)
373 fEventReplayed =
kTRUE;
375 fExtraTreeCounter = 0;
376 fFilterStatusBar =
kFALSE;
382 fShowMouseCursor =
kTRUE;
383 fWaitingForWindow =
kFALSE;
391 fWindowList =
new TList();
409 "RegisterWindow(Window_t)");
422 gCursorWin->DeleteWindow();
462 Error(
"TRecorderReplaying::Initialize",
463 "The ROOT file is not valid event logfile.");
474 Error(
"TRecorderReplaying::Initialize",
475 "The ROOT file is not valid event logfile");
481 Info(
"TRecorderReplaying::Initialize",
482 "Log file empty. No event to replay.");
491 gClient->Connect(
"RegisteredWindow(Window_t)",
"TRecorderReplaying",
492 this,
"RegisterWindow(Window_t)");
494 Info(
"TRecorderReplaying::Initialize",
"Replaying of file %s started",
498 if (f && !f->IsZombie()) {
499 TIter nextkey(f->GetListOfKeys());
502 while ((key = (
TKey*)nextkey())) {
504 obj = key->ReadObj();
512 while ((canvas = (
TCanvas*)nextc())) {
522 fTimer->
Connect(
"Timeout()",
"TRecorderReplaying",
this,
"ReplayRealtime()");
558 Error(
"TRecorderReplaying::RegisterWindow",
559 "More windows registered than expected");
565 std::ios::fmtflags
f = std::cout.flags();
566 std::cout <<
" Window registered: new ID: " <<
std::hex << w <<
567 " previous ID: " <<
fWin << std::dec << std::endl;
568 std::cout.flags( f );
587 std::ios::fmtflags
f = std::cout.flags();
589 " registered." << std::dec << std::endl;
590 std::cout.flags( f );
628 for (
Int_t i = 0; i < 5; ++i) {
649 std::ios_base::fmtflags org_flags = std::cout.flags();
654 std::cout.flags(org_flags);
830 Error(
"TRecorderReplaying::CanOverlap()",
"fGuiEvent = 0");
840 std::cout <<
"Event overlapping " <<
878 gROOT->SetEditorMode();
907 gVirtualX->LookupString(e, str,
sizeof(str), keysym);
909 if ((keysym & ~0x20) ==
kKey_S) {
930 Info(
"TRecorderReplaying::ReplayRealtime",
"Replaying finished");
952 Info(
"TRecorderReplaying::Pause",
"Replaying paused.");
960 Info(
"TRecorderReplaying::ReplayStop",
"Replaying cancelled");
1014 if (replay->
Initialize(r, showMouseCursor, mode)) {
1045 Error(
"TRecorderInactive::List",
1046 "The ROOT file is not valid event logfile.");
1055 for (
Int_t i = 0; i < entries; ++i) {
1057 std::cout <<
"[" << i <<
"] " <<
"fTime=" <<
1059 fCmdEvent->
GetText() << std::endl;
1061 std::cout << std::endl;
1088 Error(
"TRecorderInactive::ListGui",
1089 "The ROOT file is not valid event logfile.");
1099 for (
Int_t i = 0; i < entries ; ++i) {
1114 std::ios::fmtflags
f = std::cout.flags();
1115 std::cout <<
"[" << n <<
"] " << std::dec << std::setw(10)
1118 <<
" t:" << std::dec << e->
fTime
1133 for (
Int_t i=0; i<5; ++i)
1140 std::cout << std::endl;
1141 std::cout.flags( f );
1168 fReplayingState = state;
1177 Info(
"TRecorderPaused::Resume",
"Replaying resumed");
1190 Info(
"TRecorderReplaying::ReplayStop",
"Reaplying cancelled");
1213 fFilteredIdsCount = winCount;
1214 fFilteredIds =
new Window_t[fFilteredIdsCount];
1215 for(
Int_t i=0; i < fFilteredIdsCount; ++i)
1216 fFilteredIds[i] = w[i];
1219 fCmdEventPending =
kFALSE;
1222 fFilterEventPave =
kFALSE;
1231 fMouseTimer->Connect(
"Timeout()",
"TRecorderRecording",
this,
1232 "RecordMousePosition()");
1238 fWinTree =
new TTree(kWindowsTree,
"Windows");
1239 fCmdTree =
new TTree(kCmdEventTree,
"Commandline events");
1240 fGuiTree =
new TTree(kGuiEventTree,
"GUI events");
1241 fExtraTree =
new TTree(kExtraEventTree,
"Extra events");
1277 this,
"RecordCmdEvent(const char*)");
1281 gClient->Connect(
"RegisteredWindow(Window_t)",
"TRecorderRecording",
this,
1282 "RegisterWindow(Window_t)");
1287 gClient->Connect(
"ProcessedEvent(Event_t*, Window_t)",
"TRecorderRecording",
1288 this,
"RecordGuiEvent(Event_t*, Window_t)");
1293 "TRecorderRecording",
this,
"RecordGuiCNEvent(Event_t*)");
1298 this,
"RecordPave(const TObject*)");
1302 "TRecorderRecording",
this,
"RecordText(const TObject*)");
1307 "FilterEventPave()");
1316 "TRecorderRecording",
this,
"RecordGuiBldEvent(Event_t*)");
1325 Int_t numCanvases =
gROOT->GetListOfCanvases()->LastIndex();
1327 if (numCanvases >= 0){
1333 while ((twin = (
TGWindow*) nextwindow())) {
1337 std::cout <<
"WindowID "<< twin2 <<
" filtered" << std::endl;
1340 else if (twin !=
gClient->GetRoot()) {
1354 Info(
"TRecorderRecording::StartRecording",
"Recording started. Log file: %s",
1366 "RecordGuiBldEvent(Event_t*)");
1368 "RecordGuiCNEvent(Event_t*)");
1370 "RecordPave(const TObject*)");
1372 "RecordText(const TObject*)");
1375 gClient->Disconnect(
gClient,
"ProcessedEvent(Event_t*, Window_t)",
this,
1376 "RecordGuiEvent(Event_t*, Window_t)");
1378 "RegisterWindow(Window_t)");
1380 "RecordCmdEvent(const char*)");
1394 Info(
"TRecorderRecording::Stop",
"Recording finished.");
1559 cad =
"TPaveLabel *p = new TPaveLabel(";
1560 cad += pavel->
GetX1();
1562 cad += pavel->
GetY1();
1564 cad += pavel->
GetX2();
1566 cad += pavel->
GetY2();
1567 cad +=
",\"\"); p->Draw(); gPad->Modified(); gPad->Update();";
1569 interval /= (len + 2);
1571 for (i=0; i < len; ++i) {
1572 cad =
"p->SetLabel(\"";
1573 cad += (aux += label[i]);
1576 cad +=
" p->SetTextFont(83); p->SetTextSizePixels(14); ";
1578 cad +=
" gPad->Modified(); gPad->Update();";
1579 extratime += interval;
1582 cad =
"p->SetTextFont(";
1584 cad +=
"); p->SetTextSize(";
1586 cad +=
"); gPad->Modified(); gPad->Update();";
1587 extratime += interval;
1603 cad =
"TLatex *l = new TLatex(";
1604 cad += texto->
GetX();
1606 cad += texto->
GetY();
1607 cad +=
",\"\"); l->Draw(); gPad->Modified(); gPad->Update();";
1609 interval /= (len + 2);
1611 for (i=0; i < len; ++i) {
1612 cad =
"l->SetTitle(\"";
1613 cad += (aux += label[i]);
1616 cad +=
" l->SetTextFont(83); l->SetTextSizePixels(14); ";
1618 cad +=
" gPad->Modified(); gPad->Update();";
1619 extratime += interval;
1622 cad =
"l->SetTextFont(";
1624 cad +=
"); l->SetTextSize(";
1626 cad +=
"); gPad->Modified(); gPad->Update();";
1627 cad +=
" TVirtualPad *spad = gPad->GetCanvas()->GetSelectedPad();";
1628 cad +=
" gPad->GetCanvas()->Selected(spad, l, kButton1Down);";
1629 extratime += interval;
1688 for(
Int_t i=0; i<5; ++i)
1697 gVirtualX->LookupString(e, tmp,
sizeof(tmp), keysym);
1730 if ((e->
fX == 0 && e->
fY == 0)) {
1784 fFilteredIds[0] = GetId();
1789 fFilteredIds[1] = hframe->
GetId();
1795 fFilteredIds[2] = vframe->
GetId();
1802 fFilteredIds[3] = fStatusLabel->
GetId();
1809 fFilteredIds[4] = fTimeLabel->
GetId();
1815 fFilteredIds[5] = vframe->
GetId();
1817 fStatus =
new TGLabel(vframe,
"Inactive");
1818 fStatus->SetTextColor(0x7cffff);
1819 fStatus->SetBackgroundColor((
Pixel_t)0x000000);
1822 fFilteredIds[6] = fStatus->GetId();
1824 fTimeDisplay =
new TGLabel(vframe,
"00:00:00");
1825 fTimeDisplay->SetTextColor(0x7cffff);
1826 fTimeDisplay->SetTextFont(
"Helvetica -34",
kFALSE);
1827 fTimeDisplay->SetBackgroundColor((
Pixel_t)0x000000);
1830 fFilteredIds[7] = fTimeDisplay->GetId();
1838 fFilteredIds[8] = hframe->
GetId();
1843 fStartStop->Connect(
"Clicked()",
"TGRecorder",
this,
"StartStop()");
1846 fStartStop->Resize(40,40);
1847 fFilteredIds[9] = fStartStop->GetId();
1852 fReplay->Connect(
"Clicked()",
"TGRecorder",
this,
"Replay()");
1855 fReplay->Resize(40,40);
1856 fFilteredIds[10] = fReplay->GetId();
1859 fCursorCheckBox =
new TGCheckButton(
this,
"Show mouse cursor");
1861 fFilteredIds[11] = fCursorCheckBox->GetId();
1865 fTimer->Connect(
"Timeout()",
"TGRecorder",
this,
"Update()");
1869 SetEditDisabled(kEditDisable | kEditDisableGrab);
1870 SetWindowName(
"ROOT Event Recorder");
1906 running = gmtime( &elapsed_time );
1921 stime.
Form(
"%02d:%02d:%02d", running->tm_hour,
1922 running->tm_min, running->tm_sec);
1964 "All files",
"*",
"Text files",
"*.txt",
"ROOT files",
"*.root", 0, 0
1982 if (!
gROOT->GetListOfCanvases()->IsEmpty()) {
2090 Event_t *e = CreateEvent(
this);
2116 if ((e->
fX - attr.
fX > 0) && (e->
fY - attr.
fY > 0))
2131 Error(
"TRecGuiEvent::ReplayEvent",
2132 "kConfigureNotify: Unknown value: fUser[4] = %ld ",
2141 Error(
"TRecGuiEvent::ReplayEvent",
2142 "kConfigureNotify: Window does not exist anymore ");
2152 dx = px - gCursorWin->GetX();
2153 dy = py - gCursorWin->GetY();
2160 if (!gCursorWin->IsMapped()) {
2161 gCursorWin->MapRaised();
2166 gCursorWin->RaiseWindow();
2168 gCursorWin->Move(e->
fXRoot + gDecorWidth, e->
fYRoot + gDecorHeight);
2188 gClient->HandleMaskEvent(e, fMasked);
2226 for(
Int_t i=0; i<5; ++i)
void RegisterWindow(Window_t w)
This method is called when RegisteredWindow(Window_t) is emitted from TGClient.
virtual const char * BaseName(const char *pathname)
Base name of a file name. Base name of /user/root is root.
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
virtual const char * GetTitle() const
Returns title of object.
void RecordCmdEvent(const char *line)
Records commandline event (text and time) ans saves the previous commandline event This 1 event delay...
TGPictureButton * fReplay
virtual void Resize(UInt_t w=0, UInt_t h=0)
Resize the frame.
TRecExtraEvent * fExtraEvent
const char * kRecEventNames[]
Bool_t Replay(const char *filename, Bool_t showMouseCursor=kTRUE, TRecorder::EReplayModes mode=kRealtime)
Replays events from 'filename'.
friend class TRecorderInactive
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
void CopyEvent(Event_t *e, Window_t wid)
Copies all items of given event to fGuiEvent.
void RecordText(const TObject *obj)
Records TLatex object created in TCreatePrimitives::Text()
void FilterEventPave()
Change the state of the flag to kTRUE when you are recording a pavelabel.
void ListGui(const char *filename)
Prints out recorded GUI events.
virtual Font_t GetTextFont() const
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
static long DisplayValid(Long_t n)
const TGWindow * GetParent() const
void Reset()
Reset the timer.
virtual void SetTextColor(Pixel_t color, Bool_t global=kFALSE)
Changes text color.
virtual Int_t Fill()
Fill all branches.
void RecordExtraEvent(TString line, TTime extTime)
Records TLatex or TPaveLabel object created in TCreatePrimitives, ExtTime is needed for the correct r...
virtual void ListCmd(const char *)
const char * kCmdEventTree
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
TGCheckButton * fCursorCheckBox
virtual Float_t GetTextSize() const
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
static const char * filename()
virtual void Pause(TRecorder *)
virtual Int_t GetEntry(Long64_t entry=0, Int_t getall=0)
Read all branches of entry and return total number of bytes read.
R__EXTERN Atom_t gWM_DELETE_WINDOW
virtual TTime GetTime() const
TSeqCollection * fCollect
virtual Bool_t Replay(TRecorder *, const char *, Bool_t, TRecorder::EReplayModes)
virtual void SetTime(TTime t)
R__EXTERN TApplication * gApplication
Bool_t FilterEvent(TRecGuiEvent *e)
Basic time type with millisecond precision.
TObject * Next()
Return next object in the list. Returns 0 when no more objects in list.
UInt_t GetWindowHeight() const
void Start(const char *filename, Option_t *option="RECREATE", Window_t *w=0, Int_t winCount=0)
Starts recording events.
void RecordPave(const TObject *obj)
Records TPaveLabel object created in TCreatePrimitives::Pave()
virtual void ReplayStop(TRecorder *)
R__EXTERN TVirtualDragManager * gDragManager
Int_t UnLock()
Unlock the mutex.
TGCursorWindow()
TGCursorWindow constructor.
friend class TRecorderPaused
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=1, Int_t netopt=0)
Create / open a file.
virtual void ReplayStop(TRecorder *r)
Replaying is cancelled.
TRecorderReplaying * fReplayingState
const char * Data() const
virtual void Start(TRecorder *, const char *, Option_t *, Window_t *, Int_t)
void Update()
Called when fTimer timeouts (every 0.025 second) Updates GUI of recorder.
virtual Bool_t IsOpen() const
Returns kTRUE in case file is open and kFALSE if file is not open.
virtual Int_t SetBranchAddress(const char *bname, void *add, TBranch **ptr=0)
Change branch address, dealing with clone trees properly.
friend class TRecorderInactive
virtual void SetText(TGString *newText)
Set new text in label.
TRecorder()
Creates initial INACTIVE state for the recorder.
virtual void Start(Long_t milliSec=-1, Bool_t singleShot=kFALSE)
Starts the timer with a milliSec timeout.
To draw Mathematical Formula.
virtual void Stop(TRecorder *, Bool_t)
void RecordGuiCNEvent(Event_t *e)
Records GUI Event_t *e of type kConfigureNotify.
if(pyself &&pyself!=Py_None)
void Info(const char *location, const char *msgfmt,...)
void RecordMousePosition()
Try to record all mouse moves...
virtual void SetBackgroundColor(Pixel_t back)
Set background color (override from TGWindow base class).
virtual void ListGui(const char *filename)
Prints out GUI events recorded in given file.
void Replay()
Handles push of fReplay button according to the current recorder state.
Book space in a file, create I/O buffers, to fill them, (un)compress them.
Bool_t Initialize(TRecorder *r, Bool_t showMouseCursor, TRecorder::EReplayModes mode)
Initialization of data structures for replaying.
const char * AsString() const
void ListCmd(const char *filename)
Prints out recorded commandline events.
void Error(const char *location, const char *msgfmt,...)
TRecExtraEvent * fExtraEvent
virtual ~TGRecorder()
Destructor. Cleanup the GUI.
A Pave (see TPave) with a text centered in the Pave.
void SetText(const char *text)
Using a TBrowser one can browse all ROOT objects.
Bool_t Connect(const char *signal, const char *receiver_class, void *receiver, const char *slot)
Non-static method is used to connect from the signal of this object to the receiver slot...
virtual void Resize(UInt_t w, UInt_t h)
Resize the window.
virtual Bool_t Replay(TRecorder *r, const char *filename, Bool_t showMouseCursor, TRecorder::EReplayModes mode)
Switches from INACTIVE state of recorder to REPLAYING Return kTRUE if replaying has started or kFALSE...
const char * GetText() const
virtual void Stop(TRecorder *r, Bool_t guiCommand)
Disconnects all slots and stopps recording.
R__EXTERN TSystem * gSystem
const Mask_t kWASaveUnder
void Resume()
Resumes replaying.
void ChangeState(TRecorderState *newstate, Bool_t deletePreviousState=kTRUE)
Changes state from the current to the passed one (newstate) Deletes the old state if delPreviousState...
virtual Int_t Write(const char *name=0, Int_t opt=0, Int_t bufsiz=0)
Write memory objects to this file.
static const char * gFiletypes[]
void RegisterWindow(Window_t w)
Creates mapping for the newly registered window w and adds this mapping to fWindowList.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
void SetTypeOfConfigureNotify(Event_t *e)
Sets type of kConfigureNotify event to one of EConfigureNotify.
virtual void Continue()
Continues previously paused replaying.
virtual void TurnOff()
Remove timer from system timer list.
static void DumpRootEvent(TRecGuiEvent *e, Int_t n)
Prints out attributes of one GUI event TRecGuiEvent *e Int_n n is number of event if called in cycle...
void ReplayRealtime()
Replays the next event.
Handles synchronous and a-synchronous timer events.
virtual const char * GetName() const
Returns name of object.
ClassImp(TRecorderReplaying) TRecorderReplaying
Allocates all necessary data structures used for replaying What is allocated here is deleted in destr...
static Int_t gDecorHeight
const char * kGuiEventTree
UInt_t GetWindowWidth() const
virtual ERecEventType GetType() const =0
Bool_t PrepareNextEvent()
Finds the next event in log file to replay and sets it to fNextEvent.
static const Int_t fgWidgetsCount
virtual void Move(Int_t x, Int_t y)
Move the window.
const char * kExtraEventTree
void PrevCanvases(const char *filename, Option_t *option)
Save previous canvases in a .root file.
void RecordGuiEvent(Event_t *e, Window_t wid)
Records GUI Event_t *e different from kConfigureNotify (they are recorded in TRecorderRecording::Reco...
virtual void ReplayEvent(Bool_t showMouseCursor=kTRUE)=0
TRecorderState * fRecorderState
Pixmap_t GetPicture() const
virtual void ListCmd(const char *filename)
Prints out commandline events recorded in given file.
void StartStop()
Handles push of the fStartStop button according to the current recorder state.
unsigned long long ULong64_t
const Mask_t kWAOverrideRedirect
Int_t Lock()
Lock the mutex.
void RecordGuiBldEvent(Event_t *e)
Special case for the gui builder, having a timer handling some of the events.
Bool_t Disconnect(const char *signal=0, void *receiver=0, const char *slot=0)
Disconnects signal of this object from slot of receiver.
void ReplayStop()
Cancells replaying.
void SetWindowSize(UInt_t ww, UInt_t wh)
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
void SetDefault()
Sets GUI to the default inactive state.
const char * GetLabel() const
void StartEditing()
Memorize the starting time of editinga TLatex or a TPaveLabel.
Mother of all ROOT objects.
Window_t fFilteredIds[fgWidgetsCount]
virtual Int_t Branch(TCollection *list, Int_t bufsize=32000, Int_t splitlevel=99, const char *name="")
Create one branch for each element in the collection.
virtual void MoveResize(Int_t x, Int_t y, UInt_t w, UInt_t h)
Move and resize the window.
virtual void Draw(Option_t *option="")
Draw a canvas.
Bool_t StartRecording()
Connects appropriate signals and slots in order to gain all registered windows and processed events i...
typedef void((*Func_t)())
virtual ~TGCursorWindow()
Destructor.
virtual void PrevCanvases(const char *, Option_t *)
void Stop(Bool_t guiCommand=kFALSE)
Stopps recording events.
RooCmdArg Layout(Double_t xmin, Double_t xmax=0.99, Double_t ymin=0.95)
virtual void ReplayStop(TRecorder *r)
Cancels replaying.
virtual void Resume(TRecorder *)
virtual void Add(TObject *obj)
Bool_t IsFiltered(Window_t id)
Returns kTRUE if passed id belongs to window IDs of recorder GUI itself.
virtual void Resume(TRecorder *r)
Continues replaying.
static TGCursorWindow * gCursorWin
virtual Bool_t HandleTimerEvent(Event_t *, TTimer *)
static Event_t * CreateEvent(TRecGuiEvent *ge)
Converts TRecGuiEvent type to Event_t type.
virtual ~TRecorderReplaying()
Closes all signal-slot connections Frees all memory allocated in contructor.
void Pause()
Pauses replaying.
virtual ~TRecorder()
Destructor.
virtual Long64_t GetEntries() const
A TTree object has a header with a name and a title.
virtual void ListGui(const char *)
virtual TRecorder::ERecorderState GetState() const =0
virtual void Pause(TRecorder *r)
Pauses replaying.
const Mask_t kKeyControlMask
virtual void ReplayEvent(Bool_t showMouseCursor=kTRUE)
virtual ~TRecorderRecording()
Freeing of allocated memory.
virtual TRecorder::ERecorderState GetState() const
Get current state of recorder.
virtual void Cleanup()
Cleanup and delete all objects contained in this composite frame.
virtual void TurnOn()
Add the timer to the system timer list.
TGPictureButton * fStartStop
void PrevCanvases(const char *filename, Option_t *option)
Save previous canvases in a .root file.
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write all objects in this collection.
void Browse(TBrowser *)
Browse the recorder from a ROOT file.
friend class TRecorderInactive
const char * kWindowsTree
R__EXTERN Atom_t gROOT_MESSAGE
Bool_t RemapWindowReferences()
All references to the old windows (IDs) in fNextEvent are replaced by new ones according to the mappi...
virtual void Close(Option_t *option="")
Close a file.
Bool_t CanOverlap()
ButtonPress and ButtonRelease must be sometimes replayed more times Example: pressing of a button ope...