// @(#):$Id$
// Author: Andrei Gheata   01/03/11

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#ifndef ROOT_TGeoBranchArray
#define ROOT_TGeoBranchArray

#ifndef ROOT_TObject
#include "TObject.h"
#endif

////////////////////////////////////////////////////////////////////////////
//                                                                        //
// TGeoBranchArray - An array of daughter indices making a geometry path. //
//   Can be used to backup/restore a state                                //
//                                                                        //
////////////////////////////////////////////////////////////////////////////

class TGeoHMatrix;
class TGeoMatrix;
class TGeoNavigator;
class TGeoNode;

class TGeoBranchArray : public TObject
{
protected:
   Int_t             fLevel;          // Branch depth
   Int_t             fMaxLevel;       // Array length
   TGeoNode        **fArray;          //![fMaxLevel] Array of nodes
   TGeoHMatrix      *fMatrix;         // Global matrix (owned)
   TObject          *fClient;         // Client object to notify

public:
   TGeoBranchArray() : TObject(), fLevel(-1), fMaxLevel(10), fArray(NULL), fMatrix(NULL), fClient(NULL) {}
   TGeoBranchArray(Int_t level);
   virtual ~TGeoBranchArray();

   TGeoBranchArray(const TGeoBranchArray&);
   TGeoBranchArray& operator=(const TGeoBranchArray&);
   Bool_t operator ==(const TGeoBranchArray& other) const;
   Bool_t operator !=(const TGeoBranchArray& other) const;
   Bool_t operator >(const TGeoBranchArray& other) const;
   Bool_t operator <(const TGeoBranchArray& other) const;
   Bool_t operator >=(const TGeoBranchArray& other) const;
   Bool_t operator <=(const TGeoBranchArray& other) const;

   void              AddLevel(Int_t dindex);
   virtual Int_t     Compare(const TObject *obj) const;
   void              CleanMatrix();
   TGeoNode        **GetArray() const   {return fArray;}
   TObject          *GetClient() const  {return fClient;}
   Int_t             GetLevel() const   {return fLevel;}
   TGeoHMatrix      *GetMatrix() const  {return fMatrix;}
   TGeoNode         *GetNode(Int_t level) const {return fArray[level];}
   TGeoNode         *GetCurrentNode() const {return fArray[fLevel];}
   void              GetPath(TString &path) const;
   void              Init(TGeoNode **branch, TGeoMatrix *global, Int_t level);
   void              InitFromNavigator(TGeoNavigator *nav);
   virtual Bool_t    IsSortable() const {return kTRUE;}
   Bool_t            IsOutside() const {return (fLevel<0)?kTRUE:kFALSE;}
   virtual Bool_t    Notify() {return (fClient)?fClient->Notify():kFALSE;}
   virtual void      Print(Option_t *option="") const;
   void              SetClient(TObject *client) {fClient = client;}
   static void       Sort(Int_t n, TGeoBranchArray **array, Int_t *index, Bool_t down=kTRUE);
   static Long64_t   BinarySearch(Long64_t n, const TGeoBranchArray **array, TGeoBranchArray *value);
   void              UpdateNavigator(TGeoNavigator *nav) const;

   ClassDef(TGeoBranchArray, 3)
};

struct compareBAasc {
   compareBAasc(TGeoBranchArray **d) : fData(d) {}
   bool operator ()(Int_t i1, Int_t i2) {return **(fData+i1) < **(fData+i2);}
   TGeoBranchArray **fData;
};

struct compareBAdesc {
   compareBAdesc(TGeoBranchArray **d) : fData(d) {}
   bool operator ()(Int_t i1, Int_t i2) {return **(fData+i1) > **(fData+i2);}
   TGeoBranchArray **fData;
};

#endif
 TGeoBranchArray.h:1
 TGeoBranchArray.h:2
 TGeoBranchArray.h:3
 TGeoBranchArray.h:4
 TGeoBranchArray.h:5
 TGeoBranchArray.h:6
 TGeoBranchArray.h:7
 TGeoBranchArray.h:8
 TGeoBranchArray.h:9
 TGeoBranchArray.h:10
 TGeoBranchArray.h:11
 TGeoBranchArray.h:12
 TGeoBranchArray.h:13
 TGeoBranchArray.h:14
 TGeoBranchArray.h:15
 TGeoBranchArray.h:16
 TGeoBranchArray.h:17
 TGeoBranchArray.h:18
 TGeoBranchArray.h:19
 TGeoBranchArray.h:20
 TGeoBranchArray.h:21
 TGeoBranchArray.h:22
 TGeoBranchArray.h:23
 TGeoBranchArray.h:24
 TGeoBranchArray.h:25
 TGeoBranchArray.h:26
 TGeoBranchArray.h:27
 TGeoBranchArray.h:28
 TGeoBranchArray.h:29
 TGeoBranchArray.h:30
 TGeoBranchArray.h:31
 TGeoBranchArray.h:32
 TGeoBranchArray.h:33
 TGeoBranchArray.h:34
 TGeoBranchArray.h:35
 TGeoBranchArray.h:36
 TGeoBranchArray.h:37
 TGeoBranchArray.h:38
 TGeoBranchArray.h:39
 TGeoBranchArray.h:40
 TGeoBranchArray.h:41
 TGeoBranchArray.h:42
 TGeoBranchArray.h:43
 TGeoBranchArray.h:44
 TGeoBranchArray.h:45
 TGeoBranchArray.h:46
 TGeoBranchArray.h:47
 TGeoBranchArray.h:48
 TGeoBranchArray.h:49
 TGeoBranchArray.h:50
 TGeoBranchArray.h:51
 TGeoBranchArray.h:52
 TGeoBranchArray.h:53
 TGeoBranchArray.h:54
 TGeoBranchArray.h:55
 TGeoBranchArray.h:56
 TGeoBranchArray.h:57
 TGeoBranchArray.h:58
 TGeoBranchArray.h:59
 TGeoBranchArray.h:60
 TGeoBranchArray.h:61
 TGeoBranchArray.h:62
 TGeoBranchArray.h:63
 TGeoBranchArray.h:64
 TGeoBranchArray.h:65
 TGeoBranchArray.h:66
 TGeoBranchArray.h:67
 TGeoBranchArray.h:68
 TGeoBranchArray.h:69
 TGeoBranchArray.h:70
 TGeoBranchArray.h:71
 TGeoBranchArray.h:72
 TGeoBranchArray.h:73
 TGeoBranchArray.h:74
 TGeoBranchArray.h:75
 TGeoBranchArray.h:76
 TGeoBranchArray.h:77
 TGeoBranchArray.h:78
 TGeoBranchArray.h:79
 TGeoBranchArray.h:80
 TGeoBranchArray.h:81
 TGeoBranchArray.h:82
 TGeoBranchArray.h:83
 TGeoBranchArray.h:84
 TGeoBranchArray.h:85
 TGeoBranchArray.h:86
 TGeoBranchArray.h:87
 TGeoBranchArray.h:88
 TGeoBranchArray.h:89
 TGeoBranchArray.h:90