Commit 14c190fc authored by Gabriel Ivăncescu's avatar Gabriel Ivăncescu Committed by Alexandre Julliard

mshtml: Expose window.performance in all modes.

parent e0585d4c
...@@ -191,6 +191,8 @@ static HRESULT WINAPI HTMLWindow2_QueryInterface(IHTMLWindow2 *iface, REFIID rii ...@@ -191,6 +191,8 @@ static HRESULT WINAPI HTMLWindow2_QueryInterface(IHTMLWindow2 *iface, REFIID rii
*ppv = &This->IProvideMultipleClassInfo_iface; *ppv = &This->IProvideMultipleClassInfo_iface;
}else if(IsEqualGUID(&IID_IWineHTMLWindowPrivate, riid)) { }else if(IsEqualGUID(&IID_IWineHTMLWindowPrivate, riid)) {
*ppv = &This->IWineHTMLWindowPrivate_iface; *ppv = &This->IWineHTMLWindowPrivate_iface;
}else if(IsEqualGUID(&IID_IWineHTMLWindowCompatPrivate, riid)) {
*ppv = &This->IWineHTMLWindowCompatPrivate_iface;
}else if(IsEqualGUID(&IID_IMarshal, riid)) { }else if(IsEqualGUID(&IID_IMarshal, riid)) {
*ppv = NULL; *ppv = NULL;
FIXME("(%p)->(IID_IMarshal %p)\n", This, ppv); FIXME("(%p)->(IID_IMarshal %p)\n", This, ppv);
...@@ -3145,6 +3147,94 @@ static const IWineHTMLWindowPrivateVtbl WineHTMLWindowPrivateVtbl = { ...@@ -3145,6 +3147,94 @@ static const IWineHTMLWindowPrivateVtbl WineHTMLWindowPrivateVtbl = {
window_private_get_console, window_private_get_console,
}; };
static inline HTMLWindow *impl_from_IWineHTMLWindowCompatPrivateVtbl(IWineHTMLWindowCompatPrivate *iface)
{
return CONTAINING_RECORD(iface, HTMLWindow, IWineHTMLWindowCompatPrivate_iface);
}
static HRESULT WINAPI window_compat_private_QueryInterface(IWineHTMLWindowCompatPrivate *iface,
REFIID riid, void **ppv)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
}
static ULONG WINAPI window_compat_private_AddRef(IWineHTMLWindowCompatPrivate *iface)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
}
static ULONG WINAPI window_compat_private_Release(IWineHTMLWindowCompatPrivate *iface)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
}
static HRESULT WINAPI window_compat_private_GetTypeInfoCount(IWineHTMLWindowCompatPrivate *iface, UINT *pctinfo)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
}
static HRESULT WINAPI window_compat_private_GetTypeInfo(IWineHTMLWindowCompatPrivate *iface, UINT iTInfo,
LCID lcid, ITypeInfo **ppTInfo)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
}
static HRESULT WINAPI window_compat_private_GetIDsOfNames(IWineHTMLWindowCompatPrivate *iface, REFIID riid,
LPOLESTR *rgszNames, UINT cNames,
LCID lcid, DISPID *rgDispId)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
rgDispId);
}
static HRESULT WINAPI window_compat_private_Invoke(IWineHTMLWindowCompatPrivate *iface, DISPID dispIdMember,
REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
pDispParams, pVarResult, pExcepInfo, puArgErr);
}
static HRESULT WINAPI window_compat_private_put_performance(IWineHTMLWindowCompatPrivate *iface, VARIANT v)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IHTMLWindow7_put_performance(&This->IHTMLWindow7_iface, v);
}
static HRESULT WINAPI window_compat_private_get_performance(IWineHTMLWindowCompatPrivate *iface, VARIANT *p)
{
HTMLWindow *This = impl_from_IWineHTMLWindowCompatPrivateVtbl(iface);
return IHTMLWindow7_get_performance(&This->IHTMLWindow7_iface, p);
}
static const IWineHTMLWindowCompatPrivateVtbl WineHTMLWindowCompatPrivateVtbl = {
window_compat_private_QueryInterface,
window_compat_private_AddRef,
window_compat_private_Release,
window_compat_private_GetTypeInfoCount,
window_compat_private_GetTypeInfo,
window_compat_private_GetIDsOfNames,
window_compat_private_Invoke,
window_compat_private_put_performance,
window_compat_private_get_performance,
};
static inline HTMLWindow *impl_from_IDispatchEx(IDispatchEx *iface) static inline HTMLWindow *impl_from_IDispatchEx(IDispatchEx *iface)
{ {
return CONTAINING_RECORD(iface, HTMLWindow, IDispatchEx_iface); return CONTAINING_RECORD(iface, HTMLWindow, IDispatchEx_iface);
...@@ -3649,6 +3739,8 @@ static void HTMLWindow_init_dispex_info(dispex_data_t *info, compat_mode_t compa ...@@ -3649,6 +3739,8 @@ static void HTMLWindow_init_dispex_info(dispex_data_t *info, compat_mode_t compa
{ {
if(compat_mode >= COMPAT_MODE_IE9) if(compat_mode >= COMPAT_MODE_IE9)
dispex_info_add_interface(info, IHTMLWindow7_tid, NULL); dispex_info_add_interface(info, IHTMLWindow7_tid, NULL);
else
dispex_info_add_interface(info, IWineHTMLWindowCompatPrivate_tid, NULL);
if(compat_mode >= COMPAT_MODE_IE10) if(compat_mode >= COMPAT_MODE_IE10)
dispex_info_add_interface(info, IWineHTMLWindowPrivate_tid, NULL); dispex_info_add_interface(info, IWineHTMLWindowPrivate_tid, NULL);
...@@ -3715,6 +3807,7 @@ static void *alloc_window(size_t size) ...@@ -3715,6 +3807,7 @@ static void *alloc_window(size_t size)
window->IObjectIdentity_iface.lpVtbl = &ObjectIdentityVtbl; window->IObjectIdentity_iface.lpVtbl = &ObjectIdentityVtbl;
window->IProvideMultipleClassInfo_iface.lpVtbl = &ProvideMultipleClassInfoVtbl; window->IProvideMultipleClassInfo_iface.lpVtbl = &ProvideMultipleClassInfoVtbl;
window->IWineHTMLWindowPrivate_iface.lpVtbl = &WineHTMLWindowPrivateVtbl; window->IWineHTMLWindowPrivate_iface.lpVtbl = &WineHTMLWindowPrivateVtbl;
window->IWineHTMLWindowCompatPrivate_iface.lpVtbl = &WineHTMLWindowCompatPrivateVtbl;
window->ref = 1; window->ref = 1;
return window; return window;
......
...@@ -276,6 +276,7 @@ typedef struct EventTarget EventTarget; ...@@ -276,6 +276,7 @@ typedef struct EventTarget EventTarget;
XIID(IWineDOMTokenList) \ XIID(IWineDOMTokenList) \
XIID(IWineHTMLElementPrivate) \ XIID(IWineHTMLElementPrivate) \
XIID(IWineHTMLWindowPrivate) \ XIID(IWineHTMLWindowPrivate) \
XIID(IWineHTMLWindowCompatPrivate) \
XIID(IWineMSHTMLConsole) XIID(IWineMSHTMLConsole)
typedef enum { typedef enum {
...@@ -496,6 +497,7 @@ struct HTMLWindow { ...@@ -496,6 +497,7 @@ struct HTMLWindow {
IObjectIdentity IObjectIdentity_iface; IObjectIdentity IObjectIdentity_iface;
IProvideMultipleClassInfo IProvideMultipleClassInfo_iface; IProvideMultipleClassInfo IProvideMultipleClassInfo_iface;
IWineHTMLWindowPrivate IWineHTMLWindowPrivate_iface; IWineHTMLWindowPrivate IWineHTMLWindowPrivate_iface;
IWineHTMLWindowCompatPrivate IWineHTMLWindowCompatPrivate_iface;
IWineMSHTMLConsole *console; IWineMSHTMLConsole *console;
......
...@@ -18,6 +18,8 @@ ...@@ -18,6 +18,8 @@
#pragma makedep typelib #pragma makedep typelib
#include <mshtmdid.h>
import "ocidl.idl"; import "ocidl.idl";
[ [
...@@ -94,6 +96,22 @@ interface IWineHTMLWindowPrivate : IDispatch ...@@ -94,6 +96,22 @@ interface IWineHTMLWindowPrivate : IDispatch
oleautomation, oleautomation,
dual, dual,
hidden, hidden,
uuid(1b5939fc-8f84-43f3-8d89-f9a92069fad6)
]
interface IWineHTMLWindowCompatPrivate : IDispatch
{
[propput, id(DISPID_IHTMLWINDOW7_PERFORMANCE)]
HRESULT performance([in] VARIANT v);
[propget, id(DISPID_IHTMLWINDOW7_PERFORMANCE)]
HRESULT performance([out, retval] VARIANT *p);
}
[
odl,
oleautomation,
dual,
hidden,
uuid(465908fd-f394-489f-b7a3-4c00fbbe9eec) uuid(465908fd-f394-489f-b7a3-4c00fbbe9eec)
] ]
interface IWineHTMLElementPrivate : IDispatch interface IWineHTMLElementPrivate : IDispatch
......
...@@ -354,8 +354,7 @@ sync_test("window_props", function() { ...@@ -354,8 +354,7 @@ sync_test("window_props", function() {
test_exposed("requestAnimationFrame", v >= 10); test_exposed("requestAnimationFrame", v >= 10);
test_exposed("Map", v >= 11); test_exposed("Map", v >= 11);
test_exposed("Set", v >= 11); test_exposed("Set", v >= 11);
if(v >= 9) /* FIXME: native exposes it in all compat modes */ test_exposed("performance", true);
test_exposed("performance", true);
test_exposed("console", v >= 10); test_exposed("console", v >= 10);
}); });
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment