Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
af3376a6
Commit
af3376a6
authored
Oct 19, 2017
by
Jacek Caban
Committed by
Alexandre Julliard
Oct 19, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Store event id in DOMEvent.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
3077358a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
40 additions
and
8 deletions
+40
-8
htmlevent.c
dlls/mshtml/htmlevent.c
+39
-8
htmlevent.h
dlls/mshtml/htmlevent.h
+1
-0
No files found.
dlls/mshtml/htmlevent.c
View file @
af3376a6
...
@@ -1058,19 +1058,44 @@ static dispex_static_data_t DOMEvent_dispex = {
...
@@ -1058,19 +1058,44 @@ static dispex_static_data_t DOMEvent_dispex = {
DOMEvent_iface_tids
DOMEvent_iface_tids
};
};
static
HRESULT
create_event_from_nsevent
(
nsIDOMEvent
*
nsevent
,
DOMEvent
**
ret_
event
)
static
DOMEvent
*
alloc_event
(
nsIDOMEvent
*
ns
event
)
{
{
DOMEvent
*
event
;
DOMEvent
*
event
;
event
=
heap_alloc_zero
(
sizeof
(
*
event
));
event
=
heap_alloc_zero
(
sizeof
(
*
event
));
if
(
!
event
)
if
(
!
event
)
return
E_OUTOFMEMORY
;
return
NULL
;
init_dispex
(
&
event
->
dispex
,
(
IUnknown
*
)
&
event
->
IDOMEvent_iface
,
&
DOMEvent_dispex
);
init_dispex
(
&
event
->
dispex
,
(
IUnknown
*
)
&
event
->
IDOMEvent_iface
,
&
DOMEvent_dispex
);
event
->
IDOMEvent_iface
.
lpVtbl
=
&
DOMEventVtbl
;
event
->
IDOMEvent_iface
.
lpVtbl
=
&
DOMEventVtbl
;
event
->
ref
=
1
;
event
->
ref
=
1
;
nsIDOMEvent_AddRef
(
event
->
nsevent
=
nsevent
);
nsIDOMEvent_AddRef
(
event
->
nsevent
=
nsevent
);
event
->
event_id
=
EVENTID_LAST
;
return
event
;
}
static
HRESULT
create_event_from_nsevent
(
nsIDOMEvent
*
nsevent
,
DOMEvent
**
ret_event
)
{
DOMEvent
*
event
;
nsAString
nsstr
;
nsresult
nsres
;
event
=
alloc_event
(
nsevent
);
if
(
!
event
)
return
E_OUTOFMEMORY
;
nsAString_Init
(
&
nsstr
,
NULL
);
nsres
=
nsIDOMEvent_GetType
(
event
->
nsevent
,
&
nsstr
);
if
(
NS_SUCCEEDED
(
nsres
))
{
const
WCHAR
*
type
;
nsAString_GetData
(
&
nsstr
,
&
type
);
event
->
event_id
=
str_to_eid
(
type
);
if
(
event
->
event_id
==
EVENTID_LAST
)
FIXME
(
"unknown event type %s
\n
"
,
debugstr_w
(
type
));
}
else
{
ERR
(
"GetType failed: %08x
\n
"
,
nsres
);
}
nsAString_Finish
(
&
nsstr
);
*
ret_event
=
event
;
*
ret_event
=
event
;
return
S_OK
;
return
S_OK
;
...
@@ -1082,7 +1107,6 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
...
@@ -1082,7 +1107,6 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
DOMEvent
*
event
;
DOMEvent
*
event
;
nsAString
nsstr
;
nsAString
nsstr
;
nsresult
nsres
;
nsresult
nsres
;
HRESULT
hres
;
nsAString_InitDepend
(
&
nsstr
,
type
);
nsAString_InitDepend
(
&
nsstr
,
type
);
nsres
=
nsIDOMHTMLDocument_CreateEvent
(
doc
->
nsdoc
,
&
nsstr
,
&
nsevent
);
nsres
=
nsIDOMHTMLDocument_CreateEvent
(
doc
->
nsdoc
,
&
nsstr
,
&
nsevent
);
...
@@ -1092,10 +1116,10 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
...
@@ -1092,10 +1116,10 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
return
E_FAIL
;
return
E_FAIL
;
}
}
hres
=
create_event_from_nsevent
(
nsevent
,
&
event
);
event
=
alloc_event
(
ns
event
);
nsIDOMEvent_Release
(
nsevent
);
nsIDOMEvent_Release
(
nsevent
);
if
(
FAILED
(
hres
)
)
if
(
!
event
)
return
hres
;
return
E_OUTOFMEMORY
;
*
ret_event
=
&
event
->
IDOMEvent_iface
;
*
ret_event
=
&
event
->
IDOMEvent_iface
;
return
S_OK
;
return
S_OK
;
...
@@ -1104,6 +1128,7 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
...
@@ -1104,6 +1128,7 @@ HRESULT create_document_event_str(HTMLDocumentNode *doc, const WCHAR *type, IDOM
static
HRESULT
create_document_event
(
HTMLDocumentNode
*
doc
,
eventid_t
event_id
,
DOMEvent
**
ret_event
)
static
HRESULT
create_document_event
(
HTMLDocumentNode
*
doc
,
eventid_t
event_id
,
DOMEvent
**
ret_event
)
{
{
nsIDOMEvent
*
nsevent
;
nsIDOMEvent
*
nsevent
;
DOMEvent
*
event
;
nsAString
nsstr
;
nsAString
nsstr
;
nsresult
nsres
;
nsresult
nsres
;
...
@@ -1115,7 +1140,13 @@ static HRESULT create_document_event(HTMLDocumentNode *doc, eventid_t event_id,
...
@@ -1115,7 +1140,13 @@ static HRESULT create_document_event(HTMLDocumentNode *doc, eventid_t event_id,
return
E_FAIL
;
return
E_FAIL
;
}
}
return
create_event_from_nsevent
(
nsevent
,
ret_event
);
event
=
alloc_event
(
nsevent
);
if
(
!
event
)
return
E_OUTOFMEMORY
;
event
->
event_id
=
event_id
;
*
ret_event
=
event
;
return
S_OK
;
}
}
static
handler_vector_t
*
get_handler_vector
(
EventTarget
*
event_target
,
eventid_t
eid
,
BOOL
alloc
)
static
handler_vector_t
*
get_handler_vector
(
EventTarget
*
event_target
,
eventid_t
eid
,
BOOL
alloc
)
...
...
dlls/mshtml/htmlevent.h
View file @
af3376a6
...
@@ -62,6 +62,7 @@ typedef struct {
...
@@ -62,6 +62,7 @@ typedef struct {
LONG
ref
;
LONG
ref
;
nsIDOMEvent
*
nsevent
;
nsIDOMEvent
*
nsevent
;
eventid_t
event_id
;
}
DOMEvent
;
}
DOMEvent
;
eventid_t
str_to_eid
(
LPCWSTR
)
DECLSPEC_HIDDEN
;
eventid_t
str_to_eid
(
LPCWSTR
)
DECLSPEC_HIDDEN
;
...
...
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