1 // Copyright 2014 PDFium 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 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 6 7 #ifndef CORE_INCLUDE_FXCRT_FX_BIDI_H_ 8 #define CORE_INCLUDE_FXCRT_FX_BIDI_H_ 9 10 #include "fx_system.h" 11 12 // Processes characters and group them into segments based on text direction. 13 class CFX_BidiChar { 14 public: 15 enum Direction { NEUTRAL, LEFT, RIGHT }; 16 17 CFX_BidiChar(); 18 ~CFX_BidiChar(); 19 20 // Append a character and classify it as left, right, or neutral. 21 // Returns true if the character has a different direction than the 22 // existing direction to indicate there is a segment to process. 23 bool AppendChar(FX_WCHAR wch); 24 25 // Call this after the last character has been appended. AppendChar() 26 // must not be called after this. 27 // Returns true if there is still a segment to process. 28 bool EndChar(); 29 30 // Get information about the segment to process. 31 // The segment's start position and character count is returned in |iStart| 32 // and |iCount|, respectively. Pass in null pointers if the information is 33 // not needed. 34 // Returns the segment direction. 35 Direction GetBidiInfo(int32_t* iStart, int32_t* iCount) const; 36 37 private: 38 void SaveCurrentStateToLastState(); 39 40 // Position of the current segment. 41 int32_t m_iCurStart; 42 43 // Number of characters in the current segment. 44 int32_t m_iCurCount; 45 46 // Direction of the current segment. 47 Direction m_CurBidi; 48 49 // Number of characters in the last segment. 50 int32_t m_iLastStart; 51 52 // Number of characters in the last segment. 53 int32_t m_iLastCount; 54 55 // Direction of the last segment. 56 Direction m_LastBidi; 57 }; 58 59 #endif // CORE_INCLUDE_FXCRT_FX_BIDI_H_ 60