4 #include "KVGANILDataReader.h"
5 #include "GTGanilData.h"
6 #include "GTOneScaler.h"
9 #include "TPluginManager.h"
11 #include <TInterpreter.h>
36 OpenFile(file, dataset);
207 TString option = opt;
211 Bool_t make_scalers = option.Contains(
"SCALERS");
219 ParVal =
new UShort_t[maxParFired];
220 ParNum =
new UInt_t[maxParFired];
230 leaf.Form(
"%s/S", acqpar->GetName());
232 if (acqpar->
GetNbBits() <= 8) leaf +=
"1";
237 #if ROOT_VERSION_CODE > ROOT_VERSION(5,25,4)
238 #if ROOT_VERSION_CODE < ROOT_VERSION(5,26,1)
255 TObjArray* parlist =
new TObjArray(maxpar, 1);
256 parlist->SetName(
"ParameterList");
260 parlist->AddAt(
new TNamed(par->GetName(), Form(
"index=%d", par->
GetNumber())), par->
GetNumber());
262 fUserTree->SetAlias(par->GetName(), Form(
"Sum$((ParNum==%d)*ParVal)", par->
GetNumber()));
263 fUserTree->SetAlias(Form(
"%s_M", par->GetName()), Form(
"Sum$(ParNum==%d)", par->
GetNumber()));
300 SetName(gSystem->BaseName(file));
304 TString what_scale = gEnv->GetValue(
"KVGANILDataReader.ScalerBuffersManagement",
"kSkipScaler");
305 what_scale.Prepend(
"GTGanilData::");
306 Long_t ws = gInterpreter->ProcessLine(what_scale);
317 TUrl rawtfile(file, kTRUE);
318 rawtfile.SetOptions(
"filetype=raw");
319 TFile* rawfile = TFile::Open(rawtfile.GetUrl());
321 Error(
"OpenFile",
"File cannot be opened: %s",
331 Error(
"OpenFile",
"File cannot be opened: %s",
362 while ((daq_par = (
GTDataPar*) next())) {
425 TPluginHandler* ph =
LoadPlugin(
"GTGanilData", dataset);
Classes handling VME/VXI parameters in GANIL DAQ data.
Read GANIL formatted tapes or files.
void ConnectFired(const Int_t index, Bool_t **p) const
Connect a pointer to a data to the defined index in the Data Array.
void Connect(const Int_t index, UShort_t **p) const
Connect a pointer to a data to the defined index in the Data Array.
Int_t GetRunNumber(void) const
Returns current run number.
const TList * GetListOfDataParameters() const
void SetFileName(const TString filename)
Bool_t IsOpen(void) const
bool IsScalerBuffer(void) const
Int_t GetEventCount() const
GTScalers * GetScalers(void)
void SetScalerBuffersManagement(const ScalerWhat_t sc)
ScalerWhat_t
What to do with scaler buffer.
@ kAutoWriteScaler
have to take care of it.
UInt_t GetStatus(void) const
UInt_t GetCount(void) const
const GTOneScaler * GetScalerPtr(Int_t index) const
Return a constant pointer to the Scaler Index.
Int_t GetNbChannel(void) const
virtual void SetNumber(UInt_t num)
static TPluginHandler * LoadPlugin(const Char_t *base, const Char_t *uri="0")
GANIL VXI/VME 16 bit (maximum) EBYEDAT acquisition parameter.
UShort_t ** ConnectData()
UChar_t GetNbBits() const
void SetNbBits(UChar_t n)
Reads GANIL acquisition files (EBYEDAT)
Int_t GetEventCount() const
void ConnectRawDataParameters()
static KVGANILDataReader * Open(const Char_t *filename, Option_t *opt="")
void init()
default initialisations
virtual void SetUserTree(TTree *, Option_t *="arrays")
Bool_t HasScalerBuffer() const
void FillFiredParameterList()
clears and then fills list fFired with all fired acquisition parameters in event
Int_t GetNumberOfScalers() const
Int_t GetScalerStatus(Int_t index) const
const KVSeqCollection & GetRawDataParameters() const
GTGanilData * NewGanTapeInterface(Option_t *dataset)
virtual Bool_t GetNextEvent()
Int_t GetRunNumberReadFromFile() const
GTGanilData * fGanilData
object used to read GANIL acquisition file
virtual GTGanilData * GetGanTapeInterface()
void OpenFile(const Char_t *, Option_t *dataset)
TTree * fUserTree
user TTree to fill with data
virtual ~KVGANILDataReader()
Destructor.
UInt_t GetScalerCount(Int_t index) const
KVUniqueNameList fFired
list of fired parameters in one event
KVUniqueNameList fParameters
list of all data parameters contained in file
virtual void SetOwner(Bool_t enable=kTRUE)
virtual void Clear(Option_t *option="")
virtual void Add(TObject *obj)