Blame include/PointerTable.h

Packit 8a864e
// Copyright (c) 1994 James Clark
Packit 8a864e
// See the file COPYING for copying permission.
Packit 8a864e
Packit 8a864e
#ifndef PointerTable_INCLUDED
Packit 8a864e
#define PointerTable_INCLUDED 1
Packit 8a864e
Packit 8a864e
#include "Vector.h"
Packit 8a864e
#include "Boolean.h"
Packit 8a864e
#include <stddef.h>
Packit 8a864e
Packit 8a864e
#ifdef SP_NAMESPACE
Packit 8a864e
namespace SP_NAMESPACE {
Packit 8a864e
#endif
Packit 8a864e
Packit 8a864e
template<class P, class K, class HF, class KF> class PointerTableIter;
Packit 8a864e
Packit 8a864e
template<class P, class K, class HF, class KF>
Packit 8a864e
class PointerTable {
Packit 8a864e
  void constraints() {
Packit 8a864e
    P p(0);
Packit 8a864e
    const K &key = KF::key(*p);
Packit 8a864e
    unsigned long n = HF::hash(key);
Packit 8a864e
    n = 0;			// prevent warning
Packit 8a864e
  }
Packit 8a864e
public:
Packit 8a864e
  PointerTable();
Packit 8a864e
  P insert(P, Boolean replace = 0);
Packit 8a864e
  // Return a reference so that it is possible to do
Packit 8a864e
  // lookups into a table of smart-pointers from multiple threads.
Packit 8a864e
  const P &lookup(const K &) const;
Packit 8a864e
  P remove(const K &);
Packit 8a864e
  size_t count() const { return used_; }
Packit 8a864e
  void clear();
Packit 8a864e
  void swap(PointerTable<P, K, HF, KF> &);
Packit 8a864e
protected:
Packit 8a864e
  size_t used_;
Packit 8a864e
  size_t usedLimit_;
Packit 8a864e
  Vector

vec_;

Packit 8a864e
  P null_;
Packit 8a864e
Packit 8a864e
  size_t startIndex(const K &k) const {
Packit 8a864e
    return size_t(HF::hash(k) & (vec_.size() - 1));
Packit 8a864e
  }
Packit 8a864e
  size_t nextIndex(size_t i) const {
Packit 8a864e
    return i == 0 ? vec_.size() - 1 : i - 1;
Packit 8a864e
  }
Packit 8a864e
  friend class PointerTableIter<P, K, HF, KF>;
Packit 8a864e
};
Packit 8a864e
Packit 8a864e
template<class P, class K, class HF, class KF>
Packit 8a864e
class PointerTableIter {
Packit 8a864e
public:
Packit 8a864e
  PointerTableIter(const PointerTable<P, K, HF, KF> &);
Packit 8a864e
  const P &next();
Packit 8a864e
private:
Packit 8a864e
  const PointerTable<P, K, HF, KF> *tablePtr_;
Packit 8a864e
  size_t i_;
Packit 8a864e
};
Packit 8a864e
Packit 8a864e
#ifdef SP_NAMESPACE
Packit 8a864e
}
Packit 8a864e
#endif
Packit 8a864e
Packit 8a864e
#endif /* not PointerTable_INCLUDED */
Packit 8a864e
Packit 8a864e
#ifdef SP_DEFINE_TEMPLATES
Packit 8a864e
#include "PointerTable.cxx"
Packit 8a864e
#endif