]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - SHUTTLE/AliShuttleStatus.cxx
fix for bug #66294
[u/mrichter/AliRoot.git] / SHUTTLE / AliShuttleStatus.cxx
index 523770c99220fdcc5de789289d1f6f682d3f518e..979735f230fc533797e01622959d1cd4cc3fe508 100644 (file)
 
 /*
 $Log$
+Revision 1.4  2006/10/02 16:38:39  jgrosseo
+update (alberto):
+fixed memory leaks
+storing of objects that failed to be stored to the grid before
+interfacing of shuttle status table in daq system
+
+Revision 1.3  2006/08/29 09:16:05  jgrosseo
+small update
+
+Revision 1.2  2006/08/15 10:50:00  jgrosseo
+effc++ corrections (alberto)
+
+Revision 1.1  2006/07/20 13:20:13  jgrosseo
+introducing status management: The processing per subdetector is divided into several steps,
+after each step the status is stored on disk. If the system crashes in any of the steps the Shuttle
+can keep track of the number of failures and skips further processing after a certain threshold is
+exceeded. These thresholds can be configured in LDAP.
+
 */
 
 //
@@ -29,6 +47,7 @@ $Log$
 
 ClassImp(AliShuttleStatus)
 
+//______________________________________________________________________________________________
 AliShuttleStatus::AliShuttleStatus() : TObject(),
   fTimeStamp(0),
   fStatus(kInvalid),
@@ -37,6 +56,7 @@ AliShuttleStatus::AliShuttleStatus() : TObject(),
   // default constructor
 }
 
+//______________________________________________________________________________________________
 AliShuttleStatus::AliShuttleStatus(Status status) : TObject(),
   fTimeStamp(0),
   fStatus(status),
@@ -47,18 +67,24 @@ AliShuttleStatus::AliShuttleStatus(Status status) : TObject(),
   fTimeStamp = time(0);
 }
 
-AliShuttleStatus::AliShuttleStatus(const AliShuttleStatus& c) : TObject(c)
+//______________________________________________________________________________________________
+AliShuttleStatus::AliShuttleStatus(const AliShuttleStatus& c) :
+TObject(c),  fTimeStamp(0),
+fStatus(kInvalid),
+fCount(1)
 {
   // copy constructor
 
   ((AliShuttleStatus &)c).Copy(*this);
 }
 
+//______________________________________________________________________________________________
 AliShuttleStatus::~AliShuttleStatus()
 {
   // destructor
 }
 
+//______________________________________________________________________________________________
 AliShuttleStatus &AliShuttleStatus::operator=(const AliShuttleStatus &c)
 {
   // assigment operator
@@ -69,6 +95,7 @@ AliShuttleStatus &AliShuttleStatus::operator=(const AliShuttleStatus &c)
   return *this;
 }
 
+//______________________________________________________________________________________________
 void AliShuttleStatus::Copy(TObject& c) const
 {
   // copy function
@@ -80,6 +107,7 @@ void AliShuttleStatus::Copy(TObject& c) const
   target.fCount = fCount;
 }
 
+//______________________________________________________________________________________________
 void AliShuttleStatus::SetStatus(Status status)
 {
   // sets a new status, add the same time the timestamp is set to now
@@ -88,6 +116,7 @@ void AliShuttleStatus::SetStatus(Status status)
   fTimeStamp = time(0);
 }
 
+//______________________________________________________________________________________________
 const char* AliShuttleStatus::GetStatusName(Status status)
 {
   // returns a name (string) of the status
@@ -99,10 +128,18 @@ const char* AliShuttleStatus::GetStatusName(Status status)
     case kDCSStarted: return "DCSStarted";
     case kDCSError: return "DCSError";
     case kPPStarted: return "PPStarted";
+    case kPPTimeOut: return "PPTimeOut";
+    case kPPOutOfMemory: return "PPOutOfMemory";
     case kPPError: return "PPError";
     case kPPDone: return "PPDone";
+    case kStoreStarted: return "StoreStarted";
+    case kStoreError: return "StoreError";
     case kDone: return "Done";
     case kFailed: return "Failed";
+    case kStoreDelayed: return "StoreDelayed";
+    case kFXSError: return "FXSError";
+    case kSkipped: return "Skipped";
+    case kOCDBError: return "OCDBError";
   }
 
   return 0;