Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
75165d0d
Commit
75165d0d
authored
Jan 09, 2019
by
Paul Gofman
Committed by
Alexandre Julliard
Jan 09, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32/tests: Add test for 16 bit image stretch mode in CopyImage().
Signed-off-by:
Paul Gofman
<
gofmanp@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
5c844409
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
1 deletion
+23
-1
cursoricon.c
dlls/user32/tests/cursoricon.c
+23
-1
No files found.
dlls/user32/tests/cursoricon.c
View file @
75165d0d
...
@@ -2758,13 +2758,19 @@ static COLORREF get_color_from_bits(const unsigned char *bits, const BITMAPINFO
...
@@ -2758,13 +2758,19 @@ static COLORREF get_color_from_bits(const unsigned char *bits, const BITMAPINFO
unsigned
int
stride
,
shift
,
mask
;
unsigned
int
stride
,
shift
,
mask
;
const
unsigned
char
*
data
;
const
unsigned
char
*
data
;
RGBQUAD
color
;
RGBQUAD
color
;
WORD
color16
;
ok
(
h
->
biBitCount
<=
8
||
h
->
biBitCount
>=
24
,
"Unsupported bit count %u.
\n
"
,
h
->
biBitCount
);
stride
=
((
h
->
biBitCount
*
h
->
biWidth
+
7
)
/
8
+
3
)
&
~
3
;
stride
=
((
h
->
biBitCount
*
h
->
biWidth
+
7
)
/
8
+
3
)
&
~
3
;
data
=
bits
+
row
*
stride
+
column
*
h
->
biBitCount
/
8
;
data
=
bits
+
row
*
stride
+
column
*
h
->
biBitCount
/
8
;
if
(
h
->
biBitCount
>=
24
)
if
(
h
->
biBitCount
>=
24
)
return
RGB
(
data
[
2
],
data
[
1
],
data
[
0
]);
return
RGB
(
data
[
2
],
data
[
1
],
data
[
0
]);
if
(
h
->
biBitCount
==
16
)
{
color16
=
((
WORD
)
data
[
1
]
<<
8
)
|
data
[
0
];
return
RGB
(((
color16
>>
10
)
&
0x1f
)
<<
3
,
((
color16
>>
5
)
&
0x1f
)
<<
3
,
(
color16
&
0x1f
)
<<
3
);
}
shift
=
8
-
h
->
biBitCount
-
(
column
*
h
->
biBitCount
)
%
8
;
shift
=
8
-
h
->
biBitCount
-
(
column
*
h
->
biBitCount
)
%
8
;
mask
=
~
(
~
0u
<<
h
->
biBitCount
);
mask
=
~
(
~
0u
<<
h
->
biBitCount
);
color
=
bmi
->
bmiColors
[(
data
[
0
]
>>
shift
)
&
mask
];
color
=
bmi
->
bmiColors
[(
data
[
0
]
>>
shift
)
&
mask
];
...
@@ -2785,6 +2791,20 @@ static void test_CopyImage_StretchMode(void)
...
@@ -2785,6 +2791,20 @@ static void test_CopyImage_StretchMode(void)
0x3f
,
0xff
,
0x00
,
0x3f
,
0xff
,
0x3f
,
0x00
,
0x00
,
0x3f
,
0xff
,
0x00
,
0x3f
,
0xff
,
0x3f
,
0x00
,
0x00
,
0x3f
,
0xff
,
0x7f
,
0x00
,
0xff
,
0x3f
,
0x00
,
0x00
,
0x3f
,
0xff
,
0x7f
,
0x00
,
0xff
,
0x3f
,
0x00
,
0x00
,
};
};
#define rgb16(r, g, b) ((WORD)(((r >> 3) << 10) | ((g >> 3) << 5) | (b >> 3)))
static
const
WORD
test_bits_16
[]
=
{
rgb16
(
0x00
,
0x20
,
0x00
),
rgb16
(
0x00
,
0x40
,
0x00
),
rgb16
(
0x00
,
0x40
,
0xff
),
rgb16
(
0x00
,
0x20
,
0x00
),
rgb16
(
0x00
,
0x60
,
0x00
),
rgb16
(
0xff
,
0x80
,
0x00
),
rgb16
(
0xff
,
0x60
,
0x00
),
rgb16
(
0x00
,
0x80
,
0x00
),
rgb16
(
0x00
,
0x20
,
0xff
),
rgb16
(
0x00
,
0x40
,
0x00
),
rgb16
(
0x00
,
0x40
,
0xff
),
rgb16
(
0x00
,
0x20
,
0x00
),
rgb16
(
0xff
,
0x80
,
0x00
),
rgb16
(
0x00
,
0x60
,
0xff
),
rgb16
(
0x00
,
0x80
,
0x00
),
rgb16
(
0x00
,
0x60
,
0x00
),
};
static
const
WORD
expected_bits_16
[]
=
{
rgb16
(
0x00
,
0x40
,
0x00
),
rgb16
(
0x00
,
0x20
,
0x00
),
rgb16
(
0x00
,
0x40
,
0x00
),
rgb16
(
0x00
,
0x20
,
0x00
),
};
#undef rgb16
static
const
unsigned
char
test_bits_8
[]
=
static
const
unsigned
char
test_bits_8
[]
=
{
{
0x00
,
0xff
,
0x00
,
0xff
,
0x00
,
0xff
,
0x00
,
0xff
,
...
@@ -2836,6 +2856,8 @@ static void test_CopyImage_StretchMode(void)
...
@@ -2836,6 +2856,8 @@ static void test_CopyImage_StretchMode(void)
{
4
,
4
,
2
,
2
,
8
,
test_bits_8
,
expected_bits_8
,
{
4
,
4
,
2
,
2
,
8
,
test_bits_8
,
expected_bits_8
,
sizeof
(
test_bits_8
),
sizeof
(
expected_bits_8
),
colors_bits_8
,
sizeof
(
test_bits_8
),
sizeof
(
expected_bits_8
),
colors_bits_8
,
sizeof
(
colors_bits_8
),
TRUE
},
sizeof
(
colors_bits_8
),
TRUE
},
{
4
,
4
,
2
,
2
,
16
,
(
const
unsigned
char
*
)
test_bits_16
,
(
const
unsigned
char
*
)
expected_bits_16
,
sizeof
(
test_bits_16
),
sizeof
(
expected_bits_16
),
NULL
,
0
,
TRUE
},
};
};
HBITMAP
bitmap
,
bitmap_copy
;
HBITMAP
bitmap
,
bitmap_copy
;
...
...
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