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

Side by Side 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_
6 #define VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_
7 #pragma once
8
9 #include <stddef.h>
10
11 #include <algorithm>
12
13 namespace views {
14
15 // TextRange specifies the range of text in the Textfield. This is used to
16 // specify selected text and will be used to change the attributes of characters
17 // in the textfield. When this is used for selection, the end is caret position,
18 // and the start is where selection started. The range preserves the direction,
19 // and selecting from the end to the begining is considered "reverse" order.
20 // (that is, start > end is reverse)
21 class TextRange {
22 public:
23 TextRange() : start_(0), end_(0) {}
24 TextRange(size_t start, size_t end) : start_(start), end_(end) {}
25
26 // Allow copy so that the omnibox can save the view state for each tabs.
27 explicit TextRange(const TextRange& range)
28 : 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.
29
30 // Returns the start position;
31 size_t start() const { return start_; }
32
33 // Returns the end position.
34 size_t end() const { return end_; }
35
36 // Returns true if the selected text is empty.
37 bool is_empty() const { return start_ == end_; }
38
39 // Returns true if the selection is made in reverse order.
40 bool is_reverse() const { return start_ > end_; }
41
42 // Returns the min of selected range.
43 size_t GetMin() const { return std::min(start_, end_); }
44
45 // Returns the max of selected range.
46 size_t GetMax() const { return std::max(start_, end_); }
47
48 // Returns true if the the selection range is same ignoring the direction.
49 bool EqualsIgnoringDirection(const TextRange& range) const {
50 return GetMin() == range.GetMin() && GetMax() == range.GetMax();
51 }
52
53 // Set the range with |start| and |end|.
54 void SetRange(size_t start, size_t end) {
55 start_ = start;
56 end_ = end;
57 }
58
59 private:
60 size_t start_;
61 size_t end_;
62
63 // No assign.
64 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.
65 };
66
67 } // namespace views
68
69 #endif // VIEWS_CONTROLS_TEXTFIELD_TEXT_RANGE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698