[thin_delta] tidy up the comparison function
This commit is contained in:
parent
e4c5e5afb5
commit
2461cdce43
@ -103,13 +103,6 @@ namespace local {
|
|||||||
len_(len) {
|
len_(len) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void consume(uint64_t delta) {
|
|
||||||
delta = min<uint64_t>(delta, len_);
|
|
||||||
vbegin_ += delta;
|
|
||||||
dbegin_ += delta;
|
|
||||||
len_ -= delta;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t vbegin_, dbegin_, len_;
|
uint64_t vbegin_, dbegin_, len_;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -120,6 +113,51 @@ namespace local {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------
|
||||||
|
|
||||||
|
template <typename Container>
|
||||||
|
class mapping_stream {
|
||||||
|
public:
|
||||||
|
mapping_stream(Container const &c)
|
||||||
|
: it_(c.begin()),
|
||||||
|
end_(c.end()) {
|
||||||
|
m_ = *it_;
|
||||||
|
}
|
||||||
|
|
||||||
|
mapping const &get_mapping() const {
|
||||||
|
return m_;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool more_mappings() const {
|
||||||
|
return it_ != end_;
|
||||||
|
}
|
||||||
|
|
||||||
|
void consume(uint64_t delta) {
|
||||||
|
if (it_ == end_)
|
||||||
|
throw runtime_error("end of stream already reached");
|
||||||
|
|
||||||
|
if (delta > m_.len_)
|
||||||
|
throw runtime_error("delta too long");
|
||||||
|
|
||||||
|
if (delta == m_.len_) {
|
||||||
|
++it_;
|
||||||
|
m_ = *it_;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
m_.vbegin_ += delta;
|
||||||
|
m_.dbegin_ += delta;
|
||||||
|
m_.len_ -= delta;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
typename Container::const_iterator it_;
|
||||||
|
typename Container::const_iterator end_;
|
||||||
|
mapping m_;
|
||||||
|
};
|
||||||
|
|
||||||
|
//--------------------------------
|
||||||
|
|
||||||
typedef std::deque<mapping> mapping_deque;
|
typedef std::deque<mapping> mapping_deque;
|
||||||
|
|
||||||
// Builds up an in core rep of the mappings for a device.
|
// Builds up an in core rep of the mappings for a device.
|
||||||
@ -426,58 +464,45 @@ namespace local {
|
|||||||
|
|
||||||
// We iterate through both sets of mappings in parallel
|
// We iterate through both sets of mappings in parallel
|
||||||
// noting any differences.
|
// noting any differences.
|
||||||
mapping_deque::const_iterator left_it = left.begin();
|
mapping_stream<mapping_deque> ls{left};
|
||||||
mapping_deque::const_iterator right_it = right.begin();
|
mapping_stream<mapping_deque> rs{right};
|
||||||
|
|
||||||
mapping left_mapping;
|
while (ls.more_mappings() && rs.more_mappings()) {
|
||||||
mapping right_mapping;
|
auto &lm = ls.get_mapping();
|
||||||
|
auto &rm = rs.get_mapping();
|
||||||
|
|
||||||
while ((left_mapping.len_ || left_it != left.end()) &&
|
if (lm.vbegin_ < rm.vbegin_) {
|
||||||
(right_mapping.len_ || right_it != right.end())) {
|
auto delta = min<uint64_t>(lm.len_, rm.vbegin_ - lm.vbegin_);
|
||||||
if (!left_mapping.len_ && left_it != left.end())
|
e.left_only(lm.vbegin_, lm.dbegin_, delta);
|
||||||
left_mapping = *left_it++;
|
ls.consume(delta);
|
||||||
|
|
||||||
if (!right_mapping.len_ && right_it != right.end())
|
} else if (lm.vbegin_ > rm.vbegin_) {
|
||||||
right_mapping = *right_it++;
|
auto delta = min<uint64_t>(rm.len_, lm.vbegin_ - rm.vbegin_);
|
||||||
|
e.right_only(rm.vbegin_, rm.dbegin_, delta);
|
||||||
|
rs.consume(delta);
|
||||||
|
|
||||||
while (left_mapping.len_ && right_mapping.len_) {
|
} else if (lm.dbegin_ != rm.dbegin_) {
|
||||||
if (left_mapping.vbegin_ < right_mapping.vbegin_) {
|
auto delta = min<uint64_t>(lm.len_, rm.len_);
|
||||||
uint64_t delta = min<uint64_t>(left_mapping.len_, right_mapping.vbegin_ - left_mapping.vbegin_);
|
e.blocks_differ(lm.vbegin_, lm.dbegin_, rm.dbegin_, delta);
|
||||||
e.left_only(left_mapping.vbegin_, left_mapping.dbegin_, delta);
|
ls.consume(delta);
|
||||||
left_mapping.consume(delta);
|
rs.consume(delta);
|
||||||
|
|
||||||
} else if (left_mapping.vbegin_ > right_mapping.vbegin_) {
|
} else {
|
||||||
uint64_t delta = min<uint64_t>(right_mapping.len_, left_mapping.vbegin_ - right_mapping.vbegin_);
|
auto delta = min<uint64_t>(lm.len_, rm.len_);
|
||||||
e.right_only(right_mapping.vbegin_, right_mapping.dbegin_, delta);
|
e.blocks_same(lm.vbegin_, lm.dbegin_, delta);
|
||||||
right_mapping.consume(delta);
|
ls.consume(delta);
|
||||||
|
rs.consume(delta);
|
||||||
} else if (left_mapping.dbegin_ != right_mapping.dbegin_) {
|
|
||||||
uint64_t delta = min<uint64_t>(left_mapping.len_, right_mapping.len_);
|
|
||||||
e.blocks_differ(left_mapping.vbegin_, left_mapping.dbegin_, right_mapping.dbegin_, delta);
|
|
||||||
left_mapping.consume(delta);
|
|
||||||
right_mapping.consume(delta);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
uint64_t delta = min<uint64_t>(left_mapping.len_, right_mapping.len_);
|
|
||||||
e.blocks_same(left_mapping.vbegin_, left_mapping.dbegin_, delta);
|
|
||||||
left_mapping.consume(delta);
|
|
||||||
right_mapping.consume(delta);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (left_it != left.end()) {
|
while (ls.more_mappings()) {
|
||||||
left_mapping = *left_it++;
|
auto &lm = ls.get_mapping();
|
||||||
|
e.left_only(lm.vbegin_, lm.dbegin_, lm.len_);
|
||||||
if (left_mapping.len_)
|
|
||||||
e.left_only(left_mapping.vbegin_, left_mapping.dbegin_, left_mapping.len_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
while (right_it != right.end()) {
|
while (rs.more_mappings()) {
|
||||||
right_mapping = *right_it++;
|
auto &rm = rs.get_mapping();
|
||||||
|
e.right_only(rm.vbegin_, rm.dbegin_, rm.len_);
|
||||||
if (right_mapping.len_)
|
|
||||||
e.right_only(right_mapping.vbegin_, right_mapping.dbegin_, right_mapping.len_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
e.complete();
|
e.complete();
|
||||||
|
Loading…
Reference in New Issue
Block a user