#ifndef ROO_HASH_TABLE
#define ROO_HASH_TABLE
#include "TObject.h"
#include "TString.h"
class RooAbsArg ;
class RooLinkedList ;
class RooLinkedListElem ;
class RooSetPair ;
class RooArgSet ;
class RooHashTable : public TObject {
public:
enum HashMethod { Pointer=0, Name=1, Intrinsic=2 } ;
RooHashTable(Int_t initSize = 17, HashMethod hashMethod=Name) ;
RooHashTable(const RooHashTable& other) ;
virtual ~RooHashTable() ;
void add(TObject* arg, TObject* hashArg=0) ;
Bool_t remove(TObject* arg, TObject* hashArg=0) ;
TObject* find(const char* name) const ;
RooAbsArg* findArg(const RooAbsArg* arg) const ;
TObject* find(const TObject* arg) const ;
RooLinkedListElem* findLinkTo(const TObject* arg) const ;
RooSetPair* findSetPair(const RooArgSet* set1, const RooArgSet* set2) const ;
Bool_t replace(const TObject* oldArg, const TObject* newArg, const TObject* oldHashArg=0) ;
Int_t size() const { return _size ; }
Int_t entries() const { return _entries ; }
Double_t avgCollisions() const ;
protected:
inline ULong_t hash(const TObject* arg) const {
switch(_hashMethod) {
case Pointer: return TString::Hash((void*)(&arg),sizeof(void*)) ;
case Name: return TString::Hash(arg->GetName(),strlen(arg->GetName())) ;
case Intrinsic: return arg->Hash() ;
}
return 0 ;
}
HashMethod _hashMethod ;
Int_t _usedSlots ;
Int_t _entries ;
Int_t _size ;
RooLinkedList** _arr ;
ClassDef(RooHashTable,1)
};
#endif