2013-04-22 13:41:34 +01:00
|
|
|
#ifndef SPAN_ITERATOR_H
|
|
|
|
#define SPAN_ITERATOR_H
|
|
|
|
|
|
|
|
#include "persistent-data/space_map.h"
|
2013-07-09 11:25:09 +01:00
|
|
|
#include "persistent-data/run_set.h"
|
2013-04-22 13:41:34 +01:00
|
|
|
|
|
|
|
#include <set>
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
namespace persistent_data {
|
|
|
|
class subtracting_span_iterator : public space_map::span_iterator {
|
|
|
|
public:
|
2013-07-09 11:25:09 +01:00
|
|
|
typedef typename base::run_set<block_address> block_set;
|
2013-04-22 13:41:34 +01:00
|
|
|
typedef space_map::span span;
|
|
|
|
|
2013-07-09 11:25:09 +01:00
|
|
|
subtracting_span_iterator(block_address max,
|
|
|
|
span_iterator &sub_it,
|
2013-04-22 13:41:34 +01:00
|
|
|
block_set const &forbidden_blocks)
|
2013-07-09 11:25:09 +01:00
|
|
|
: max_(max) {
|
|
|
|
for (maybe_span ms = sub_it.first(); ms; ms = sub_it.next())
|
|
|
|
runs_.add(ms->first, ms->second);
|
|
|
|
|
|
|
|
block_set bs(forbidden_blocks);
|
|
|
|
runs_.negate();
|
|
|
|
runs_.merge(bs);
|
|
|
|
runs_.negate();
|
2013-04-22 13:41:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual maybe_span first() {
|
2013-07-09 11:25:09 +01:00
|
|
|
current_ = runs_.begin();
|
|
|
|
return get_current();
|
2013-04-22 13:41:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual maybe_span next() {
|
2013-07-09 11:25:09 +01:00
|
|
|
if (current_ != runs_.end())
|
|
|
|
++current_;
|
2013-04-22 13:41:34 +01:00
|
|
|
|
2013-07-09 11:25:09 +01:00
|
|
|
return get_current();
|
2013-04-22 13:41:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2013-07-09 11:25:09 +01:00
|
|
|
maybe_span get_current() {
|
|
|
|
return (current_ == runs_.end()) ?
|
|
|
|
maybe_span() :
|
|
|
|
maybe_span(std::make_pair(maybe_default(current_->begin_, 0ULL),
|
|
|
|
maybe_default(current_->end_, max_)));
|
2013-04-22 13:41:34 +01:00
|
|
|
}
|
|
|
|
|
2013-07-09 11:25:09 +01:00
|
|
|
typedef boost::optional<block_address> maybe;
|
|
|
|
static block_address maybe_default(maybe const &m, block_address default_) {
|
|
|
|
return m ? *m : default_;
|
2013-04-22 13:41:34 +01:00
|
|
|
}
|
|
|
|
|
2013-07-09 11:25:09 +01:00
|
|
|
block_address max_;
|
|
|
|
block_set runs_;
|
|
|
|
block_set::const_iterator current_;
|
2013-04-22 13:41:34 +01:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
|
|
|
|
#endif
|