BOSS 7.1.0
BESIII Offline Software System
Loading...
Searching...
No Matches
eformat::ROSFragment< TPointer > Class Template Reference

#include <ROSFragment.h>

+ Inheritance diagram for eformat::ROSFragment< TPointer >:

Public Member Functions

 ROSFragment (const TPointer &it)
 
 ROSFragment ()
 
 ROSFragment (const ROSFragment &other)
 
virtual ~ROSFragment ()
 
ROSFragmentoperator= (const ROSFragment &other)
 
ROSFragmentassign (const TPointer &it)
 
virtual bool check () const
 
bool check_tree () const
 
uint32_t run_no () const
 
uint32_t lvl1_id () const
 
uint32_t bc_id () const
 
- Public Member Functions inherited from eformat::Header< TPointer >
 Header (const TPointer &it, uint32_t match)
 
 Header ()
 
 Header (const Header &other)
 
virtual ~Header ()
 
Headeroperator= (const Header &other)
 
Headerassign (const TPointer &it, uint32_t match)
 
virtual bool check () const
 
uint32_t marker () const
 
uint32_t fragment_size_word () const
 
uint32_t header_size_word () const
 
uint32_t version () const
 
uint32_t source_id () const
 
uint32_t nstatus () const
 
void start (TPointer &it) const
 
void payload (TPointer &it) const
 
void end (TPointer &it) const
 
uint32_t payload_size_word (void) const
 
void status (TPointer &it) const
 
uint32_t nspecific () const
 
void specific_header (TPointer &it) const
 
virtual uint32_t nchildren () const
 
virtual void child (TPointer &p, size_t n) const
 
virtual void child_check (TPointer &p, size_t n) const
 
virtual uint32_t children (TPointer *p, size_t max) const
 

Detailed Description

template<class TPointer>
class eformat::ROSFragment< TPointer >

Describes how to access the contents of a subdetector fragment, as prescribed by the event format note.

Definition at line 29 of file ROSFragment.h.

Constructor & Destructor Documentation

◆ ROSFragment() [1/3]

template<class TPointer >
eformat::ROSFragment< TPointer >::ROSFragment ( const TPointer &  it)

To build a fragment given the containing buffer. I need to know where the fragment starts in order to do that.

Parameters
itThe exact position where this fragment should start.

Definition at line 115 of file ROSFragment.h.

117 m_start()
118{
120}
void specific_header(TPointer &it) const
Definition: Header.h:172
@ ROS
The ROS marker.
Definition: HeaderMarker.h:28

◆ ROSFragment() [2/3]

template<class TPointer >
eformat::ROSFragment< TPointer >::ROSFragment ( )
inline

Builds an empty, otherwise useless ROSFragment

Definition at line 44 of file ROSFragment.h.

44: Header<TPointer>(), m_start() {}

◆ ROSFragment() [3/3]

template<class TPointer >
eformat::ROSFragment< TPointer >::ROSFragment ( const ROSFragment< TPointer > &  other)
inline

Copy constructor

Parameters
otherThe fragment to be copied

Definition at line 51 of file ROSFragment.h.

52 : Header<TPointer>(other), m_start(other.m_start) {}
Index other(Index i, Index j)
Definition: EvtCyclic3.cc:118

◆ ~ROSFragment()

template<class TPointer >
virtual eformat::ROSFragment< TPointer >::~ROSFragment ( )
inlinevirtual

Destructor virtualisation

Definition at line 57 of file ROSFragment.h.

57{}

Member Function Documentation

◆ assign()

template<class TPointer >
eformat::ROSFragment< TPointer > & eformat::ROSFragment< TPointer >::assign ( const TPointer &  it)

Manual re-assignment

Parameters
itThe position pointing the first word of this fragment

Definition at line 123 of file ROSFragment.h.

124{
125 ERS_DEBUG_3("Re-building ROSFragment from pointer");
128 ERS_DEBUG_1("Initialized header with source identifier = %s",
130 return *this;
131}
#define ERS_DEBUG_1(...)
#define ERS_DEBUG_3(...)
uint32_t source_id() const
Definition: Header.h:116
Header & assign(const TPointer &it, uint32_t match)
Definition: Header.h:236
char * c_str(Index i)
Definition: EvtCyclic3.cc:252

◆ bc_id()

template<class TPointer >
uint32_t eformat::ROSFragment< TPointer >::bc_id ( ) const
inline

Returns the bunch crossing identifier

Definition at line 97 of file ROSFragment.h.

97{ return m_start[2]; }

◆ check()

template<class TPointer >
bool eformat::ROSFragment< TPointer >::check
virtual

Says if the the fragment is valid. This may throw exceptions.

Reimplemented from eformat::Header< TPointer >.

Definition at line 134 of file ROSFragment.h.

135{
136 ERS_DEBUG_2("Checking for consistency of ROSFragment");
137 eformat::Header<TPointer>::check(); //< first do a generic check
138 if (eformat::Header<TPointer>::nspecific() != NSPECIFIC)
139 throw EFORMAT_SIZE_CHECK(NSPECIFIC, this->nspecific());
140 return true;
141}
#define EFORMAT_SIZE_CHECK(actual, informed)
#define ERS_DEBUG_2(...)
uint32_t nspecific() const
Definition: Header.h:164
virtual bool check() const
Definition: Header.h:249

◆ check_tree()

template<class TPointer >
bool eformat::ROSFragment< TPointer >::check_tree

Says if the the fragment is valid. This may throw exceptions.

Definition at line 144 of file ROSFragment.h.

145{
146 ERS_DEBUG_2("Checking recursively for consistency of ROSFragment");
147 check(); // check myself
148 uint32_t total = this->nchildren();
149 for (size_t i=0; i<total; ++i) {
150 TPointer fp;
153 f.check_tree();
154 }
155 return true;
156}
TFile f("ana_bhabha660a_dqa_mcPat_zy_old.root")
virtual uint32_t nchildren() const
Definition: Header.h:263
virtual void child(TPointer &p, size_t n) const
Definition: Header.h:272
virtual bool check() const
Definition: ROSFragment.h:134

Referenced by main().

◆ lvl1_id()

template<class TPointer >
uint32_t eformat::ROSFragment< TPointer >::lvl1_id ( ) const
inline

Returns the lvl1 identifier

Definition at line 92 of file ROSFragment.h.

92{ return m_start[1]; }

Referenced by main().

◆ operator=()

template<class TPointer >
ROSFragment & eformat::ROSFragment< TPointer >::operator= ( const ROSFragment< TPointer > &  other)
inline

Copy operator

Parameters
otherThe fragment to be copied

Definition at line 64 of file ROSFragment.h.

65 { Header<TPointer>::operator=(other); m_start=other.m_start; return *this; }
Header & operator=(const Header &other)
Definition: Header.h:75

◆ run_no()

template<class TPointer >
uint32_t eformat::ROSFragment< TPointer >::run_no ( ) const
inline

Returns the run number

Definition at line 87 of file ROSFragment.h.

87{ return m_start[0]; }

The documentation for this class was generated from the following file: