// Copyright 2017 PDFium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef TESTING_RANGE_SET_H_ #define TESTING_RANGE_SET_H_ #include <set> #include <utility> class RangeSet { public: using Range = std::pair<size_t, size_t>; RangeSet(); ~RangeSet(); bool Contains(const Range& range) const; void Union(const Range& range); void Union(const RangeSet& range_set); bool IsEmpty() const { return ranges().empty(); } void Clear() { ranges_.clear(); } struct range_compare { bool operator()(const Range& lval, const Range& rval) const { return lval.first < rval.first; } }; using RangesContainer = std::set<Range, range_compare>; const RangesContainer& ranges() const { return ranges_; } private: Range FixDirection(const Range& range) const; bool IsEmptyRange(const Range& range) const; RangesContainer ranges_; }; #endif // TESTING_RANGE_SET_H_