GSI Object Oriented Online Offline (Go4) GO4-6.4.0
Loading...
Searching...
No Matches
TMeshB1AnlProc.cxx
Go to the documentation of this file.
1// $Id$
2//-----------------------------------------------------------------------
3// The GSI Online Offline Object Oriented (Go4) Project
4// Experiment Data Processing at EE department, GSI
5//-----------------------------------------------------------------------
6// Copyright (C) 2000- GSI Helmholtzzentrum fuer Schwerionenforschung GmbH
7// Planckstr. 1, 64291 Darmstadt, Germany
8// Contact: http://go4.gsi.de
9//-----------------------------------------------------------------------
10// This software can be used under the license agreements as stated
11// in Go4License.txt file which is part of the distribution.
12//-----------------------------------------------------------------------
13
14#include "TMeshB1AnlProc.h"
15
16#include "TGo4UserException.h"
17#include "TGo4Log.h"
18
19#include "TMeshRawEvent.h"
20#include "TMeshB1OutputEvent.h"
21#include "TMeshB1InputEvent.h"
22
23//***********************************************************
24// this one is used in TXXXAnlFact
27{
28 TGo4Log::Info("TMeshB1AnlProc: Create %s", name);
29}
30
31//***********************************************************
36
37//***********************************************************
41
42//-----------------------------------------------------------
44{
45 if(!poutevt) return;
46 if(!fxInput) {
47 // lazy init for input event from framework
48 TGo4EventElement *providerinput = GetInputEvent("Input1Provider");
49 TMeshRawEvent *raw = dynamic_cast<TMeshRawEvent *>(providerinput);
50 if (raw)
51 fxInput = &(raw->fxSub1);
52 // provider delivers full raw event, we use only our component
53 else
54 fxInput = dynamic_cast<TMeshB1InputEvent *>(providerinput);
55 // provider with partial io delivers just our component
56 }
57 if (fxInput) {
58 // do the processing here:
59 for (Int_t i = 0; i < 4; i++) {
60 poutevt->frData[i] = (Float_t)fxInput->fiCrate1[i];
61 }
62 } else {
63 throw TGo4UserException(3, "Error: no input event for processor %s", GetName());
64 }
65}
TGo4EventProcessor(const char *name)
TGo4EventElement * GetInputEvent()
Access to external raw event which is set as association member.
friend class TGo4EventElement
static void Info(const char *text,...) GO4_PRINTF_ARGS
User shortcut for message with prio 1.
Definition TGo4Log.cxx:294
Exception to be thrown by analysis user.
virtual ~TMeshB1AnlProc()
TMeshB1InputEvent * fxInput
void Analysis(TMeshB1OutputEvent *target)
TMeshB1InputEvent fxSub1
we compose data structure from subbranches: