source: src/Fragmentation/Mask.hpp@ 53ef16e

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since 53ef16e was 87d6bd, checked in by Frederik Heber <heber@…>, 12 years ago

FIX: Fixing several clang errors such that we may safely use the compiler.

Changes:

  • clang does not like execeptions as pure forward declarations.
  • clang does not like AtomTypes[MaxTypes] with MaxTypes being dynamic.
  • clang does not like cppunit to have no operator<<() for std::sets (it though finds the ones for std::vector?), it cannot use one from toString.hpp as it is declared afterwards (although before instantiation site).
  • clang does not tolerate inheriting from a protected member class TQuery.
  • clang does not tolerate shadowing of a variable inside a for-loop (i.e. declaring variable in loop body with same name as e.g. loop variable).
  • clang compilation ran through after these changes without a single failing test.
  • Property mode set to 100644
File size: 2.1 KB
Line 
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 */
29template <typename T>
30struct 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 std::set<T>::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 std::set<T>::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_ */
Note: See TracBrowser for help on using the repository browser.