| // 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 BASE_I18N_BIDI_LINE_ITERATOR_H_ |
| #define BASE_I18N_BIDI_LINE_ITERATOR_H_ |
| |
| #include "base/i18n/base_i18n_export.h" |
| #include "base/i18n/rtl.h" |
| #include "base/macros.h" |
| #include "base/strings/string16.h" |
| #include "third_party/icu/source/common/unicode/ubidi.h" |
| #include "third_party/icu/source/common/unicode/uchar.h" |
| |
| namespace base { |
| namespace i18n { |
| |
| // A simple wrapper class for the bidirectional iterator of ICU. |
| // This class uses the bidirectional iterator of ICU to split a line of |
| // bidirectional texts into visual runs in its display order. |
| class BASE_I18N_EXPORT BiDiLineIterator { |
| public: |
| // Specifies some alternative iteration behavior. |
| enum class CustomBehavior { |
| // No special behavior. |
| NONE, |
| // Treat URL delimiter characters as strong LTR. This is a special treatment |
| // for URLs that purposefully violates the URL Standard, as an experiment. |
| // It should only be used behind a flag. |
| AS_URL |
| }; |
| |
| BiDiLineIterator(); |
| ~BiDiLineIterator(); |
| |
| // Initializes the bidirectional iterator with the specified text. Returns |
| // whether initialization succeeded. |
| bool Open(const string16& text, |
| TextDirection direction, |
| CustomBehavior behavior); |
| |
| // Returns the number of visual runs in the text, or zero on error. |
| int CountRuns() const; |
| |
| // Gets the logical offset, length, and direction of the specified visual run. |
| UBiDiDirection GetVisualRun(int index, int* start, int* length) const; |
| |
| // Given a start position, figure out where the run ends (and the BiDiLevel). |
| void GetLogicalRun(int start, int* end, UBiDiLevel* level) const; |
| |
| private: |
| UBiDi* bidi_; |
| |
| DISALLOW_COPY_AND_ASSIGN(BiDiLineIterator); |
| }; |
| |
| } // namespace i18n |
| } // namespace base |
| |
| #endif // BASE_I18N_BIDI_LINE_ITERATOR_H_ |