ROOT logo
// @(#)root/proofplayer:$Id: TStatus.cxx 40091 2011-06-30 17:47:56Z ganis $
// Author: Maarten Ballintijn   7/06/2004

/*************************************************************************
 * Copyright (C) 1995-2004, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TStatus                                                              //
//                                                                      //
// This class holds the status of an ongoing operation and collects     //
// error messages. It provides a Merge() operation allowing it to       //
// be used in PROOF to monitor status in the slaves.                    //
// No messages indicates success.                                       //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#include "TStatus.h"
#include "Riostream.h"
#include "TClass.h"
#include "TList.h"
#include "TProofDebug.h"


ClassImp(TStatus)

//______________________________________________________________________________
TStatus::TStatus() : fExitStatus(-1), fVirtMemMax(-1), fResMemMax(-1)
{
   // Deafult constructor.

   SetName("PROOF_Status");
   fIter = fMsgs.begin();
}

//______________________________________________________________________________
void TStatus::Add(const char *mesg)
{
   // Add an error message.

   fMsgs.insert(mesg);
   Reset();
}

//______________________________________________________________________________
Int_t TStatus::Merge(TCollection *li)
{
   // PROOF Merge() function.

   TIter stats(li);
   PDB(kOutput,1)
      Info("Merge", "start: max virtual memory: %.2f MB \tmax resident memory: %.2f MB ",
                    GetVirtMemMax()/1024., GetResMemMax()/1024.);
   while (TObject *obj = stats()) {
      TStatus *s = dynamic_cast<TStatus*>(obj);
      if (s == 0) continue;

      MsgIter_t i = s->fMsgs.begin();
      MsgIter_t end = s->fMsgs.end();
      for (; i != end; i++)
         Add(i->c_str());
      
      SetMemValues(s->GetVirtMemMax(), s->GetResMemMax());
      PDB(kOutput,1)
         Info("Merge", "during: max virtual memory: %.2f MB \t"
                       "max resident memory: %.2f MB ",
                       GetVirtMemMax()/1024., GetResMemMax()/1024.);
   }

   return fMsgs.size();
}

//______________________________________________________________________________
void TStatus::Print(Option_t * /*option*/) const
{
   // Standard print function.

   Printf("OBJ: %s\t%s\t%s", IsA()->GetName(), GetName(), (IsOk() ? "OK" : "ERROR"));

   MsgIter_t i = fMsgs.begin();
   for (; i != fMsgs.end(); i++)
      Printf("\t%s", (*i).c_str());

   Printf(" Max virtual memory: %.2f MB \tMax resident memory: %.2f MB ",
          GetVirtMemMax()/1024., GetResMemMax()/1024.);
}

//______________________________________________________________________________
void TStatus::Reset()
{
   // Reset the iterator on the messages.

   fIter = fMsgs.begin();
}

//______________________________________________________________________________
const char *TStatus::NextMesg()
{
   // Return the next message or 0.

   if (fIter != fMsgs.end()) {
      return (*fIter++).c_str();
   } else {
      return 0;
   }
}

//______________________________________________________________________________
void TStatus::SetMemValues(Long_t vmem, Long_t rmem)
{
   // Set max memory values

   if (vmem > 0. && (fVirtMemMax < 0. || vmem > fVirtMemMax)) fVirtMemMax = vmem;
   if (rmem > 0. && (fResMemMax < 0. || rmem > fResMemMax)) fResMemMax = rmem;
}

 TStatus.cxx:1
 TStatus.cxx:2
 TStatus.cxx:3
 TStatus.cxx:4
 TStatus.cxx:5
 TStatus.cxx:6
 TStatus.cxx:7
 TStatus.cxx:8
 TStatus.cxx:9
 TStatus.cxx:10
 TStatus.cxx:11
 TStatus.cxx:12
 TStatus.cxx:13
 TStatus.cxx:14
 TStatus.cxx:15
 TStatus.cxx:16
 TStatus.cxx:17
 TStatus.cxx:18
 TStatus.cxx:19
 TStatus.cxx:20
 TStatus.cxx:21
 TStatus.cxx:22
 TStatus.cxx:23
 TStatus.cxx:24
 TStatus.cxx:25
 TStatus.cxx:26
 TStatus.cxx:27
 TStatus.cxx:28
 TStatus.cxx:29
 TStatus.cxx:30
 TStatus.cxx:31
 TStatus.cxx:32
 TStatus.cxx:33
 TStatus.cxx:34
 TStatus.cxx:35
 TStatus.cxx:36
 TStatus.cxx:37
 TStatus.cxx:38
 TStatus.cxx:39
 TStatus.cxx:40
 TStatus.cxx:41
 TStatus.cxx:42
 TStatus.cxx:43
 TStatus.cxx:44
 TStatus.cxx:45
 TStatus.cxx:46
 TStatus.cxx:47
 TStatus.cxx:48
 TStatus.cxx:49
 TStatus.cxx:50
 TStatus.cxx:51
 TStatus.cxx:52
 TStatus.cxx:53
 TStatus.cxx:54
 TStatus.cxx:55
 TStatus.cxx:56
 TStatus.cxx:57
 TStatus.cxx:58
 TStatus.cxx:59
 TStatus.cxx:60
 TStatus.cxx:61
 TStatus.cxx:62
 TStatus.cxx:63
 TStatus.cxx:64
 TStatus.cxx:65
 TStatus.cxx:66
 TStatus.cxx:67
 TStatus.cxx:68
 TStatus.cxx:69
 TStatus.cxx:70
 TStatus.cxx:71
 TStatus.cxx:72
 TStatus.cxx:73
 TStatus.cxx:74
 TStatus.cxx:75
 TStatus.cxx:76
 TStatus.cxx:77
 TStatus.cxx:78
 TStatus.cxx:79
 TStatus.cxx:80
 TStatus.cxx:81
 TStatus.cxx:82
 TStatus.cxx:83
 TStatus.cxx:84
 TStatus.cxx:85
 TStatus.cxx:86
 TStatus.cxx:87
 TStatus.cxx:88
 TStatus.cxx:89
 TStatus.cxx:90
 TStatus.cxx:91
 TStatus.cxx:92
 TStatus.cxx:93
 TStatus.cxx:94
 TStatus.cxx:95
 TStatus.cxx:96
 TStatus.cxx:97
 TStatus.cxx:98
 TStatus.cxx:99
 TStatus.cxx:100
 TStatus.cxx:101
 TStatus.cxx:102
 TStatus.cxx:103
 TStatus.cxx:104
 TStatus.cxx:105
 TStatus.cxx:106
 TStatus.cxx:107
 TStatus.cxx:108
 TStatus.cxx:109
 TStatus.cxx:110
 TStatus.cxx:111
 TStatus.cxx:112
 TStatus.cxx:113
 TStatus.cxx:114
 TStatus.cxx:115
 TStatus.cxx:116
 TStatus.cxx:117
 TStatus.cxx:118
 TStatus.cxx:119
 TStatus.cxx:120
 TStatus.cxx:121