]> git.uio.no Git - u/mrichter/AliRoot.git/commitdiff
Protection against index out of range
authormarian <marian@f7af4fe6-9843-0410-8265-dc069ae4e863>
Tue, 5 Feb 2008 20:11:45 +0000 (20:11 +0000)
committermarian <marian@f7af4fe6-9843-0410-8265-dc069ae4e863>
Tue, 5 Feb 2008 20:11:45 +0000 (20:11 +0000)
SetFastCluster(Int_t i, Short_t cl)

In case of misscalibrated drift velocity the index can go out of range
(Marian)

TPC/AliTPCtrackerMI.cxx
TPC/AliTPCtrackerMI.h

index 47767ab6a9f9dbf08a5b02aee706c613be0505c6..b2872192a4e80d53242de2b8417c73caafd74d99 100644 (file)
@@ -4441,7 +4441,7 @@ void  AliTPCtrackerMI::FindSplitted(TObjArray * array, AliESDEvent */*esd*/, Int
 
 
 
-void  AliTPCtrackerMI::FindCurling(TObjArray * array, AliESDEvent *esd, Int_t iter)
+void  AliTPCtrackerMI::FindCurling(TObjArray * array, AliESDEvent */*esd*/, Int_t iter)
 {
   //
   //  find Curling tracks
@@ -7061,6 +7061,10 @@ AliTPCtrackerMI::AliTPCRow::InsertCluster(const AliTPCclusterMI* c, UInt_t index
   if (fN==kMaxClusterPerRow) {
     cerr<<"AliTPCRow::InsertCluster(): Too many clusters !\n"; return;
   }
+  if (fN>=fN1+fN2) {
+    cout<<"AliTPCRow::InsertCluster(): Too many clusters !\n";
+  }
+
   if (fN==0) {fIndex[0]=index; fClusters[fN++]=c; return;}
   Int_t i=Find(c->GetZ());
   memmove(fClusters+i+1 ,fClusters+i,(fN-i)*sizeof(AliTPCclusterMI*));
@@ -7163,6 +7167,17 @@ AliTPCclusterMI * AliTPCtrackerMI::AliTPCRow::FindNearest2(Double_t y, Double_t
 }
 
 
+void AliTPCtrackerMI::AliTPCRow::SetFastCluster(Int_t i, Short_t cl){
+  //
+  // Set cluster info for fast navigation
+  //
+  if (i>510|| i<0){
+    cerr<<"Out of range cluster\t"<<i<<"\n";
+  }else{
+    fFastCluster[i]=cl;
+  }
+}
+
 
 
 
index 50386449cee47e9268ef012a27bd9bea9472ccca..bed5ad704d9982d04ca9a00de1e2e14da4e1fb99 100644 (file)
@@ -140,7 +140,7 @@ public:
      AliTPCclusterMI* GetCluster1(Int_t i) const {return &fClusters1[i];}
      AliTPCclusterMI* GetCluster2(Int_t i) const {return &fClusters2[i];}
      Short_t GetFastCluster(Int_t i) const {return fFastCluster[i];}
-     void SetFastCluster(Int_t i, Short_t cl) {fFastCluster[i]=cl;}
+     void SetFastCluster(Int_t i, Short_t cl);
 
 private:  
      AliTPCRow & operator=(const AliTPCRow & );