Location: LEMON/LEMON-main/lemon/concepts/maps.h - annotation
Load file history
Port error.h from svn -r3438 + minor changes (error_test does not pass!)
In svn -r3438 error_test is not used as a test program and it does not pass.
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 | 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 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r48:93ae269876de r28:e337bdf46777 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 r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a 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 r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r48:93ae269876de r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a 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 r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r28:e337bdf46777 r48:93ae269876de r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r35:f8ddf1b1541a r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r25:751cd8f9bb1c r48:93ae269876de r25:751cd8f9bb1c r48:93ae269876de r28:e337bdf46777 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 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 a key.
/// Returns the value associated with a 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(val);
ignore_unused_variable_warning(own_val);
ignore_unused_variable_warning(key);
}
Key& key;
typename _ReadMap::Key& own_key;
_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 a key.
void set(const Key &,const Value &) {}
///Default constructor
WriteMap() {}
template <typename _WriteMap>
struct Constraints {
void constraints() {
// No constraints for constructor.
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);
}
Value& val;
typename _WriteMap::Value own_val;
Key& key;
typename _WriteMap::Key& own_key;
_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 a key.
Value operator[](const Key &) const {return Value();}
/// Sets the value associated with a 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.
///
/// \todo Rethink this 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 a key.
Reference operator[](const Key &) { return tmp; }
///Returns a const reference to the value associated with a key.
ConstReference operator[](const Key &) const { return tmp; }
/// Sets the value associated with a key.
void set(const Key &k,const Value &t) { operator[](k)=t; }
template<typename _ReferenceMap>
struct ReferenceMapConcept {
void constraints() {
checkConcept<ReadWriteMap, _ReferenceMap >();
m[key] = val;
val = m[key];
m[key] = ref;
ref = m[key];
m[own_key] = own_val;
own_val = m[own_key];
m[own_key] = own_ref;
own_ref = m[own_key];
}
typename _ReferenceMap::Key& own_key;
typename _ReferenceMap::Value& own_val;
typename _ReferenceMap::Reference& own_ref;
Key& key;
Value& val;
Reference& ref;
_ReferenceMap& m;
};
};
// @}
} //namespace concepts
} //namespace lemon
#endif // LEMON_CONCEPT_MAPS_H
|