Location: LEMON/LEMON-official/lemon/concepts/maps.h - annotation
Load file history
Merge #419 to branch 1.1
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 210 211 212 213 214 215 216 217 | r209:765619b7cbb2 r25:751cd8f9bb1c r209:765619b7cbb2 r25:751cd8f9bb1c r463:88ed40ad0d4f 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 r576:f5bc148f7e1f r576:f5bc148f7e1f r25:751cd8f9bb1c r220:a5d8c039f218 r25:751cd8f9bb1c r25:751cd8f9bb1c r314:2cc60866a0c9 r25:751cd8f9bb1c r114:c837d1e449dc r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r314:2cc60866a0c9 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r210:81cfc04531e8 r210:81cfc04531e8 r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r209:765619b7cbb2 r94:a4688e4138ec r94:a4688e4138ec r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r25:751cd8f9bb1c r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 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 r210:81cfc04531e8 r210:81cfc04531e8 r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r79:d73c2e8b25cb r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r48:93ae269876de r79:d73c2e8b25cb r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r209:765619b7cbb2 r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r79:d73c2e8b25cb r210:81cfc04531e8 r210:81cfc04531e8 r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r209:765619b7cbb2 r94:a4688e4138ec r94:a4688e4138ec r79:d73c2e8b25cb r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 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 r210:81cfc04531e8 r210:81cfc04531e8 r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r79:d73c2e8b25cb r209:765619b7cbb2 r94:a4688e4138ec r94:a4688e4138ec r79:d73c2e8b25cb r79:d73c2e8b25cb r94:a4688e4138ec r94:a4688e4138ec r94:a4688e4138ec r79:d73c2e8b25cb r79:d73c2e8b25cb r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r74:9394072da54f r1064:40bbb450143e r1064:40bbb450143e r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r209:765619b7cbb2 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r28:e337bdf46777 r25:751cd8f9bb1c r28:e337bdf46777 r576:f5bc148f7e1f | /* -*- mode: C++; indent-tabs-mode: nil; -*-
*
* This file is a part of LEMON, a generic C++ optimization library.
*
* Copyright (C) 2003-2009
* 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_CONCEPTS_MAPS_H
#define LEMON_CONCEPTS_MAPS_H
#include <lemon/core.h>
#include <lemon/concept_check.h>
///\ingroup map_concepts
///\file
///\brief The concept of maps.
namespace lemon {
namespace concepts {
/// \addtogroup map_concepts
/// @{
/// Readable map concept
/// Readable map concept.
///
template<typename K, typename T>
class ReadMap
{
public:
/// The key type of the map.
typedef K Key;
/// \brief 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 *static_cast<Value *>(0);
}
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;
/// \brief 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;
/// \brief 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 *static_cast<Value *>(0);
}
/// 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;
/// \brief 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;
public:
/// Returns a reference to the value associated with the given key.
Reference operator[](const Key &) {
return *static_cast<Value *>(0);
}
/// Returns a const reference to the value associated with the given key.
ConstReference operator[](const Key &) const {
return *static_cast<Value *>(0);
}
/// Sets the value associated with the given key.
void set(const Key &k,const Value &t) { operator[](k)=t; }
template<typename _ReferenceMap>
struct Constraints {
typename enable_if<typename _ReferenceMap::ReferenceMapTag, void>::type
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
|