Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-fonts
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
Aleksandr Isakov
wine-fonts
Commits
26f731f4
Commit
26f731f4
authored
Nov 30, 2017
by
Jacek Caban
Committed by
Alexandre Julliard
Nov 30, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Store listener container type as a string.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
dda20ef4
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
7 deletions
+8
-7
htmlevent.c
dlls/mshtml/htmlevent.c
+8
-7
No files found.
dlls/mshtml/htmlevent.c
View file @
26f731f4
...
@@ -50,8 +50,8 @@ typedef struct {
...
@@ -50,8 +50,8 @@ typedef struct {
typedef
struct
{
typedef
struct
{
struct
wine_rb_entry
entry
;
struct
wine_rb_entry
entry
;
eventid_t
event_id
;
struct
list
listeners
;
struct
list
listeners
;
WCHAR
type
[
1
];
}
listener_container_t
;
}
listener_container_t
;
static
const
WCHAR
abortW
[]
=
{
'a'
,
'b'
,
'o'
,
'r'
,
't'
,
0
};
static
const
WCHAR
abortW
[]
=
{
'a'
,
'b'
,
'o'
,
'r'
,
't'
,
0
};
...
@@ -242,8 +242,9 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
...
@@ -242,8 +242,9 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
const
event_target_vtbl_t
*
vtbl
;
const
event_target_vtbl_t
*
vtbl
;
listener_container_t
*
container
;
listener_container_t
*
container
;
struct
wine_rb_entry
*
entry
;
struct
wine_rb_entry
*
entry
;
size_t
type_len
;
entry
=
wine_rb_get
(
&
event_target
->
handler_map
,
(
const
void
*
)
eid
);
entry
=
wine_rb_get
(
&
event_target
->
handler_map
,
event_info
[
eid
].
name
);
if
(
entry
)
if
(
entry
)
return
WINE_RB_ENTRY_VALUE
(
entry
,
listener_container_t
,
entry
);
return
WINE_RB_ENTRY_VALUE
(
entry
,
listener_container_t
,
entry
);
if
(
!
alloc
)
if
(
!
alloc
)
...
@@ -252,11 +253,11 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
...
@@ -252,11 +253,11 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
if
(
event_info
[
eid
].
flags
&
EVENT_FIXME
)
if
(
event_info
[
eid
].
flags
&
EVENT_FIXME
)
FIXME
(
"unimplemented event %s
\n
"
,
debugstr_w
(
event_info
[
eid
].
name
));
FIXME
(
"unimplemented event %s
\n
"
,
debugstr_w
(
event_info
[
eid
].
name
));
container
=
heap_alloc
(
sizeof
(
*
container
));
type_len
=
strlenW
(
event_info
[
eid
].
name
);
container
=
heap_alloc
(
FIELD_OFFSET
(
listener_container_t
,
type
[
type_len
+
1
]));
if
(
!
container
)
if
(
!
container
)
return
NULL
;
return
NULL
;
memcpy
(
container
->
type
,
event_info
[
eid
].
name
,
(
type_len
+
1
)
*
sizeof
(
WCHAR
));
container
->
event_id
=
eid
;
list_init
(
&
container
->
listeners
);
list_init
(
&
container
->
listeners
);
vtbl
=
dispex_get_vtbl
(
&
event_target
->
dispex
);
vtbl
=
dispex_get_vtbl
(
&
event_target
->
dispex
);
if
(
vtbl
->
bind_event
)
if
(
vtbl
->
bind_event
)
...
@@ -264,7 +265,7 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
...
@@ -264,7 +265,7 @@ static listener_container_t *get_listener_container(EventTarget *event_target, e
else
else
FIXME
(
"Unsupported event binding on target %p
\n
"
,
event_target
);
FIXME
(
"Unsupported event binding on target %p
\n
"
,
event_target
);
wine_rb_put
(
&
event_target
->
handler_map
,
(
const
void
*
)
eid
,
&
container
->
entry
);
wine_rb_put
(
&
event_target
->
handler_map
,
container
->
type
,
&
container
->
entry
);
return
container
;
return
container
;
}
}
...
@@ -2264,7 +2265,7 @@ void EventTarget_init_dispex_info(dispex_data_t *dispex_info, compat_mode_t comp
...
@@ -2264,7 +2265,7 @@ void EventTarget_init_dispex_info(dispex_data_t *dispex_info, compat_mode_t comp
static
int
event_id_cmp
(
const
void
*
key
,
const
struct
wine_rb_entry
*
entry
)
static
int
event_id_cmp
(
const
void
*
key
,
const
struct
wine_rb_entry
*
entry
)
{
{
return
(
INT_PTR
)
key
-
WINE_RB_ENTRY_VALUE
(
entry
,
listener_container_t
,
entry
)
->
event_id
;
return
strcmpW
(
key
,
WINE_RB_ENTRY_VALUE
(
entry
,
listener_container_t
,
entry
)
->
type
)
;
}
}
void
EventTarget_Init
(
EventTarget
*
event_target
,
IUnknown
*
outer
,
dispex_static_data_t
*
dispex_data
,
void
EventTarget_Init
(
EventTarget
*
event_target
,
IUnknown
*
outer
,
dispex_static_data_t
*
dispex_data
,
...
...
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