lemon/bits/array_map.h
changeset 802 994c7df296c9
parent 492 9605e051942f
child 877 141f9c0db4a3
     1.1 --- a/lemon/bits/array_map.h	Fri Nov 13 12:33:33 2009 +0100
     1.2 +++ b/lemon/bits/array_map.h	Thu Dec 10 17:05:35 2009 +0100
     1.3 @@ -2,7 +2,7 @@
     1.4   *
     1.5   * This file is a part of LEMON, a generic C++ optimization library.
     1.6   *
     1.7 - * Copyright (C) 2003-2008
     1.8 + * Copyright (C) 2003-2009
     1.9   * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
    1.10   * (Egervary Research Group on Combinatorial Optimization, EGRES).
    1.11   *
    1.12 @@ -36,25 +36,24 @@
    1.13    //
    1.14    // \brief Graph map based on the array storage.
    1.15    //
    1.16 -  // The ArrayMap template class is graph map structure what
    1.17 -  // automatically updates the map when a key is added to or erased from
    1.18 -  // the map. This map uses the allocators to implement
    1.19 -  // the container functionality.
    1.20 +  // The ArrayMap template class is graph map structure that automatically
    1.21 +  // updates the map when a key is added to or erased from the graph.
    1.22 +  // This map uses the allocators to implement the container functionality.
    1.23    //
    1.24 -  // The template parameters are the Graph the current Item type and
    1.25 +  // The template parameters are the Graph, the current Item type and
    1.26    // the Value type of the map.
    1.27    template <typename _Graph, typename _Item, typename _Value>
    1.28    class ArrayMap
    1.29      : public ItemSetTraits<_Graph, _Item>::ItemNotifier::ObserverBase {
    1.30    public:
    1.31 -    // The graph type of the maps.
    1.32 -    typedef _Graph Graph;
    1.33 -    // The item type of the map.
    1.34 +    // The graph type.
    1.35 +    typedef _Graph GraphType;
    1.36 +    // The item type.
    1.37      typedef _Item Item;
    1.38      // The reference map tag.
    1.39      typedef True ReferenceMapTag;
    1.40  
    1.41 -    // The key type of the maps.
    1.42 +    // The key type of the map.
    1.43      typedef _Item Key;
    1.44      // The value type of the map.
    1.45      typedef _Value Value;
    1.46 @@ -64,13 +63,17 @@
    1.47      // The reference type of the map.
    1.48      typedef _Value& Reference;
    1.49  
    1.50 +    // The map type.
    1.51 +    typedef ArrayMap Map;
    1.52 +
    1.53      // The notifier type.
    1.54      typedef typename ItemSetTraits<_Graph, _Item>::ItemNotifier Notifier;
    1.55  
    1.56 +  private:
    1.57 +  
    1.58      // The MapBase of the Map which imlements the core regisitry function.
    1.59      typedef typename Notifier::ObserverBase Parent;
    1.60  
    1.61 -  private:
    1.62      typedef std::allocator<Value> Allocator;
    1.63  
    1.64    public:
    1.65 @@ -78,7 +81,7 @@
    1.66      // \brief Graph initialized map constructor.
    1.67      //
    1.68      // Graph initialized map constructor.
    1.69 -    explicit ArrayMap(const Graph& graph) {
    1.70 +    explicit ArrayMap(const GraphType& graph) {
    1.71        Parent::attach(graph.notifier(Item()));
    1.72        allocate_memory();
    1.73        Notifier* nf = Parent::notifier();
    1.74 @@ -92,7 +95,7 @@
    1.75      // \brief Constructor to use default value to initialize the map.
    1.76      //
    1.77      // It constructs a map and initialize all of the the map.
    1.78 -    ArrayMap(const Graph& graph, const Value& value) {
    1.79 +    ArrayMap(const GraphType& graph, const Value& value) {
    1.80        Parent::attach(graph.notifier(Item()));
    1.81        allocate_memory();
    1.82        Notifier* nf = Parent::notifier();
    1.83 @@ -136,7 +139,7 @@
    1.84  
    1.85      // \brief Template assign operator.
    1.86      //
    1.87 -    // The given parameter should be conform to the ReadMap
    1.88 +    // The given parameter should conform to the ReadMap
    1.89      // concecpt and could be indiced by the current item set of
    1.90      // the NodeMap. In this case the value for each item
    1.91      // is assigned by the value of the given ReadMap.
    1.92 @@ -200,7 +203,7 @@
    1.93  
    1.94      // \brief Adds a new key to the map.
    1.95      //
    1.96 -    // It adds a new key to the map. It called by the observer notifier
    1.97 +    // It adds a new key to the map. It is called by the observer notifier
    1.98      // and it overrides the add() member function of the observer base.
    1.99      virtual void add(const Key& key) {
   1.100        Notifier* nf = Parent::notifier();
   1.101 @@ -228,7 +231,7 @@
   1.102  
   1.103      // \brief Adds more new keys to the map.
   1.104      //
   1.105 -    // It adds more new keys to the map. It called by the observer notifier
   1.106 +    // It adds more new keys to the map. It is called by the observer notifier
   1.107      // and it overrides the add() member function of the observer base.
   1.108      virtual void add(const std::vector<Key>& keys) {
   1.109        Notifier* nf = Parent::notifier();
   1.110 @@ -272,7 +275,7 @@
   1.111  
   1.112      // \brief Erase a key from the map.
   1.113      //
   1.114 -    // Erase a key from the map. It called by the observer notifier
   1.115 +    // Erase a key from the map. It is called by the observer notifier
   1.116      // and it overrides the erase() member function of the observer base.
   1.117      virtual void erase(const Key& key) {
   1.118        int id = Parent::notifier()->id(key);
   1.119 @@ -281,7 +284,7 @@
   1.120  
   1.121      // \brief Erase more keys from the map.
   1.122      //
   1.123 -    // Erase more keys from the map. It called by the observer notifier
   1.124 +    // Erase more keys from the map. It is called by the observer notifier
   1.125      // and it overrides the erase() member function of the observer base.
   1.126      virtual void erase(const std::vector<Key>& keys) {
   1.127        for (int i = 0; i < int(keys.size()); ++i) {
   1.128 @@ -290,9 +293,9 @@
   1.129        }
   1.130      }
   1.131  
   1.132 -    // \brief Buildes the map.
   1.133 +    // \brief Builds the map.
   1.134      //
   1.135 -    // It buildes the map. It called by the observer notifier
   1.136 +    // It builds the map. It is called by the observer notifier
   1.137      // and it overrides the build() member function of the observer base.
   1.138      virtual void build() {
   1.139        Notifier* nf = Parent::notifier();
   1.140 @@ -306,7 +309,7 @@
   1.141  
   1.142      // \brief Clear the map.
   1.143      //
   1.144 -    // It erase all items from the map. It called by the observer notifier
   1.145 +    // It erase all items from the map. It is called by the observer notifier
   1.146      // and it overrides the clear() member function of the observer base.
   1.147      virtual void clear() {
   1.148        Notifier* nf = Parent::notifier();