Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3592)

Unified Diff: pdf/range_set.h

Issue 2349753003: Improve linearized pdf load/show time. (Closed)
Patch Set: rebase Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « pdf/preview_mode_client.cc ('k') | pdf/range_set.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: pdf/range_set.h
diff --git a/pdf/range_set.h b/pdf/range_set.h
new file mode 100644
index 0000000000000000000000000000000000000000..b615999285a5ac72d4e81b8b91cc8357e0fb20e7
--- /dev/null
+++ b/pdf/range_set.h
@@ -0,0 +1,77 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// Defines a set of geometric ranges, and standard operations on it.
+
+#ifndef PDF_RANGE_SET_H_
+#define PDF_RANGE_SET_H_
+
+#include <ostream>
+#include <set>
+#include <string>
+
+#include "ui/gfx/range/range.h"
+
+namespace chrome_pdf {
+
+class RangeSet {
+ public:
+ RangeSet();
+ explicit RangeSet(const gfx::Range& range);
+ ~RangeSet();
+
+ RangeSet(const RangeSet& range_set);
+ RangeSet(RangeSet&& range_set);
+ RangeSet& operator=(const RangeSet& other);
+
+ bool operator==(const RangeSet& other) const;
+ bool operator!=(const RangeSet& other) const;
+
+ bool Contains(uint32_t point) const;
+ bool Contains(const gfx::Range& range) const;
+ bool Contains(const RangeSet& range_set) const;
+
+ bool Intersects(const gfx::Range& range) const;
+ bool Intersects(const RangeSet& range_set) const;
+
+ void Union(const gfx::Range& range);
+ void Union(const RangeSet& range_set);
+
+ void Intersect(const gfx::Range& range);
+ void Intersect(const RangeSet& range_set);
+
+ void Subtract(const gfx::Range& range);
+ void Subtract(const RangeSet& range_set);
+
+ void Xor(const gfx::Range& range);
+ void Xor(const RangeSet& range_set);
+
+ bool IsEmpty() const;
+ void Clear();
+
+ gfx::Range First() const;
+ gfx::Range Last() const;
+ std::string ToString() const;
+
+ struct range_compare {
+ bool operator()(const gfx::Range& lval, const gfx::Range& rval) const {
+ return lval.start() < rval.start();
+ }
+ };
+
+ using RangesContainer = std::set<gfx::Range, range_compare>;
+
+ const RangesContainer& ranges() const { return ranges_; }
+ size_t Size() const { return ranges_.size(); }
+
+ private:
+ RangesContainer ranges_;
+};
+
+} // namespace chrome_pdf
+
+std::ostream& operator<<(std::ostream& os,
+ const chrome_pdf::RangeSet& range_set);
+
+#endif // PDF_RANGE_SET_H_
« no previous file with comments | « pdf/preview_mode_client.cc ('k') | pdf/range_set.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698