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
30ff940a
Commit
30ff940a
authored
Jul 12, 2005
by
Robert Shearman
Committed by
Alexandre Julliard
Jul 12, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Call SetLastError on errors.
parent
ff93df6e
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
7 deletions
+44
-7
listbox.c
dlls/user/listbox.c
+44
-7
No files found.
dlls/user/listbox.c
View file @
30ff940a
...
@@ -431,7 +431,12 @@ static void LISTBOX_UpdateSize( LB_DESCR *descr )
...
@@ -431,7 +431,12 @@ static void LISTBOX_UpdateSize( LB_DESCR *descr )
static
LRESULT
LISTBOX_GetItemRect
(
LB_DESCR
*
descr
,
INT
index
,
RECT
*
rect
)
static
LRESULT
LISTBOX_GetItemRect
(
LB_DESCR
*
descr
,
INT
index
,
RECT
*
rect
)
{
{
/* Index <= 0 is legal even on empty listboxes */
/* Index <= 0 is legal even on empty listboxes */
if
(
index
&&
(
index
>=
descr
->
nb_items
))
return
-
1
;
if
(
index
&&
(
index
>=
descr
->
nb_items
))
{
memset
(
rect
,
0
,
sizeof
(
*
rect
));
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
}
SetRect
(
rect
,
0
,
0
,
descr
->
width
,
descr
->
height
);
SetRect
(
rect
,
0
,
0
,
descr
->
width
,
descr
->
height
);
if
(
descr
->
style
&
LBS_MULTICOLUMN
)
if
(
descr
->
style
&
LBS_MULTICOLUMN
)
{
{
...
@@ -762,7 +767,11 @@ static BOOL LISTBOX_SetTabStops( LB_DESCR *descr, INT count, LPINT tabs, BOOL sh
...
@@ -762,7 +767,11 @@ static BOOL LISTBOX_SetTabStops( LB_DESCR *descr, INT count, LPINT tabs, BOOL sh
*/
*/
static
LRESULT
LISTBOX_GetText
(
LB_DESCR
*
descr
,
INT
index
,
LPWSTR
buffer
,
BOOL
unicode
)
static
LRESULT
LISTBOX_GetText
(
LB_DESCR
*
descr
,
INT
index
,
LPWSTR
buffer
,
BOOL
unicode
)
{
{
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
return
LB_ERR
;
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
}
if
(
HAS_STRINGS
(
descr
))
if
(
HAS_STRINGS
(
descr
))
{
{
if
(
!
buffer
)
if
(
!
buffer
)
...
@@ -1163,7 +1172,11 @@ static LRESULT LISTBOX_GetItemHeight( LB_DESCR *descr, INT index )
...
@@ -1163,7 +1172,11 @@ static LRESULT LISTBOX_GetItemHeight( LB_DESCR *descr, INT index )
{
{
if
(
descr
->
style
&
LBS_OWNERDRAWVARIABLE
)
if
(
descr
->
style
&
LBS_OWNERDRAWVARIABLE
)
{
{
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
return
LB_ERR
;
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
}
return
descr
->
items
[
index
].
height
;
return
descr
->
items
[
index
].
height
;
}
}
else
return
descr
->
item_height
;
else
return
descr
->
item_height
;
...
@@ -1179,7 +1192,11 @@ static LRESULT LISTBOX_SetItemHeight( LB_DESCR *descr, INT index, INT height, BO
...
@@ -1179,7 +1192,11 @@ static LRESULT LISTBOX_SetItemHeight( LB_DESCR *descr, INT index, INT height, BO
if
(
descr
->
style
&
LBS_OWNERDRAWVARIABLE
)
if
(
descr
->
style
&
LBS_OWNERDRAWVARIABLE
)
{
{
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
return
LB_ERR
;
if
((
index
<
0
)
||
(
index
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
}
TRACE
(
"[%p]: item %d height = %d
\n
"
,
descr
->
self
,
index
,
height
);
TRACE
(
"[%p]: item %d height = %d
\n
"
,
descr
->
self
,
index
,
height
);
descr
->
items
[
index
].
height
=
height
;
descr
->
items
[
index
].
height
=
height
;
LISTBOX_UpdateScroll
(
descr
);
LISTBOX_UpdateScroll
(
descr
);
...
@@ -1728,7 +1745,12 @@ static LRESULT LISTBOX_SetCount( LB_DESCR *descr, INT count )
...
@@ -1728,7 +1745,12 @@ static LRESULT LISTBOX_SetCount( LB_DESCR *descr, INT count )
{
{
LRESULT
ret
;
LRESULT
ret
;
if
(
HAS_STRINGS
(
descr
))
return
LB_ERR
;
if
(
HAS_STRINGS
(
descr
))
{
SetLastError
(
ERROR_SETCOUNT_ON_BAD_LB
);
return
LB_ERR
;
}
/* FIXME: this is far from optimal... */
/* FIXME: this is far from optimal... */
if
(
count
>
descr
->
nb_items
)
if
(
count
>
descr
->
nb_items
)
{
{
...
@@ -2628,20 +2650,29 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
...
@@ -2628,20 +2650,29 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
case
LB_DELETESTRING16
:
case
LB_DELETESTRING16
:
case
LB_DELETESTRING
:
case
LB_DELETESTRING
:
if
(
LISTBOX_RemoveItem
(
descr
,
wParam
)
!=
LB_ERR
)
if
(
LISTBOX_RemoveItem
(
descr
,
wParam
)
!=
LB_ERR
)
return
descr
->
nb_items
;
return
descr
->
nb_items
;
else
else
return
LB_ERR
;
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
}
case
LB_GETITEMDATA16
:
case
LB_GETITEMDATA16
:
case
LB_GETITEMDATA
:
case
LB_GETITEMDATA
:
if
(((
INT
)
wParam
<
0
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
if
(((
INT
)
wParam
<
0
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
return
LB_ERR
;
}
return
descr
->
items
[
wParam
].
data
;
return
descr
->
items
[
wParam
].
data
;
case
LB_SETITEMDATA16
:
case
LB_SETITEMDATA16
:
case
LB_SETITEMDATA
:
case
LB_SETITEMDATA
:
if
(((
INT
)
wParam
<
0
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
if
(((
INT
)
wParam
<
0
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
return
LB_ERR
;
}
descr
->
items
[
wParam
].
data
=
(
DWORD
)
lParam
;
descr
->
items
[
wParam
].
data
=
(
DWORD
)
lParam
;
return
LB_OKAY
;
return
LB_OKAY
;
...
@@ -2659,7 +2690,10 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
...
@@ -2659,7 +2690,10 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
/* fall through */
/* fall through */
case
LB_GETTEXTLEN
:
case
LB_GETTEXTLEN
:
if
((
INT
)
wParam
>=
descr
->
nb_items
||
(
INT
)
wParam
<
0
)
if
((
INT
)
wParam
>=
descr
->
nb_items
||
(
INT
)
wParam
<
0
)
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
return
LB_ERR
;
}
if
(
!
HAS_STRINGS
(
descr
))
return
sizeof
(
DWORD
);
if
(
!
HAS_STRINGS
(
descr
))
return
sizeof
(
DWORD
);
if
(
unicode
)
return
strlenW
(
descr
->
items
[
wParam
].
str
);
if
(
unicode
)
return
strlenW
(
descr
->
items
[
wParam
].
str
);
return
WideCharToMultiByte
(
CP_ACP
,
0
,
descr
->
items
[
wParam
].
str
,
return
WideCharToMultiByte
(
CP_ACP
,
0
,
descr
->
items
[
wParam
].
str
,
...
@@ -2888,7 +2922,10 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
...
@@ -2888,7 +2922,10 @@ static LRESULT WINAPI ListBoxWndProc_common( HWND hwnd, UINT msg,
/* fall through */
/* fall through */
case
LB_SETANCHORINDEX
:
case
LB_SETANCHORINDEX
:
if
(((
INT
)
wParam
<
-
1
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
if
(((
INT
)
wParam
<
-
1
)
||
((
INT
)
wParam
>=
descr
->
nb_items
))
{
SetLastError
(
ERROR_INVALID_INDEX
);
return
LB_ERR
;
return
LB_ERR
;
}
descr
->
anchor_item
=
(
INT
)
wParam
;
descr
->
anchor_item
=
(
INT
)
wParam
;
return
LB_OKAY
;
return
LB_OKAY
;
...
...
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