Commit 21589993 authored by Dmitry Timoshkov's avatar Dmitry Timoshkov Committed by Alexandre Julliard

gdi32: Rework the test for too large width/height font ratio to pass with…

gdi32: Rework the test for too large width/height font ratio to pass with different font heights, make it pass under Wine.
parent fa6ffb4d
...@@ -5430,12 +5430,18 @@ BOOL WineEngGetTextMetrics(GdiFont *font, LPTEXTMETRICW ptm) ...@@ -5430,12 +5430,18 @@ BOOL WineEngGetTextMetrics(GdiFont *font, LPTEXTMETRICW ptm)
LeaveCriticalSection( &freetype_cs ); LeaveCriticalSection( &freetype_cs );
return FALSE; return FALSE;
} }
}
if(!font->potm) /* Make sure that the font has sane width/height ratio */
if (font->aveWidth)
{ {
LeaveCriticalSection( &freetype_cs ); if ((font->aveWidth + font->potm->otmTextMetrics.tmHeight - 1) / font->potm->otmTextMetrics.tmHeight > 100)
return FALSE; {
WARN("Ignoring too large font->aveWidth %d\n", font->aveWidth);
font->aveWidth = 0;
}
} }
}
*ptm = font->potm->otmTextMetrics; *ptm = font->potm->otmTextMetrics;
scale_font_metrics(font, ptm); scale_font_metrics(font, ptm);
LeaveCriticalSection( &freetype_cs ); LeaveCriticalSection( &freetype_cs );
......
...@@ -2920,14 +2920,13 @@ static void test_GetGlyphOutline(void) ...@@ -2920,14 +2920,13 @@ static void test_GetGlyphOutline(void)
} }
/* bug #9995: there is a limit to the character width that can be specified */ /* bug #9995: there is a limit to the character width that can be specified */
static void test_GetTextMetrics2( const char *fontname) static void test_GetTextMetrics2(const char *fontname, int font_height)
{ {
HFONT of, hf; HFONT of, hf;
HDC hdc; HDC hdc;
TEXTMETRICA tm; TEXTMETRICA tm;
LOGFONTA lf;
BOOL ret; BOOL ret;
int avecharw[3], maxcharw[3]; int ave_width, height, width, ratio, scale;
if (!is_truetype_font_installed( fontname)) { if (!is_truetype_font_installed( fontname)) {
skip("%s is not installed\n", fontname); skip("%s is not installed\n", fontname);
...@@ -2936,60 +2935,46 @@ static void test_GetTextMetrics2( const char *fontname) ...@@ -2936,60 +2935,46 @@ static void test_GetTextMetrics2( const char *fontname)
hdc = CreateCompatibleDC(0); hdc = CreateCompatibleDC(0);
ok( hdc != NULL, "CreateCompatibleDC failed\n"); ok( hdc != NULL, "CreateCompatibleDC failed\n");
/* select width = 0 */ /* select width = 0 */
hf = CreateFontA( -11, 0, 0, 0, FW_REGULAR, FALSE, FALSE, FALSE, hf = CreateFontA(font_height, 0, 0, 0, FW_REGULAR, FALSE, FALSE, FALSE,
DEFAULT_CHARSET, OUT_TT_PRECIS, CLIP_LH_ANGLES, DEFAULT_CHARSET, OUT_TT_PRECIS, CLIP_LH_ANGLES,
DEFAULT_QUALITY, VARIABLE_PITCH, DEFAULT_QUALITY, VARIABLE_PITCH,
fontname); fontname);
ok( hf != NULL, "CreateFontA failed\n"); ok( hf != NULL, "CreateFontA failed\n");
of = SelectObject( hdc, hf); of = SelectObject( hdc, hf);
ret = GetObjectA( hf, sizeof( lf), &lf);
ret = GetTextMetricsA( hdc, &tm); ret = GetTextMetricsA( hdc, &tm);
ok(ret, "GetTextMetricsA error %u\n", GetLastError()); ok(ret, "GetTextMetricsA error %u\n", GetLastError());
avecharw[0] =tm.tmAveCharWidth; height = tm.tmHeight;
maxcharw[0] =tm.tmMaxCharWidth; ave_width = tm.tmAveCharWidth;
SelectObject( hdc, of); SelectObject( hdc, of);
DeleteObject( hf); DeleteObject( hf);
/* select LARGE width = 1023 */
hf = CreateFontA( -11, 1023, 0, 0, FW_REGULAR, FALSE, FALSE, FALSE, trace("height %d, ave width %d\n", height, ave_width);
DEFAULT_CHARSET, OUT_TT_PRECIS, CLIP_LH_ANGLES,
DEFAULT_QUALITY, VARIABLE_PITCH, for (width = ave_width * 2; /* nothing*/; width += ave_width)
fontname); {
ok( hf != NULL, "CreateFontA failed\n"); hf = CreateFont(height, width, 0, 0, FW_REGULAR, FALSE, FALSE, FALSE,
of = SelectObject( hdc, hf);
ret = GetObjectA( hf, sizeof( lf), &lf);
ret = GetTextMetricsA( hdc, &tm);
ok(ret, "GetTextMetricsA error %u\n", GetLastError());
avecharw[1] =tm.tmAveCharWidth;
maxcharw[1] =tm.tmMaxCharWidth;
SelectObject( hdc, of);
DeleteObject( hf);
/* select TOOLARGE width = 1536 */
hf = CreateFontA( -11, 1536, 0, 0, FW_REGULAR, FALSE, FALSE, FALSE,
DEFAULT_CHARSET, OUT_TT_PRECIS, CLIP_LH_ANGLES, DEFAULT_CHARSET, OUT_TT_PRECIS, CLIP_LH_ANGLES,
DEFAULT_QUALITY, VARIABLE_PITCH, DEFAULT_QUALITY, VARIABLE_PITCH, fontname);
fontname); ok(hf != 0, "CreateFont failed\n");
ok( hf != NULL, "CreateFontA failed\n"); of = SelectObject(hdc, hf);
of = SelectObject( hdc, hf); ret = GetTextMetrics(hdc, &tm);
ret = GetObjectA( hf, sizeof( lf), &lf); ok(ret, "GetTextMetrics error %u\n", GetLastError());
ret = GetTextMetricsA( hdc, &tm); SelectObject(hdc, of);
ok(ret, "GetTextMetricsA error %u\n", GetLastError()); DeleteObject(hf);
avecharw[2] =tm.tmAveCharWidth;
maxcharw[2] =tm.tmMaxCharWidth; if (tm.tmAveCharWidth == ave_width || width / height > 200)
SelectObject( hdc, of); break;
DeleteObject( hf); }
/* tests */
ok( avecharw[1] > 10 * avecharw[0], "Av. charwidth not large ( %d cmp.to %d)\n",
avecharw[1], avecharw[0]);
ok( maxcharw[1] > 10 * maxcharw[0], "Max charwidth not large ( %d cmp.to %d)\n",
maxcharw[1], maxcharw[0]);
todo_wine {
ok( avecharw[2] == avecharw[0], "Unexpected Av. charwidth ( %d cmp.to %d)\n",
avecharw[2], avecharw[0]);
ok( maxcharw[2] == maxcharw[0], "Unexpected Max charwidth ( %d cmp.to %d)\n",
maxcharw[2], maxcharw[0]);
}
/* clean up */
DeleteDC(hdc); DeleteDC(hdc);
ratio = width / height;
scale = width / ave_width;
trace("max width/height ratio (%d / %d) %d, max width scale (%d / %d) %d\n",
width, height, ratio, width, ave_width, scale);
ok(ratio >= 90 && ratio <= 110, "expected width/height ratio 90-110, got %d\n", ratio);
} }
START_TEST(font) START_TEST(font)
...@@ -3029,6 +3014,10 @@ START_TEST(font) ...@@ -3029,6 +3014,10 @@ START_TEST(font)
test_GdiRealizationInfo(); test_GdiRealizationInfo();
test_GetTextFace(); test_GetTextFace();
test_GetGlyphOutline(); test_GetGlyphOutline();
test_GetTextMetrics2( "Tahoma"); test_GetTextMetrics2("Tahoma", -11);
test_GetTextMetrics2( "Arial"); test_GetTextMetrics2("Tahoma", -55);
test_GetTextMetrics2("Tahoma", -110);
test_GetTextMetrics2("Arial", -11);
test_GetTextMetrics2("Arial", -55);
test_GetTextMetrics2("Arial", -110);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment