Index: /trunk/MagicSoft/Mars/mdatacheck/DataCheckIncl.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/DataCheckIncl.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/DataCheckIncl.h	(revision 462)
@@ -0,0 +1,14 @@
+#ifndef __CINT__
+
+#include "MParList.h"
+
+#include "MRawRunHeader.h"
+#include "MRawEvtHeader.h"
+#include "MRawEvtData.h"
+#include "MRawCrateArray.h"
+#include "MTime.h"
+#include "MInputStreamID.h"
+
+#include "MReadTree.h"
+
+#endif // __CINT__
Index: /trunk/MagicSoft/Mars/mdatacheck/DataCheckLinkDef.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/DataCheckLinkDef.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/DataCheckLinkDef.h	(revision 462)
@@ -0,0 +1,14 @@
+#ifdef __CINT__
+
+#pragma link off all globals;
+#pragma link off all classes;
+#pragma link off all functions;
+
+#pragma link C++ class MDumpEvtHeader;
+#pragma link C++ class MFillAdcSpect;
+#pragma link C++ class MShowSpect;
+
+#pragma link C++ class MHistosAdc;
+#pragma link C++ class MGDisplayAdc;
+
+#endif
Index: /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.cc	(revision 462)
@@ -0,0 +1,47 @@
+#include "MDumpEvtHeader.h"
+
+//ClassImp(MDumpEvtHeader)
+
+Bool_t MDumpEvtHeader::PreProcess (MParList *pList)
+{
+  fRawEvtHeader = (MRawEvtHeader*)pList->FindObject("MRawEvtHeader");
+  if (!fRawEvtHeader)
+    {
+      cout << "MRawFileRead::PreProcess - WARNING: MRawEvtHeader not found... creating." << endl;
+      exit(123) ;  
+    }
+  
+  fRawEvtData = (MRawEvtData*)pList->FindObject("MRawEvtData");
+  
+  if (!fRawEvtData)
+    {
+      cout << "MRawFileRead::PreProcess - WARNING: MRawEvtData not found... creating." << endl;
+      exit(123) ;  
+    }
+
+  fPixelIter = new MRawEvtPixelIter( fRawEvtData );
+  
+  return kTRUE ; 
+
+} 
+
+    
+Bool_t MDumpEvtHeader::Process()
+{
+  fRawEvtHeader->Print() ; 
+
+  //fRawEvtData->Print() ; 
+
+  fPixelIter->Reset() ; 
+
+  while ( fPixelIter->Next() )
+    { 
+      cout << " " << fPixelIter->GetPixelId() ; 
+      
+    } 
+
+  cout << endl ; 
+  
+  return kTRUE;
+
+} 
Index: /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MDumpEvtHeader.h	(revision 462)
@@ -0,0 +1,35 @@
+#ifndef MDUMPEVTHEADER_H
+#define MDUMPEVTHEADER_H
+
+#ifndef MTASK_H
+#include "MTask.h"
+#endif
+
+#include "MParList.h"
+#include <TSystem.h>
+
+#include "MRawEvtHeader.h"
+#include "MRawEvtData.h"
+#include "MRawEvtPixelIter.h"
+
+class MDumpEvtHeader : public MTask {
+ private:
+  MRawEvtHeader    *fRawEvtHeader;
+
+  MRawEvtData      *fRawEvtData;
+
+  MRawEvtPixelIter *fPixelIter ; 
+
+ public:   
+  MDumpEvtHeader () { 
+    fRawEvtHeader = NULL ; 
+  } ; 
+
+  Bool_t PreProcess(MParList *pList);
+  Bool_t Process() ;
+  
+  //  ClassDef(MDumpEvtHeader, 1)	// Task to read the raw data binary file
+
+};
+    
+#endif
Index: /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.cc	(revision 462)
@@ -0,0 +1,74 @@
+#include "MFillAdcSpect.h"
+
+//ClassImp(MFillAdcSpect)
+
+MFillAdcSpect::MFillAdcSpect (const char *name, const char *title)
+{
+  *fName  = name  ? name  : "MFillAdcSpect";
+  *fTitle = title ? title : "Task to fill the adc spectra with  raw data";
+
+
+  
+  fRawEvtData   = NULL ; 
+  fPixelIter    = NULL ; 
+}
+
+
+
+Bool_t MFillAdcSpect::PreProcess (MParList *pList)
+{
+  // connect the raw data with this task
+  
+  fRawEvtData = (MRawEvtData*)pList->FindObject("MRawEvtData");
+  
+  if (!fRawEvtData)
+    {
+      cout << "MRawFileRead::PreProcess - WARNING: MRawEvtData not found... creating." << endl;
+      exit(123) ;  
+    }
+
+  fPixelIter = new MRawEvtPixelIter( fRawEvtData );
+  
+  fHistos = (MHistosAdc*)pList->FindObject("MHistosAdc");
+  
+  if (!fHistos) 
+    {
+      cout << "MRawFileRead::PreProcess - WARNING: MHistosAdc not found... exit..." << endl;
+      return kFALSE ;  
+    }
+
+
+  return kTRUE ; 
+
+} 
+
+    
+Bool_t MFillAdcSpect::Process()
+{
+  //  loop over the pixels and fill the values in the histograms
+  
+  fPixelIter->Reset() ; 
+
+  Int_t iHighSamples = fRawEvtData->GetNumHiGainSamples() ; 
+  Int_t iLowSamples  = fRawEvtData->GetNumLoGainSamples() ; 
+
+  //  cout << "HighSamples " << iHighSamples ;
+
+  while ( fPixelIter->Next() )
+    { 
+      for (Int_t i=0 ; i< iHighSamples ; i++ )
+	{ 
+	  fHistos->FillAdcHistHigh ( fPixelIter->GetPixelId(),
+				     fPixelIter->GetHiGainFadcSamples()[i] );
+	}
+
+      for (Int_t i=0 ; i< iLowSamples ; i++ )
+	{ 
+	  fHistos->FillAdcHistLow ( fPixelIter->GetPixelId(),
+				    fPixelIter->GetLoGainFadcSamples()[i] );
+	}
+    } 
+  
+  return kTRUE;
+  
+} 
Index: /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MFillAdcSpect.h	(revision 462)
@@ -0,0 +1,34 @@
+#ifndef MFILLADCSPECT_H
+#define MFILLADCSPECT_H
+
+#ifndef MTASK_H
+#include "MTask.h"
+#endif
+
+#include "MParList.h"
+#include <TSystem.h>
+
+#include "MRawEvtHeader.h"
+#include "MRawEvtData.h"
+#include "MRawEvtPixelIter.h"
+#include "MHistosAdc.h"
+
+class MFillAdcSpect : public MTask {
+ private:
+  MRawEvtData      *fRawEvtData;
+  MRawEvtPixelIter *fPixelIter ; 
+
+  MHistosAdc       *fHistos ; 
+
+ public:   
+  MFillAdcSpect (const char *name=NULL, const char *title=NULL); 
+
+  Bool_t PreProcess(MParList *pList);
+  Bool_t Process() ;
+  
+  //  ClassDef(MFillAdcSpect, 1)	// Task to read the raw data binary file
+
+};
+    
+#endif
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.cc	(revision 462)
@@ -0,0 +1,548 @@
+
+#include "MGDisplayAdc.h"
+
+MGDisplayAdc::MGDisplayAdc ( MHistosAdc *Histos,
+			    const TGWindow *p, const TGWindow *main, 
+			    UInt_t w, UInt_t h, 
+			    UInt_t options) 
+	: TGTransientFrame(p, main, w, h, options ) 
+{
+	//   default constructor
+	// 
+	fHists = Histos ; 
+	
+	//   the top frame for the list and some buttons and the Canvas 
+  
+	fFrameTop = new TGHorizontalFrame (this, 60,20,  kFitWidth ) ;
+  
+  
+	//    left part of top frame
+	fFT1 =  new TGVerticalFrame (fFrameTop, 80,300,  kFitWidth ) ; 
+  
+	fHistoList = new TGListBox ( fFT1, M_LIST_HISTO ) ; 
+	fHistoList->Associate( this ) ;
+	fFT1->AddFrame ( fHistoList, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 10, 10 ) )  ;
+	
+	fHistoList->Resize(80, 405 ) ; 
+	
+	
+	fFrameTop->AddFrame (fFT1, new TGLayoutHints ( kLHintsTop , 10, 10, 10, 10 ) ) ; 
+	
+	//    middle part of top frame
+	// 
+  
+	fFT2 =  new TGVerticalFrame (fFrameTop, 80,20,  kFitWidth ) ;  
+	
+	fButtonPrev = new TGTextButton ( fFT2, "Prev Histo", M_BUTTON_PREV ) ; 
+	fButtonPrev->Associate (this) ; 
+	fFT2->AddFrame ( fButtonPrev, new TGLayoutHints (kLHintsLeft | kLHintsTop,10, 10, 0, 10 ) )  ; 
+	
+  
+	fVslider1 = new TGVSlider (fFT2, 250, kSlider1 | kScaleBoth, M_VSId1);
+	
+	fVslider1->Associate(this);
+	fVslider1->SetRange(0, 576);
+	fFT2->AddFrame(fVslider1);   	
+	
+	fButtonNext = new TGTextButton ( fFT2, "Next Histo", M_BUTTON_NEXT ) ;
+	fButtonNext->Associate (this) ;
+	fFT2->AddFrame ( fButtonNext, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 10, 5 ) )  ;  		
+	
+	fFrameTop->AddFrame (fFT2, new TGLayoutHints ( kLHintsTop , 10, 10, 10, 10 ) ) ; 	
+	
+
+
+	// Radio buttons, used to select the high, low anh high/low display
+		
+	fRadio[0] = new  TGRadioButton(fFT2, "&High Gain", M_RADIO_HIGH);                       
+	fFT2->AddFrame ( fRadio[0], new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 10, 5 ) )  ; 
+	fRadio[0]->Associate(this); 
+	fRadio[0]->SetState(kButtonDown);
+	fHistoLock = kFALSE;
+	fHistoType=1;  	
+	
+        fRadio[1] = new  TGRadioButton(fFT2, "&Low Gain", M_RADIO_LOW);  
+	fFT2->AddFrame ( fRadio[1], new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 10, 5 ) )  ;
+	fRadio[1]->Associate(this); 
+	
+	fRadio[2] = new  TGRadioButton(fFT2, "H&igh/Low Gain", M_RADIO_LH); 
+	fFT2->AddFrame ( fRadio[2], new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 10, 5 ) )  ; 
+	fRadio[2]->Associate(this); 
+       
+	
+	
+	//    right part of top frame
+	// 
+	fFT3 =  new TGVerticalFrame (fFrameTop, 60, 60,  kFitWidth ) ;
+  
+    
+	
+	fECanv = new TRootEmbeddedCanvas("fECanv", fFT3, 400, 400 ) ;	 
+	
+	fFT3->AddFrame( fECanv, new TGLayoutHints ( kLHintsCenterX | kLHintsCenterY | kLHintsExpandX | kLHintsExpandY , 10, 10, 10, 10 ) ) ;
+	
+	
+	//the button for reseting the histogram
+        fButtonReset = new TGTextButton ( fFT3, "Reset histo", M_BUTTON_RESET ) ;
+        fButtonReset->Associate (this) ;
+        fFT3->AddFrame ( fButtonReset, new TGLayoutHints (kLHintsCenterX | kLHintsTop,10, 10, 0, 10 ) )  ;
+	//
+	 
+	  
+	
+	fCanv = fECanv->GetCanvas() ; 
+	
+	fFrameTop->AddFrame (fFT3, new TGLayoutHints ( kLHintsCenterX | kLHintsCenterY | kLHintsExpandX | kLHintsExpandY , 10, 10, 10, 10 ) ) ; 
+	
+	AddFrame ( fFrameTop, new TGLayoutHints ( kLHintsTop | kLHintsExpandX , 10, 10, 10, 10 ) ) ; 
+ 
+	
+	//  fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;  
+	//
+	//   the low frame for the control buttons
+	//
+	fFrameLow = new TGHorizontalFrame (this, 60,20, kFixedWidth ) ;
+  
+	fButtonSave = new TGTextButton ( fFrameLow, "Save", M_BUTTON_SAVE ) ; 
+	fButtonSave->Associate (this) ; 
+	fFrameLow->AddFrame ( fButtonSave, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 5, 5 ) )  ;
+	
+	fButtonPrint = new TGTextButton ( fFrameLow, "Print", M_BUTTON_PRINT ) ; 
+	fButtonPrint->Associate (this) ; 
+	fFrameLow->AddFrame ( fButtonPrint, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 5, 5 ) )  ; 
+  
+	fButtonPrintAll = new TGTextButton ( fFrameLow, "PrintAll", M_BUTTON_PRINTALL ) ; 
+	fButtonPrintAll->Associate (this) ; 
+	fFrameLow->AddFrame ( fButtonPrintAll, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 5, 5 ) )  ;
+  
+  
+  
+	fButtonClose = new TGTextButton ( fFrameLow, "Close", M_BUTTON_CLOSE ) ; 
+	fButtonClose->Associate (this) ; 
+	fFrameLow->AddFrame ( fButtonClose, new TGLayoutHints (kLHintsLeft | kLHintsTop, 10, 10, 5, 5 ) )  ; 
+	AddFrame ( fFrameLow, new TGLayoutHints ( kLHintsBottom | kLHintsExpandX , 10, 10, 10, 10 ) ) ; 
+	
+	//
+	//
+	//
+	BuildHistoList() ; 
+  
+	MapSubwindows();
+ 
+	Layout();
+	
+	SetWindowName("ADC Spectra");
+	SetIconName("ADC Spectra");
+
+	//Here the initial display is set to hitogram 0
+	
+	fHistoList->Select(1, kTRUE);
+	fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+	fHistoList->SetTopEntry(fHistoList->GetSelected());
+	fCanv->Modified() ;
+	fCanv->Update() ;
+	fVslider1->SetPosition( fHistoList->GetSelected()-1);
+	 
+	
+	MapWindow();
+	SetWMSizeHints(550, 550, 1000, 1000, 1, 1); 
+
+}  
+
+// ======================================================================
+// ======================================================================
+// 
+// 
+
+MGDisplayAdc::~MGDisplayAdc () 
+{ 
+
+		
+	delete fButtonSave ; 
+	delete fButtonPrint ; 
+	delete fButtonPrintAll ; 
+	delete fButtonClose ; 
+	
+	delete fButtonPrev; 
+	delete fButtonNext ; 
+	delete fButtonReset ;
+	
+	delete fVslider1; 
+	delete fECanv ;
+	
+
+	delete fHists; 
+	delete fHistoList ;
+	delete fRadio[2];
+	delete fRadio[1];
+	delete fRadio[0]; 
+	delete fFT1 ; 
+	delete fFT2 ; 
+	delete fFT3 ; 
+	delete fFrameLow ; 
+	delete fFrameTop ; 
+	
+	
+}  
+
+// ======================================================================
+// ======================================================================
+
+void MGDisplayAdc::CloseWindow()
+{
+  // Got close message for this MainFrame. Calls parent CloseWindow()
+  // (which destroys the window) and terminate the application.
+  // The close message is generated by the window manager when its close
+  // window menu item is selected.
+  // 
+  delete this ; 
+  //  TGTransientFrame::CloseWindow();
+  //  TGMainFrame::CloseWindow();
+  //   gROOT->GetApplication()->Terminate(0)  ; 
+}
+
+
+
+// ======================================================================
+// ======================================================================
+
+Bool_t MGDisplayAdc::BuildHistoList(Int_t type ) 
+{ 
+	//   looks in the container of the AdcSpectra and reads in the 
+	//   Histogramms in there. 
+	//
+	//   In the class MHistosAdc are in fact two lists. One for the high and
+	//   one for the low gain. Here we will use only the high gain list!!!
+	//   With some special options (settings in the gui) we will also be able
+	//   to plot the low gain
+	// 
+	for ( Int_t i=0 ; i < fHists->GetHighEntries(); i++ ) {	       				
+		fHistoList->AddEntry(fHists->GetHighList()->At(i)->GetName(), i+1) ;
+		
+	} 
+	
+	fHistoList->MapSubwindows() ;
+	fHistoList->Layout() ;
+	return (kTRUE) ; 
+} 
+
+// ======================================================================
+// ======================================================================
+
+Bool_t MGDisplayAdc::ProcessMessage(Long_t msg, Long_t parm1, Long_t parm2)
+{     
+	
+	// Process events generated by the buttons in the frame.
+	// 
+	Int_t   buttons = 4, retval = 0 ; 
+	Char_t  wort[100] ;
+	Char_t  extens[5] ;
+	Char_t  command[110] ;
+	
+	TGFileItem *item ;     // to process items in the file view container
+	void *np = NULL ;      // null pointer
+	
+	switch (GET_MSG(msg)) 
+	{
+	    case kC_COMMAND:
+		switch (GET_SUBMSG(msg)) 
+		{
+		    case kCM_BUTTON:
+			
+			switch (parm1)
+			{  
+				
+			    case M_BUTTON_SAVE:
+				new TGMsgBox(fClient->GetRoot(), this,
+					     "WARNING!",
+					     "Not implemented yet.",
+					     kMBIconExclamation, buttons, &retval); 
+				
+				break ; 
+				
+			    case M_BUTTON_PRINT:
+				break;
+				
+			    case M_BUTTON_RESET:
+				new TGMsgBox(fClient->GetRoot(), this,
+					     "WARNING!",
+                                             "Not implemented yet.",
+					     kMBIconExclamation, buttons, &retval);  												
+				
+				break;
+				
+				
+			    case M_BUTTON_CLOSE: 
+				CloseWindow() ; 
+				break ; 
+				
+				// The selection for "Next Histogram".
+				// There is also a link for the sicronisation with the slider 
+				// 
+			    case M_BUTTON_PREV:
+								
+				if (!( fHistoList->GetSelected()-1 ) == 0)
+				{
+				    if (fHistoLock == kTRUE )
+				    {
+					    fCanvas->cd(1);
+					    fHistoList->Select(fHistoList->GetSelected()-1, kTRUE); 
+					    fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+					    fCanvas->cd(2);
+					    fHists->GetLowList()->At( fHistoList->GetSelected()-1)->Draw() ; 
+				    }
+					else
+					{
+						fCanv->cd();
+						fHistoList->Select(fHistoList->GetSelected()-1, kTRUE);
+						fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ; 
+					}
+					
+					fHistoList->SetTopEntry(fHistoList->GetSelected());  
+					fCanv->Modified() ;
+					fCanv->Update() ;
+					fVslider1->SetPosition( fHistoList->GetSelected()-1);
+				}
+				if ((fRadio[1]->GetState()) == kButtonDown)
+				{
+					fRadio[0]->SetState(kButtonDown);
+					fRadio[1]->SetState(kButtonUp);
+				} 
+				
+
+				break;
+				
+				//The same as above, but for next histogram
+				
+			    case M_BUTTON_NEXT:
+			        
+				if (!((fHistoList->GetSelected()-1)==576))
+					
+                                {
+					if (fHistoLock == kTRUE )
+					{
+						fCanvas->cd(1);
+						fHistoList->Select(fHistoList->GetSelected()+1, kTRUE);
+						fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+						fCanvas->cd(2);
+						fHists->GetLowList()->At( fHistoList->GetSelected()-1)->Draw() ;  
+					}										
+					else
+                                        {  
+						fCanv->cd();
+                                                fHistoList->Select(fHistoList->GetSelected()+1, kTRUE);
+                                                fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ; 
+						
+					}
+						fHistoList->SetTopEntry(fHistoList->GetSelected());
+						fCanv->Modified() ;
+						fCanv->Update() ;
+						fVslider1->SetPosition( fHistoList->GetSelected()-1);
+					
+				}
+				if ((fRadio[1]->GetState()) == kButtonDown)
+					{
+						fRadio[0]->SetState(kButtonDown);
+						fRadio[1]->SetState(kButtonUp);
+					}
+				break;
+			    default:
+				break ;
+			} 
+			
+		    case kCM_MENU:
+			switch (parm1)
+			{
+			}
+			break ;
+			
+		    default:
+			break ;
+		
+		
+			
+		    case kCM_RADIOBUTTON:
+	  
+			switch(parm1)
+			{
+			    case M_RADIO_HIGH:
+				fRadio[1]->SetState(kButtonUp);
+				fRadio[2]->SetState(kButtonUp);
+				fHistoLock = kFALSE;
+				fHistoType=1;
+                                fCanv->cd();
+				fHistoList->Select(fHistoList->GetSelected(), kTRUE);
+                                fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+                                fHistoList->SetTopEntry(fHistoList->GetSelected());
+                                fCanv->Modified() ;
+                                fCanv->Update() ;
+                                fVslider1->SetPosition( fHistoList->GetSelected()-1);
+				
+				
+				break;
+				
+			    case M_RADIO_LOW:
+				fRadio[0]->SetState(kButtonUp);
+				fRadio[2]->SetState(kButtonUp);
+				fCanv->cd(); 
+				fHistoLock = kFALSE;
+				fHistoType = 2;
+				
+				fHistoList->Select(fHistoList->GetSelected(), kTRUE);
+				fHists->GetLowList()->At( fHistoList->GetSelected()-1)->Draw() ;
+				fHistoList->SetTopEntry(fHistoList->GetSelected());
+				
+				fCanv->Modified() ;
+				fCanv->Update() ;
+				fVslider1->SetPosition( fHistoList->GetSelected()-1);
+				
+				break;
+			    case M_RADIO_LH:
+				fRadio[0]->SetState(kButtonUp);
+                                fRadio[1]->SetState(kButtonUp); 
+				
+				if (fHistoLock == kFALSE)
+				{
+					fCanvas = fECanv->GetCanvas(); 
+					fCanvas->Divide(1,2, 0, 0 ,0);
+
+					fCanv->Modified() ;
+					fCanv->Update() ;  
+					fHistoLock = kTRUE;
+					fHistoType = 3; 
+				
+				}
+			       
+				fCanvas->cd(1);
+ 
+				fHistoList->Select(fHistoList->GetSelected(), kTRUE);
+                                fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+                                fHistoList->SetTopEntry(fHistoList->GetSelected());
+				
+				
+				
+				
+				fCanvas->cd(2);
+                                fHistoList->Select(fHistoList->GetSelected(), kTRUE);
+                                fHists->GetLowList()->At( fHistoList->GetSelected()-1)->Draw() ;
+                                fHistoList->SetTopEntry(fHistoList->GetSelected());     
+				
+				
+				
+                                fCanv->Modified() ;
+                                fCanv->Update();
+				
+			    default:
+				break;
+			}
+			break;
+		   
+			
+		}
+		
+	    case kCM_LISTBOX:
+	      switch  (GET_SUBMSG(msg)) 
+		{
+		    case M_LIST_HISTO: 
+			
+			if (fHistoLock == kTRUE ) 
+			{
+				fCanvas->cd(1);
+				fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ;
+				fCanvas->cd(2);
+				fHists->GetLowList()->At( fHistoList->GetSelected()-1)->Draw() ; 				
+				
+			}
+			else
+			{
+			
+				fCanv->cd() ; 
+			
+				fHists->GetHighList()->At( fHistoList->GetSelected()-1)->Draw() ; 
+			
+			}
+			fCanv->Modified() ; 
+			fCanv->Update() ;
+			fVslider1->SetPosition( fHistoList->GetSelected()-1);
+		  
+		  
+		  
+		default:
+		  break ;
+		}
+	      
+		
+	case kC_CONTAINER: 
+	  switch (GET_SUBMSG(msg)) 
+	    {
+	      
+	    case kCT_ITEMDBLCLICK: 
+	      
+	      break; 
+			
+	    default:
+	      break ;
+	    }
+	  
+	  
+	  
+	default:
+	  break;
+	  
+	case kC_VSLIDER:
+	  switch(GET_SUBMSG(msg))
+	    {
+	    case kSL_POS:
+	      {
+		switch(parm1)
+		  {
+		      case M_VSId1:
+
+			  // Check for the slider movement and sicronise with TGListBox		    
+			  if ((parm2 >= 0) && (parm2) <= 576)
+			  {
+				  
+				  if (fHistoLock==kTRUE)
+				  {
+					  fCanvas->cd(1) ;
+					  fHists->GetHighList()->At(parm2)->Draw() ;
+					  fHistoList->Select(parm2+1, kTRUE);
+					 
+					  fCanvas->cd(2) ; 
+					  fHists->GetLowList()->At(parm2)->Draw() ;
+                                          fHistoList->Select(parm2+1, kTRUE);
+					  fHistoList->SetTopEntry(fHistoList->GetSelected()); 
+					  
+				  }
+				  
+				  else 
+				  {
+					  fCanv->cd() ;  
+					  fHists->GetHighList()->At(parm2)->Draw() ;
+					  fHistoList->Select(parm2+1, kTRUE); 
+					  
+					  fHistoList->SetTopEntry(fHistoList->GetSelected());
+					  
+				  }
+					  fCanv->Modified() ;
+					  fCanv->Update() ;
+				  
+				  if ((fRadio[1]->GetState()) == kButtonDown)
+				  {
+					  fRadio[0]->SetState(kButtonDown);
+					  fRadio[1]->SetState(kButtonUp);
+				  }   
+				  
+				  
+			  }
+		    break;
+		  }
+		break;				
+	      }					
+	      break;
+	    }
+	  break;
+	  
+	}
+	return kTRUE;
+} 
Index: /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MGDisplayAdc.h	(revision 462)
@@ -0,0 +1,115 @@
+#ifndef MGDISPLAYADC_H
+#define MGDISPLAYADC_H
+
+#include <iostream.h>
+#include <TROOT.h> 
+#include <TApplication.h> 
+#include <TSystem.h> 
+#include <TGClient.h> 
+#include <TGButton.h>
+#include <TGMenu.h>
+#include <TGTab.h> 
+#include <TGListBox.h> 
+#include <TGPicture.h>
+#include <TRootEmbeddedCanvas.h>
+#include <TCanvas.h>
+#include <TGFSContainer.h>
+#include <TGMsgBox.h>
+#include <TVirtualX.h>
+#include <TGFrame.h>
+#include <TGTextEntry.h>
+#include <TGSlider.h>
+#include <TGDoubleSlider.h>
+#include <TGScrollBar.h>
+#include <TSlider.h>
+
+
+#include <TVirtualX.h>
+#include <TGClient.h>   
+    
+#include "MHistosAdc.h"
+	
+    class MHistosAdc;
+
+
+
+enum ComIdentDisplayAdc {
+	M_BUTTON_SAVE,
+		M_BUTTON_PRINT,
+		M_BUTTON_PRINTALL,
+		M_BUTTON_CLOSE , 
+		
+		M_BUTTON_PREV, 
+		M_BUTTON_NEXT,
+
+		M_LIST_HISTO,
+		M_RADIO_HIGH,
+		M_RADIO_LOW,
+		M_RADIO_LH,
+		M_BUTTON_RESET,
+		M_VSId1
+} ; 
+
+class MGDisplayAdc : public TGTransientFrame {
+    private:
+	
+	MHistosAdc *fHists;		// Pointer to Container with the histograms
+	
+	// Create a main frame with a number of different buttons.
+	//   
+	TGCompositeFrame  *fFrameTop ;   // top part of the main window
+	TGCompositeFrame  *fFrameLow ;   // low part of the main window
+  
+	TGVerticalFrame   *fFT1, *fFT2, *fFT3 ;
+	
+	TGListBox         *fHistoList ;
+	TGTextButton      *fButtonPrev, *fButtonNext , *fButtonReset ;
+	
+	TRootEmbeddedCanvas  *fECanv , *fECanvLow;
+
+	TGTextButton   *fButtonSave, *fButtonPrint, *fButtonPrintAll, *fButtonClose ; 
+	
+	TCanvas            *fCanv ;	
+	
+	
+	//for sliders
+	
+	TGVSlider       *fVslider1;
+	
+       
+	
+  
+    public:
+	
+	//for radio buttons
+
+	TGRadioButton *fRadio[3];
+
+	
+        Int_t    fHistoType;
+        Bool_t    fHistoLock; 
+	//
+			
+	
+	TGPicture *fPicture;  
+	TCanvas *fCanvas;
+	
+	MGDisplayAdc(MHistosAdc *fHists , 
+		     const TGWindow *p, const TGWindow *main, 
+		     UInt_t w, UInt_t h, 
+		     UInt_t options = kMainFrame | kVerticalFrame ) ;
+	
+	~MGDisplayAdc(); 
+  
+	void  CloseWindow()  ;
+       
+	
+	Bool_t BuildHistoList(Int_t type=1) ;
+	
+	Bool_t ProcessMessage(Long_t msg, Long_t parm1, Long_t parm2);
+  
+} ; 
+
+#endif
+
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.cc	(revision 462)
@@ -0,0 +1,110 @@
+///////////////////////////////////////////////////////////////////////
+//
+// MHistosAdc
+//
+// This class contains a list of all ADC spektra histograms
+//
+///////////////////////////////////////////////////////////////////////
+
+#include "MHistosAdc.h"
+
+#include <iostream.h>
+
+#include <TH1.h>
+#include <TFile.h>
+
+ClassImp(MHistosAdc)
+
+MHistosAdc::MHistosAdc (const char *name, const char *title)
+{
+    //
+    //  default constructor
+    //  creates an a list of histograms for all pixels and both gain channels
+    //
+
+    fHistHigh = new TObjArray(577);
+    fHistLow  = new TObjArray(577);
+
+    //
+    //   set the name and title of this object
+    //
+    
+    *fName  = name  ? name  : "MHistosAdc" ;
+    *fTitle = title ? title : "Container for ADC spectra histograms" ;
+
+    //
+    //   loop over all Pixels and create two histograms
+    //   one for the Low and one for the High gain
+    //   connect all the histogram with the container fHist
+    //
+
+    Char_t  tmp1[40];
+    Char_t  tmp2[40];
+    TH1F    *h1;
+
+    for ( Int_t i = 0 ; i < 577 ; i++)
+    {
+        sprintf ( tmp1, "high%d", i ) ;
+        sprintf ( tmp2, "high gain Pixel %d", i ) ;
+
+        h1 = new TH1F ( tmp1, tmp2, 256, 0., 255. ) ;
+
+        fHistHigh->Add( h1 ) ;
+
+        sprintf ( tmp1, "low %d", i ) ;
+        sprintf ( tmp2, "low gain Pixel %d", i ) ;
+
+        h1 = new TH1F ( tmp1, tmp2, 256, 0., 255. ) ;
+
+        fHistLow->Add( h1 ) ;
+
+    }
+}
+
+MHistosAdc::~MHistosAdc ()
+{
+  
+  //   default destructor 
+  //
+  delete fHistHigh ; 
+  delete fHistLow  ; 
+}
+
+void MHistosAdc::Print(Option_t *)
+{
+  for ( Int_t i = 0 ; i < 576 ; i++)
+    {
+      fHistHigh[i].Print() ;
+    }
+}
+
+void MHistosAdc::FillAdcHistHigh ( Int_t iPix, Byte_t data)
+{
+  //
+  
+  ((TH1F*) (fHistHigh->At(iPix)))->Fill( (Float_t) data ) ;
+}
+
+void MHistosAdc::FillAdcHistLow ( Int_t iPix, Byte_t data)
+{
+  //
+  
+  ((TH1F*) (fHistLow->At(iPix)))->Fill( (Float_t) data ) ;
+}
+
+void MHistosAdc::SaveHist ( char *name )
+{
+    //
+    //   save all histogram in this class to a root file
+    //
+
+    TFile out( name, "recreate") ;
+
+    //
+    //  loop over all pixels and write the files out
+    //
+
+    fHistLow->Write() ;
+    fHistHigh->Write() ;
+}
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MHistosAdc.h	(revision 462)
@@ -0,0 +1,53 @@
+#ifndef MHISTOSADC_H
+#define MHISTOSADC_H
+
+#include "MAGIC.h"
+
+#include <TObjArray.h>
+
+#include "MParContainer.h"
+
+class MHistosAdc : public MParContainer
+{
+private:
+    TObjArray *fHistHigh;	// List of High gain Histograms
+    TObjArray *fHistLow;	// List of Low  gain Histograms
+
+public:
+     MHistosAdc(const char *name=NULL, const char *title=NULL);
+    ~MHistosAdc();
+
+    void FillAdcHistHigh(Int_t iPix, Byte_t data); 
+    void FillAdcHistLow (Int_t iPix, Byte_t data); 
+
+    void SaveHist(char *name);
+
+    void Print(Option_t * t = NULL);
+
+
+    TObjArray* GetHighList() 
+      { 
+	return ( fHistHigh ) ; 
+      }   
+
+    TObjArray* GetLowList() 
+      { 
+	return ( fHistLow ) ; 
+      } 
+    
+    Int_t GetHighEntries() 
+      { 
+	return (fHistHigh->GetEntries() ) ;  
+      } 
+
+    Int_t GetLowEntries() 
+      { 
+	return (fHistLow->GetEntries() ) ;  
+      } 
+
+      
+    ClassDef(MHistosAdc, 1)	// list of Histograms with ADC spectra
+};
+
+#endif
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.cc	(revision 462)
@@ -0,0 +1,70 @@
+#include "MShowSpect.h"
+
+#include <stdlib.h>
+
+#include <TROOT.h> 
+#include <TApplication.h> 
+#include <TSystem.h> 
+#include <TGClient.h> 
+#include <TGFileDialog.h> 
+#include <TVirtualX.h>
+
+#include "MParList.h"
+#include "MHistosAdc.h"
+
+
+////////////////////////////////////////////////////////////////////////
+//
+//  MGShowSpect.h
+//
+//  A Gui Task to show the raw ADC values in the histograms
+//
+
+ClassImp(MShowSpect)
+
+MShowSpect::MShowSpect(char *nameHist ) 
+{ 
+  // default constructor 
+
+  sprintf (fHistName, "%s", nameHist ) ; 
+} 
+
+
+Bool_t MShowSpect::PreProcess(MParList *pList)
+{
+  //
+  //   Do the preprocessing for MShowSpect
+  // 
+  //   Connects Histogramms in the MHistosAdc container as the input
+  //
+
+  fHists = (MHistosAdc*) pList->FindObject( fHistName );
+  
+  if (!fHists)
+    {
+      cout << "ERROR: MShowSpect::PreProc(): " << fHistName << " not found!" << endl;
+      exit(1);
+    }
+  
+  return (kTRUE) ; 
+} 
+
+
+Bool_t MShowSpect::PostProcess()
+{
+  //   just start the gui for displaying the adc spectra
+
+  new MGDisplayAdc(fHists, gClient->GetRoot(), gClient->GetRoot(), 600, 600);
+
+  return (kTRUE) ; 
+} 
+
+
+
+
+
+
+
+
+
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MShowSpect.h	(revision 462)
@@ -0,0 +1,35 @@
+#ifndef MSHOWSPECT_H
+#define MSHOWSPECT_H
+
+#include "MAGIC.h"
+
+#include "MTask.h"
+#include "MGDisplayAdc.h"
+
+class MGDisplayAdc ; 
+
+class MHistosAdc;
+class MHistosTdc; 
+class MParList ;
+
+class MShowSpect : public MTask 
+{
+private:
+  char       fHistName[256] ; 
+
+  MHistosAdc *fHists;		// Pointer to Container with the histograms
+  
+ public:
+  
+  MShowSpect(char* histName );
+  
+  Bool_t PreProcess(MParList * pList); 
+  Bool_t PostProcess();
+  
+  ClassDef(MShowSpect, 1)	// Fill the raw ADC in the histograms
+};
+
+#endif
+
+
+
Index: /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.cc
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.cc	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.cc	(revision 462)
@@ -0,0 +1,97 @@
+#include "MViewAdcSpectra.h" 
+
+#include <iostream.h>
+
+#include "MParList.h"
+#include "MTaskList.h"
+#include "MEvtLoop.h"
+
+#include "MRawRunHeader.h"
+#include "MRawEvtHeader.h"
+#include "MRawEvtData.h"
+#include "MRawCrateArray.h"
+#include "MTime.h"
+
+#include "MReadTree.h" 
+#include "MDumpEvtHeader.h" 
+#include "MFillAdcSpect.h" 
+#include "MShowSpect.h" 
+#include "MHistosAdc.h" 
+
+MViewAdcSpectra::MViewAdcSpectra() 
+{
+  // default constructor  
+} 
+
+MViewAdcSpectra::~MViewAdcSpectra() 
+{
+  // default destructor  
+} 
+
+
+// ================================================================================
+Bool_t MViewAdcSpectra::PedAdcSpectra ( Char_t *inputfile ) 
+{
+  //   This job reads in the FADC data from all events and fills
+  //   the spectrum for each pmt pixel.
+  //
+
+  cout << "PedAdcSpectra:: Analyse the file " << inputfile << endl ;
+  
+  // create a (empty) list of parameters which can be used by the tasks
+  // and an (empty) list of tasks which should be executed
+  // connect them in the required way. 
+ 
+  MParList *plist  = new MParList;
+  MTaskList *tasks = new MTaskList;
+  plist->AddToList(tasks);
+
+  //   create the data containers for the raw data 
+  
+  MRawRunHeader *runheader = new MRawRunHeader;
+  plist->AddToList(runheader);
+
+  MRawEvtHeader *evtheader = new MRawEvtHeader;
+  plist->AddToList(evtheader);
+  
+  MRawEvtData *evtdata = new MRawEvtData;
+  plist->AddToList(evtdata);
+  
+  MRawCrateArray *cratearray = new MRawCrateArray;
+  plist->AddToList(cratearray);
+  
+  MTime *evttime = new MTime("MTime");
+  plist->AddToList(evttime);
+
+  MHistosAdc *histosAdc = new MHistosAdc() ; 
+  plist->AddToList( histosAdc ) ; 
+  
+  //    set up the tasks for this job
+
+  MReadTree *readin  =  new MReadTree ( inputfile, "Data") ; 
+  tasks->AddToList( readin ) ; 
+
+  //  MDumpEvtHeader *dumpheader = new MDumpEvtHeader() ; 
+  //  tasks->AddToList( dumpheader ) ; 
+ 
+  MFillAdcSpect *fillspect = new MFillAdcSpect() ; 
+  tasks->AddToList( fillspect ) ; 
+
+  MShowSpect *showspect = new MShowSpect( "MHistosAdc" ) ; 
+  tasks->AddToList( showspect ) ;
+
+  //    set up the loop for the processing 
+  
+  MEvtLoop magic;
+  magic.SetParList(plist);
+
+  //    start the loop running 
+
+  magic.Eventloop() ; 
+  
+
+  cout << " End of this job " << endl ; 
+
+  return kTRUE ; 
+
+} 
Index: /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.h
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.h	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/MViewAdcSpectra.h	(revision 462)
@@ -0,0 +1,27 @@
+#ifndef MVIEWADCSPECTRA_H
+#define MVIEWADCSPECTRA_H
+
+#ifndef MAGIC_H
+#include "MAGIC.h"
+#endif
+
+class MViewAdcSpectra {
+
+ private:
+  
+ public:
+  
+  MViewAdcSpectra() ; 
+  
+  ~MViewAdcSpectra() ; 
+  
+  Bool_t PedAdcSpectra( Char_t *inputFile ) ; 
+
+  //  Bool_t CrAdcSpectra ( Char_t *inputFile ) ; 
+
+  //  Bool_t PedTdcSpectra( Char_t *inputFile ) ; 
+  //  Bool_t CrTdcSpectra ( Char_t *inputFile ) ; 
+
+} ;
+
+#endif 
Index: /trunk/MagicSoft/Mars/mdatacheck/Makefile
===================================================================
--- /trunk/MagicSoft/Mars/mdatacheck/Makefile	(revision 462)
+++ /trunk/MagicSoft/Mars/mdatacheck/Makefile	(revision 462)
@@ -0,0 +1,127 @@
+##################################################################
+#
+#   makefile
+# 
+#   for the MARS software
+#
+##################################################################
+# @maintitle
+
+# @code
+
+#
+#  please change all system depend values in the 
+#  config.mk.${OSTYPE} file 
+#
+#
+include ../Makefile.conf.$(OSTYPE)
+include ../Makefile.conf.general
+
+# @endcode 
+
+# @code 
+
+LIB   = libmdatacheck.a
+
+#
+#  connect the include files defined in the config.mk file
+#
+INCLUDES = -I. -I../ -I../mbase -I../mraw
+
+#
+#  ----->>>   root libraries
+#
+
+ROOTLIBS   =  `root-config --libs`
+ROOTGLIBS  =  `root-config --glibs`
+ROOTCFLAGS =  `root-config --cflags`
+
+#
+#  compiler flags
+#
+
+CXXFLAGS  = $(ROOTCFLAGS) $(INCLUDES) $(OPTIM) $(DEBUG)
+CFLAGS    = $(CXXFLAGS)
+FFLAGS    = $(CXXFLAGS)
+
+#------------------------------------------------------------------------------
+
+#.SILENT:
+
+.SUFFIXES: .c .cc .cxx .h .hxx .o 
+
+
+SRCFILES = MViewAdcSpectra.cc \
+	   MFillAdcSpect.cc \
+	   MDumpEvtHeader.cc \
+	   MShowSpect.cc \
+	   MHistosAdc.cc \
+	   MGDisplayAdc.cc
+
+SRCS    = $(SRCFILES)
+HEADERS = $(SRCFILES:.cc=.h)
+OBJS    = $(SRCFILES:.cc=.o) 
+
+############################################################
+
+all: $(LIB)
+
+depend:
+	@makedepend $(SRCS) $(INCLUDES) $(ROOTCFLAGS) \
+        -f../Makefile.depend 2> kk.kk ; cat kk.kk
+
+$(LIB): $(OBJS) DataCheckCint.o
+	@echo " - Building Library $(LIB) ... "
+	$(AR) $(LIB) *.o
+
+DataCheckCint.cc: $(HEADERS) 
+	@echo 
+	@echo " - Generating dictionary DataCheckCint.cc ..."
+
+	$(ROOTSYS)/bin/rootcint -f DataCheckCint.cc \
+	-c $(INCLUDES) $(HEADERS) DataCheckIncl.h DataCheckLinkDef.h 
+
+.cxx.o:	
+	@echo " - Compiling " $<
+	$(CXX) $(CXXFLAGS) -c $< -o $@
+
+.cc.o:	
+	@echo " - Compiling " $<
+	$(CXX) $(CXXFLAGS) -c $< -o $@
+
+.c.o:	
+	@echo " - Compiling " $<
+	$(CC) $(CFLAGS) -c $< -o $@
+
+#
+# The cleaning facility
+#
+
+rmlib:	
+	@echo "Removing libraries..."
+	@rm -f lib*.a
+
+rmcint:	
+	@echo "Removing cint-stuff..."
+	@rm -f DataCheckCint.*
+
+rmobjs:	
+	@echo "Removing object files..."
+	@rm -f *.o
+
+rmbin:	
+	@echo "Removing binary files..."
+	@rm -f core
+
+
+clean:	rmlib rmcint rmobjs rmbin
+
+mrproper:	clean
+	@echo "Removing *~ kk.kk html/..."
+	@rm -f *~ kk.kk
+
+cflags: 
+	@echo $(INCLUDES) $(CXXFLAGS)
+
+# @endcode
+
