3 /**************************************************************************
4 * This file is property of and copyright by the ALICE HLT Project *
5 * ALICE Experiment at CERN, All rights reserved. *
7 * Primary Authors: Matthias Richter <Matthias.Richter@ift.uib.no> *
8 * for The ALICE HLT Project. *
10 * Permission to use, copy, modify and distribute this software and its *
11 * documentation strictly for non-commercial purposes is hereby granted *
12 * without fee, provided that the above copyright notice appears in all *
13 * copies and that both the copyright notice and this permission notice *
14 * appear in the supporting documentation. The authors make no claims *
15 * about the suitability of this software for any purpose. It is *
16 * provided "as is" without express or implied warranty. *
17 **************************************************************************/
19 /** @file AliHLTConsumerDescriptor.cxx
20 @author Matthias Richter
22 @brief Helper class to describe a consumer component.
29 #include "AliHLTConsumerDescriptor.h"
31 /** ROOT macro for the implementation of ROOT specific class methods */
32 ClassImp(AliHLTConsumerDescriptor)
34 AliHLTConsumerDescriptor::AliHLTConsumerDescriptor()
39 // see header file for class documentation
41 // refer to README to build package
43 // visit http://web.ift.uib.no/~kjeks/doc/alice-hlt
47 AliHLTConsumerDescriptor::AliHLTConsumerDescriptor(AliHLTComponent* pConsumer)
49 fpConsumer(pConsumer),
52 // see header file for function documentation
56 AliHLTConsumerDescriptor::~AliHLTConsumerDescriptor()
58 // see header file for function documentation
59 if (fSegments.size()>0) {
60 //HLTWarning("unreleased data segments found");
64 int AliHLTConsumerDescriptor::SetActiveDataSegment(AliHLTDataBuffer::AliHLTDataSegment segment)
66 // see header file for function documentation
68 fSegments.push_back(segment);
69 //HLTDebug("set active segment (%d:%d) for consumer %p", offset, size, this);
73 int AliHLTConsumerDescriptor::CheckActiveDataSegment(AliHLTDataBuffer::AliHLTDataSegment segment)
75 // see header file for function documentation
77 if (fSegments.size()>0) {
78 vector<AliHLTDataBuffer::AliHLTDataSegment>::iterator element=fSegments.begin();
79 while (element!=fSegments.end()) {
80 if ((iResult=(segment==(*element)))>0) {
86 //HLTWarning("no data segment active for consumer %p", this);
92 int AliHLTConsumerDescriptor::ReleaseActiveDataSegment(AliHLTDataBuffer::AliHLTDataSegment segment)
94 // see header file for function documentation
96 if (fSegments.size()>0) {
97 vector<AliHLTDataBuffer::AliHLTDataSegment>::iterator element=fSegments.begin();
98 while (element!=fSegments.end()) {
99 if ((iResult=(segment==(*element)))>0) {
100 fSegments.erase(element);
106 //HLTWarning("no data segment (%d:%d) active for consumer %p", offset, size, this);
110 //HLTWarning("no data segment active for consumer %p", this);