Chromium Code Reviews| 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_ |