47void SpyServ::HandleSocket(
TSocket *s)
58 if (s->
Recv(request,
sizeof(request)) <= 0) {
68 if (!strcmp(request,
"get hpx"))
69 answer.WriteObject(fHpx);
70 else if (!strcmp(request,
"get hpxpy"))
71 answer.WriteObject(fHpxpy);
72 else if (!strcmp(request,
"get hprof"))
73 answer.WriteObject(fHprof);
75 Error(
"SpyServ::HandleSocket",
"unexpected message");
90 if (!fServ->IsValid())
102 fCanvas =
new TCanvas(
"SpyServ",
"SpyServ",200,10,700,500);
103 fCanvas->SetFillColor(42);
104 fCanvas->GetFrame()->SetFillColor(21);
105 fCanvas->GetFrame()->SetBorderSize(6);
106 fCanvas->GetFrame()->SetBorderMode(-1);
109 fHpx =
new TH1F(
"hpx",
"This is the px distribution",100,-4,4);
110 fHpxpy =
new TH2F(
"hpxpy",
"py vs px",40,-4,4,40,-4,4);
111 fHprof =
new TProfile(
"hprof",
"Profile of pz versus px",100,-4,4,0,20);
114 fHpx->SetFillColor(48);
120 for (
Int_t i = 0; ; i++) {
127 if (i ==
kUPDATE) fHpx->Draw();
134 if ((s = fMon->Select(20)) != (
TSocket*)-1)
138 if (
gROOT->IsInterrupted())
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
R__EXTERN TRandom * gRandom
R__EXTERN TSystem * gSystem
1-D histogram with a float per channel (see TH1 documentation)
2-D histogram with a float per channel (see TH1 documentation)
const char * GetHostName() const
virtual void Add(TSocket *sock, Int_t interest=kRead)
Add socket to the monitor's active list.
virtual void SetSeed(ULong_t seed=0)
Set the random generator seed.
virtual void Rannor(Float_t &a, Float_t &b)
Return 2 numbers distributed following a gaussian with mean=0 and sigma=1.
virtual Int_t Recv(TMessage *&mess)
Receive a TMessage object.
TInetAddress GetInetAddress() const
TClass * IsA() const override
virtual Int_t Send(const TMessage &mess)
Send a TMessage object.
virtual void Exit(int code, Bool_t mode=kTRUE)
Exit the application.
R__ALWAYS_INLINE bool HasBeenDeleted(const TObject *obj)
Check if the TObject's memory has been deleted.