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

Unified Diff: views/controls/textfield/text_range.h

Issue 6628037: views: Moves TextfieldController/TextRange into their own headers. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix a typo Created 9 years, 9 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
Index: views/controls/textfield/text_range.h
diff --git a/views/controls/textfield/text_range.h b/views/controls/textfield/text_range.h
new file mode 100644
index 0000000000000000000000000000000000000000..e3d31e3e96ab927ec180319c25e0917a6fd2e8c3
--- /dev/null
+++ b/views/controls/textfield/text_range.h
@@ -0,0 +1,69 @@
+// Copyright (c) 2011 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.
+
+#ifndef VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_
+#define VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_
+#pragma once
+
+#include <stddef.h>
+
+#include <algorithm>
+
+namespace views {
+
+// TextRange specifies the range of text in the Textfield. This is used to
+// specify selected text and will be used to change the attributes of characters
+// in the textfield. When this is used for selection, the end is caret position,
+// and the start is where selection started. The range preserves the direction,
+// and selecting from the end to the begining is considered "reverse" order.
+// (that is, start > end is reverse)
+class TextRange {
+ public:
+ TextRange() : start_(0), end_(0) {}
+ TextRange(size_t start, size_t end) : start_(start), end_(end) {}
+
+ // Allow copy so that the omnibox can save the view state for each tabs.
+ explicit TextRange(const TextRange& range)
+ : start_(range.start_), end_(range.end_) {}
sky 2011/03/09 17:02:33 Once you wrap, each variable should be on its own
tfarina 2011/03/09 17:31:06 Done.
+
+ // Returns the start position;
+ size_t start() const { return start_; }
+
+ // Returns the end position.
+ size_t end() const { return end_; }
+
+ // Returns true if the selected text is empty.
+ bool is_empty() const { return start_ == end_; }
+
+ // Returns true if the selection is made in reverse order.
+ bool is_reverse() const { return start_ > end_; }
+
+ // Returns the min of selected range.
+ size_t GetMin() const { return std::min(start_, end_); }
+
+ // Returns the max of selected range.
+ size_t GetMax() const { return std::max(start_, end_); }
+
+ // Returns true if the the selection range is same ignoring the direction.
+ bool EqualsIgnoringDirection(const TextRange& range) const {
+ return GetMin() == range.GetMin() && GetMax() == range.GetMax();
+ }
+
+ // Set the range with |start| and |end|.
+ void SetRange(size_t start, size_t end) {
+ start_ = start;
+ end_ = end;
+ }
+
+ private:
+ size_t start_;
+ size_t end_;
+
+ // No assign.
+ void operator=(const TextRange&);
sky 2011/03/09 17:02:33 I can't think of a good reason why we should disal
tfarina 2011/03/09 17:31:06 Removed.
+};
+
+} // namespace views
+
+#endif // VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_

Powered by Google App Engine
This is Rietveld 408576698