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
9727750c
Commit
9727750c
authored
Dec 13, 2009
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Move Get/SetWindowLong16 implementation to wnd16.c.
parent
2f0bfbac
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
79 additions
and
82 deletions
+79
-82
win.c
dlls/user32/win.c
+0
-82
wnd16.c
dlls/user32/wnd16.c
+79
-0
No files found.
dlls/user32/win.c
View file @
9727750c
...
@@ -2307,55 +2307,6 @@ LONG_PTR WIN_SetWindowLong( HWND hwnd, INT offset, UINT size, LONG_PTR newval, B
...
@@ -2307,55 +2307,6 @@ LONG_PTR WIN_SetWindowLong( HWND hwnd, INT offset, UINT size, LONG_PTR newval, B
/**********************************************************************
/**********************************************************************
* GetWindowLong (USER.135)
*/
LONG
WINAPI
GetWindowLong16
(
HWND16
hwnd
,
INT16
offset
)
{
WND
*
wndPtr
;
LONG_PTR
retvalue
;
BOOL
is_winproc
=
(
offset
==
GWLP_WNDPROC
);
if
(
offset
>=
0
)
{
if
(
!
(
wndPtr
=
WIN_GetPtr
(
WIN_Handle32
(
hwnd
)
)))
{
SetLastError
(
ERROR_INVALID_WINDOW_HANDLE
);
return
0
;
}
if
(
wndPtr
!=
WND_OTHER_PROCESS
&&
wndPtr
!=
WND_DESKTOP
)
{
if
(
offset
>
(
int
)(
wndPtr
->
cbWndExtra
-
sizeof
(
LONG
)))
{
/*
* Some programs try to access last element from 16 bit
* code using illegal offset value. Hopefully this is
* what those programs really expect.
*/
if
(
wndPtr
->
cbWndExtra
>=
4
&&
offset
==
wndPtr
->
cbWndExtra
-
sizeof
(
WORD
))
{
INT
offset2
=
wndPtr
->
cbWndExtra
-
sizeof
(
LONG
);
ERR
(
"- replaced invalid offset %d with %d
\n
"
,
offset
,
offset2
);
offset
=
offset2
;
}
else
{
WARN
(
"Invalid offset %d
\n
"
,
offset
);
WIN_ReleasePtr
(
wndPtr
);
SetLastError
(
ERROR_INVALID_INDEX
);
return
0
;
}
}
is_winproc
=
((
offset
==
DWLP_DLGPROC
)
&&
(
wndPtr
->
flags
&
WIN_ISDIALOG
));
WIN_ReleasePtr
(
wndPtr
);
}
}
retvalue
=
GetWindowLongA
(
WIN_Handle32
(
hwnd
),
offset
);
if
(
is_winproc
)
retvalue
=
(
LONG_PTR
)
WINPROC_GetProc16
(
(
WNDPROC
)
retvalue
,
FALSE
);
return
retvalue
;
}
/**********************************************************************
* GetWindowWord (USER32.@)
* GetWindowWord (USER32.@)
*/
*/
WORD
WINAPI
GetWindowWord
(
HWND
hwnd
,
INT
offset
)
WORD
WINAPI
GetWindowWord
(
HWND
hwnd
,
INT
offset
)
...
@@ -2398,39 +2349,6 @@ LONG WINAPI GetWindowLongW( HWND hwnd, INT offset )
...
@@ -2398,39 +2349,6 @@ LONG WINAPI GetWindowLongW( HWND hwnd, INT offset )
/**********************************************************************
/**********************************************************************
* SetWindowLong (USER.136)
*/
LONG
WINAPI
SetWindowLong16
(
HWND16
hwnd
,
INT16
offset
,
LONG
newval
)
{
WND
*
wndPtr
;
BOOL
is_winproc
=
(
offset
==
GWLP_WNDPROC
);
if
(
offset
==
DWLP_DLGPROC
)
{
if
(
!
(
wndPtr
=
WIN_GetPtr
(
WIN_Handle32
(
hwnd
)
)))
{
SetLastError
(
ERROR_INVALID_WINDOW_HANDLE
);
return
0
;
}
if
(
wndPtr
!=
WND_OTHER_PROCESS
&&
wndPtr
!=
WND_DESKTOP
)
{
is_winproc
=
((
wndPtr
->
cbWndExtra
-
sizeof
(
LONG_PTR
)
>=
DWLP_DLGPROC
)
&&
(
wndPtr
->
flags
&
WIN_ISDIALOG
));
WIN_ReleasePtr
(
wndPtr
);
}
}
if
(
is_winproc
)
{
WNDPROC
new_proc
=
WINPROC_AllocProc16
(
(
WNDPROC16
)
newval
);
WNDPROC
old_proc
=
(
WNDPROC
)
SetWindowLongPtrA
(
WIN_Handle32
(
hwnd
),
offset
,
(
LONG_PTR
)
new_proc
);
return
(
LONG
)
WINPROC_GetProc16
(
old_proc
,
FALSE
);
}
else
return
SetWindowLongA
(
WIN_Handle32
(
hwnd
),
offset
,
newval
);
}
/**********************************************************************
* SetWindowWord (USER32.@)
* SetWindowWord (USER32.@)
*/
*/
WORD
WINAPI
SetWindowWord
(
HWND
hwnd
,
INT
offset
,
WORD
newval
)
WORD
WINAPI
SetWindowWord
(
HWND
hwnd
,
INT
offset
,
WORD
newval
)
...
...
dlls/user32/wnd16.c
View file @
9727750c
...
@@ -719,6 +719,85 @@ WORD WINAPI SetWindowWord16( HWND16 hwnd, INT16 offset, WORD newval )
...
@@ -719,6 +719,85 @@ WORD WINAPI SetWindowWord16( HWND16 hwnd, INT16 offset, WORD newval )
}
}
/**********************************************************************
* GetWindowLong (USER.135)
*/
LONG
WINAPI
GetWindowLong16
(
HWND16
hwnd
,
INT16
offset
)
{
WND
*
wndPtr
;
LONG_PTR
retvalue
;
BOOL
is_winproc
=
(
offset
==
GWLP_WNDPROC
);
if
(
offset
>=
0
)
{
if
(
!
(
wndPtr
=
WIN_GetPtr
(
WIN_Handle32
(
hwnd
)
)))
{
SetLastError
(
ERROR_INVALID_WINDOW_HANDLE
);
return
0
;
}
if
(
wndPtr
!=
WND_OTHER_PROCESS
&&
wndPtr
!=
WND_DESKTOP
)
{
if
(
offset
>
(
int
)(
wndPtr
->
cbWndExtra
-
sizeof
(
LONG
)))
{
/*
* Some programs try to access last element from 16 bit
* code using illegal offset value. Hopefully this is
* what those programs really expect.
*/
if
(
wndPtr
->
cbWndExtra
>=
4
&&
offset
==
wndPtr
->
cbWndExtra
-
sizeof
(
WORD
))
{
offset
=
wndPtr
->
cbWndExtra
-
sizeof
(
LONG
);
}
else
{
WIN_ReleasePtr
(
wndPtr
);
SetLastError
(
ERROR_INVALID_INDEX
);
return
0
;
}
}
is_winproc
=
((
offset
==
DWLP_DLGPROC
)
&&
(
wndPtr
->
flags
&
WIN_ISDIALOG
));
WIN_ReleasePtr
(
wndPtr
);
}
}
retvalue
=
GetWindowLongA
(
WIN_Handle32
(
hwnd
),
offset
);
if
(
is_winproc
)
retvalue
=
(
LONG_PTR
)
WINPROC_GetProc16
(
(
WNDPROC
)
retvalue
,
FALSE
);
return
retvalue
;
}
/**********************************************************************
* SetWindowLong (USER.136)
*/
LONG
WINAPI
SetWindowLong16
(
HWND16
hwnd
,
INT16
offset
,
LONG
newval
)
{
WND
*
wndPtr
;
BOOL
is_winproc
=
(
offset
==
GWLP_WNDPROC
);
if
(
offset
==
DWLP_DLGPROC
)
{
if
(
!
(
wndPtr
=
WIN_GetPtr
(
WIN_Handle32
(
hwnd
)
)))
{
SetLastError
(
ERROR_INVALID_WINDOW_HANDLE
);
return
0
;
}
if
(
wndPtr
!=
WND_OTHER_PROCESS
&&
wndPtr
!=
WND_DESKTOP
)
{
is_winproc
=
((
wndPtr
->
cbWndExtra
-
sizeof
(
LONG_PTR
)
>=
DWLP_DLGPROC
)
&&
(
wndPtr
->
flags
&
WIN_ISDIALOG
));
WIN_ReleasePtr
(
wndPtr
);
}
}
if
(
is_winproc
)
{
WNDPROC
new_proc
=
WINPROC_AllocProc16
(
(
WNDPROC16
)
newval
);
WNDPROC
old_proc
=
(
WNDPROC
)
SetWindowLongPtrA
(
WIN_Handle32
(
hwnd
),
offset
,
(
LONG_PTR
)
new_proc
);
return
(
LONG
)
WINPROC_GetProc16
(
old_proc
,
FALSE
);
}
else
return
SetWindowLongA
(
WIN_Handle32
(
hwnd
),
offset
,
newval
);
}
/**************************************************************************
/**************************************************************************
* OpenClipboard (USER.137)
* OpenClipboard (USER.137)
*/
*/
...
...
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