Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
dddbd3cb
Commit
dddbd3cb
authored
Jun 21, 2007
by
Francois Gouget
Committed by
Alexandre Julliard
Jun 21, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gdi32/tests: Run the GetTextMetricsA() tests on Windows 9x too.
parent
a114483e
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
50 additions
and
50 deletions
+50
-50
font.c
dlls/gdi32/tests/font.c
+50
-50
No files found.
dlls/gdi32/tests/font.c
View file @
dddbd3cb
...
@@ -1552,63 +1552,71 @@ static void test_text_metrics(const LOGFONTA *lf)
...
@@ -1552,63 +1552,71 @@ static void test_text_metrics(const LOGFONTA *lf)
SetLastError
(
0xdeadbeef
);
SetLastError
(
0xdeadbeef
);
ret
=
GetTextMetricsA
(
hdc
,
&
tmA
);
ret
=
GetTextMetricsA
(
hdc
,
&
tmA
);
ok
(
ret
,
"GetTextMetricsA error %u
\n
"
,
GetLastError
());
ok
(
ret
,
"GetTextMetricsA error %u
\n
"
,
GetLastError
());
trace
(
"A: first %x, last %x, default %x, break %x
\n
"
,
trace
(
"A: first %x, last %x, default %x, break %x
\n
"
,
tmA
.
tmFirstChar
,
tmA
.
tmLastChar
,
tmA
.
tmDefaultChar
,
tmA
.
tmBreakChar
);
tmA
.
tmFirstChar
,
tmA
.
tmLastChar
,
tmA
.
tmDefaultChar
,
tmA
.
tmBreakChar
);
SetLastError
(
0xdeadbeef
);
#if 0 /* FIXME: This doesn't appear to be what Windows does */
ret
=
GetTextMetricsW
(
hdc
,
&
tmW
);
test_char = min(first_unicode_char - 1, 255);
ok
(
ret
,
"GetTextMetricsA error %u
\n
"
,
GetLastError
());
ok(tmA.tmFirstChar == test_char, "A: tmFirstChar for %s %02x != %02x\n",
font_name, tmA.tmFirstChar, test_char);
trace
(
"W: first %x, last %x, default %x, break %x
\n
"
,
#endif
tmW
.
tmFirstChar
,
tmW
.
tmLastChar
,
tmW
.
tmDefaultChar
,
tmW
.
tmBreakChar
);
if
(
lf
->
lfCharSet
==
SYMBOL_CHARSET
)
if
(
lf
->
lfCharSet
==
SYMBOL_CHARSET
)
{
{
test_char
=
min
(
last_unicode_char
-
0xf000
,
255
);
test_char
=
min
(
last_unicode_char
-
0xf000
,
255
);
ok
(
tmA
.
tmLastChar
==
test_char
,
"A: tmLastChar for %s %02x != %02x
\n
"
,
ok
(
tmA
.
tmLastChar
==
test_char
,
"A: tmLastChar for %s %02x != %02x
\n
"
,
font_name
,
tmA
.
tmLastChar
,
test_char
);
font_name
,
tmA
.
tmLastChar
,
test_char
);
/* It appears that for fonts with SYMBOL_CHARSET Windows always sets
* symbol range to 0 - f0ff
*/
ok
(
tmW
.
tmFirstChar
==
0
,
"W: tmFirstChar for %s %02x != 0
\n
"
,
font_name
,
tmW
.
tmFirstChar
);
/* FIXME: Windows returns f0ff here, while Wine f0xx */
ok
(
tmW
.
tmLastChar
>=
0xf000
,
"W: tmLastChar for %s %02x != 0xf0ff
\n
"
,
font_name
,
tmW
.
tmLastChar
);
ok
(
tmA
.
tmDefaultChar
==
0x1f
,
"A: tmDefaultChar for %s %02x != 0
\n
"
,
font_name
,
tmW
.
tmDefaultChar
);
ok
(
tmA
.
tmBreakChar
==
0x20
,
"A: tmBreakChar for %s %02x != 0xf0ff
\n
"
,
font_name
,
tmW
.
tmBreakChar
);
ok
(
tmW
.
tmDefaultChar
==
0x1f
,
"W: tmDefaultChar for %s %02x != 0
\n
"
,
font_name
,
tmW
.
tmDefaultChar
);
ok
(
tmW
.
tmBreakChar
==
0x20
,
"W: tmBreakChar for %s %02x != 0xf0ff
\n
"
,
font_name
,
tmW
.
tmBreakChar
);
}
}
else
else
{
{
test_char
=
min
(
tmW
.
tmLastC
har
,
255
);
test_char
=
min
(
last_unicode_c
har
,
255
);
ok
(
tmA
.
tmLastChar
==
test_char
,
"A: tmLastChar for %s %02x != %02x
\n
"
,
ok
(
tmA
.
tmLastChar
==
test_char
,
"A: tmLastChar for %s %02x != %02x
\n
"
,
font_name
,
tmA
.
tmLastChar
,
test_char
);
font_name
,
tmA
.
tmLastChar
,
test_char
);
ok
(
tmA
.
tmDefaultChar
==
0x1f
,
"A: tmDefaultChar for %s %02x != 0x1f
\n
"
,
font_name
,
tmA
.
tmDefaultChar
);
ok
(
tmA
.
tmBreakChar
==
0x20
,
"A: tmBreakChar for %s %02x != 0x20
\n
"
,
font_name
,
tmA
.
tmBreakChar
);
}
SetLastError
(
0xdeadbeef
);
ret
=
GetTextMetricsW
(
hdc
,
&
tmW
);
ok
(
ret
||
GetLastError
()
==
ERROR_CALL_NOT_IMPLEMENTED
,
"GetTextMetricsW error %u
\n
"
,
GetLastError
());
if
(
ret
)
{
trace
(
"W: first %x, last %x, default %x, break %x
\n
"
,
tmW
.
tmFirstChar
,
tmW
.
tmLastChar
,
tmW
.
tmDefaultChar
,
tmW
.
tmBreakChar
);
ok
(
tmW
.
tmFirstChar
==
first_unicode_char
,
"W: tmFirstChar for %s %02x != %02x
\n
"
,
if
(
lf
->
lfCharSet
==
SYMBOL_CHARSET
)
font_name
,
tmW
.
tmFirstChar
,
first_unicode_char
);
{
ok
(
tmW
.
tmLastChar
==
last_unicode_char
,
"W: tmLastChar for %s %02x != %02x
\n
"
,
/* It appears that for fonts with SYMBOL_CHARSET Windows always
font_name
,
tmW
.
tmLastChar
,
last_unicode_char
);
* sets symbol range to 0 - f0ff
*/
ok
(
tmW
.
tmFirstChar
==
0
,
"W: tmFirstChar for %s %02x != 0
\n
"
,
font_name
,
tmW
.
tmFirstChar
);
/* FIXME: Windows returns f0ff here, while Wine f0xx */
ok
(
tmW
.
tmLastChar
>=
0xf000
,
"W: tmLastChar for %s %02x < 0xf000
\n
"
,
font_name
,
tmW
.
tmLastChar
);
ok
(
tmW
.
tmDefaultChar
==
0x1f
,
"W: tmDefaultChar for %s %02x != 0x1f
\n
"
,
font_name
,
tmW
.
tmDefaultChar
);
ok
(
tmW
.
tmBreakChar
==
0x20
,
"W: tmBreakChar for %s %02x != 0x20
\n
"
,
font_name
,
tmW
.
tmBreakChar
);
}
else
{
ok
(
tmW
.
tmFirstChar
==
first_unicode_char
,
"W: tmFirstChar for %s %02x != %02x
\n
"
,
font_name
,
tmW
.
tmFirstChar
,
first_unicode_char
);
ok
(
tmW
.
tmLastChar
==
last_unicode_char
,
"W: tmLastChar for %s %02x != %02x
\n
"
,
font_name
,
tmW
.
tmLastChar
,
last_unicode_char
);
}
ret
=
GetDeviceCaps
(
hdc
,
LOGPIXELSX
);
ok
(
tmW
.
tmDigitizedAspectX
==
ret
,
"W: tmDigitizedAspectX %u != %u
\n
"
,
tmW
.
tmDigitizedAspectX
,
ret
);
ret
=
GetDeviceCaps
(
hdc
,
LOGPIXELSY
);
ok
(
tmW
.
tmDigitizedAspectX
==
ret
,
"W: tmDigitizedAspectY %u != %u
\n
"
,
tmW
.
tmDigitizedAspectX
,
ret
);
}
}
#if 0 /* FIXME: This doesn't appear to be what Windows does */
test_char = min(tmW.tmFirstChar - 1, 255);
ok(tmA.tmFirstChar == test_char, "A: tmFirstChar for %s %02x != %02x\n",
font_name, tmA.tmFirstChar, test_char);
#endif
ret
=
GetDeviceCaps
(
hdc
,
LOGPIXELSX
);
ok
(
tmW
.
tmDigitizedAspectX
==
ret
,
"tmDigitizedAspectX %u != %u
\n
"
,
tmW
.
tmDigitizedAspectX
,
ret
);
ret
=
GetDeviceCaps
(
hdc
,
LOGPIXELSY
);
ok
(
tmW
.
tmDigitizedAspectX
==
ret
,
"tmDigitizedAspectY %u != %u
\n
"
,
tmW
.
tmDigitizedAspectX
,
ret
);
end_of_test:
end_of_test:
SelectObject
(
hdc
,
hfont_old
);
SelectObject
(
hdc
,
hfont_old
);
...
@@ -1635,14 +1643,6 @@ static void test_GetTextMetrics(void)
...
@@ -1635,14 +1643,6 @@ static void test_GetTextMetrics(void)
HDC
hdc
;
HDC
hdc
;
INT
enumed
;
INT
enumed
;
SetLastError
(
0xdeadbeef
);
GetTextMetricsW
(
0
,
NULL
);
if
(
GetLastError
()
==
ERROR_CALL_NOT_IMPLEMENTED
)
{
skip
(
"Skipping GetTextMetrics test on a Win9x platform
\n
"
);
return
;
}
hdc
=
GetDC
(
0
);
hdc
=
GetDC
(
0
);
memset
(
&
lf
,
0
,
sizeof
(
lf
));
memset
(
&
lf
,
0
,
sizeof
(
lf
));
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment