Location: LEMON/LEMON-main/lemon/concepts/maps.h - annotation
Load file history
More exact concept checking for map concepts.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 | r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r39:0a01d811071f r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r48:93ae269876de r79:d73c2e8b25cb r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r28:e337bdf46777 r79:d73c2e8b25cb r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r28:e337bdf46777 r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r74:9394072da54f r25:751cd8f9bb1c r74:9394072da54f r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r74:9394072da54f r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r28:e337bdf46777 r25:751cd8f9bb1c r28:e337bdf46777 r25:751cd8f9bb1c | /* -*- C++ -*-
*
* This file is a part of LEMON, a generic C++ optimization library
*
* Copyright (C) 2003-2008
* Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
* (Egervary Research Group on Combinatorial Optimization, EGRES).
*
* Permission to use, modify and distribute this software is granted
* provided that this copyright notice appears in all copies. For
* precise terms see the accompanying LICENSE file.
*
* This software is provided "AS IS" with no warranty of any kind,
* express or implied, and with no claim as to its suitability for any
* purpose.
*
*/
#ifndef LEMON_CONCEPT_MAPS_H
#define LEMON_CONCEPT_MAPS_H
#include <lemon/bits/utility.h>
#include <lemon/concept_check.h>
///\ingroup concept
///\file
///\brief Map concepts checking classes for testing and documenting.
namespace lemon {
namespace concepts {
/// \addtogroup concept
/// @{
/// Readable map concept
/// Readable map concept.
///
template<typename K, typename T>
class ReadMap
{
public:
/// The key type of the map.
typedef K Key;
/// The value type of the map. (The type of objects associated with the keys).
typedef T Value;
/// Returns the value associated with the given key.
/// Returns the value associated with the given key.
/// \bug Value shouldn't need to be default constructible.
Value operator[](const Key &) const { return Value(); }
template<typename _ReadMap>
struct Constraints {
void constraints() {
Value val = m[key];
val = m[key];
typename _ReadMap::Value own_val = m[own_key];
own_val = m[own_key];
ignore_unused_variable_warning(key);
ignore_unused_variable_warning(val);
ignore_unused_variable_warning(own_key);
ignore_unused_variable_warning(own_val);
}
const Key& key;
const typename _ReadMap::Key& own_key;
const _ReadMap& m;
};
};
/// Writable map concept
/// Writable map concept.
///
template<typename K, typename T>
class WriteMap
{
public:
/// The key type of the map.
typedef K Key;
/// The value type of the map. (The type of objects associated with the keys).
typedef T Value;
/// Sets the value associated with the given key.
void set(const Key &, const Value &) {}
/// Default constructor.
WriteMap() {}
template <typename _WriteMap>
struct Constraints {
void constraints() {
m.set(key, val);
m.set(own_key, own_val);
ignore_unused_variable_warning(key);
ignore_unused_variable_warning(val);
ignore_unused_variable_warning(own_key);
ignore_unused_variable_warning(own_val);
}
const Key& key;
const Value& val;
const typename _WriteMap::Key& own_key;
const typename _WriteMap::Value own_val;
_WriteMap& m;
};
};
/// Read/writable map concept
/// Read/writable map concept.
///
template<typename K, typename T>
class ReadWriteMap : public ReadMap<K,T>,
public WriteMap<K,T>
{
public:
/// The key type of the map.
typedef K Key;
/// The value type of the map. (The type of objects associated with the keys).
typedef T Value;
/// Returns the value associated with the given key.
Value operator[](const Key &) const { return Value(); }
/// Sets the value associated with the given key.
void set(const Key &, const Value &) {}
template<typename _ReadWriteMap>
struct Constraints {
void constraints() {
checkConcept<ReadMap<K, T>, _ReadWriteMap >();
checkConcept<WriteMap<K, T>, _ReadWriteMap >();
}
};
};
/// Dereferable map concept
/// Dereferable map concept.
///
template<typename K, typename T, typename R, typename CR>
class ReferenceMap : public ReadWriteMap<K,T>
{
public:
/// Tag for reference maps.
typedef True ReferenceMapTag;
/// The key type of the map.
typedef K Key;
/// The value type of the map. (The type of objects associated with the keys).
typedef T Value;
/// The reference type of the map.
typedef R Reference;
/// The const reference type of the map.
typedef CR ConstReference;
protected:
Value tmp;
public:
/// Returns a reference to the value associated with the given key.
Reference operator[](const Key &) { return tmp; }
/// Returns a const reference to the value associated with the given key.
ConstReference operator[](const Key &) const { return tmp; }
/// Sets the value associated with the given key.
void set(const Key &k,const Value &t) { operator[](k)=t; }
template<typename _ReferenceMap>
struct Constraints {
void constraints() {
checkConcept<ReadWriteMap<K, T>, _ReferenceMap >();
ref = m[key];
m[key] = val;
m[key] = ref;
m[key] = cref;
own_ref = m[own_key];
m[own_key] = own_val;
m[own_key] = own_ref;
m[own_key] = own_cref;
m[key] = m[own_key];
m[own_key] = m[key];
}
const Key& key;
Value& val;
Reference ref;
ConstReference cref;
const typename _ReferenceMap::Key& own_key;
typename _ReferenceMap::Value& own_val;
typename _ReferenceMap::Reference own_ref;
typename _ReferenceMap::ConstReference own_cref;
_ReferenceMap& m;
};
};
// @}
} //namespace concepts
} //namespace lemon
#endif // LEMON_CONCEPT_MAPS_H
|