gdi32: Handle a BiDi string being shaped into more or less glyphs than characters in the string.
This commit is contained in:
parent
a27e03bf5d
commit
ec62c33d79
|
@ -352,7 +352,8 @@ BOOL BIDI_Reorder(
|
||||||
LPWSTR lpOutString, /* [out] Reordered string */
|
LPWSTR lpOutString, /* [out] Reordered string */
|
||||||
INT uCountOut, /* [in] Size of output buffer */
|
INT uCountOut, /* [in] Size of output buffer */
|
||||||
UINT *lpOrder, /* [out] Logical -> Visual order map */
|
UINT *lpOrder, /* [out] Logical -> Visual order map */
|
||||||
WORD **lpGlyphs /* [out] reordered, mirrored, shaped glyphs to display */
|
WORD **lpGlyphs, /* [out] reordered, mirrored, shaped glyphs to display */
|
||||||
|
INT *cGlyphs /* [out] number of glyphs generated */
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
WORD *chartype;
|
WORD *chartype;
|
||||||
|
@ -637,6 +638,8 @@ BOOL BIDI_Reorder(
|
||||||
|
|
||||||
done += i;
|
done += i;
|
||||||
}
|
}
|
||||||
|
if (cGlyphs)
|
||||||
|
*cGlyphs = glyph_i;
|
||||||
|
|
||||||
HeapFree(GetProcessHeap(), 0, chartype);
|
HeapFree(GetProcessHeap(), 0, chartype);
|
||||||
HeapFree(GetProcessHeap(), 0, levels);
|
HeapFree(GetProcessHeap(), 0, levels);
|
||||||
|
|
|
@ -1702,16 +1702,21 @@ BOOL WINAPI ExtTextOutW( HDC hdc, INT x, INT y, UINT flags,
|
||||||
|
|
||||||
if( !(flags & (ETO_GLYPH_INDEX | ETO_IGNORELANGUAGE)) && count > 0 )
|
if( !(flags & (ETO_GLYPH_INDEX | ETO_IGNORELANGUAGE)) && count > 0 )
|
||||||
{
|
{
|
||||||
|
INT cGlyphs;
|
||||||
reordered_str = HeapAlloc(GetProcessHeap(), 0, count*sizeof(WCHAR));
|
reordered_str = HeapAlloc(GetProcessHeap(), 0, count*sizeof(WCHAR));
|
||||||
|
|
||||||
BIDI_Reorder( hdc, str, count, GCP_REORDER,
|
BIDI_Reorder( hdc, str, count, GCP_REORDER,
|
||||||
((flags&ETO_RTLREADING)!=0 || (GetTextAlign(hdc)&TA_RTLREADING)!=0)?
|
((flags&ETO_RTLREADING)!=0 || (GetTextAlign(hdc)&TA_RTLREADING)!=0)?
|
||||||
WINE_GCPW_FORCE_RTL:WINE_GCPW_FORCE_LTR,
|
WINE_GCPW_FORCE_RTL:WINE_GCPW_FORCE_LTR,
|
||||||
reordered_str, count, NULL, &glyphs );
|
reordered_str, count, NULL, &glyphs, &cGlyphs);
|
||||||
|
|
||||||
flags |= ETO_IGNORELANGUAGE;
|
flags |= ETO_IGNORELANGUAGE;
|
||||||
if (glyphs)
|
if (glyphs)
|
||||||
|
{
|
||||||
flags |= ETO_GLYPH_INDEX;
|
flags |= ETO_GLYPH_INDEX;
|
||||||
|
if (cGlyphs != count)
|
||||||
|
count = cGlyphs;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if(flags & ETO_GLYPH_INDEX)
|
else if(flags & ETO_GLYPH_INDEX)
|
||||||
glyphs = reordered_str;
|
glyphs = reordered_str;
|
||||||
|
@ -2874,7 +2879,7 @@ GetCharacterPlacementW(
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
BIDI_Reorder(NULL, lpString, uCount, dwFlags, WINE_GCPW_FORCE_LTR, lpResults->lpOutString,
|
BIDI_Reorder(NULL, lpString, uCount, dwFlags, WINE_GCPW_FORCE_LTR, lpResults->lpOutString,
|
||||||
nSet, lpResults->lpOrder, NULL );
|
nSet, lpResults->lpOrder, NULL, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* FIXME: Will use the placement chars */
|
/* FIXME: Will use the placement chars */
|
||||||
|
|
|
@ -356,7 +356,7 @@ typedef struct tagBITMAPOBJ
|
||||||
#define WINE_GCPW_LOOSE_MASK 2
|
#define WINE_GCPW_LOOSE_MASK 2
|
||||||
|
|
||||||
extern BOOL BIDI_Reorder( HDC hDC, LPCWSTR lpString, INT uCount, DWORD dwFlags, DWORD dwWineGCP_Flags,
|
extern BOOL BIDI_Reorder( HDC hDC, LPCWSTR lpString, INT uCount, DWORD dwFlags, DWORD dwWineGCP_Flags,
|
||||||
LPWSTR lpOutString, INT uCountOut, UINT *lpOrder, WORD **lpGlyphs ) DECLSPEC_HIDDEN;
|
LPWSTR lpOutString, INT uCountOut, UINT *lpOrder, WORD **lpGlyphs, INT* cGlyphs ) DECLSPEC_HIDDEN;
|
||||||
|
|
||||||
/* bitmap.c */
|
/* bitmap.c */
|
||||||
extern HBITMAP BITMAP_CopyBitmap( HBITMAP hbitmap ) DECLSPEC_HIDDEN;
|
extern HBITMAP BITMAP_CopyBitmap( HBITMAP hbitmap ) DECLSPEC_HIDDEN;
|
||||||
|
|
Loading…
Reference in New Issue