40 mapping(_In_ T _from, _In_ T _to) : from(_from), to(_to) {}
49 bool operator==(
const mapping& other)
const {
return from == other.from && to == other.to; }
69 return mapping(from + other.from, to + other.to);
83 template <
class T,
class AX = std::allocator<mapping<T>>>
84 using mapping_vector = std::vector<mapping<T>, AX>;
94 template <
class T,
class AX = std::allocator<mapping<T>>>
100 for (
size_t l = 0, r = mapping.size();;) {
102 auto m = (l + r) / 2;
103 const auto& el = mapping[m];
104 if (to < el.to) r = m;
105 else if (el.to < to) l = m + 1;
109 const auto& el = mapping[l - 1];
110 return el.from + (to - el.to);
113 const auto& el = mapping[0];
114 return std::min<T>(to, el.from);
128 template <
class T,
class AX = std::allocator<mapping<T>>>
129 T dst2src(_In_
const std::vector<
stdex::mapping<T>, AX>& mapping, _In_ T to, _Inout_opt_
size_t& m)
136 const auto& el = mapping[m];
141 else if (el.to < to) {
142 if (mapping.size() - 1 <= m || to < mapping[m + 1].to)
143 return el.from + (to - el.to);
154 const auto& el = mapping[m];
155 if (to < el.to) r = m;
156 else if (el.to < to) l = m + 1;
160 const auto& el = mapping[m = l - 1];
161 return el.from + (to - el.to);
164 const auto& el = mapping[m = 0];
165 return std::min<T>(to, el.from);
178 template <
class T,
class AX = std::allocator<mapping<T>>>
184 for (
size_t l = 0, r = mapping.size();;) {
186 auto m = (l + r) / 2;
187 const auto& el = mapping[m];
188 if (from < el.from) r = m;
189 else if (el.from < from) l = m + 1;
193 const auto& el = mapping[l - 1];
194 return el.to + (from - el.from);
197 const auto& el = mapping[0];
198 return std::min<T>(from, el.to);
212 template <
class T,
class AX = std::allocator<mapping<T>>>
213 T src2dst(_In_
const std::vector<
stdex::mapping<T>, AX>& mapping, _In_ T from, _Inout_opt_
size_t& m)
220 const auto& el = mapping[m];
221 if (from < el.from) {
225 else if (el.from < from) {
226 if (mapping.size() - 1 <= m || from < mapping[m + 1].from)
227 return el.to + (from - el.from);
238 const auto& el = mapping[m];
239 if (from < el.from) r = m;
240 else if (el.from < from) l = m + 1;
244 const auto& el = mapping[m = l - 1];
245 return el.to + (from - el.from);
248 const auto& el = mapping[m = 0];
249 return std::min<T>(from, el.to);
Maps index in source string to index in destination string.
Definition mapping.hpp:18
mapping(T x)
Constructs an id mapping.
Definition mapping.hpp:32
bool operator==(const mapping &other) const
Are mappings identical?
Definition mapping.hpp:49
mapping()
Constructs a zero to zero mapping.
Definition mapping.hpp:25
bool operator!=(const mapping &other) const
Are mappings different?
Definition mapping.hpp:58
mapping operator+(const mapping &other) const
Adds two mappings by components.
Definition mapping.hpp:67
mapping(T _from, T _to)
Constructs a mapping.
Definition mapping.hpp:40
void invert()
Reverses source and destination indexes.
Definition mapping.hpp:75