| 1 | /*
 | 
|---|
| 2 |  * Mask.hpp
 | 
|---|
| 3 |  *
 | 
|---|
| 4 |  *  Created on: Sep 7, 2012
 | 
|---|
| 5 |  *      Author: heber
 | 
|---|
| 6 |  */
 | 
|---|
| 7 | 
 | 
|---|
| 8 | #ifndef MASK_HPP_
 | 
|---|
| 9 | #define MASK_HPP_
 | 
|---|
| 10 | 
 | 
|---|
| 11 | 
 | 
|---|
| 12 | // include config.h
 | 
|---|
| 13 | #ifdef HAVE_CONFIG_H
 | 
|---|
| 14 | #include <config.h>
 | 
|---|
| 15 | #endif
 | 
|---|
| 16 | 
 | 
|---|
| 17 | #include <set>
 | 
|---|
| 18 | 
 | 
|---|
| 19 | #include "CodePatterns/Assert.hpp"
 | 
|---|
| 20 | 
 | 
|---|
| 21 | #include "types.hpp"
 | 
|---|
| 22 | 
 | 
|---|
| 23 | /** A Mask_t is just a set of ids such that one can use the set as a filter
 | 
|---|
| 24 |  * for any type by looking them up in the map.
 | 
|---|
| 25 |  *
 | 
|---|
| 26 |  * The interface is such that we have a bitmask for every given id. Only we
 | 
|---|
| 27 |  * store only ids associated to true.
 | 
|---|
| 28 |  */
 | 
|---|
| 29 | template <typename T>
 | 
|---|
| 30 | struct Mask_t : public std::set<T>
 | 
|---|
| 31 | {
 | 
|---|
| 32 |   /** Checks whether the bit for the given \a id is true.
 | 
|---|
| 33 |    *
 | 
|---|
| 34 |    * @param id id to check
 | 
|---|
| 35 |    * @return true - bit set, false - bit not set
 | 
|---|
| 36 |    */
 | 
|---|
| 37 |   bool isTrue(const T id) const {
 | 
|---|
| 38 |     const typename std::set<T>::const_iterator iter = std::set<T>::find(id);
 | 
|---|
| 39 |     return (iter != std::set<T>::end());
 | 
|---|
| 40 |   }
 | 
|---|
| 41 | 
 | 
|---|
| 42 |   /** Checks whether the bit for the given \a id is true.
 | 
|---|
| 43 |    *
 | 
|---|
| 44 |    * @param id id to check
 | 
|---|
| 45 |    * @return true - bit set, false - bit not set
 | 
|---|
| 46 |    */
 | 
|---|
| 47 |   bool isFalse(const T id) const {
 | 
|---|
| 48 |     return (!isTrue(id));
 | 
|---|
| 49 |   }
 | 
|---|
| 50 | 
 | 
|---|
| 51 |   /** Setter for the bit associated to \a id.
 | 
|---|
| 52 |    *
 | 
|---|
| 53 |    * @param id id to set to true
 | 
|---|
| 54 |    */
 | 
|---|
| 55 |   void setTrue(const T id)
 | 
|---|
| 56 |   {
 | 
|---|
| 57 |     insert(id);
 | 
|---|
| 58 |   }
 | 
|---|
| 59 | 
 | 
|---|
| 60 |   /** Unsetter for the bit associated to \a id.
 | 
|---|
| 61 |    *
 | 
|---|
| 62 |    * @param id id to set to false
 | 
|---|
| 63 |    */
 | 
|---|
| 64 |   void setFalse(const T id)
 | 
|---|
| 65 |   {
 | 
|---|
| 66 |     typename std::set<T>::iterator iter = std::set<T>::find(id);
 | 
|---|
| 67 |     if (iter != std::set<T>::end())
 | 
|---|
| 68 |       erase(iter);
 | 
|---|
| 69 |   }
 | 
|---|
| 70 | 
 | 
|---|
| 71 |   /** Sets bit associated to \a id to a specific boolean value.
 | 
|---|
| 72 |    *
 | 
|---|
| 73 |    * @param id id to set or unset
 | 
|---|
| 74 |    * @param value bit giving whether to set or unset
 | 
|---|
| 75 |    */
 | 
|---|
| 76 |   void setValue(const T id, bool value) {
 | 
|---|
| 77 |     if (value)
 | 
|---|
| 78 |       setTrue(id);
 | 
|---|
| 79 |     else
 | 
|---|
| 80 |       setFalse(id);
 | 
|---|
| 81 |   }
 | 
|---|
| 82 | 
 | 
|---|
| 83 |   /** Use in printing the bit mask bit by bit.
 | 
|---|
| 84 |    *
 | 
|---|
| 85 |    * @param id bit to print
 | 
|---|
| 86 |    * @return "t" or "f" whether bit is set or not.
 | 
|---|
| 87 |    */
 | 
|---|
| 88 |   const char* printBit(const T id) const
 | 
|---|
| 89 |   {
 | 
|---|
| 90 |     const typename std::set<T>::const_iterator iter = std::set<T>::find(id);
 | 
|---|
| 91 |     return (iter != std::set<T>::end() ? "t" : "f");
 | 
|---|
| 92 |   }
 | 
|---|
| 93 | };
 | 
|---|
| 94 | 
 | 
|---|
| 95 | 
 | 
|---|
| 96 | #endif /* MASK_HPP_ */
 | 
|---|