gdi32: Handle a BiDi string being shaped into more or less glyphs than characters in the string.

This commit is contained in:
Aric Stewart 2010-05-21 15:11:34 -05:00 committed by Alexandre Julliard
parent a27e03bf5d
commit ec62c33d79
3 changed files with 12 additions and 4 deletions

View File

@ -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);

View File

@ -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 */

View File

@ -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;