New interface of a VStore to hold tracks (Laurent)
authorhristov <hristov@f7af4fe6-9843-0410-8265-dc069ae4e863>
Sun, 17 Jun 2007 20:36:50 +0000 (20:36 +0000)
committerhristov <hristov@f7af4fe6-9843-0410-8265-dc069ae4e863>
Sun, 17 Jun 2007 20:36:50 +0000 (20:36 +0000)
MUON/AliMUONVTrackStore.cxx [new file with mode: 0644]
MUON/AliMUONVTrackStore.h [new file with mode: 0644]

diff --git a/MUON/AliMUONVTrackStore.cxx b/MUON/AliMUONVTrackStore.cxx
new file mode 100644 (file)
index 0000000..2088993
--- /dev/null
@@ -0,0 +1,74 @@
+/**************************************************************************
+* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
+*                                                                        *
+* Author: The ALICE Off-line Project.                                    *
+* Contributors are mentioned in the code where appropriate.              *
+*                                                                        *
+* Permission to use, copy, modify and distribute this software and its   *
+* documentation strictly for non-commercial purposes is hereby granted   *
+* without fee, provided that the above copyright notice appears in all   *
+* copies and that both the copyright notice and this permission notice   *
+* appear in the supporting documentation. The authors make no claims     *
+* about the suitability of this software for any purpose. It is          *
+* provided "as is" without express or implied warranty.                  *
+**************************************************************************/
+
+// $Id$
+
+/// \class AliMUONVTrackStore
+///
+/// Base class of a track store
+///
+/// Note that objects stored are of concrete class AliMUONTrack, which 
+/// might evolve to a virtual AliMUONVTrack for instance in the future...
+///
+/// \author Laurent Aphecetche, Subatech
+
+#include "AliMUONVTrackStore.h"
+#include "AliMUONTrack.h"
+#include "AliLog.h"
+
+/// \cond CLASSIMP
+ClassImp(AliMUONVTrackStore)
+/// \endcond
+
+//_____________________________________________________________________________
+AliMUONVTrackStore::AliMUONVTrackStore()
+{
+  /// ctor
+}
+
+//_____________________________________________________________________________
+AliMUONVTrackStore::~AliMUONVTrackStore()
+{
+  /// dtor
+}
+
+//_____________________________________________________________________________
+Bool_t
+AliMUONVTrackStore::Add(TObject* object)
+{
+  /// Add object, if of type AliMUONTrack
+  if (object)
+  {
+    AliMUONTrack* t = dynamic_cast<AliMUONTrack*>(object);
+    if (t)
+    {
+      Add(*t);
+      return kTRUE;
+    }
+    else
+    {
+      AliError(Form("object not of expected AliMUONTrack type but %s",object->ClassName()));
+    }
+  }
+  return kFALSE;
+}
+
+//_____________________________________________________________________________
+AliMUONVTrackStore*
+AliMUONVTrackStore::Create(TTree& tree)
+{
+  /// Create a VTrackStore from the tree (if possible)
+  return static_cast<AliMUONVTrackStore*>(AliMUONVStore::Create(tree,"MUONTrack"));
+}
diff --git a/MUON/AliMUONVTrackStore.h b/MUON/AliMUONVTrackStore.h
new file mode 100644 (file)
index 0000000..b8cb7c8
--- /dev/null
@@ -0,0 +1,46 @@
+#ifndef ALIMUONVTRACKSTORE_H
+#define ALIMUONVTRACKSTORE_H
+
+/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
+* See cxx source for full Copyright notice                               */
+
+// $Id$
+
+/// \ingroup rec
+/// \class AliMUONVTrackStore
+/// \brief Base class of a track container
+/// 
+// Author Laurent Aphecetche, Subatech
+
+#ifndef ALIMUONVSTORE_H
+#  include "AliMUONVStore.h"
+#endif
+
+class AliMUONTrack;
+
+class AliMUONVTrackStore : public AliMUONVStore
+{
+public:
+  AliMUONVTrackStore();
+  virtual ~AliMUONVTrackStore();
+  
+  /// Add an object, if of the right type
+  virtual Bool_t Add(TObject* object);
+  
+  /// Add a track
+  virtual void Add(const AliMUONTrack& track) = 0;
+  
+  using AliMUONVStore::Create;
+  
+  /// Create a store from the tree (if possible).
+  static AliMUONVTrackStore* Create(TTree& tree);
+
+  /// Create an iterator to loop over tracks
+  virtual TIterator* CreateIterator() const = 0;
+  
+  using AliMUONVStore::GetSize;
+  
+  ClassDef(AliMUONVTrackStore,1) // Base class of a track store
+};
+
+#endif