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
a3dbd506
Commit
a3dbd506
authored
Oct 31, 2022
by
Gabriel Ivăncescu
Committed by
Alexandre Julliard
Oct 31, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Allow null or undefined listeners in attachEvent/detachEvent.
Signed-off-by:
Gabriel Ivăncescu
<
gabrielopcode@gmail.com
>
parent
d984fb14
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
81 additions
and
12 deletions
+81
-12
dispex.c
dlls/mshtml/dispex.c
+10
-1
htmlevent.c
dlls/mshtml/htmlevent.c
+5
-0
script.c
dlls/mshtml/tests/script.c
+66
-11
No files found.
dlls/mshtml/dispex.c
View file @
a3dbd506
...
@@ -1072,7 +1072,8 @@ HRESULT change_type(VARIANT *dst, VARIANT *src, VARTYPE vt, IServiceProvider *ca
...
@@ -1072,7 +1072,8 @@ HRESULT change_type(VARIANT *dst, VARIANT *src, VARTYPE vt, IServiceProvider *ca
if
(
SUCCEEDED
(
hres
))
{
if
(
SUCCEEDED
(
hres
))
{
hres
=
IVariantChangeType_ChangeType
(
change_type
,
dst
,
src
,
LOCALE_NEUTRAL
,
vt
);
hres
=
IVariantChangeType_ChangeType
(
change_type
,
dst
,
src
,
LOCALE_NEUTRAL
,
vt
);
IVariantChangeType_Release
(
change_type
);
IVariantChangeType_Release
(
change_type
);
return
hres
;
if
(
SUCCEEDED
(
hres
))
return
S_OK
;
}
}
}
}
...
@@ -1084,6 +1085,14 @@ HRESULT change_type(VARIANT *dst, VARIANT *src, VARTYPE vt, IServiceProvider *ca
...
@@ -1084,6 +1085,14 @@ HRESULT change_type(VARIANT *dst, VARIANT *src, VARTYPE vt, IServiceProvider *ca
return
S_OK
;
return
S_OK
;
}
}
break
;
break
;
case
VT_UNKNOWN
:
case
VT_DISPATCH
:
if
(
V_VT
(
src
)
==
VT_EMPTY
||
V_VT
(
src
)
==
VT_NULL
)
{
V_VT
(
dst
)
=
vt
;
V_DISPATCH
(
dst
)
=
NULL
;
return
S_OK
;
}
break
;
}
}
return
VariantChangeType
(
dst
,
src
,
0
,
vt
);
return
VariantChangeType
(
dst
,
src
,
0
,
vt
);
...
...
dlls/mshtml/htmlevent.c
View file @
a3dbd506
...
@@ -3870,6 +3870,11 @@ HRESULT attach_event(EventTarget *event_target, BSTR name, IDispatch *disp, VARI
...
@@ -3870,6 +3870,11 @@ HRESULT attach_event(EventTarget *event_target, BSTR name, IDispatch *disp, VARI
event_listener_t
*
listener
;
event_listener_t
*
listener
;
eventid_t
eid
;
eventid_t
eid
;
if
(
!
disp
)
{
*
res
=
VARIANT_FALSE
;
return
S_OK
;
}
eid
=
attr_to_eid
(
name
);
eid
=
attr_to_eid
(
name
);
if
(
eid
==
EVENTID_LAST
)
{
if
(
eid
==
EVENTID_LAST
)
{
WARN
(
"Unknown event
\n
"
);
WARN
(
"Unknown event
\n
"
);
...
...
dlls/mshtml/tests/script.c
View file @
a3dbd506
...
@@ -135,7 +135,8 @@ DEFINE_EXPECT(external_success);
...
@@ -135,7 +135,8 @@ DEFINE_EXPECT(external_success);
DEFINE_EXPECT
(
QS_VariantConversion
);
DEFINE_EXPECT
(
QS_VariantConversion
);
DEFINE_EXPECT
(
QS_IActiveScriptSite
);
DEFINE_EXPECT
(
QS_IActiveScriptSite
);
DEFINE_EXPECT
(
QS_GetCaller
);
DEFINE_EXPECT
(
QS_GetCaller
);
DEFINE_EXPECT
(
ChangeType
);
DEFINE_EXPECT
(
ChangeType_bstr
);
DEFINE_EXPECT
(
ChangeType_dispatch
);
DEFINE_EXPECT
(
GetTypeInfo
);
DEFINE_EXPECT
(
GetTypeInfo
);
#define TESTSCRIPT_CLSID "{178fc163-f585-4e24-9c13-4bb7faf80746}"
#define TESTSCRIPT_CLSID "{178fc163-f585-4e24-9c13-4bb7faf80746}"
...
@@ -364,18 +365,29 @@ static ULONG WINAPI VariantChangeType_Release(IVariantChangeType *iface)
...
@@ -364,18 +365,29 @@ static ULONG WINAPI VariantChangeType_Release(IVariantChangeType *iface)
static
HRESULT
WINAPI
VariantChangeType_ChangeType
(
IVariantChangeType
*
iface
,
VARIANT
*
dst
,
VARIANT
*
src
,
LCID
lcid
,
VARTYPE
vt
)
static
HRESULT
WINAPI
VariantChangeType_ChangeType
(
IVariantChangeType
*
iface
,
VARIANT
*
dst
,
VARIANT
*
src
,
LCID
lcid
,
VARTYPE
vt
)
{
{
CHECK_EXPECT
(
ChangeType
);
ok
(
dst
!=
NULL
,
"dst = NULL
\n
"
);
ok
(
dst
!=
NULL
,
"dst = NULL
\n
"
);
ok
(
V_VT
(
dst
)
==
VT_EMPTY
,
"V_VT(dst) = %d
\n
"
,
V_VT
(
dst
));
ok
(
V_VT
(
dst
)
==
VT_EMPTY
,
"V_VT(dst) = %d
\n
"
,
V_VT
(
dst
));
ok
(
src
!=
NULL
,
"src = NULL
\n
"
);
ok
(
src
!=
NULL
,
"src = NULL
\n
"
);
ok
(
V_VT
(
src
)
==
VT_I4
,
"V_VT(src) = %d
\n
"
,
V_VT
(
src
));
ok
(
V_I4
(
src
)
==
0xf0f0f0
,
"V_I4(src) = %lx
\n
"
,
V_I4
(
src
));
ok
(
lcid
==
LOCALE_NEUTRAL
,
"lcid = %ld
\n
"
,
lcid
);
ok
(
lcid
==
LOCALE_NEUTRAL
,
"lcid = %ld
\n
"
,
lcid
);
ok
(
vt
==
VT_BSTR
,
"vt = %d
\n
"
,
vt
);
V_VT
(
dst
)
=
VT_BSTR
;
switch
(
vt
)
{
V_BSTR
(
dst
)
=
SysAllocString
(
L"red"
);
case
VT_BSTR
:
CHECK_EXPECT
(
ChangeType_bstr
);
ok
(
V_VT
(
src
)
==
VT_I4
,
"V_VT(src) = %d
\n
"
,
V_VT
(
src
));
ok
(
V_I4
(
src
)
==
0xf0f0f0
,
"V_I4(src) = %lx
\n
"
,
V_I4
(
src
));
V_VT
(
dst
)
=
VT_BSTR
;
V_BSTR
(
dst
)
=
SysAllocString
(
L"red"
);
break
;
case
VT_DISPATCH
:
CHECK_EXPECT
(
ChangeType_dispatch
);
ok
(
V_VT
(
src
)
==
VT_NULL
,
"V_VT(src) = %d
\n
"
,
V_VT
(
src
));
/* native jscript returns E_NOTIMPL, use a "valid" error to test that it doesn't matter */
return
E_OUTOFMEMORY
;
default:
ok
(
0
,
"unexpected vt %d
\n
"
,
vt
);
return
E_NOTIMPL
;
}
return
S_OK
;
return
S_OK
;
}
}
...
@@ -2292,10 +2304,13 @@ static void test_global_id(void)
...
@@ -2292,10 +2304,13 @@ static void test_global_id(void)
static
void
test_arg_conv
(
IHTMLWindow2
*
window
)
static
void
test_arg_conv
(
IHTMLWindow2
*
window
)
{
{
DISPPARAMS
dp
=
{
0
};
IHTMLDocument2
*
doc
;
IHTMLDocument2
*
doc
;
IDispatchEx
*
dispex
;
IDispatchEx
*
dispex
;
IHTMLElement
*
elem
;
IHTMLElement
*
elem
;
VARIANT
v
;
VARIANT
v
,
args
[
2
];
DISPID
id
;
BSTR
bstr
;
HRESULT
hres
;
HRESULT
hres
;
hres
=
IHTMLWindow2_get_document
(
window
,
&
doc
);
hres
=
IHTMLWindow2_get_document
(
window
,
&
doc
);
...
@@ -2310,20 +2325,60 @@ static void test_arg_conv(IHTMLWindow2 *window)
...
@@ -2310,20 +2325,60 @@ static void test_arg_conv(IHTMLWindow2 *window)
ok
(
hres
==
S_OK
,
"Could not get IDispatchEx iface: %08lx
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"Could not get IDispatchEx iface: %08lx
\n
"
,
hres
);
SET_EXPECT
(
QS_VariantConversion
);
SET_EXPECT
(
QS_VariantConversion
);
SET_EXPECT
(
ChangeType
);
SET_EXPECT
(
ChangeType
_bstr
);
V_VT
(
&
v
)
=
VT_I4
;
V_VT
(
&
v
)
=
VT_I4
;
V_I4
(
&
v
)
=
0xf0f0f0
;
V_I4
(
&
v
)
=
0xf0f0f0
;
hres
=
dispex_propput
(
dispex
,
DISPID_IHTMLBODYELEMENT_BACKGROUND
,
0
,
&
v
,
&
caller_sp
);
hres
=
dispex_propput
(
dispex
,
DISPID_IHTMLBODYELEMENT_BACKGROUND
,
0
,
&
v
,
&
caller_sp
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
CHECK_CALLED
(
QS_VariantConversion
);
CHECK_CALLED
(
QS_VariantConversion
);
CHECK_CALLED
(
ChangeType
);
CHECK_CALLED
(
ChangeType
_bstr
);
V_VT
(
&
v
)
=
VT_EMPTY
;
V_VT
(
&
v
)
=
VT_EMPTY
;
hres
=
dispex_propget
(
dispex
,
DISPID_IHTMLBODYELEMENT_BGCOLOR
,
&
v
,
&
caller_sp
);
hres
=
dispex_propget
(
dispex
,
DISPID_IHTMLBODYELEMENT_BGCOLOR
,
&
v
,
&
caller_sp
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
ok
(
V_VT
(
&
v
)
==
VT_BSTR
,
"V_VT(var)=%d
\n
"
,
V_VT
(
&
v
));
ok
(
V_VT
(
&
v
)
==
VT_BSTR
,
"V_VT(var)=%d
\n
"
,
V_VT
(
&
v
));
ok
(
!
V_BSTR
(
&
v
),
"V_BSTR(&var) = %s
\n
"
,
wine_dbgstr_w
(
V_BSTR
(
&
v
)));
ok
(
!
V_BSTR
(
&
v
),
"V_BSTR(&var) = %s
\n
"
,
wine_dbgstr_w
(
V_BSTR
(
&
v
)));
IDispatchEx_Release
(
dispex
);
hres
=
IHTMLWindow2_QueryInterface
(
window
,
&
IID_IDispatchEx
,
(
void
**
)
&
dispex
);
ok
(
hres
==
S_OK
,
"Could not get IDispatchEx iface: %08lx
\n
"
,
hres
);
SET_EXPECT
(
GetScriptDispatch
);
bstr
=
SysAllocString
(
L"attachEvent"
);
hres
=
IDispatchEx_GetDispID
(
dispex
,
bstr
,
fdexNameCaseSensitive
,
&
id
);
ok
(
hres
==
S_OK
,
"GetDispID failed: %08lx
\n
"
,
hres
);
CHECK_CALLED
(
GetScriptDispatch
);
SysFreeString
(
bstr
);
SET_EXPECT
(
QS_VariantConversion
);
SET_EXPECT
(
ChangeType_dispatch
);
dp
.
cArgs
=
2
;
dp
.
rgvarg
=
args
;
V_VT
(
&
args
[
1
])
=
VT_BSTR
;
V_BSTR
(
&
args
[
1
])
=
SysAllocString
(
L"onload"
);
V_VT
(
&
args
[
0
])
=
VT_NULL
;
hres
=
IDispatchEx_InvokeEx
(
dispex
,
id
,
LOCALE_NEUTRAL
,
DISPATCH_METHOD
,
&
dp
,
&
v
,
NULL
,
&
caller_sp
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
ok
(
V_VT
(
&
v
)
==
VT_BOOL
,
"V_VT(var) = %d
\n
"
,
V_VT
(
&
v
));
ok
(
V_BOOL
(
&
v
)
==
VARIANT_FALSE
,
"V_BOOL(var) = %d
\n
"
,
V_BOOL
(
&
v
));
CHECK_CALLED
(
QS_VariantConversion
);
CHECK_CALLED
(
ChangeType_dispatch
);
SET_EXPECT
(
GetScriptDispatch
);
bstr
=
SysAllocString
(
L"detachEvent"
);
hres
=
IDispatchEx_GetDispID
(
dispex
,
bstr
,
fdexNameCaseSensitive
,
&
id
);
ok
(
hres
==
S_OK
,
"GetDispID failed: %08lx
\n
"
,
hres
);
CHECK_CALLED
(
GetScriptDispatch
);
SysFreeString
(
bstr
);
SET_EXPECT
(
QS_VariantConversion
);
SET_EXPECT
(
ChangeType_dispatch
);
hres
=
IDispatchEx_InvokeEx
(
dispex
,
id
,
LOCALE_NEUTRAL
,
DISPATCH_METHOD
,
&
dp
,
NULL
,
NULL
,
&
caller_sp
);
ok
(
hres
==
S_OK
,
"InvokeEx failed: %08lx
\n
"
,
hres
);
CHECK_CALLED
(
QS_VariantConversion
);
CHECK_CALLED
(
ChangeType_dispatch
);
SysFreeString
(
V_BSTR
(
&
args
[
1
]));
IDispatchEx_Release
(
dispex
);
IDispatchEx_Release
(
dispex
);
}
}
...
...
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