ddraw: Use unsafe_impl_from_IDirectDrawPalette for application provided interfaces.
diff --git a/dlls/ddraw/ddraw_private.h b/dlls/ddraw/ddraw_private.h
index 0572172..7898d28 100644
--- a/dlls/ddraw/ddraw_private.h
+++ b/dlls/ddraw/ddraw_private.h
@@ -369,6 +369,8 @@
IUnknown *ifaceToRelease;
};
+IDirectDrawPaletteImpl *unsafe_impl_from_IDirectDrawPalette(IDirectDrawPalette *iface) DECLSPEC_HIDDEN;
+
HRESULT ddraw_palette_init(IDirectDrawPaletteImpl *palette,
IDirectDrawImpl *ddraw, DWORD flags, PALETTEENTRY *entries) DECLSPEC_HIDDEN;
diff --git a/dlls/ddraw/palette.c b/dlls/ddraw/palette.c
index b68cf82..ff78411 100644
--- a/dlls/ddraw/palette.c
+++ b/dlls/ddraw/palette.c
@@ -258,6 +258,13 @@
IDirectDrawPaletteImpl_SetEntries
};
+IDirectDrawPaletteImpl *unsafe_impl_from_IDirectDrawPalette(IDirectDrawPalette *iface)
+{
+ if (!iface) return NULL;
+ assert(iface->lpVtbl == &ddraw_palette_vtbl);
+ return CONTAINING_RECORD(iface, IDirectDrawPaletteImpl, lpVtbl);
+}
+
HRESULT ddraw_palette_init(IDirectDrawPaletteImpl *palette,
IDirectDrawImpl *ddraw, DWORD flags, PALETTEENTRY *entries)
{
diff --git a/dlls/ddraw/surface.c b/dlls/ddraw/surface.c
index 4cd1452..7c70f0f 100644
--- a/dlls/ddraw/surface.c
+++ b/dlls/ddraw/surface.c
@@ -4288,7 +4288,7 @@
IDirectDrawSurfaceImpl *This = impl_from_IDirectDrawSurface7(iface);
IDirectDrawPalette *oldPal;
IDirectDrawSurfaceImpl *surf;
- IDirectDrawPaletteImpl *PalImpl = (IDirectDrawPaletteImpl *)Pal;
+ IDirectDrawPaletteImpl *PalImpl = unsafe_impl_from_IDirectDrawPalette(Pal);
HRESULT hr;
TRACE("iface %p, palette %p.\n", iface, Pal);