Changes in / [115:7b44eea654d0:111:e47fb28cda5e] in lemon-1.2
- Location:
- lemon
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
lemon/assert.h
r112 r108 116 116 const char *assertion) 117 117 { 118 assert_fail_log(file, line, function, exception, assertion); 118 std::cerr << file << ":" << line << ": "; 119 if (function) 120 std::cerr << function << ": "; 121 std::cerr << exception.what(); 122 if (assertion) 123 std::cerr << " (assertion '" << assertion << "' failed)"; 124 std::cerr << std::endl; 119 125 std::abort(); 120 126 } … … 124 130 const char *assertion) 125 131 { 126 assert_fail_log(file, line, function, message, assertion); 132 std::cerr << file << ":" << line << ": "; 133 if (function) 134 std::cerr << function << ": "; 135 std::cerr << message; 136 if (assertion) 137 std::cerr << " (assertion '" << assertion << "' failed)"; 138 std::cerr << std::endl; 127 139 std::abort(); 128 140 } … … 133 145 const char *assertion) 134 146 { 135 assert_fail_log(file, line, function, message.c_str(), assertion); 136 std::abort(); 147 assert_fail_abort(file, line, function, message.c_str(), assertion); 137 148 } 138 149 … … 158 169 const char *assertion) 159 170 { 160 throw AssertionFailedError(file, line, function, message.c_str(), assertion);171 assert_fail_error(file, line, function, message.c_str(), assertion); 161 172 } 162 173 … … 182 193 const char *assertion) 183 194 { 184 throw AssertionFailedError(file, line, function, message.c_str(), assertion);195 assert_fail_exception(file, line, function, message.c_str(), assertion); 185 196 } 186 197 … … 198 209 (defined(LEMON_ASSERT_EXCEPTION) ? 1 : 0) + \ 199 210 (defined(LEMON_ASSERT_CUSTOM) ? 1 : 0) > 1 200 #error "L EMONassertion system is not set properly"211 #error "Lemon assertion system is not set properly" 201 212 #endif 202 213 … … 206 217 (defined(LEMON_ASSERT_EXCEPTION) ? 1 : 0) + \ 207 218 (defined(LEMON_ASSERT_CUSTOM) ? 1 : 0) == 1 || \ 208 defined(LEMON_ENABLE_ASSERT S)) && \219 defined(LEMON_ENABLE_ASSERT)) && \ 209 220 defined(LEMON_DISABLE_ASSERTS) 210 #error "L EMONassertion system is not set properly"221 #error "Lemon assertion system is not set properly" 211 222 #endif 212 223 … … 246 257 /// \ingroup exceptions 247 258 /// 248 /// \brief Macro for assertion with customizable message249 /// 250 /// Macro for assertion with customizable message.251 /// \param exp An expression that must be convertible to \c bool.252 /// If it is \c false, then an assertion is raised. The concrete253 /// behaviour dependson the settings of the assertion system.254 /// \param msg A <tt>const char*</tt>, a <tt>const std::string&</tt> or255 /// a <tt>const std::exception&</tt> parameter, whichcan be used to256 /// provide information about the circumstances of thefailed assertion.257 /// 258 /// The assertions are disabled in the default behaviour. 259 /// You can enable themwith the following code:259 /// \brief Macro for assertions with customizable message 260 /// 261 /// Macro for assertions with customizable message. 262 /// \param exp An expression convertible to bool. If the expression is 263 /// false, then an assertion is raised. The concrete behaviour depends 264 /// on the settings of the assertion system. 265 /// \param msg A \e const \e char*, a \e const std::string& or a \e 266 /// const \e std::exception& parameter. The variable can be used to 267 /// provide information about the circumstances of failed assertion. 268 /// 269 /// The assertions are disabled in the default behaviour. You can 270 /// enable the assertions with the following code: 260 271 /// \code 261 272 /// #define LEMON_ENABLE_ASSERTS … … 267 278 /// \endcode 268 279 /// 269 /// The LEMONassertion system has a wide range of customization270 /// properties. As adefault behaviour the failed assertion prints a271 /// short log message to the standard errorand aborts the execution.280 /// The %lemon assertion system has a wide range of customization 281 /// properties. As default behaviour the failed assertion prints a 282 /// short log message to the standard ouput and aborts the execution. 272 283 /// 273 284 /// The following modes can be used in the assertion system: 274 285 /// 275 /// - \c LEMON_ASSERT_LOG The failed assertion prints a short log 276 /// message to the standard error and continues the execution. 277 /// - \c LEMON_ASSERT_ABORT This mode is similar to the 278 /// \c LEMON_ASSERT_LOG, but it aborts the program. It is the default 279 /// behaviour mode when the assertions are enabled with 280 /// \c LEMON_ENABLE_ASSERTS. 281 /// - \c LEMON_ASSERT_ERROR The assertion throws an 282 /// \ref lemon::AssertionFailedError "AssertionFailedError". 283 /// If the \c msg parameter is an exception, then the result of the 284 /// \ref lemon::Exception::what() "what()" member function is passed 285 /// as error message. 286 /// - \c LEMON_ASSERT_EXCEPTION If the specified \c msg is an 287 /// exception, then it raised directly (solving that the exception 286 /// - \e LEMON_ASSERT_LOG The failed assert print a short convenient 287 /// error message to the standard error and continues the 288 /// execution. 289 /// - \e LEMON_ASSERT_ABORT This mode is similar to the \e 290 /// LEMON_ASSERT_LOG, but it aborts the program. It is the default 291 /// operation mode when the asserts are enabled with \e 292 /// LEMON_ENABLE_ASSERTS. 293 /// - \e LEMON_ASSERT_ERROR The assert throws an \ref 294 /// lemon::AssertionFailedError "AssertionFailedError". If the \c 295 /// msg parameter is an exception, then the result of the \ref 296 /// lemon::Exception::what() "what()" member function is passed as 297 /// error message. 298 /// - \e LEMON_ASSERT_EXCEPTION If the specified \c msg is an 299 /// exception then it raised directly (solving that the exception 288 300 /// can not be thrown polymorphically), otherwise an \ref 289 301 /// lemon::AssertionFailedError "AssertionFailedError" is thrown with 290 /// the given parameter s.291 /// - \ c LEMON_ASSERT_CUSTOM The user can define own assertion handler292 /// functions. Three overloaded functions should be defined with the293 /// following parameter lists:302 /// the given parameter. 303 /// - \e LEMON_ASSERT_CUSTOM The user can define an own assertion 304 /// handler functions. Three overloaded functions should be defined 305 /// with the following parameter lists: 294 306 /// \code 295 /// void custom_assert_handler(const char* file, int line, const char* function,296 /// const char* message, const char* assertion);297 /// void custom_assert_handler(const char* file, int line, const char* function,298 /// const std::string& message, const char* assertion);299 /// void custom_assert_handler(const char* file, int line, const char* function,300 /// const std::exception& message, const char* assertion);307 /// void custom_assert_handler(const char* file, int line, 308 /// const char* function, const char* message, const char* expression); 309 /// void custom_assert_handler(const char* file, int line, 310 /// const char* function, const std::string& message, const char* expression); 311 /// void custom_assert_handler(const char* file, int line, 312 /// const char* function, const std::exception& message, const char* expression); 301 313 /// \endcode 302 314 /// The name of the functions should be defined as the \c … … 306 318 /// \endcode 307 319 /// Whenever an assertion is occured, one of the custom assertion 308 /// handler sis called with appropiate parameters.309 /// 310 /// The assertion mode can also be changed within one compilation unit.311 /// Ifthe macros are redefined with other settings and the312 /// \ref lemon/assert.h "assert.h" file is reincluded, then the313 /// behaviour is changedappropiately to the new settings.320 /// handler is called with appropiate parameters. 321 /// 322 /// The assertion mode can be changed within one compilation unit, if 323 /// the macros are redefined with other settings and the 324 /// lemon/assert.h file is reincluded then the behaviour is changed 325 /// appropiately to the new settings. 314 326 # define LEMON_ASSERT(exp, msg) \ 315 327 (static_cast<void> (!!(exp) ? 0 : ( \ … … 335 347 336 348 # ifndef LEMON_ASSERT_HANDLER 337 # define LEMON_ASSERT(exp, msg) (static_cast<void> (0))349 # define LEMON_ASSERT(exp, msg) (static_cast<void> (0)) 338 350 # define LEMON_FIXME(msg) (static_cast<void>(0)) 339 351 # else -
lemon/concepts/heap.h
r113 r100 19 19 ///\ingroup concept 20 20 ///\file 21 ///\brief The concept of heaps. 21 ///\brief Classes for representing heaps. 22 /// 22 23 23 24 #ifndef LEMON_CONCEPT_HEAP_H … … 27 28 28 29 namespace lemon { 29 30 30 namespace concepts { 31 32 31 /// \addtogroup concept 33 32 /// @{ 34 33 35 /// \brief The heap concept. 34 35 /// \brief A concept structure describes the main interface of heaps. 36 36 /// 37 /// Concept class describing the main interface of heaps. 38 template <typename Priority, typename ItemIntMap> 37 /// A concept structure describes the main interface of heaps. 38 /// 39 template <typename Prio, typename ItemIntMap> 39 40 class Heap { 40 41 public: 41 42 42 /// Type of the items stored in the heap. 43 typedef typename ItemIntMap::Key Item; 44 45 /// Type of the priorities. 46 typedef Priority Prio; 47 48 /// \brief Type to represent the states of the items. 49 /// 50 /// Each item has a state associated to it. It can be "in heap", 51 /// "pre heap" or "post heap". The later two are indifferent 52 /// from the point of view of the heap, but may be useful for 53 /// the user. 54 /// 55 /// The \c ItemIntMap must be initialized in such a way, that it 56 /// assigns \c PRE_HEAP (<tt>-1</tt>) to every item. 43 ///\brief Type of the items stored in the heap. 44 typedef typename ItemIntMap::Key Item; 45 46 47 /// \brief Type to represent the items states. 48 /// 49 /// Each Item element have a state associated to it. It may be "in heap", 50 /// "pre heap" or "post heap". The later two are indifferent from the 51 /// heap's point of view, but may be useful to the user. 52 /// 53 /// The ItemIntMap _should_ be initialized in such way, that it maps 54 /// PRE_HEAP (-1) to any element to be put in the heap... 57 55 enum State { 58 56 IN_HEAP = 0, … … 64 62 /// 65 63 /// The constructor. 66 /// \param map A map that assigns \c int values to keys of type 67 /// \c Item. It is used internally by the heap implementations to 68 /// handle the cross references. The assigned value must be 69 /// \c PRE_HEAP (<tt>-1</tt>) for every item. 70 explicit Heap(ItemIntMap &map) {} 64 /// \param _iim should be given to the constructor, since it is used 65 /// internally to handle the cross references. The value of the map 66 /// should be PRE_HEAP (-1) for each element. 67 explicit Heap(ItemIntMap &_iim) {} 71 68 72 69 /// \brief The number of items stored in the heap. … … 75 72 int size() const { return 0; } 76 73 77 /// \brief Checks if the heap is empty.78 /// 79 /// Returns \c true if the heap is empty.74 /// \brief Checks if the heap stores no items. 75 /// 76 /// Returns \c true if and only if the heap stores no items. 80 77 bool empty() const { return false; } 81 78 82 /// \brief Makes the heap empty.83 /// 84 /// Makes th eheap empty.79 /// \brief Makes empty this heap. 80 /// 81 /// Makes this heap empty. 85 82 void clear(); 86 83 87 /// \brief Insert s an item into the heap with the given priority.84 /// \brief Insert an item into the heap with the given heap. 88 85 /// 89 /// Inserts the given item into the heap with the given priority.86 /// Adds \c i to the heap with priority \c p. 90 87 /// \param i The item to insert. 91 88 /// \param p The priority of the item. 92 89 void push(const Item &i, const Prio &p) {} 93 90 94 /// \brief Returns the item havingminimum priority.95 /// 96 /// Returns the item having minimum priority.97 /// \pre The heap must be non -empty.91 /// \brief Returns the item with minimum priority. 92 /// 93 /// This method returns the item with minimum priority. 94 /// \pre The heap must be nonempty. 98 95 Item top() const {} 99 96 100 /// \brief The minimum priority.101 /// 102 /// Returns the minimum priority.103 /// \pre The heap must be non -empty.97 /// \brief Returns the minimum priority. 98 /// 99 /// It returns the minimum priority. 100 /// \pre The heap must be nonempty. 104 101 Prio prio() const {} 105 102 106 /// \brief Removes the item havingminimum priority.107 /// 108 /// Removes the item havingminimum priority.109 /// \pre The heap must be non-empty. 103 /// \brief Deletes the item with minimum priority. 104 /// 105 /// This method deletes the item with minimum priority. 106 /// \pre The heap must be non-empty. 110 107 void pop() {} 111 108 112 /// \brief Removes an item from the heap. 113 /// 114 /// Removes the given item from the heap if it is already stored. 115 /// \param i The item to delete. 109 /// \brief Deletes \c i from the heap. 110 /// 111 /// This method deletes item \c i from the heap, if \c i was 112 /// already stored in the heap. 113 /// \param i The item to erase. 116 114 void erase(const Item &i) {} 117 115 118 /// \brief The priority of an item.119 /// 120 /// Returns the priority of the given item.116 /// \brief Returns the priority of \c i. 117 /// 118 /// This function returns the priority of item \c i. 121 119 /// \pre \c i must be in the heap. 122 120 /// \param i The item. 123 121 Prio operator[](const Item &i) const {} 124 122 125 /// \brief Sets the priority of an item or inserts it, if it is 126 /// not stored in the heap. 127 /// 128 /// This method sets the priority of the given item if it is 129 /// already stored in the heap. 130 /// Otherwise it inserts the given item with the given priority. 131 /// 132 /// It may throw an \ref UnderflowPriorityException. 123 /// \brief \c i gets to the heap with priority \c p independently 124 /// if \c i was already there. 125 /// 126 /// This method calls \ref push(\c i, \c p) if \c i is not stored 127 /// in the heap and sets the priority of \c i to \c p otherwise. 128 /// It may throw an \e UnderFlowPriorityException. 133 129 /// \param i The item. 134 130 /// \param p The priority. 135 131 void set(const Item &i, const Prio &p) {} 136 132 137 /// \brief Decreases the priority of an item to the given value.138 /// 139 /// Decreases the priority of an item to the given value.133 /// \brief Decreases the priority of \c i to \c p. 134 /// 135 /// This method decreases the priority of item \c i to \c p. 140 136 /// \pre \c i must be stored in the heap with priority at least \c p. 141 137 /// \param i The item. … … 143 139 void decrease(const Item &i, const Prio &p) {} 144 140 145 /// \brief Increases the priority of an item to the given value. 146 /// 147 /// Increases the priority of an item to the given value. 148 /// \pre \c i must be stored in the heap with priority at most \c p. 141 /// \brief Increases the priority of \c i to \c p. 142 /// 143 /// This method sets the priority of item \c i to \c p. 144 /// \pre \c i must be stored in the heap with priority at most \c 145 /// p relative to \c Compare. 149 146 /// \param i The item. 150 147 /// \param p The priority. 151 148 void increase(const Item &i, const Prio &p) {} 152 149 153 /// \brief Returns if an item is in, has already been in, or has150 /// \brief Returns if \c item is in, has already been in, or has 154 151 /// never been in the heap. 155 152 /// 156 /// This method returns \c PRE_HEAP if the given item has never 157 /// been in the heap, \c IN_HEAP if it is in the heap at the moment, 158 /// and \c POST_HEAP otherwise. 159 /// In the latter case it is possible that the item will get back 160 /// to the heap again. 153 /// This method returns PRE_HEAP if \c item has never been in the 154 /// heap, IN_HEAP if it is in the heap at the moment, and POST_HEAP 155 /// otherwise. In the latter case it is possible that \c item will 156 /// get back to the heap again. 161 157 /// \param i The item. 162 158 State state(const Item &i) const {} 163 159 164 /// \brief Sets the state of anitem in the heap.165 /// 166 /// Sets the state of the given item in the heap. It can be used167 /// tomanually clear the heap when it is important to achive the160 /// \brief Sets the state of the \c item in the heap. 161 /// 162 /// Sets the state of the \c item in the heap. It can be used to 163 /// manually clear the heap when it is important to achive the 168 164 /// better time complexity. 169 165 /// \param i The item. 170 /// \param st The state. It should not be \c IN_HEAP. 166 /// \param st The state. It should not be \c IN_HEAP. 171 167 void state(const Item& i, State st) {} 172 168 … … 175 171 struct Constraints { 176 172 public: 173 177 174 void constraints() { 178 typedef typename _Heap::Item OwnItem;179 typedef typename _Heap::Prio OwnPrio;180 typedef typename _Heap::State OwnState;181 182 175 Item item; 183 176 Prio prio; 184 State state; 177 185 178 item=Item(); 186 179 prio=Prio(); 180 187 181 ignore_unused_variable_warning(item); 188 182 ignore_unused_variable_warning(prio); 183 184 typedef typename _Heap::State State; 185 State state; 186 189 187 ignore_unused_variable_warning(state); 190 191 OwnItem own_item; 192 OwnPrio own_prio; 193 OwnState own_state; 194 own_item=Item(); 195 own_prio=Prio(); 196 ignore_unused_variable_warning(own_item); 197 ignore_unused_variable_warning(own_prio); 198 ignore_unused_variable_warning(own_state); 199 200 _Heap heap1(map); 201 _Heap heap2 = heap1; 188 189 _Heap heap1 = _Heap(map); 190 202 191 ignore_unused_variable_warning(heap1); 203 ignore_unused_variable_warning(heap2); 204 205 int s = heap.size(); 206 bool e = heap.empty(); 192 193 heap.push(item, prio); 207 194 208 195 prio = heap.prio(); 209 196 item = heap.top(); 210 prio = heap[item]; 211 own_prio = heap.prio(); 212 own_item = heap.top(); 213 own_prio = heap[own_item]; 214 215 heap.push(item, prio); 216 heap.push(own_item, own_prio); 197 217 198 heap.pop(); 218 199 … … 220 201 heap.decrease(item, prio); 221 202 heap.increase(item, prio); 222 heap.set(own_item, own_prio); 223 heap.decrease(own_item, own_prio); 224 heap.increase(own_item, own_prio); 203 prio = heap[item]; 225 204 226 205 heap.erase(item); 227 heap.erase(own_item);228 heap.clear();229 206 230 207 state = heap.state(item); 231 heap.state(item, state);232 state = heap.state(own_item);233 heap.state(own_item, own_state);234 208 235 209 state = _Heap::PRE_HEAP; 236 210 state = _Heap::IN_HEAP; 237 211 state = _Heap::POST_HEAP; 238 own_state = _Heap::PRE_HEAP; 239 own_state = _Heap::IN_HEAP; 240 own_state = _Heap::POST_HEAP; 212 213 heap.clear(); 241 214 } 242 215 243 216 _Heap& heap; 244 217 ItemIntMap& map; 218 219 Constraints() : heap(0), map(0) {} 245 220 }; 246 221 }; -
lemon/concepts/maps.h
r114 r94 25 25 ///\ingroup concept 26 26 ///\file 27 ///\brief The concept of maps.27 ///\brief Map concepts checking classes for testing and documenting. 28 28 29 29 namespace lemon { … … 106 106 const Value& val; 107 107 const typename _WriteMap::Key& own_key; 108 const typename _WriteMap::Value &own_val;108 const typename _WriteMap::Value own_val; 109 109 _WriteMap& m; 110 110 };
Note: See TracChangeset
for help on using the changeset viewer.