Index: core/src/fxcrt/fx_bidi.cpp |
diff --git a/core/src/fxcrt/fx_arabic.cpp b/core/src/fxcrt/fx_bidi.cpp |
similarity index 36% |
rename from core/src/fxcrt/fx_arabic.cpp |
rename to core/src/fxcrt/fx_bidi.cpp |
index 3b7d0c1c71a98781aab5416ddc84c8519cc699e7..0310fa0e94b9d676fc9c9d74dd93691a2a039ccf 100644 |
--- a/core/src/fxcrt/fx_arabic.cpp |
+++ b/core/src/fxcrt/fx_bidi.cpp |
@@ -4,81 +4,63 @@ |
// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
+#include "../../include/fxcrt/fx_bidi.h" |
#include "../../include/fxcrt/fx_ucd.h" |
-#include "fx_arabic.h" |
-extern const FX_DWORD gs_FX_TextLayout_CodeProperties[65536]; |
-IFX_BidiChar* IFX_BidiChar::Create() { |
- return new CFX_BidiChar; |
-} |
CFX_BidiChar::CFX_BidiChar() |
- : m_bSeparateNeutral(TRUE), |
- m_iCurStart(0), |
+ : m_iCurStart(0), |
m_iCurCount(0), |
- m_iCurBidi(0), |
- m_iLastBidi(0), |
+ m_CurBidi(NEUTRAL), |
m_iLastStart(0), |
- m_iLastCount(0) {} |
-void CFX_BidiChar::SetPolicy(FX_BOOL bSeparateNeutral) { |
- m_bSeparateNeutral = bSeparateNeutral; |
+ m_iLastCount(0), |
+ m_LastBidi(NEUTRAL) { |
+} |
+ |
+CFX_BidiChar::~CFX_BidiChar() { |
} |
-FX_BOOL CFX_BidiChar::AppendChar(FX_WCHAR wch) { |
- FX_DWORD dwProps = gs_FX_TextLayout_CodeProperties[(FX_WORD)wch]; |
+bool CFX_BidiChar::AppendChar(FX_WCHAR wch) { |
+ FX_DWORD dwProps = FX_GetUnicodeProperties(wch); |
int32_t iBidiCls = (dwProps & FX_BIDICLASSBITSMASK) >> FX_BIDICLASSBITS; |
- int32_t iContext = 0; |
+ Direction bidi = NEUTRAL; |
switch (iBidiCls) { |
case FX_BIDICLASS_L: |
case FX_BIDICLASS_AN: |
case FX_BIDICLASS_EN: |
- iContext = 1; |
+ bidi = LEFT; |
break; |
case FX_BIDICLASS_R: |
case FX_BIDICLASS_AL: |
- iContext = 2; |
+ bidi = RIGHT; |
break; |
} |
- FX_BOOL bRet = FALSE; |
- if (iContext != m_iCurBidi) { |
- if (m_bSeparateNeutral) { |
- bRet = TRUE; |
- } else { |
- if (m_iCurBidi == 0) { |
- bRet = (m_iCurCount > 0); |
- } else { |
- bRet = (iContext != 0); |
- } |
- } |
- if (bRet) { |
- m_iLastBidi = m_iCurBidi; |
- m_iLastStart = m_iCurStart; |
- m_iCurStart = m_iCurCount; |
- m_iLastCount = m_iCurCount - m_iLastStart; |
- } |
- if (m_bSeparateNeutral || iContext != 0) { |
- m_iCurBidi = iContext; |
- } |
+ |
+ bool bRet = (bidi != m_CurBidi); |
+ if (bRet) { |
+ SaveCurrentStateToLastState(); |
+ m_CurBidi = bidi; |
} |
m_iCurCount++; |
return bRet; |
} |
-FX_BOOL CFX_BidiChar::EndChar() { |
- m_iLastBidi = m_iCurBidi; |
- m_iLastStart = m_iCurStart; |
- m_iCurStart = m_iCurCount; |
- m_iLastCount = m_iCurCount - m_iLastStart; |
+ |
+bool CFX_BidiChar::EndChar() { |
+ SaveCurrentStateToLastState(); |
return m_iLastCount > 0; |
} |
-int32_t CFX_BidiChar::GetBidiInfo(int32_t& iStart, int32_t& iCount) { |
- iStart = m_iLastStart; |
- iCount = m_iLastCount; |
- return m_iLastBidi; |
+ |
+CFX_BidiChar::Direction CFX_BidiChar::GetBidiInfo(int32_t* iStart, |
+ int32_t* iCount) const { |
+ if (iStart) |
+ *iStart = m_iLastStart; |
+ if (iCount) |
+ *iCount = m_iLastCount; |
+ return m_LastBidi; |
} |
-void CFX_BidiChar::Reset() { |
- m_iCurStart = 0; |
- m_iCurCount = 0; |
- m_iCurBidi = 0; |
- m_iLastBidi = 0; |
- m_iLastStart = 0; |
- m_iLastCount = 0; |
+ |
+void CFX_BidiChar::SaveCurrentStateToLastState() { |
+ m_LastBidi = m_CurBidi; |
+ m_iLastStart = m_iCurStart; |
+ m_iCurStart = m_iCurCount; |
+ m_iLastCount = m_iCurCount - m_iLastStart; |
} |