]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - TFluka/abscff.cxx
START becomes T0
[u/mrichter/AliRoot.git] / TFluka / abscff.cxx
index 38c5fc2c44ff823ffa6978d03149e2cf19d37489..94967baaa9a67cb9a7bd439fe89657e64c140162 100644 (file)
@@ -1,10 +1,9 @@
 #include "Fdimpar.h"  //(DIMPAR) fluka include
 #include "Ftrackr.h"  //(TRACKR) fluka common
 #include "Fiounit.h"  //(IOUNIT) fluka common
-#include "TFlukaGeo.h"
+#include "TFluka.h"
 #include "TGeoMaterial.h"
 #include "TFlukaCerenkov.h"
-#include "TGeoManager.h"
 
 
 #ifndef WIN32
 extern "C" {
 Double_t abscff(Double_t& wvlngt, Double_t& /*omgpho*/, Int_t& mmat)
 {
+//    printf("abscff%f %d\n", wvlngt, mmat);
+    
 //
 //  Return absorption length  for given photon energy and material
 //
+    
     TFluka* fluka =  (TFluka*) gMC;
-    TGeoMaterial*    material =  (TGeoMaterial*) (gGeoManager->GetListOfMaterials())->At(fluka->GetMaterialIndex(mmat));
+//
+//  Check if stopping has been required by user
+//
+    if (fluka->GetStoppingCondition()) {
+       fluka->ResetStoppingCondition();
+       return (1.e15);
+    }
+//
+//  Get absorption coefficient for current material
+//    
+    TGeoMaterial*    material =  (TGeoMaterial*) (fluka->GetFlukaMaterials())->At(fluka->GetMaterialIndex(mmat));
     TFlukaCerenkov*  cerenkov = dynamic_cast<TFlukaCerenkov*> (material->GetCerenkovProperties());
     Double_t y = (cerenkov->GetAbsorptionCoefficientByWaveLength(wvlngt));
     return (y);