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
|
#ifndef CondFormats_RPCObjects_RPCAMCLink_icc
#define CondFormats_RPCObjects_RPCAMCLink_icc
#include "CondFormats/RPCObjects/interface/RPCAMCLink.h"
#include "FWCore/Utilities/interface/Exception.h"
inline ::uint32_t RPCAMCLink::getId() const { return id_; }
inline RPCAMCLink::operator ::uint32_t() const { return id_; }
inline bool RPCAMCLink::matches(RPCAMCLink const& rhs) const {
return ((id_ & rhs.getMask()) == (getMask() & rhs.id_));
}
inline void RPCAMCLink::setId(::uint32_t const& id) { id_ = id; }
inline void RPCAMCLink::reset() { id_ = 0x0; }
// Field Getters
inline int RPCAMCLink::getFED() const { return bf_get(min_fed_, mask_fed_, pos_fed_); }
inline int RPCAMCLink::getAMCNumber() const { return bf_get(min_amcnumber_, mask_amcnumber_, pos_amcnumber_); }
inline int RPCAMCLink::getAMCInput() const { return bf_get(min_amcinput_, mask_amcinput_, pos_amcinput_); }
// Field Setters
inline RPCAMCLink& RPCAMCLink::setFED(int fed) { return bf_set(min_fed_, max_fed_, mask_fed_, pos_fed_, fed); }
inline RPCAMCLink& RPCAMCLink::setAMCNumber(int amcnumber) {
return bf_set(min_amcnumber_, max_amcnumber_, mask_amcnumber_, pos_amcnumber_, amcnumber);
}
inline RPCAMCLink& RPCAMCLink::setAMCInput(int amcinput) {
return bf_set(min_amcinput_, max_amcinput_, mask_amcinput_, pos_amcinput_, amcinput);
}
inline bool RPCAMCLink::operator<(RPCAMCLink const& rhs) const { return (id_ < rhs.id_); }
inline bool RPCAMCLink::operator==(RPCAMCLink const& rhs) const { return (id_ == rhs.id_); }
inline bool RPCAMCLink::operator!=(RPCAMCLink const& rhs) const { return (id_ != rhs.id_); }
inline bool RPCAMCLink::operator<(::uint32_t const& rhs) const { return (id_ < rhs); }
inline bool RPCAMCLink::operator==(::uint32_t const& rhs) const { return (id_ == rhs); }
inline bool RPCAMCLink::operator!=(::uint32_t const& rhs) const { return (id_ != rhs); }
inline RPCAMCLink& RPCAMCLink::operator++() {
int value(0);
if ((value = getAMCInput()) != wildcard_) {
if (value < max_amcinput_)
return setAMCInput(value + 1);
setAMCInput(min_amcinput_);
}
if ((value = getAMCNumber()) != wildcard_) {
if (value < max_amcnumber_)
return setAMCNumber(value + 1);
setAMCNumber(min_amcnumber_);
}
if ((value = getFED()) != wildcard_) {
if (value < max_fed_)
return setFED(value + 1);
setFED(min_fed_);
}
return *this;
}
inline RPCAMCLink RPCAMCLink::operator++(int) {
RPCAMCLink _value(*this);
++(*this);
return _value;
}
inline RPCAMCLink& RPCAMCLink::operator--() {
int value(0);
if ((value = getAMCInput()) != wildcard_) {
if (value > min_amcinput_)
return setAMCInput(value - 1);
setAMCInput(max_amcinput_);
}
if ((value = getAMCNumber()) != wildcard_) {
if (value > min_amcnumber_)
return setAMCNumber(value - 1);
setAMCNumber(max_amcnumber_);
}
if ((value = getFED()) != wildcard_) {
if (value > min_fed_)
return setFED(value - 1);
setFED(max_fed_);
}
return *this;
}
inline RPCAMCLink RPCAMCLink::operator--(int) {
RPCAMCLink _value(*this);
--(*this);
return _value;
}
inline int RPCAMCLink::bf_get(int const min, ::uint32_t const mask, int const pos) const {
::uint32_t value(id_ & mask);
if (value == 0)
return wildcard_;
return min + (int)(value >> pos) - 1;
}
inline RPCAMCLink& RPCAMCLink::bf_set(
int const min, int const max, ::uint32_t const mask, int const pos, int const value) {
if (value >= min && value <= max) {
id_ &= ~mask;
id_ |= (((::uint32_t)(value - min + 1) << pos) & mask);
} else if (value == wildcard_)
id_ &= ~mask;
else
throw cms::Exception("OutOfRange") << "Out-of-range input for RPCAMCLink::bf_set, position " << pos << ": "
<< value;
return *this;
}
inline std::ostream& RPCAMCLink::bf_stream(std::ostream& ostream,
int const min,
::uint32_t const mask,
int const pos) const {
::uint32_t value(id_ & mask);
if (value == 0)
return (ostream << '*');
return (ostream << (min + (int)(value >> pos) - 1));
}
#endif // CondFormats_RPCObjects_RPCAMCLink_icc
|