79#define kPEX_STOPPED 1001
80#define kPEX_ABORTED 1002
86class TAutoBinVal :
public TNamed {
88 Double_t fXmin, fXmax, fYmin, fYmax, fZmin, fZmax;
96 fZmin = zmin; fZmax = zmax;
103 zmin = fZmin; zmax = fZmax;
112class TDispatchTimer :
public TTimer {
126Bool_t TDispatchTimer::Notify()
128 if (
gDebug > 0) printf(
"TDispatchTimer::Notify: called!\n");
141class TProctimeTimer :
public TTimer {
155Bool_t TProctimeTimer::Notify()
157 if (
gDebug > 0) printf(
"TProctimeTimer::Notify: called!\n");
169class TStopTimer :
public TTimer {
187 :
TTimer(((to <= 0 || to > 864000) ? 10 : to * 1000),
kFALSE)
190 Info (
"TStopTimer",
"enter: %d, timeout: %d", abort, to);
196 Info (
"TStopTimer",
"timeout set to %s ms", fTime.AsString());
205Bool_t TStopTimer::Notify()
207 if (
gDebug > 0) printf(
"TStopTimer::Notify: called!\n");
227 : fAutoBins(0), fOutput(0), fSelector(0), fCreateSelObj(
kTRUE), fSelectorClass(0),
228 fFeedbackTimer(0), fFeedbackPeriod(2000),
229 fEvIter(0), fSelStatus(0),
230 fTotalEvents(0), fReadBytesRun(0), fReadCallsRun(0), fProcessedRun(0),
231 fQueryResults(0), fQuery(0), fPreviousQuery(0), fDrawQueries(0),
232 fMaxDrawQueries(1), fStopTimer(0), fDispatchTimer(0),
233 fProcTimeTimer(0), fProcTime(0),
235 fSaveMemThreshold(-1), fSavePartialResults(
kFALSE), fSaveResultsPerPacket(
kFALSE)
248 initLimitsFinder =
kTRUE;
290 Info (
"StopProcess",
"abort: %d, timeout: %d", abort, timeout);
295 if (abort ==
kTRUE) {
331 fStopTimer =
new TStopTimer(
this, abort, timeout);
335 Info (
"SetStopTimer",
"%s timer STARTED (timeout: %d)",
336 (abort ?
"ABORT" :
"STOP"), timeout);
339 Info (
"SetStopTimer",
"timer STOPPED");
350 Warning(
"AddQueryResult",
"query undefined - do nothing");
355 if (!(
q->IsDraw())) {
431 if (ref && strlen(ref) > 0) {
505 Info(
"ReinitSelector",
"query undefined - do nothing");
511 if (selec.
Length() <= 0) {
512 Info(
"ReinitSelector",
"selector name undefined - do nothing");
525 if (!stdselec && !compselec) {
532 TMD5 *md5icur = 0, *md5iold = 0, *md5hcur = 0, *md5hold = 0;
546 if (md5hcur && md5hold && md5icur && md5iold)
547 if (*md5hcur == *md5hold && *md5icur == *md5iold)
554 if (selc)
delete [] selc;
586 selec += opt(
id + 1, opt.
Length());
589 Info(
"ReinitSelector",
"problems locating or exporting selector files");
637 Info(
"ReinitSelector",
"compiled selector re-init failed:"
638 " automatic reload unsuccessful:"
639 " please load manually the correct library");
655 if (ipathold.
Length() > 0)
786 Info(
"SavePartialResults",
"partial result saving disabled");
792 Error(
"SavePartialResults",
"gProofServ undefined: something really wrong going on!!!");
796 Error(
"SavePartialResults",
"fOutput undefined: something really wrong going on!!!");
801 Info(
"SavePartialResults",
"start saving partial results {%d,%d,%d,%d}",
805 PDB(kOutput, 2)
Info(
"SavePartialResults",
"fEvIter: %p",
fEvIter);
808 PDB(kOutput, 2)
Info(
"SavePartialResults",
"list of packets: %p, sz: %d",
809 packets, (packets ? packets->
GetSize(): -1));
812 const char *oopt =
"UPDATE";
841 if (packetsDir) packetsDir->
cd();
851 while ((o = nxo())) {
853 if (o->
InheritsFrom(TProofOutputFile::Class()))
continue;
855 if (!strncmp(o->
GetName(),
"PROOF_", 6))
continue;
857 if (o->
InheritsFrom(TOutputListSelectorDataMap::Class()))
continue;
859 if (!strcmp(o->
GetName(),
"MissingFiles"))
continue;
865 if (!
d || (
d && !
d->InheritsFrom(
"TFile"))) {
890 if (queryend) torm.
Add(o);
917 if (!strcmp(
TUrl(oname,
kTRUE).GetProtocol(),
"file")) {
930 oname.
Form(
"<datadir>/%s", baseName.
Data());
950 if (queryend && torm.
GetSize() > 0) {
957 Info(
"SavePartialResults",
"partial results saved to file");
968 if (selector_file && strlen(selector_file)) {
986 Error(
"AssertSelector",
"cannot load: %s", selector_file );
991 Info(
"AssertSelector",
"Processing via filename (%s)", selector_file);
993 Error(
"AssertSelector",
"no TSelector object define : cannot continue!");
996 Info(
"AssertSelector",
"Processing via TSelector object");
1027 PDB(kGlobal,1)
Info(
"Process",
"Enter");
1038 Error(
"Process",
"cannot assert the selector object");
1065 while ((
e = dset->
Next())) {
1073 Int_t useTreeCache = 1;
1075 if (useTreeCache > -1 && useTreeCache < 2)
1076 gEnv->
SetValue(
"ProofPlayer.UseTreeCache", useTreeCache);
1084 Int_t useParallelUnzip = 0;
1086 if (useParallelUnzip > -1 && useParallelUnzip < 2)
1087 gEnv->
SetValue(
"ProofPlayer.UseParallelUnzip", useParallelUnzip);
1090 Int_t dontCacheFiles = 0;
1092 if (dontCacheFiles == 1)
1105 opt =
gEnv->
GetValue(
"ProofPlayer.SavePartialResults", 0);
1118 Info(
"Process",
"memory threshold for saving objects to file set to %ld kB",
1121 Error(
"Process",
"cannot get SysInfo_t (!)");
1126 PDB(kLoop,1)
Info(
"Process",
"Call Begin(0)");
1131 PDB(kLoop,1)
Info(
"Process",
"Call Begin(0)");
1135 PDB(kLoop,1)
Info(
"Process",
"Call SlaveBegin(0)");
1143 Error(
"Process",
"exception %d caught", excode);
1150 Warning(
"Process",
"problems seetting up file-object swapping");
1159 Info(
"Process",
"Looping over Process()");
1186 TString lastMsg(
"(unfortunately no detailed info is available about current packet)");
1189 if (!
CheckMemUsage(singleshot, warnHWMres, warnHWMvir, wmsg)) {
1199 }
else if (!wmsg.
IsNull()) {
1203 TPair *currentElem = 0;
1230 lastMsg =
"check logs for possible stacktrace - last cycle:";
1234 lastMsg.
Form(
"while processing dset:'%s', file:'%s'"
1235 " - check logs for possible stacktrace - last event:", dset->
GetName(), fn.
Data());
1248 if (maxproctime > 0) {
1255 if (refnum < 0 && maxproctime <= 0) {
1256 wmsg.
Form(
"neither entries nor max proc time specified:"
1257 " risk of infinite loop: processing aborted");
1268 while (refnum < 0 || num--) {
1285 Info(
"Process",
"max proc time reached (%ld msecs): packet processing stopped:\n%s",
1286 maxproctime, lastMsg.
Data());
1304 Info(
"Process",
"Call ProcessCut(%lld)", entry);
1307 Info(
"Process",
"Call ProcessFill(%lld)", entry);
1312 Info(
"Process",
"Call Process(%lld)", entry);
1318 Info(
"Process",
"packet processing aborted following the"
1319 " selector settings:\n%s", lastMsg.
Data());
1328 if (!
CheckMemUsage(memlogfreq, warnHWMres, warnHWMvir, wmsg)) {
1365 Info(
"Process",
"received stop-process signal");
1369 Info(
"Process",
"received abort-process signal");
1372 Error(
"Process",
"exception %d caught", excode);
1381 TPair *currentElem = 0;
1384 delete currentElem->
Key();
1393 if (!wmsg.
IsNull())
Warning(
"Process",
"%s (%s)", wmsg.
Data(), shrc ?
"warn" :
"hwm");
1415 Warning(
"Process",
"problems saving the results to file");
1425 while ((o = nxo())) {
1427 if (o->IsA() == TProofOutputFile::Class()) {
1431 const char *dir = of->
GetDir();
1432 if (!dir || (dir && strlen(dir) <= 0)) {
1434 }
else if (dir && strlen(dir) > 0) {
1436 if (!strcmp(u.
GetHost(),
"localhost") || !strcmp(u.
GetHost(),
"127.0.0.1") ||
1437 !strcmp(u.
GetHost(),
"localhost.localdomain")) {
1450 PDB(kLoop,1)
Info(
"Process",
"Call Terminate()");
1453 PDB(kLoop,1)
Info(
"Process",
"Call SlaveTerminate()");
1456 PDB(kLoop,1)
Info(
"Process",
"Call Terminate()");
1489 Error(
"Process",
"selector object undefiend!");
1516 if (mfreq > 0 && processed%mfreq == 0) {
1522 Info(
"CheckMemUsage|Svc",
"Memory %ld virtual %ld resident event %lld",
1529 wmsg.
Form(
"using more than %d%% of allowed virtual memory (%ld kB)"
1535 wmsg.
Form(
"using more than %d%% of allowed virtual memory (%ld kB)",
1543 wmsg.
Form(
"using more than %d%% of allowed resident memory (%ld kB)"
1550 wmsg.
Form(
"using more than %d%% of allowed both virtual and resident memory ({%ld,%ld} kB)",
1553 wmsg.
Form(
"using more than %d%% of allowed resident memory (%ld kB)",
1701 if (!gDrawCanvasHook) {
1703 TString drawlib =
"libProofDraw";
1713 Warning(
"DrawCanvas",
"can't find DrawCanvas");
1715 Warning(
"DrawCanvas",
"can't load %s", drawlib.
Data());
1717 Warning(
"DrawCanvas",
"can't locate %s", drawlib.
Data());
1719 if (gDrawCanvasHook && obj)
1720 return (*gDrawCanvasHook)(obj);
1733 static Int_t (*gGetDrawArgsHook)(
const char *,
const char *,
Option_t *,
1737 if (!gGetDrawArgsHook) {
1739 TString drawlib =
"libProofDraw";
1747 gGetDrawArgsHook = (
Int_t (*)(
const char *,
const char *,
Option_t *,
1750 Warning(
"GetDrawArgs",
"can't find GetDrawArgs");
1752 Warning(
"GetDrawArgs",
"can't load %s", drawlib.
Data());
1754 Warning(
"GetDrawArgs",
"can't locate %s", drawlib.
Data());
1756 if (gGetDrawArgsHook)
1757 return (*gGetDrawArgsHook)(var, sel, opt, selector, objname);
1767 static void (*gFeedBackCanvasHook)(
const char *,
Bool_t) = 0;
1770 if (!gFeedBackCanvasHook) {
1772 TString drawlib =
"libProofDraw";
1780 gFeedBackCanvasHook = (
void (*)(
const char *,
Bool_t))(
f);
1782 Warning(
"FeedBackCanvas",
"can't find FeedBackCanvas");
1784 Warning(
"FeedBackCanvas",
"can't load %s", drawlib.
Data());
1786 Warning(
"FeedBackCanvas",
"can't locate %s", drawlib.
Data());
1788 if (gFeedBackCanvasHook) (*gFeedBackCanvasHook)(
name, create);
1820 if (fNumMergers <= 0 && fProof->fMergersCount > 0)
1856 Error(
"Process",
"selector object undefiend!");
1917 const char *defpackdata)
1920 PDB(kGlobal,1)
Info(
"Process",
"Enter");
1925 Int_t honebyone = 1;
1927 honebyone =
gEnv->
GetValue(
"ProofPlayer.MergeTH1OneByOne", 1);
1933 TList *listOfMissingFiles = 0;
1942 packetizer = defpackunit;
1944 Info(
"InitPacketizer",
"using alternate packetizer: %s", packetizer.
Data());
1949 Error(
"InitPacketizer",
"class '%s' not found", packetizer.
Data());
1957 Error(
"InitPacketizer",
1958 "cannot find correct constructor for '%s'", cl->
GetName());
1973 Error(
"InitPacketizer",
"received stop/abort request");
1979 packetizer =
"TPacketizerMulti";
1984 Error(
"InitPacketizer",
"class '%s' not found", packetizer.
Data());
1992 Error(
"InitPacketizer",
"cannot find correct constructor for '%s'", cl->
GetName());
2018 listOfMissingFiles =
new TList;
2027 Error(
"InitPacketizer",
"received stop/abort request");
2036 Error(
"InitPacketizer",
"No files from the data set were found - Aborting");
2038 if (listOfMissingFiles) {
2048 packetizer = defpackdata;
2050 Info(
"InitPacketizer",
"using alternate packetizer: %s", packetizer.
Data());
2055 Error(
"InitPacketizer",
"class '%s' not found", packetizer.
Data());
2063 Error(
"InitPacketizer",
"cannot find correct constructor for '%s'", cl->
GetName());
2084 Error(
"InitPacketizer",
"cannot construct '%s'", cl->
GetName());
2090 Error(
"InitPacketizer",
2091 "instantiated packetizer object '%s' is invalid", cl->
GetName());
2112 if (!listOfMissingFiles)
2113 listOfMissingFiles =
new TList;
2123 if (listOfMissingFiles && listOfMissingFiles->
GetSize() > 0) {
2124 TIter missingFiles(listOfMissingFiles);
2130 msg =
Form(
"File not found: %s - skipping!",
2133 msg =
Form(
"File not found: %s - skipping!", fi->
GetName());
2140 listOfMissingFiles->
SetName(
"MissingFiles");
2150 msg =
Form(
" About %.2f %c of the requested files (%d out of %d) were missing or unusable; details in"
2151 " the 'missingFiles' list", xb * 100.,
'%', nbad, nbad + ngood);
2154 " +++ About %.2f %c of the requested files (%d out of %d) are missing or unusable; details in"
2155 " the 'MissingFiles' list\n"
2156 " +++", xb * 100.,
'%', nbad, nbad + ngood);
2178 PDB(kGlobal,1)
Info(
"Process",
"Enter");
2184 Error(
"Process",
"No progress status");
2221 TList *inputtmp = 0;
2225 PDB(kPacketizer,1)
Info(
"Process",
"Create Proxy TDSet");
2232 Error(
"Process",
"cannot init the packetizer");
2247 if (clf.
IsDigit()) { memlogfreq = clf.
Atoi(); mrc = 0; }
2250 if (memlogfreq == 0) {
2252 if (memlogfreq <= 0) memlogfreq = 1;
2260 Warning(
"Process",
"could not forward input data: %s", emsg.
Data());
2265 Warning(
"Process",
"could not attach to histogram 'PROOF_ProcPcktHist'");
2268 Info(
"Process",
"attached to histogram 'PROOF_ProcPcktHist' to record"
2269 " packets being processed");
2303 Info(
"Process",
"starting new query");
2326 while ((o = nxi())) {
2330 inputtmp =
new TList;
2344 PDB(kLoop,1)
Info(
"Process",
"Call Begin(0)");
2379 mesg << set << fn <<
fInput << opt << num << fst << evl << sync << enl;
2380 (*fProcessMessage) << set << fn <<
fInput << opt << num << fst << evl << sync << enl;
2382 mesg << set << fn <<
fInput << opt << num << fst << evl << sync;
2385 Warning(
"Process",
"entry lists not supported by the server");
2392 PDB(kGlobal,1)
Info(
"Process",
"Broadcast called: %d workers notified", nb);
2405 Info(
"Process|Svc",
"Start merging Memory information");
2412 PDB(kGlobal,1)
Info(
"Process",
"Asynchronous processing:"
2413 " activating CollectInputFrom");
2422 PDB(kGlobal,1)
Info(
"Process",
"Calling Collect");
2447 PDB(kGlobal,1)
Info(
"Process",
"Synchronous processing: calling Collect");
2451 Info(
"Process",
"switching to the asynchronous mode ...");
2489 TIter nxi(inputtmp);
2511 Error(
"Process",
"selector object undefined");
2536 Error(
"Process",
"Should not happen: fProcessMessage=%p fProof=%p fPacketizer=%p",
2542 Error(
"Process",
"Invalid call");
2547 Info(
"Process",
"Preparing %d new worker(s) to process", workers->
GetEntries());
2562 Info(
"Process",
"Adding new workers to the packetizer");
2564 Error(
"Process",
"Cannot add new workers to the packetizer!");
2569 Info(
"Process",
"Broadcasting process message to new workers");
2592 while ((o = nxo())) {
2603 Error(
"MergeOutputFiles",
"file merger is null in TProofOutputFile! Protocol error?");
2621 if (outfile.
Contains(
"<datadir>/")) {
2667 outfilerem.
Insert(0, srv);
2675 Error(
"MergeOutputFiles",
"cannot open the output file");
2680 if (!filemerger->
Merge()) {
2681 Error(
"MergeOutputFiles",
"cannot merge the output files");
2687 TIter next(fileList);
2699 filemerger->
Reset();
2709 pf->
Merge(&dumlist);
2714 Error(
"MergeOutputFiles",
"file collection is null in TProofOutputFile! Protocol error?");
2735 if (!rmList) rmList =
new TList;
2744 if (rmList && rmList->
GetSize() > 0) {
2747 while((o = nxo())) {
2754 PDB(kOutput,1)
Info(
"MergeOutputFiles",
"done!");
2771 PDB(kOutput,1)
Warning(
"SetSelectorDataMembersFromOutputList",
2772 "failed to find map object in output list!");
2794 PDB(kGlobal,1)
Info(
"Finalize",
"Calling Merge Output to finalize the output list");
2813 PDB(kOutput,1)
Info(
"Finalize",
"Calling Merge Output");
2837 if (!listOfMissingFiles) {
2838 listOfMissingFiles =
new TList;
2839 listOfMissingFiles->
SetName(
"MissingFiles");
2865 Info(
"Finalize",
"problems reinitializing selector \"%s\"",
2874 failedPackets->SetName(
"FailedPackets");
2879 status->
Add(
"Some packets were not processed! Check the the"
2880 " 'FailedPackets' list in the output list");
2889 while(
TObject* obj = next()) {
2896 Warning(
"Finalize",
"undefined output list in the selector! Protocol error?");
2908 PDB(kLoop,1)
Info(
"Finalize",
"Call Terminate()");
2930 Warning(
"Finalize",
"current TQueryResult object is undefined!");
2960 PDB(kGlobal,1)
Info(
"Process",
"exit");
2975 PDB(kGlobal,1)
Info(
"Finalize(TQueryResult *)",
"Enter");
2978 Info(
"Finalize(TQueryResult *)",
2979 "method to be executed only on the clients");
2984 Info(
"Finalize(TQueryResult *)",
"query undefined");
2989 Info(
"Finalize(TQueryResult *)",
"query already finalized");
3013 Info(
"Finalize(TQueryResult *)",
"outputlist is empty");
3047 if (!selector_file) {
3048 Info(
"SendSelector",
"Invalid input: selector (file) name undefined");
3054 Info(
"SendSelector",
"selector name '%s' does not contain a '.':"
3055 " nothing to send, it will be loaded from a library", selector_file);
3060 TString selec = selector_file;
3092 Info(
"SendSelector",
3093 "header file not found: tried: %s %s",
h.Data(), header.
Data());
3100 Info(
"SendSelector",
"problems sending implementation file %s", selec.
Data());
3104 Info(
"SendSelector",
"problems sending header file %s", header.
Data());
3116 PDB(kOutput,1)
Info(
"MergeOutput",
"Enter");
3124 while ( (list = (
TList *) next()) ) {
3127 obj = list->
First();
3132 if ( list->
IsEmpty() )
continue;
3142 while ( (obj = list->
First()) ) {
3152 PDB(kOutput,1)
Info(
"MergeOutput",
"fOutputLists empty");
3169 while ((obj = nxo())) {
3173 PDB(kOutput,2)
Info(
"MergeOutput",
"found TProofOutputFile '%s'", obj->
GetName());
3175 PDB(kOutput,2)
Info(
"MergeOutput",
"outputfilename: '%s'", dir.
Data());
3178 PDB(kOutput,2)
Info(
"MergeOutput",
"dir: '%s'", dir.
Data());
3187 PDB(kOutput,2)
Info(
"MergeOutput",
"rawdir: '%s'", dir.
Data());
3222 PDB(kOutput,2)
Info(
"MergeOutput",
"output object '%s' is not a TProofOutputFile", obj->
GetName());
3228 TIter nxrm(&rmlist);
3229 while ((obj = nxrm()))
3236 if (saveMemValues) {
3273 Info(
"Progress",
"%lld %lld %lld %f %f %f %f",
total, processed, bytesread,
3274 initTime, procTime, evtrti, mbrti);
3281 m <<
total << processed << bytesread << initTime << procTime << evtrti << mbrti;
3309 Warning(
"Progress",
"TProofProgressInfo object undefined!");
3347 Info(
"AddOutputObject",
"Enter: %p (%s)", obj, obj ? obj->
ClassName() :
"undef");
3351 PDB(kOutput,1)
Info(
"AddOutputObject",
"Invalid input (obj == 0x0)");
3364 if (elists && !strcmp(elists->
GetName(),
"PROOF_EventListsList")) {
3371 TIter nxevl(elists);
3373 while ((evl =
dynamic_cast<TEventList *
> (nxevl()))) {
3379 while ((elem =
dynamic_cast<TDSetElement *
> (nxelem()))) {
3384 Error(
"AddOutputObject",
"Found an event list for %s, but no object with"
3385 " the same name in the TDSet", evl->
GetName());
3393 if (arr && offset > 0)
3394 for (
Int_t i = 0; i < num; i++)
3460 if (!of.
EndsWith(
".merger")) of +=
".merger";
3482 return (merged ? 1 : 0);
3509 PDB(kOutput,1)
Info(
"AddOutput",
"Enter");
3513 PDB(kOutput,1)
Info(
"AddOutput",
"Invalid input (out == 0x0)");
3531 TIter nxevl(elists);
3533 while ((evl =
dynamic_cast<TEventList *
> (nxevl()))) {
3539 while ((elem =
dynamic_cast<TDSetElement *
> (nxelem()))) {
3544 Error(
"AddOutput",
"Found an event list for %s, but no object with"
3545 " the same name in the TDSet", evl->
GetName());
3553 if (arr && offset > 0)
3554 for (
Int_t i = 0; i < num; i++)
3575 while ((obj = nxo())) {
3601 Info(
"NotifyMemory|Svc",
"Memory %ld virtual %ld resident after merging object %s",
3634 Info(
"Incorporate",
"enter: obj: %p (%s), list: %p",
3635 newobj, newobj ? newobj->
ClassName() :
"undef", outlist);
3638 if (!newobj || !outlist) {
3639 Error(
"Incorporate",
"Invalid inputs: obj: %p, list: %p", newobj, outlist);
3649 PDB(kOutput,1)
Info(
"Incorporate",
"histogram object '%s' merged", newobj->
GetName());
3651 PDB(kOutput,1)
Info(
"Incorporate",
"histogram object '%s' added to the"
3652 " appropriate list for delayed merging", newobj->
GetName());
3663 outlist->
Add(newobj);
3684 outlist->
Add(newobj);
3697 TH1 *
h =
dynamic_cast<TH1 *
>(obj);
3711 Int_t nent =
h->GetBufferLength();
3712 PDB(kOutput,2)
Info(
"HandleHistogram",
"h:%s ent:%d, buffer size: %d",
3713 h->GetName(), nent,
h->GetBufferSize());
3718 PDB(kOutput,2)
Info(
"HandleHistogram",
"create fOutputLists");
3743 while ((href = (
TH1 *) nxh())) {
3758 while ((href = (
TH1 *) nxh())) {
3779 Int_t hsz =
h->GetNbinsX() *
h->GetNbinsY() *
h->GetNbinsZ();
3814 if (!h0 || !
h1)
return rc;
3816 TAxis *a0 = 0, *a1 = 0;
3821 if (a0->
GetNbins() == a1->GetNbins())
3830 if (a0->
GetNbins() == a1->GetNbins())
3840 if (a0->
GetNbins() == a1->GetNbins())
3854 PDB(kOutput,1)
Info(
"StoreOutput",
"Enter");
3857 PDB(kOutput,1)
Info(
"StoreOutput",
"Leave (empty)");
3865 PDB(kOutput,2)
Info(
"StoreOutput",
"Create fOutputLists");
3877 while ( (aList =
dynamic_cast<TEventList*
> (it())) ) {
3881 while ( (elem =
dynamic_cast<TDSetElement*
> (nxe())) ) {
3886 Error(
"StoreOutput",
"found the EventList for %s, but no object with that name "
3887 "in the TDSet", aList->
GetName());
3896 for (
int i = 0; i < num; i++)
3899 mainList->
Add(aList);
3905 while( (obj = next()) ) {
3906 PDB(kOutput,2)
Info(
"StoreOutput",
"find list for '%s'", obj->
GetName() );
3910 PDB(kOutput,2)
Info(
"StoreOutput",
"list for '%s' not found (creating)", obj->
GetName());
3920 PDB(kOutput,1)
Info(
"StoreOutput",
"leave");
3929 Info(
"MergeFeedback",
"Enter");
3933 Info(
"MergeFeedback",
"Leave (no output)");
3943 while ( (map = (
TMap*) next()) ) {
3953#ifndef R__TH1MERGEFIXED
3957 while (
TObject *key = keys() ) {
3959 TH1 *
h =
dynamic_cast<TH1 *
>(o);
3960#ifndef R__TH1MERGEFIXED
3965 if (
h && !strncmp(o->
GetName(),
"PROOF_",6)) {
3966 if (
h->GetNbinsX() > nbmx) {
3967 nbmx=
h->GetNbinsX();
3975 while ((href = (
TH1 *)nxh())) {
3976 if (
h->GetBuffer()) {
3993#ifdef R__TH1MERGEFIXED
4016 while ( (obj = list->
First()) ) {
4026 Info(
"MergeFeedback",
"Leave (%d object(s))", fb->
GetSize());
4037 Info(
"StoreFeedback",
"Enter");
4041 Info(
"StoreFeedback",
"Leave (empty)");
4053 PDB(kFeedback,2)
Info(
"StoreFeedback",
"Create fFeedbackLists");
4061 const char *ord = ((
TSlave*) slave)->GetOrdinal();
4064 while( (obj = next()) ) {
4066 Info(
"StoreFeedback",
"%s: Find '%s'", ord, obj->
GetName() );
4070 Info(
"StoreFeedback",
"%s: map for '%s' not found (creating)", ord, obj->
GetName());
4077 Info(
"StoreFeedback",
"%s: removing previous value", ord);
4082 map->
Add(slave, obj);
4089 Info(
"StoreFeedback",
"Leave");
4101 PDB(kFeedback,1)
Info(
"SetupFeedback",
"\"FeedbackList\" %sfound",
4122 PDB(kFeedback,1)
Info(
"StopFeedback",
"Stop Timer");
4132 PDB(kFeedback,2)
Info(
"HandleTimer",
"Entry");
4170 PDB(kFeedback,2)
Info(
"HandleTimer",
"Sending %d objects", fb->
GetSize());
4211 Info(
"GetNextPacket",
"%s (%s): '%s' '%s' '%s' %lld %lld",
4213 e->GetDirectory(),
e->GetObjName(),
e->GetFirst(),
e->GetNum());
4233 const char *selection,
Option_t *option,
4252 if (
GetDrawArgs(varexp, selection, option, selector, objname) != 0) {
4253 Error(
"DrawSelect",
"parsing arguments");
4258 TNamed *selectionobj =
new TNamed(
"selection", selection);
4264 while ((o = nxi())) {
4276 if (objname ==
"") objname =
"htemp";
4290 delete selectionobj;
4294 TIter nxsi(savedInput);
4295 while ((o = nxsi()))
4325 Info(
"SetupFeedback",
"\"FeedbackList\" found: %d objects", fb->
GetSize());
4328 Info(
"SetupFeedback",
"\"FeedbackList\" NOT found");
4331 if (fb == 0 || fb->
GetSize() == 0)
return;
4352 PDB(kFeedback,1)
Info(
"StopFeedback",
"Stop Timer");
4362 PDB(kFeedback,2)
Info(
"HandleTimer",
"Entry");
4399 if (o != 0) fb->
Add(o);
4403 PDB(kFeedback,2)
Info(
"HandleTimer",
"Sending %d objects", fb->
GetSize());
4433 PDB(kGlobal, 1)
Info(
"HandleGetTreeHeader",
"empty TDSet");
4438 t = (
TTree*)
f->Get(
e->GetObjName());
4445 while ((
e = dset->
Next()) != 0) {
4450 entries +=
t1->GetEntries();
4461 answ <<
TString(
"Success") << t;
4463 answ <<
TString(
"Failed") << t;
4486 PDB(kGlobal,1)
Info(
"Process",
"Enter");
4489 if (!proof)
return -1;
4497 Error(
"Process",
"sending selector %s", selector_file);
4510 Error(
"Process",
"could not validate TDSet");
4525 while (
TSlave *sl =
dynamic_cast<TSlave*
>(nextslave())) {
4526 TList *submasters = 0;
4529 submasters =
new TList;
4530 submasters->
SetName(sl->GetMsd());
4531 keyholder.
Add(submasters);
4534 valueholder.
Add(setelements);
4535 msds.
Add(
new TPair(submasters, setelements));
4537 submasters =
dynamic_cast<TList*
>(msd->
Key());
4539 if (submasters) submasters->
Add(sl);
4547 if (elem->GetNum()<1)
continue;
4554 if (cur+elem->GetNum()-1<
first) {
4556 cur+=elem->GetNum();
4562 elem->SetNum(elem->GetNum()-(
first-cur));
4563 elem->SetFirst(elem->GetFirst()+
first-cur);
4568 cur+=elem->GetNum();
4577 Error(
"Process",
"data requires mass storage domain '%s'"
4578 " which is not accessible in this proof session",
4583 if (elements) elements->
Add(elem);
4589 while (
TPair *msd =
dynamic_cast<TPair*
>(nextmsd())) {
4590 TList *submasters =
dynamic_cast<TList*
>(msd->Key());
4591 TList *setelements =
dynamic_cast<TList*
>(msd->Value());
4594 Int_t nmasters = submasters ? submasters->
GetSize() : -1;
4595 Int_t nelements = setelements ? setelements->
GetSize() : -1;
4596 for (
Int_t i=0; i<nmasters; i++) {
4601 for (
Int_t j = (i*nelements)/nmasters;
4602 j < ((i+1)*nelements)/nmasters;
4612 Warning(
"Process",
"not a TDSetElement object");
4624 PDB(kGlobal,1)
Info(
"Process",
4625 "Sending TDSet with %d elements to submaster %s",
4629 usedmasters.
Add(sl);
4654 Warning(
"Process",
"not a TSlave object");
4661 PDB(kGlobal,1)
Info(
"Process",
"Calling Collect");
4669 PDB(kGlobal,1)
Info(
"Process",
"Calling Merge Output");
4685 Warning(
"Progress",
"total events has changed for slave %s", sl->
GetName());
4706 Info(
"Progress",
"%s: %lld %lld %f %f %f %f", sl->
GetName(),
4707 processed, bytesread, initTime, procTime, evtrti, mbrti);
4711 Warning(
"Progress",
"total events has changed for slave %s", sl->
GetName());
4753 srti = (nsrti > 0) ? srti / nerti : 0.;
4755 Progress(tot, proc, bytes, init, ptime, erti, srti);
4765 Info(
"Progress",
"%s: %lld %lld %lld %f %f %f %f %d %f", wrk->
GetOrdinal(),
4772 Warning(
"Progress",
"total events has changed for worker %s", wrk->
GetName());
4865 erti = (nerti > 0) ? erti / nerti : 0.;
4866 srti = (nsrti > 0) ? srti / nerti : 0.;
4877 m << tot << proc << bytes << init << ptime << erti << srti;
void Info(const char *location, const char *msgfmt,...)
Use this function for informational messages.
R__EXTERN Int_t gErrorIgnoreLevel
ErrorHandlerFunc_t SetErrorHandler(ErrorHandlerFunc_t newhandler)
Set an errorhandler function. Returns the old handler.
R__EXTERN void Throw(int code)
If an exception context has been set (using the TRY and RETRY macros) jump back to where it was set.
static unsigned int total
const Bool_t kSortDescending
R__EXTERN TProofServ * gProofServ
char * Form(const char *fmt,...)
void Printf(const char *fmt,...)
typedef void((*Func_t)())
R__EXTERN TSystem * gSystem
R__EXTERN TVirtualMonitoringWriter * gMonitoringWriter
static struct mg_connection * fc(struct mg_context *ctx)
void Set(Int_t n)
Set size of this array to n floats.
void Set(Int_t n)
Set size of this array to n ints.
void Set(Int_t n)
Set size of this array to n long64s.
Class to manage histogram axis.
virtual Int_t FindBin(Double_t x)
Find bin number corresponding to abscissa x.
TObject * ReadObject(const TClass *cl) override
Read object from I/O buffer.
TClass instances represent classes, structs and namespaces in the ROOT type system.
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
virtual void ls(Option_t *option="") const
List (ls) all objects in this collection.
virtual const char * GetName() const
Return name of this collection.
virtual void Print(Option_t *option="") const
Default print for collections, calls Print(option, 1).
void SetName(const char *name)
virtual Int_t GetEntries() const
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
virtual Bool_t IsEmpty() const
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write all objects in this collection.
Manages an element of a TDSet.
TFileInfo * GetFileInfo(const char *type="TTree")
Return the content of this element in the form of a TFileInfo.
const char * GetObjName() const
Float_t GetMaxProcTime() const
const char * GetDirectory() const
Return directory where to look for object.
Long64_t GetTDSetOffset() const
const char * GetMsd() const
const char * GetFileName() const
Long64_t GetFirst() const
This class implements a data set to be used for PROOF processing.
virtual TDSetElement * Next(Long64_t totalEntries=-1)
Returns next TDSetElement.
Int_t Remove(TDSetElement *elem, Bool_t deleteElem=kTRUE)
Remove TDSetElement 'elem' from the list.
virtual Bool_t Add(const char *file, const char *objname=0, const char *dir=0, Long64_t first=0, Long64_t num=-1, const char *msd=0)
Add file to list of files to be analyzed.
virtual void Reset()
Reset or initialize access to the elements.
Bool_t ElementsValid()
Check if all elements are valid.
void Lookup(Bool_t removeMissing=kFALSE, TList **missingFiles=0)
Resolve the end-point URL for the current elements of this data set If the removeMissing option is se...
TDSetElement * Current() const
TObject * GetEntryList() const
void Validate()
Validate the TDSet by opening files.
const char * GetType() const
void SetWriteV3(Bool_t on=kTRUE)
Set/Reset the 'OldStreamer' bit in this instance and its elements.
TList * GetListOfElements() const
const char * GetDirectory() const
const char * GetObjName() const
UInt_t Convert(Bool_t toGMT=kFALSE) const
Convert fDatime from TDatime format to the standard time_t format.
TDirectory * mkdir(const char *name, const char *title="", Bool_t returnExistingDirectory=kFALSE) override
Create a sub-directory "a" or a hierarchy of sub-directories "a/b/c/...".
Bool_t cd(const char *path=nullptr) override
Change current directory to "this" directory.
Describe directory structure in memory.
virtual Bool_t cd(const char *path=nullptr)
Change current directory to "this" directory.
Utility class to draw objects in the feedback list during queries.
A List of entry numbers in a TTree or TChain.
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
virtual void SetValue(const char *name, const char *value, EEnvLevel level=kEnvChange, const char *type=nullptr)
Set the value of a resource or create a new resource.
virtual TEnvRec * Lookup(const char *n) const
Loop over all resource records and return the one with name.
virtual Long64_t GetEntryNumber(Long64_t)
virtual Int_t GetLearnEntries()=0
virtual void StopProcess(Bool_t abort)
Set flag to stop the process.
virtual Long64_t GetCacheSize()=0
static TEventIter * Create(TDSet *dset, TSelector *sel, Long64_t first, Long64_t num)
Create and instance of the appropriate iterator.
virtual Int_t GetNextPacket(Long64_t &first, Long64_t &num)=0
virtual void InvalidatePacket()
Invalidated the current packet (if any) by setting the TDSetElement::kCorrupted bit.
A TEventList object is a list of selected events (entries) in a TTree.
virtual Int_t GetN() const
virtual Long64_t * GetList() const
virtual void Add(const TEventList *list)
Merge contents of alist with this list.
Class that contains a list of TFileInfo's and accumulated meta data information about its entries.
Class describing a generic file including meta information.
TUrl * GetCurrentUrl() const
Return the current url.
This class provides file copy and merging services.
virtual Bool_t OutputFile(const char *url, Bool_t force)
Open merger output file.
virtual Bool_t AddFile(TFile *source, Bool_t own, Bool_t cpProgress)
Add the TFile to this file merger and give ownership of the TFile to this object (unless kFALSE is re...
virtual void PrintFiles(Option_t *options)
Print list of files being merged.
virtual Bool_t Merge(Bool_t=kTRUE)
Merge the files.
virtual void Reset()
Reset merger file list.
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
static Long64_t GetFileBytesRead()
Static function returning the total number of bytes read from all files.
static EFileType GetType(const char *name, Option_t *option="", TString *prefix=nullptr)
Resolve the file type as a function of the protocol field in 'name'.
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
Create / open a file.
void Close(Option_t *option="") override
Close a file.
static Int_t GetFileReadCalls()
Static function returning the total number of read calls from all files.
1-D histogram with an int per channel (see TH1 documentation)}
TH1 is the base class of all histogram classes in ROOT.
virtual Int_t GetDimension() const
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
Int_t GetBufferLength() const
virtual Bool_t Add(TF1 *h1, Double_t c1=1, Option_t *option="")
Performs the operation: this = this + c1*f1 if errors are defined (see TH1::Sumw2),...
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
virtual TObject * FindObject(const char *name) const
Search object named name in the list of functions.
virtual Double_t GetEntries() const
Return the current number of entries.
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
const Double_t * GetBuffer() const
static void SetLimitsFinder(THLimitsFinder *finder)
This static function can be used to specify a finder derived from THLimitsFinder.
THashList implements a hybrid collection class consisting of a hash table and a list to store TObject...
TObject * FindObject(const char *name) const
Find object using its name.
TObject * Remove(TObject *obj)
Remove object from the list.
void Clear(Option_t *option="")
Remove all objects from the list.
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
virtual TObject * FindObject(const char *name) const
Find an object in this list using its name.
virtual TObject * At(Int_t idx) const
Returns the object at position idx. Returns 0 if idx is out of range.
virtual TObject * Last() const
Return the last object in the list. Returns 0 when list is empty.
virtual void AddAfter(const TObject *after, TObject *obj)
Insert object after object after in the list.
virtual void AddBefore(const TObject *before, TObject *obj)
Insert object before object before in the list.
virtual TIterator * MakeIterator(Bool_t dir=kIterForward) const
Return a list iterator.
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
virtual TObject * First() const
Return the first object in the list. Returns 0 when list is empty.
virtual void AddLast(TObject *obj)
Add object at the end of the list.
virtual void Clear(Option_t *option="")
Remove all objects from the list.
This code implements the MD5 message-digest algorithm.
static TMD5 * FileChecksum(const char *file)
Returns checksum of specified file.
virtual TMD5 * Checksum()
Returns checksum of the current content.
void SaveSource(FILE *fp)
Save macro source in file pointer fp.
TMap implements an associative array of (key,value) pairs using a THashTable for efficient retrieval ...
void Add(TObject *obj)
This function may not be used (but we need to provide it since it is a pure virtual in TCollection).
TObject * GetValue(const char *keyname) const
Returns a pointer to the value associated with keyname as name of the key.
TObject * Remove(TObject *key)
Remove the (key,value) pair with key from the map.
TClass * GetClass() const
Method or function calling interface.
void ResetParam()
Reset parameter list. To be used before the first call the SetParam().
Bool_t IsValid() const
Return true if the method call has been properly initialized and is usable.
void Execute(const char *, const char *, int *=0)
Execute method on this object with the given parameter string, e.g.
void InitWithPrototype(TClass *cl, const char *method, const char *proto, Bool_t objectIsConst=kFALSE, ROOT::EFunctionMatchMode mode=ROOT::kConversionMatch)
Initialize the method invocation environment.
void SetParam(Long_t l)
Add a long method parameter.
The TNamed class is the base class for all named ROOT classes.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual const char * GetTitle() const
Returns title of object.
virtual const char * GetName() const
Returns name of object.
Collectable string class.
const char * GetName() const
Returns name of object.
Mother of all ROOT objects.
virtual void Clear(Option_t *="")
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
@ kOverwrite
overwrite existing object with same name
@ kSingleKey
write collection with single key
virtual const char * GetName() const
Returns name of object.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual Bool_t HandleTimer(TTimer *timer)
Execute action in response of a timer timing out.
virtual TObject * Clone(const char *newname="") const
Make a clone of an object using the Streamer facility.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
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...
R__ALWAYS_INLINE Bool_t IsZombie() const
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
Set the selector's data members to the corresponding elements of the output list.
static TOutputListSelectorDataMap * FindInList(TCollection *coll)
Find a TOutputListSelectorDataMap in a collection.
Bool_t SetDataMembers(TSelector *sel) const
Given an output list, set the data members of a TSelector.
Class used by TMap to store (key,value) pairs.
void SetValue(TObject *val)
Named parameter, streamable and storable.
static void SetMemValues()
Record memory usage.
static void Setup(TList *input)
Setup the PROOF input list with requested statistics and tracing options.
static void Stop()
Terminate the PROOF statistics run.
static void GetMemValues(Long_t &vmax, Long_t &rmax)
Get memory usage.
static void Start(TList *input, TList *output)
Initialize PROOF statistics run.
Implement Tree drawing using PROOF.
Class to find axis limits and synchronize them between workers.
static void AutoBinFunc(TString &key, Double_t &xmin, Double_t &xmax, Double_t &ymin, Double_t &ymax, Double_t &zmin, Double_t &zmax)
Get bining information.
Int_t Unlock()
Unlock the directory.
Int_t Lock()
Locks the directory.
Class to steer the merging of files produced on the workers.
UInt_t GetTypeOpt() const
const char * GetDir(Bool_t raw=kFALSE) const
const char * GetOutputFileName() const
Bool_t IsRegister() const
const char * GetFileName() const
Bool_t IsRetrieve() const
void ResetFileCollection()
TFileCollection * GetFileCollection()
Get instance of the file collection to be used in 'dataset' mode.
Long64_t Merge(TCollection *list)
Merge objects from the list into this object.
void SetDir(const char *dir, Bool_t raw=kFALSE)
void SetMerged(Bool_t merged=kTRUE)
void SetOutputFileName(const char *name)
Set the name of the output file; in the form of an Url.
void SetFileName(const char *name)
void Print(Option_t *option="") const
Dump the class content.
void SetWorkerOrdinal(const char *ordinal)
Int_t AdoptFile(TFile *f)
Adopt a file already open.
TFileMerger * GetFileMerger(Bool_t local=kFALSE)
Get instance of the file merger to be used in 'merge' mode.
Long64_t Process(const char *selector, Long64_t nentries=-1, Option_t *option="")
Process the specified TSelector file 'nentries' times.
ErrorHandlerFunc_t fErrorHandler
tdset for current processing
Int_t InitPacketizer(TDSet *dset, Long64_t nentries, Long64_t first, const char *defpackunit, const char *defpackdata)
Init the packetizer Return 0 on success (fPacketizer is correctly initialized), -1 on failure.
void NotifyMemory(TObject *obj)
Printout the memory record after merging object 'obj' This record is used by the memory monitor.
void StopProcess(Bool_t abort, Int_t timeout=-1)
Stop process after this event.
TObject * HandleHistogram(TObject *obj, Bool_t &merged)
Low statistic histograms need a special treatment when using autobin.
Bool_t IsClient() const
Is the player running on the client?
TList * MergeFeedback()
Merge feedback lists.
void SetInitTime()
Set init time.
TVirtualPacketizer * fPacketizer
void RedirectOutput(Bool_t on=kTRUE)
Control output redirection to TProof::fLogFileW.
void AddOutput(TList *out)
Incorporate the content of the received output list 'out' into the final output list fOutput.
TString fSelectorFileName
void Feedback(TList *objs)
Feedback signal.
TMessage * fProcessMessage
Histogram with packets being processed (owned by TPerfStats)
virtual ~TProofPlayerRemote()
Destructor.
Bool_t MergeOutputFiles()
Merge output in files.
virtual Long64_t Finalize(Bool_t force=kFALSE, Bool_t sync=kFALSE)
Finalize query (may not be used in this class).
Int_t Incorporate(TObject *obj, TList *out, Bool_t &merged)
Incorporate object 'newobj' in the list 'outlist'.
void StoreOutput(TList *out)
Store received output list.
virtual void MergeOutput(Bool_t savememvalues=kFALSE)
Merge objects in output the lists.
void SetSelectorDataMembersFromOutputList()
Set the selector's data members: find the mapping of data members to otuput list entries in the outpu...
void SetMerging(Bool_t on=kTRUE)
Switch on/off merge timer.
Bool_t HistoSameAxis(TH1 *h0, TH1 *h1)
Return kTRUE is the histograms 'h0' and 'h1' have the same binning and ranges on the axis (i....
Int_t AddOutputObject(TObject *obj)
Incorporate the received object 'obj' into the output list fOutput.
virtual void StoreFeedback(TObject *slave, TList *out)
Store feedback results from the specified slave.
void StopFeedback()
Stop reporting of feedback objects.
virtual Bool_t JoinProcess(TList *workers)
Prepares the given list of new workers to join a progressing process.
TProof * GetProof() const
TDSetElement * GetNextPacket(TSlave *slave, TMessage *r)
Get next packet for specified slave.
virtual Bool_t HandleTimer(TTimer *timer)
Send feedback objects to client.
void Progress(Long64_t total, Long64_t processed)
Progress signal.
Long64_t DrawSelect(TDSet *set, const char *varexp, const char *selection, Option_t *option="", Long64_t nentries=-1, Long64_t firstentry=0)
Draw (support for TChain::Draw()).
void SetLastMergingMsg(TObject *obj)
Set the message to be notified in case of exception.
virtual Bool_t SendSelector(const char *selector_file)
Send the selector file(s) to master or worker nodes.
void SetupFeedback()
Setup reporting of feedback objects.
virtual Long64_t Process(TDSet *set, const char *selector, Option_t *option="", Long64_t nentries=-1, Long64_t firstentry=0)
Process specified TDSet on PROOF.
void SetupFeedback()
Setup feedback.
Bool_t HandleTimer(TTimer *timer)
Handle timer event.
void StopFeedback()
Stop feedback.
void HandleGetTreeHeader(TMessage *mess)
Handle tree header request.
void SetupFeedback()
Setup reporting of feedback objects and progress messages.
TArrayL64 fSlaveBytesRead
Long64_t Process(TDSet *set, const char *selector, Option_t *option="", Long64_t nentries=-1, Long64_t firstentry=0)
Process specified TDSet on PROOF.
Bool_t HandleTimer(TTimer *timer)
Send progress and feedback to client.
void Progress(Long64_t total, Long64_t processed)
Progress signal.
Internal class steering processing in PROOF.
Long64_t fReadCallsRun
Bytes read in this run.
void HandleGetTreeHeader(TMessage *mess)
Handle tree header request.
void Progress(Long64_t total, Long64_t processed)
Report progress (may not be used in this class).
Bool_t fCreateSelObj
the latest selector
virtual void StopFeedback()
Stop feedback (may not be used in this class).
virtual Int_t DrawCanvas(TObject *obj)
Draw the object if it is a canvas.
void AddOutput(TList *out)
Incorporate output list (may not be used in this class).
static THashList * fgDrawInputPars
void Feedback(TList *objs)
Set feedback list (may not be used in this class).
TEventIter * fEvIter
period (ms) for sending intermediate results
TTimer * fFeedbackTimer
class of the latest selector
TProofPlayer(TProof *proof=0)
Default ctor.
TList * GetOutputList() const
Get output list.
Int_t SavePartialResults(Bool_t queryend=kFALSE, Bool_t force=kFALSE)
Save the partial results of this query to a dedicated file under the user data directory.
void RestorePreviousQuery()
void RemoveQueryResult(const char *ref)
Remove all query result instances referenced 'ref' from the list of results.
void SetDrawFeedbackOption(TDrawFeedback *f, Option_t *opt)
Set draw feedback option.
void UpdateProgressInfo()
Update fProgressStatus.
Long64_t GetEventsProcessed() const
void UpdateAutoBin(const char *name, Double_t &xmin, Double_t &xmax, Double_t &ymin, Double_t &ymax, Double_t &zmin, Double_t &zmax)
Update automatic binning parameters for given object "name".
Long64_t GetCacheSize()
Return the size in bytes of the cache.
TProofProgressStatus * GetProgressStatus() const
Int_t GetLearnEntries()
Return the number of entries in the learning phase.
EExitStatus fExitStatus
status of query in progress
Long_t fFeedbackPeriod
timer for sending intermediate results
TList * fQueryResults
Events processed in this run.
virtual Bool_t JoinProcess(TList *workers)
Not implemented: meaningful only in the remote player. Returns kFALSE.
virtual void MergeOutput(Bool_t savememvalues=kFALSE)
Merge output (may not be used in this class).
void MapOutputListToDataMembers() const
void FeedBackCanvas(const char *name, Bool_t create)
Create/destroy a named canvas for feedback.
void ClearInput()
Clear input list.
Bool_t fSaveResultsPerPacket
Long64_t fProcessedRun
Read calls in this run.
Bool_t fSavePartialResults
void AddQueryResult(TQueryResult *q)
Add query result to the list, making sure that there are no duplicates.
void StoreFeedback(TObject *slave, TList *out)
Store feedback list (may not be used in this class).
TDSetElement * GetNextPacket(TSlave *slave, TMessage *r)
Get next packet (may not be used in this class).
TStatus * fSelStatus
iterator on events or objects
Int_t AddOutputObject(TObject *obj)
Incorporate output object (may not be used in this class).
virtual ~TProofPlayer()
Destructor.
TClass * fSelectorClass
kTRUE when fSelector has been created locally
TQueryResult * fPreviousQuery
void SetDispatchTimer(Bool_t on=kTRUE)
Enable/disable the timer to dispatch pening events while processing.
Long64_t Process(TDSet *set, const char *selector, Option_t *option="", Long64_t nentries=-1, Long64_t firstentry=0)
Process specified TDSet on PROOF worker.
TObject * GetOutput(const char *name) const
Get output object by name.
Long64_t Finalize(Bool_t force=kFALSE, Bool_t sync=kFALSE)
Finalize query (may not be used in this class).
TDrawFeedback * CreateDrawFeedback(TProof *p)
Draw feedback creation proxy.
void StopProcess(Bool_t abort, Int_t timeout=-1)
Stop the process after this event.
Int_t GetDrawArgs(const char *var, const char *sel, Option_t *opt, TString &selector, TString &objname)
Parse the arguments from var, sel and opt and fill the selector and object name accordingly.
void DeleteDrawFeedback(TDrawFeedback *f)
Delete draw feedback object.
TProofProgressStatus * fProgressStatus
Int_t ReinitSelector(TQueryResult *qr)
Reinitialize fSelector using the selector files in the query result.
void SetStopTimer(Bool_t on=kTRUE, Bool_t abort=kFALSE, Int_t timeout=0)
Enable/disable the timer to stop/abort processing.
TQueryResult * GetQueryResult(const char *ref)
Get query result instances referenced 'ref' from the list of results.
Long64_t DrawSelect(TDSet *set, const char *varexp, const char *selection, Option_t *option="", Long64_t nentries=-1, Long64_t firstentry=0)
Draw (may not be used in this class).
virtual void SetupFeedback()
Set up feedback (may not be used in this class).
void StoreOutput(TList *out)
Store output list (may not be used in this class).
void SetCurrentQuery(TQueryResult *q)
Set current query and save previous value.
EExitStatus GetExitStatus() const
void AddInput(TObject *inp)
Add object to input list.
void SetProcessing(Bool_t on=kTRUE)
Set processing bit according to 'on'.
Bool_t CheckMemUsage(Long64_t &mfreq, Bool_t &w80r, Bool_t &w80v, TString &wmsg)
Check the memory usage, if requested.
Int_t AssertSelector(const char *selector_file)
Make sure that a valid selector object Return -1 in case of problems, 0 otherwise.
void HandleRecvHisto(TMessage *mess)
Receive histo from slave.
Container class for processing statistics.
void SetLastUpdate(Double_t updtTime=0)
Update time stamp either with the passed value (if > 0) or with the current time.
Double_t GetProcTime() const
void SetBytesRead(Long64_t bytesRead)
Long64_t GetEntries() const
void IncEntries(Long64_t entries=1)
void SetReadCalls(Long64_t readCalls)
Long64_t GetBytesRead() const
const char * GetOrdinal() const
Int_t GetQuerySeqNum() const
const char * GetTopSessionTag() const
static void ErrorHandler(Int_t level, Bool_t abort, const char *location, const char *msg)
The PROOF error handler function.
static void GetLocalServer(TString &dsrv)
Extract LOCALDATASERVER info in 'dsrv'.
static void SetLastEntry(Long64_t lastentry)
Set the last entry before exception.
static Float_t GetMemHWM()
MemHWM getter.
Bool_t IsParallel() const
True if in parallel mode.
static void FilterLocalroot(TString &path, const char *url="root://dum/")
If 'path' is local and 'dsrv' is Xrootd, apply 'path.Localroot' settings, if any.
static FILE * SetErrorHandlerFile(FILE *ferr)
Set the file stream where to log (default stderr).
Float_t GetEffSessions() const
static void SetLastMsg(const char *lastmsg)
Set the message to be sent back in case of exceptions.
const char * GetDataDirOpts() const
TSocket * GetSocket() const
void SendAsynMessage(const char *msg, Bool_t lf=kTRUE)
Send an asychronous message to the master / client .
const char * GetDataDir() const
Int_t GetTotSessions() const
Long64_t GetMsgSizeHWM() const
TProofLockPath * GetCacheLock()
static Long_t GetResMemMax()
ResMemMax getter.
const char * GetCacheDir() const
static Long_t GetVirtMemMax()
VirtMemMax getter.
const char * GetSessionDir() const
Int_t GetProtocol() const
const char * GetPrefix() const
static Float_t GetMemStop()
MemStop getter.
Bool_t IsTopMaster() const
Implementation of TProof controlling PROOF federated clusters.
void ValidateDSet(TDSet *dset)
Validate a TDSet.
This class controls a Parallel ROOT Facility, PROOF, cluster.
void Activate(TList *slaves=0)
Activate slave server list.
void AddFeedback(const char *name)
Add object to feedback list.
Bool_t IsParallel() const
TObject * GetParameter(const char *par) const
Get specified parameter.
void ResetMergePrg()
Reset the merge progress notificator.
Int_t Collect(const TSlave *sl, Long_t timeout=-1, Int_t endtype=-1, Bool_t deactonfail=kFALSE)
Collect responses from slave sl.
static Int_t SendInputData(TQueryResult *qr, TProof *p, TString &emsg)
Send the input data file to the workers.
Int_t Broadcast(const TMessage &mess, TList *slaves)
Broadcast a message to all slaves in the specified list.
void SetParameter(const char *par, const char *value)
Set input list parameter.
Int_t GetParallel() const
Returns number of slaves active in parallel mode.
void RemoveFeedback(const char *name)
Remove object from feedback list.
ERunStatus GetRunStatus() const
TList * GetListOfActiveSlaves() const
void Progress(Long64_t total, Long64_t processed)
Get query progress information.
Long64_t Finalize(Int_t query=-1, Bool_t force=kFALSE)
Finalize the qry-th query in fQueries.
Int_t SendFile(const char *file, Int_t opt=(kBinary|kForward|kCp|kCpBin), const char *rfile=0, TSlave *sl=0)
Send a file to master or slave servers.
void Feedback(TList *objs)
Get list of feedback objects.
EQueryMode GetQueryMode(Option_t *mode=0) const
Find out the query mode based on the current setting and 'mode'.
virtual void SendInputDataFile()
Send the input data objects to the master; the objects are taken from the dedicated list and / or the...
TList * GetInputList()
Get input list.
A container class for query results.
virtual void SetOutputList(TList *out, Bool_t adopt=kTRUE)
Set / change the output list.
void SetNumMergers(Int_t nmergers)
const char * GetLibList() const
Bool_t Matches(const char *ref)
Return TRUE if reference ref matches.
TMacro * GetSelecImp() const
void SetMergeTime(Float_t mergetime)
void SetRecvTime(Float_t recvtime)
void Print(Option_t *opt="") const
Print query content. Use opt = "F" for a full listing.
TDatime GetStartTime() const
virtual void SetProcessInfo(Long64_t ent, Float_t cpu=0., Long64_t siz=-1, Float_t inittime=0., Float_t proctime=0.)
Set processing info.
TMacro * GetSelecHdr() const
const char * GetOptions() const
virtual void SetFinalized()
Bool_t IsFinalized() const
static const char * GetMacroPath()
Get macro search path. Static utility function.
static void SetMacroPath(const char *newpath)
Set or extend the macro search path.
A TSelector object is used by the TTree::Draw, TTree::Scan, TTree::Process to navigate in a TTree and...
virtual EAbort GetAbort() const
virtual void ProcessFill(Long64_t)
virtual int Version() const
virtual TList * GetInputList() const
virtual Bool_t Process(Long64_t)
static Bool_t IsStandardDraw(const char *selec)
Find out if this is a standard selection used for Draw actions (either TSelectorDraw,...
virtual void SlaveBegin(TTree *)
virtual Bool_t ProcessCut(Long64_t)
virtual void SetOption(const char *option)
virtual Long64_t GetStatus() const
virtual void SetInputList(TList *input)
virtual void Abort(const char *why, EAbort what=kAbortProcess)
Abort processing.
virtual TList * GetOutputList() const
virtual void SlaveTerminate()
virtual void Begin(TTree *)
static TSelector * GetSelector(const char *filename)
The code in filename is loaded (interpreted or compiled, see below), filename must contain a valid cl...
virtual Int_t IndexOf(const TObject *obj) const
Return index of object in collection.
Class describing a PROOF worker server.
TSocket * GetSocket() const
const char * GetName() const
Returns name of object.
const char * GetOrdinal() const
virtual Int_t Send(const TMessage &mess)
Send a TMessage object.
A sorted doubly linked list.
This class holds the status of an ongoing operation and collects error messages.
void Add(const char *mesg)
Add an error message.
void SetMemValues(Long_t vmem=-1, Long_t rmem=-1, Bool_t master=kFALSE)
Set max memory values.
void SetExitStatus(Int_t est)
Double_t RealTime()
Stop the stopwatch (if it is running) and return the realtime (in seconds) passed between the start a...
void Stop()
Stop the stopwatch.
TString & Insert(Ssiz_t pos, const char *s)
Int_t Atoi() const
Return integer value of string.
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
const char * Data() const
Bool_t IsDigit() const
Returns true if all characters in string are digits (0-9) or white spaces, i.e.
TString & ReplaceAll(const TString &s1, const TString &s2)
Ssiz_t Last(char c) const
Find last occurrence of a character c.
TObjArray * Tokenize(const TString &delim) const
This function is used to isolate sequential tokens in a TString.
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
TString & Remove(Ssiz_t pos)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual Int_t RedirectOutput(const char *name, const char *mode="a", RedirectHandle_t *h=nullptr)
Redirect standard output (stdout, stderr) to the specified file.
virtual Func_t DynFindSymbol(const char *module, const char *entry)
Find specific entry point in specified library.
virtual Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.
virtual const char * Getenv(const char *env)
Get environment variable.
virtual const char * GetIncludePath()
Get the list of include path.
virtual TString SplitAclicMode(const char *filename, TString &mode, TString &args, TString &io) const
This method split a filename of the form:
virtual int MakeDirectory(const char *name)
Make a directory.
virtual int GetSysInfo(SysInfo_t *info) const
Returns static system info, like OS type, CPU type, number of CPUs RAM size, etc into the SysInfo_t s...
virtual void SetIncludePath(const char *includePath)
IncludePath should contain the list of compiler flags to indicate where to find user defined header f...
virtual int Load(const char *module, const char *entry="", Bool_t system=kFALSE)
Load a shared library.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
virtual Bool_t ChangeDirectory(const char *path)
Change directory.
virtual int GetProcInfo(ProcInfo_t *info) const
Returns cpu and memory used by this process into the ProcInfo_t structure.
virtual void DispatchOneEvent(Bool_t pendingOnly=kFALSE)
Dispatch a single event.
virtual const char * BaseName(const char *pathname)
Base name of a file name. Base name of /user/root is root.
virtual const char * HostName()
Return the system's host name.
virtual const char * WorkingDirectory()
Return working directory.
virtual char * Which(const char *search, const char *file, EAccessMode mode=kFileExists)
Find location of file in a search path.
virtual TString GetDirName(const char *pathname)
Return the directory name in pathname.
virtual int Unlink(const char *name)
Unlink, i.e.
virtual const char * TempDirectory() const
Return a user configured or systemwide directory to create temporary files in.
char * DynamicPathName(const char *lib, Bool_t quiet=kFALSE)
Find a dynamic library called lib using the system search paths.
Handles synchronous and a-synchronous timer events.
virtual void Start(Long_t milliSec=-1, Bool_t singleShot=kFALSE)
Starts the timer with a milliSec timeout.
void SetObject(TObject *object)
Set the object to be notified at time out.
virtual Bool_t Notify()
Notify when timer times out.
A TTree represents a columnar dataset.
virtual void SetMaxEntryLoop(Long64_t maxev=kMaxEntries)
TDirectory * GetDirectory() const
virtual void SetMaxVirtualSize(Long64_t size=0)
virtual void DropBaskets()
Remove some baskets from memory.
virtual void SetDirectory(TDirectory *dir)
Change the tree's directory.
virtual Long64_t GetEntries() const
virtual void SetAutoFlush(Long64_t autof=-30000000)
This function may be called at the start of a program to change the default value for fAutoFlush.
This class defines a UUID (Universally Unique IDentifier), also known as GUIDs (Globally Unique IDent...
const char * AsString() const
Return UUID as string. Copy string immediately since it will be reused.
This class represents a WWW compatible URL.
const char * GetUrl(Bool_t withDeflt=kFALSE) const
Return full URL.
const char * GetFile() const
const char * GetHost() const
const char * GetHostFQDN() const
Return fully qualified domain name of url host.
void SetHost(const char *host)
const char * GetProtocol() const
virtual Bool_t SendProcessingProgress(Double_t, Double_t, Bool_t=kFALSE)
virtual Bool_t SendProcessingStatus(const char *, Bool_t=kFALSE)
The packetizer is a load balancing object created for each query.
Float_t GetProcTime() const
TList * GetFailedPackets()
virtual Int_t AddWorkers(TList *workers)
Adds new workers.
TNtuple * GetProgressPerf(Bool_t steal=kFALSE)
void SetFailedPackets(TList *list)
Long64_t GetTotalEntries() const
virtual void StopProcess(Bool_t abort, Bool_t stoptimer=kFALSE)
Stop process.
Float_t GetInitTime() const
virtual void SetInitTime()
Set the initialization time.
Long64_t GetBytesRead() const
TList * GetConfigParams(Bool_t steal=kFALSE)
virtual TDSetElement * GetNextPacket(TSlave *sl, TMessage *r)
Get next packet.
static void output(int code)