1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
17 //-----------------------------------------------------------------------------
18 /// \class AliMpSlatMotifMap
20 /// Basically this class provide a garbage collection of AliMpMotif and
21 /// AliMpMotifType objects.
24 /// \author Laurent Aphecetche
25 //-----------------------------------------------------------------------------
30 #include "AliMpSlatMotifMap.h"
32 #include "AliMpVMotif.h"
33 #include "AliMpMotifType.h"
36 #include "TObjString.h"
38 #include "Riostream.h"
41 ClassImp(AliMpSlatMotifMap)
44 //_____________________________________________________________________________
45 AliMpSlatMotifMap::AliMpSlatMotifMap()
51 fMotifs.SetOwner(kTRUE);
52 fMotifTypes.SetOwner(kTRUE);
55 //_____________________________________________________________________________
56 AliMpSlatMotifMap::~AliMpSlatMotifMap()
62 //_____________________________________________________________________________
64 AliMpSlatMotifMap::Reset()
68 fMotifTypes.DeleteAll();
71 //_____________________________________________________________________________
73 AliMpSlatMotifMap::AddMotif(AliMpVMotif* motif, Bool_t warn)
75 /// Add a motif to the map
76 AliDebug(1,Form("Adding motif %s",motif->GetID().Data()));
78 AliMpVMotif* found = FindMotif(motif->GetID());
80 if (warn && found == motif)
82 AliWarning(Form("The motif %s is already in map",motif->GetID().Data()));
84 if (warn && found != motif)
86 AliError(Form("Another motif with the same ID=%s is already in map",
87 motif->GetID().Data()));
92 fMotifs.Add(new TObjString(motif->GetID()),motif);
96 //_____________________________________________________________________________
98 AliMpSlatMotifMap::AddMotifType(AliMpMotifType* motifType, Bool_t warn)
100 /// Add a motif to the map
102 AliDebug(1,Form("Adding motifType %s",motifType->GetID().Data()));
104 AliMpMotifType* found = FindMotifType(motifType->GetID());
106 if (warn && found == motifType)
108 AliWarning(Form("The motifType %s is already in map",
109 motifType->GetID().Data()));
111 if (warn && found != motifType)
113 AliError(Form("Another motifType with the same ID=%s is already in map",
114 motifType->GetID().Data()));
119 fMotifTypes.Add(new TObjString(motifType->GetID()),motifType);
124 //_____________________________________________________________________________
126 AliMpSlatMotifMap::FindMotif(const TString& id) const
128 /// Search a given motif in the map and returns it if it's there.
130 AliDebug(1,Form("Looking for motif %s",id.Data()));
132 TObject* object = fMotifs.GetValue(id.Data());
136 AliMpVMotif* motif = static_cast<AliMpVMotif*>(object);
137 AliDebug(1,Form("Found : %p id=%s",motif,motif->GetID().Data()));
140 AliDebug(1,"Not found");
144 //_____________________________________________________________________________
146 AliMpSlatMotifMap::FindMotifType(const TString& id) const
148 /// Search a given motifType in the map and returns it if it's there.
149 AliDebug(1,Form("Looking for motifType %s",id.Data()));
151 TObject* object = fMotifTypes.GetValue(id.Data());
155 AliMpMotifType* motifType = static_cast<AliMpMotifType*>(object);
156 AliDebug(1,Form("Found : %p id=%s",motifType,motifType->GetID().Data()));
159 AliDebug(1,"Not found");
164 //_____________________________________________________________________________
166 AliMpSlatMotifMap::Print(Option_t*) const
169 cout << "Motifs=" << endl;
171 TIter next(&fMotifs);
172 while ( ( key = next() ) )
174 AliMpVMotif* motif = dynamic_cast<AliMpVMotif*>(fMotifs.GetValue(key));
175 if (motif) cout << motif->GetID() << endl;
178 cout << "MotifTypes=" << endl;
179 TIter tnext(&fMotifTypes);
180 while ( ( key = tnext() ) )
182 AliMpMotifType* motifType = dynamic_cast<AliMpMotifType*>(fMotifTypes.GetValue(key));
183 if (motifType) cout << motifType->GetID() << endl;