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
2f02bbb4
Commit
2f02bbb4
authored
Jun 05, 2011
by
Ričardas Barkauskas
Committed by
Alexandre Julliard
Jun 06, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ddraw: Change lpVtbl to IDirectDrawSurface7_iface.
parent
4074dd76
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
58 additions
and
48 deletions
+58
-48
ddraw.c
dlls/ddraw/ddraw.c
+22
-14
ddraw_private.h
dlls/ddraw/ddraw_private.h
+2
-2
device.c
dlls/ddraw/device.c
+34
-32
surface.c
dlls/ddraw/surface.c
+0
-0
No files found.
dlls/ddraw/ddraw.c
View file @
2f02bbb4
...
@@ -3407,7 +3407,7 @@ static HRESULT CreateSurface(IDirectDrawImpl *ddraw, DDSURFACEDESC2 *DDSD,
...
@@ -3407,7 +3407,7 @@ static HRESULT CreateSurface(IDirectDrawImpl *ddraw, DDSURFACEDESC2 *DDSD,
if
(
hr
!=
DD_OK
)
if
(
hr
!=
DD_OK
)
{
{
/* This destroys and possibly created surfaces too */
/* This destroys and possibly created surfaces too */
IDirectDrawSurface
_Release
((
IDirectDrawSurface7
*
)
object
);
IDirectDrawSurface
7_Release
(
&
object
->
IDirectDrawSurface7_iface
);
LeaveCriticalSection
(
&
ddraw_cs
);
LeaveCriticalSection
(
&
ddraw_cs
);
return
hr
;
return
hr
;
}
}
...
@@ -3521,7 +3521,7 @@ static HRESULT WINAPI ddraw7_CreateSurface(IDirectDraw7 *iface, DDSURFACEDESC2 *
...
@@ -3521,7 +3521,7 @@ static HRESULT WINAPI ddraw7_CreateSurface(IDirectDraw7 *iface, DDSURFACEDESC2 *
return
hr
;
return
hr
;
}
}
*
surface
=
(
IDirectDrawSurface7
*
)
impl
;
*
surface
=
&
impl
->
IDirectDrawSurface7_iface
;
return
hr
;
return
hr
;
}
}
...
@@ -3874,8 +3874,8 @@ static HRESULT WINAPI ddraw7_EnumSurfaces(IDirectDraw7 *iface, DWORD Flags,
...
@@ -3874,8 +3874,8 @@ static HRESULT WINAPI ddraw7_EnumSurfaces(IDirectDraw7 *iface, DWORD Flags,
if
(
all
||
(
nomatch
!=
ddraw_match_surface_desc
(
DDSD
,
&
surf
->
surface_desc
)))
if
(
all
||
(
nomatch
!=
ddraw_match_surface_desc
(
DDSD
,
&
surf
->
surface_desc
)))
{
{
desc
=
surf
->
surface_desc
;
desc
=
surf
->
surface_desc
;
IDirectDrawSurface7_AddRef
(
(
IDirectDrawSurface7
*
)
surf
);
IDirectDrawSurface7_AddRef
(
&
surf
->
IDirectDrawSurface7_iface
);
if
(
Callback
(
(
IDirectDrawSurface7
*
)
surf
,
&
desc
,
Context
)
!=
DDENUMRET_OK
)
if
(
Callback
(
&
surf
->
IDirectDrawSurface7_iface
,
&
desc
,
Context
)
!=
DDENUMRET_OK
)
{
{
LeaveCriticalSection
(
&
ddraw_cs
);
LeaveCriticalSection
(
&
ddraw_cs
);
return
DD_OK
;
return
DD_OK
;
...
@@ -4250,7 +4250,7 @@ static HRESULT WINAPI ddraw4_DuplicateSurface(IDirectDraw4 *iface, IDirectDrawSu
...
@@ -4250,7 +4250,7 @@ static HRESULT WINAPI ddraw4_DuplicateSurface(IDirectDraw4 *iface, IDirectDrawSu
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
(
IDirectDrawSurface7
*
)
src_impl
,
&
dst7
);
src_impl
?
&
src_impl
->
IDirectDrawSurface7_iface
:
NULL
,
&
dst7
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
{
{
*
dst
=
NULL
;
*
dst
=
NULL
;
...
@@ -4272,11 +4272,13 @@ static HRESULT WINAPI ddraw3_DuplicateSurface(IDirectDraw3 *iface, IDirectDrawSu
...
@@ -4272,11 +4272,13 @@ static HRESULT WINAPI ddraw3_DuplicateSurface(IDirectDraw3 *iface, IDirectDrawSu
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
(
IDirectDrawSurface7
*
)
src_impl
,
&
dst7
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
src_impl
?
&
src_impl
->
IDirectDrawSurface7_iface
:
NULL
,
&
dst7
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
return
hr
;
return
hr
;
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
return
hr
;
return
hr
;
}
}
...
@@ -4290,11 +4292,13 @@ static HRESULT WINAPI ddraw2_DuplicateSurface(IDirectDraw2 *iface,
...
@@ -4290,11 +4292,13 @@ static HRESULT WINAPI ddraw2_DuplicateSurface(IDirectDraw2 *iface,
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
(
IDirectDrawSurface7
*
)
src_impl
,
&
dst7
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
src_impl
?
&
src_impl
->
IDirectDrawSurface7_iface
:
NULL
,
&
dst7
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
return
hr
;
return
hr
;
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
return
hr
;
return
hr
;
}
}
...
@@ -4308,11 +4312,13 @@ static HRESULT WINAPI ddraw1_DuplicateSurface(IDirectDraw *iface, IDirectDrawSur
...
@@ -4308,11 +4312,13 @@ static HRESULT WINAPI ddraw1_DuplicateSurface(IDirectDraw *iface, IDirectDrawSur
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
TRACE
(
"iface %p, src %p, dst %p.
\n
"
,
iface
,
src
,
dst
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
(
IDirectDrawSurface7
*
)
src_impl
,
&
dst7
);
hr
=
ddraw7_DuplicateSurface
(
&
This
->
IDirectDraw7_iface
,
src_impl
?
&
src_impl
->
IDirectDrawSurface7_iface
:
NULL
,
&
dst7
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
return
hr
;
return
hr
;
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
dst_impl
=
impl_from_IDirectDrawSurface7
(
dst7
);
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
*
dst
=
(
IDirectDrawSurface
*
)
&
dst_impl
->
IDirectDrawSurface3_iface
;
return
hr
;
return
hr
;
}
}
...
@@ -4873,6 +4879,7 @@ static HRESULT WINAPI d3d3_CreateDevice(IDirect3D3 *iface, REFCLSID riid,
...
@@ -4873,6 +4879,7 @@ static HRESULT WINAPI d3d3_CreateDevice(IDirect3D3 *iface, REFCLSID riid,
IDirectDrawSurface4
*
surface
,
IDirect3DDevice3
**
device
,
IUnknown
*
outer_unknown
)
IDirectDrawSurface4
*
surface
,
IDirect3DDevice3
**
device
,
IUnknown
*
outer_unknown
)
{
{
IDirectDrawImpl
*
This
=
impl_from_IDirect3D3
(
iface
);
IDirectDrawImpl
*
This
=
impl_from_IDirect3D3
(
iface
);
IDirectDrawSurfaceImpl
*
surface_impl
=
(
IDirectDrawSurfaceImpl
*
)
surface
;
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"iface %p, riid %s, surface %p, device %p, outer_unknown %p.
\n
"
,
TRACE
(
"iface %p, riid %s, surface %p, device %p, outer_unknown %p.
\n
"
,
...
@@ -4880,7 +4887,8 @@ static HRESULT WINAPI d3d3_CreateDevice(IDirect3D3 *iface, REFCLSID riid,
...
@@ -4880,7 +4887,8 @@ static HRESULT WINAPI d3d3_CreateDevice(IDirect3D3 *iface, REFCLSID riid,
if
(
outer_unknown
)
return
CLASS_E_NOAGGREGATION
;
if
(
outer_unknown
)
return
CLASS_E_NOAGGREGATION
;
hr
=
d3d7_CreateDevice
(
&
This
->
IDirect3D7_iface
,
riid
,
(
IDirectDrawSurface7
*
)
surface
,
hr
=
d3d7_CreateDevice
(
&
This
->
IDirect3D7_iface
,
riid
,
surface_impl
?
&
surface_impl
->
IDirectDrawSurface7_iface
:
NULL
,
(
IDirect3DDevice7
**
)
device
);
(
IDirect3DDevice7
**
)
device
);
if
(
*
device
)
*
device
=
(
IDirect3DDevice3
*
)
&
((
IDirect3DDeviceImpl
*
)
*
device
)
->
IDirect3DDevice3_vtbl
;
if
(
*
device
)
*
device
=
(
IDirect3DDevice3
*
)
&
((
IDirect3DDeviceImpl
*
)
*
device
)
->
IDirect3DDevice3_vtbl
;
...
@@ -4898,7 +4906,7 @@ static HRESULT WINAPI d3d2_CreateDevice(IDirect3D2 *iface, REFCLSID riid,
...
@@ -4898,7 +4906,7 @@ static HRESULT WINAPI d3d2_CreateDevice(IDirect3D2 *iface, REFCLSID riid,
iface
,
debugstr_guid
(
riid
),
surface
,
device
);
iface
,
debugstr_guid
(
riid
),
surface
,
device
);
hr
=
d3d7_CreateDevice
(
&
This
->
IDirect3D7_iface
,
riid
,
hr
=
d3d7_CreateDevice
(
&
This
->
IDirect3D7_iface
,
riid
,
surface_impl
?
(
IDirectDrawSurface7
*
)
surface_impl
:
NULL
,
surface_impl
?
&
surface_impl
->
IDirectDrawSurface7_iface
:
NULL
,
(
IDirect3DDevice7
**
)
device
);
(
IDirect3DDevice7
**
)
device
);
if
(
*
device
)
*
device
=
(
IDirect3DDevice2
*
)
&
((
IDirect3DDeviceImpl
*
)
*
device
)
->
IDirect3DDevice2_vtbl
;
if
(
*
device
)
*
device
=
(
IDirect3DDevice2
*
)
&
((
IDirect3DDeviceImpl
*
)
*
device
)
->
IDirect3DDevice2_vtbl
;
...
@@ -5796,7 +5804,7 @@ static HRESULT CDECL device_parent_create_surface(struct wined3d_device_parent *
...
@@ -5796,7 +5804,7 @@ static HRESULT CDECL device_parent_create_surface(struct wined3d_device_parent *
if
(
!
surf
)
if
(
!
surf
)
{
{
IDirectDrawSurface7
*
attached
;
IDirectDrawSurface7
*
attached
;
IDirectDrawSurface7_GetAttachedSurface
(
(
IDirectDrawSurface7
*
)
ddraw
->
tex_root
,
&
searchcaps
,
&
attached
);
IDirectDrawSurface7_GetAttachedSurface
(
&
ddraw
->
tex_root
->
IDirectDrawSurface7_iface
,
&
searchcaps
,
&
attached
);
surf
=
unsafe_impl_from_IDirectDrawSurface7
(
attached
);
surf
=
unsafe_impl_from_IDirectDrawSurface7
(
attached
);
IDirectDrawSurface7_Release
(
attached
);
IDirectDrawSurface7_Release
(
attached
);
}
}
...
@@ -5806,7 +5814,7 @@ static HRESULT CDECL device_parent_create_surface(struct wined3d_device_parent *
...
@@ -5806,7 +5814,7 @@ static HRESULT CDECL device_parent_create_surface(struct wined3d_device_parent *
while
(
i
<
level
)
while
(
i
<
level
)
{
{
IDirectDrawSurface7
*
attached
;
IDirectDrawSurface7
*
attached
;
IDirectDrawSurface7_GetAttachedSurface
(
(
IDirectDrawSurface7
*
)
surf
,
&
searchcaps
,
&
attached
);
IDirectDrawSurface7_GetAttachedSurface
(
&
surf
->
IDirectDrawSurface7_iface
,
&
searchcaps
,
&
attached
);
if
(
!
attached
)
ERR
(
"Surface not found
\n
"
);
if
(
!
attached
)
ERR
(
"Surface not found
\n
"
);
surf
=
impl_from_IDirectDrawSurface7
(
attached
);
surf
=
impl_from_IDirectDrawSurface7
(
attached
);
IDirectDrawSurface7_Release
(
attached
);
IDirectDrawSurface7_Release
(
attached
);
...
@@ -5859,7 +5867,7 @@ static HRESULT CDECL device_parent_create_rendertarget(struct wined3d_device_par
...
@@ -5859,7 +5867,7 @@ static HRESULT CDECL device_parent_create_rendertarget(struct wined3d_device_par
if
(
d3d_surface
->
isRenderTarget
)
if
(
d3d_surface
->
isRenderTarget
)
{
{
IDirectDrawSurface7_EnumAttachedSurfaces
(
(
IDirectDrawSurface7
*
)
d3d_sur
face
,
&
target
,
findRenderTarget
);
IDirectDrawSurface7_EnumAttachedSurfaces
(
&
d3d_surface
->
IDirectDrawSurface7_i
face
,
&
target
,
findRenderTarget
);
}
}
else
else
{
{
...
@@ -5928,7 +5936,7 @@ static HRESULT CDECL device_parent_create_depth_stencil(struct wined3d_device_pa
...
@@ -5928,7 +5936,7 @@ static HRESULT CDECL device_parent_create_depth_stencil(struct wined3d_device_pa
ddraw_surface
=
impl_from_IDirectDrawSurface7
(
ddraw7
);
ddraw_surface
=
impl_from_IDirectDrawSurface7
(
ddraw7
);
*
surface
=
ddraw_surface
->
wined3d_surface
;
*
surface
=
ddraw_surface
->
wined3d_surface
;
wined3d_surface_incref
(
*
surface
);
wined3d_surface_incref
(
*
surface
);
IDirectDrawSurface7_Release
(
(
IDirectDrawSurface7
*
)
ddraw_sur
face
);
IDirectDrawSurface7_Release
(
&
ddraw_surface
->
IDirectDrawSurface7_i
face
);
return
D3D_OK
;
return
D3D_OK
;
}
}
...
...
dlls/ddraw/ddraw_private.h
View file @
2f02bbb4
...
@@ -152,7 +152,7 @@ extern WINED3DSURFTYPE DefaultSurfaceType DECLSPEC_HIDDEN;
...
@@ -152,7 +152,7 @@ extern WINED3DSURFTYPE DefaultSurfaceType DECLSPEC_HIDDEN;
struct
IDirectDrawSurfaceImpl
struct
IDirectDrawSurfaceImpl
{
{
/* IUnknown fields */
/* IUnknown fields */
const
IDirectDrawSurface7Vtbl
*
lpVtbl
;
IDirectDrawSurface7
IDirectDrawSurface7_iface
;
IDirectDrawSurface3
IDirectDrawSurface3_iface
;
IDirectDrawSurface3
IDirectDrawSurface3_iface
;
const
IDirectDrawGammaControlVtbl
*
IDirectDrawGammaControl_vtbl
;
const
IDirectDrawGammaControlVtbl
*
IDirectDrawGammaControl_vtbl
;
const
IDirect3DTexture2Vtbl
*
IDirect3DTexture2_vtbl
;
const
IDirect3DTexture2Vtbl
*
IDirect3DTexture2_vtbl
;
...
@@ -227,7 +227,7 @@ static inline IDirectDrawSurfaceImpl *impl_from_IDirectDrawSurface3(IDirectDrawS
...
@@ -227,7 +227,7 @@ static inline IDirectDrawSurfaceImpl *impl_from_IDirectDrawSurface3(IDirectDrawS
static
inline
IDirectDrawSurfaceImpl
*
impl_from_IDirectDrawSurface7
(
IDirectDrawSurface7
*
iface
)
static
inline
IDirectDrawSurfaceImpl
*
impl_from_IDirectDrawSurface7
(
IDirectDrawSurface7
*
iface
)
{
{
return
CONTAINING_RECORD
(
iface
,
IDirectDrawSurfaceImpl
,
lpVtbl
);
return
CONTAINING_RECORD
(
iface
,
IDirectDrawSurfaceImpl
,
IDirectDrawSurface7_iface
);
}
}
IDirectDrawSurfaceImpl
*
unsafe_impl_from_IDirectDrawSurface3
(
IDirectDrawSurface3
*
iface
)
DECLSPEC_HIDDEN
;
IDirectDrawSurfaceImpl
*
unsafe_impl_from_IDirectDrawSurface3
(
IDirectDrawSurface3
*
iface
)
DECLSPEC_HIDDEN
;
...
...
dlls/ddraw/device.c
View file @
2f02bbb4
This diff is collapsed.
Click to expand it.
dlls/ddraw/surface.c
View file @
2f02bbb4
This diff is collapsed.
Click to expand it.
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