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
00293e9b
Commit
00293e9b
authored
Mar 24, 2010
by
Jacek Caban
Committed by
Alexandre Julliard
Mar 24, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Added IHTMLElement::removeAttribute implementation.
parent
30bed7ea
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
83 additions
and
20 deletions
+83
-20
dispex.c
dlls/mshtml/dispex.c
+78
-18
htmlelem.c
dlls/mshtml/htmlelem.c
+4
-2
mshtml_private.h
dlls/mshtml/mshtml_private.h
+1
-0
No files found.
dlls/mshtml/dispex.c
View file @
00293e9b
...
@@ -52,8 +52,11 @@ struct dispex_data_t {
...
@@ -52,8 +52,11 @@ struct dispex_data_t {
typedef
struct
{
typedef
struct
{
VARIANT
var
;
VARIANT
var
;
LPWSTR
name
;
LPWSTR
name
;
DWORD
flags
;
}
dynamic_prop_t
;
}
dynamic_prop_t
;
#define DYNPROP_DELETED 0x01
typedef
struct
{
typedef
struct
{
DispatchEx
dispex
;
DispatchEx
dispex
;
const
IUnknownVtbl
*
lpIUnknownVtbl
;
const
IUnknownVtbl
*
lpIUnknownVtbl
;
...
@@ -442,7 +445,7 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
...
@@ -442,7 +445,7 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
{
{
const
BOOL
alloc
=
flags
&
fdexNameEnsure
;
const
BOOL
alloc
=
flags
&
fdexNameEnsure
;
dispex_dynamic_data_t
*
data
;
dispex_dynamic_data_t
*
data
;
unsigned
i
;
dynamic_prop_t
*
prop
;
data
=
get_dynamic_data
(
This
,
alloc
);
data
=
get_dynamic_data
(
This
,
alloc
);
if
(
!
data
)
{
if
(
!
data
)
{
...
@@ -453,9 +456,14 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
...
@@ -453,9 +456,14 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
return
DISP_E_UNKNOWNNAME
;
return
DISP_E_UNKNOWNNAME
;
}
}
for
(
i
=
0
;
i
<
data
->
prop_cnt
;
i
++
)
{
for
(
prop
=
data
->
props
;
prop
<
data
->
props
+
data
->
prop_cnt
;
prop
++
)
{
if
(
flags
&
fdexNameCaseInsensitive
?
!
strcmpiW
(
data
->
props
[
i
].
name
,
name
)
:
!
strcmpW
(
data
->
props
[
i
].
name
,
name
))
{
if
(
flags
&
fdexNameCaseInsensitive
?
!
strcmpiW
(
prop
->
name
,
name
)
:
!
strcmpW
(
prop
->
name
,
name
))
{
*
ret
=
data
->
props
+
i
;
if
(
prop
->
flags
&
DYNPROP_DELETED
)
{
if
(
!
alloc
)
return
DISP_E_UNKNOWNNAME
;
prop
->
flags
&=
~
DYNPROP_DELETED
;
}
*
ret
=
prop
;
return
S_OK
;
return
S_OK
;
}
}
}
}
...
@@ -481,10 +489,16 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
...
@@ -481,10 +489,16 @@ static HRESULT get_dynamic_prop(DispatchEx *This, const WCHAR *name, DWORD flags
data
->
buf_size
<<=
1
;
data
->
buf_size
<<=
1
;
}
}
data
->
props
[
data
->
prop_cnt
].
name
=
heap_strdupW
(
name
);
prop
=
data
->
props
+
data
->
prop_cnt
;
VariantInit
(
&
data
->
props
[
data
->
prop_cnt
].
var
);
*
ret
=
data
->
props
+
data
->
prop_cnt
++
;
prop
->
name
=
heap_strdupW
(
name
);
if
(
!
prop
->
name
)
return
E_OUTOFMEMORY
;
VariantInit
(
&
prop
->
var
);
prop
->
flags
=
0
;
data
->
prop_cnt
++
;
*
ret
=
prop
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -795,6 +809,43 @@ static HRESULT invoke_builtin_prop(DispatchEx *This, DISPID id, LCID lcid, WORD
...
@@ -795,6 +809,43 @@ static HRESULT invoke_builtin_prop(DispatchEx *This, DISPID id, LCID lcid, WORD
return
hres
;
return
hres
;
}
}
HRESULT
remove_prop
(
DispatchEx
*
This
,
BSTR
name
,
VARIANT_BOOL
*
success
)
{
dynamic_prop_t
*
prop
;
DISPID
id
;
HRESULT
hres
;
hres
=
get_builtin_id
(
This
,
name
,
0
,
&
id
);
if
(
hres
==
S_OK
)
{
DISPID
named_id
=
DISPID_PROPERTYPUT
;
VARIANT
var
;
DISPPARAMS
dp
=
{
&
var
,
&
named_id
,
1
,
1
};
EXCEPINFO
ei
;
V_VT
(
&
var
)
=
VT_EMPTY
;
memset
(
&
ei
,
0
,
sizeof
(
ei
));
hres
=
invoke_builtin_prop
(
This
,
id
,
0
,
DISPATCH_PROPERTYPUT
,
&
dp
,
NULL
,
&
ei
,
NULL
);
if
(
FAILED
(
hres
))
return
hres
;
*
success
=
VARIANT_TRUE
;
return
S_OK
;
}
hres
=
get_dynamic_prop
(
This
,
name
,
0
,
&
prop
);
if
(
FAILED
(
hres
))
{
if
(
hres
!=
DISP_E_UNKNOWNNAME
)
return
hres
;
*
success
=
VARIANT_FALSE
;
return
S_OK
;
}
VariantClear
(
&
prop
->
var
);
prop
->
flags
|=
DYNPROP_DELETED
;
*
success
=
VARIANT_TRUE
;
return
S_OK
;
}
#define DISPATCHEX_THIS(iface) DEFINE_THIS(DispatchEx, IDispatchEx, iface)
#define DISPATCHEX_THIS(iface) DEFINE_THIS(DispatchEx, IDispatchEx, iface)
static
HRESULT
WINAPI
DispatchEx_QueryInterface
(
IDispatchEx
*
iface
,
REFIID
riid
,
void
**
ppv
)
static
HRESULT
WINAPI
DispatchEx_QueryInterface
(
IDispatchEx
*
iface
,
REFIID
riid
,
void
**
ppv
)
...
@@ -926,12 +977,12 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
...
@@ -926,12 +977,12 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
if
(
is_dynamic_dispid
(
id
))
{
if
(
is_dynamic_dispid
(
id
))
{
DWORD
idx
=
id
-
DISPID_DYNPROP_0
;
DWORD
idx
=
id
-
DISPID_DYNPROP_0
;
VARIANT
*
var
;
dynamic_prop_t
*
prop
;
if
(
!
This
->
dynamic_data
||
This
->
dynamic_data
->
prop_cnt
<=
idx
)
if
(
!
This
->
dynamic_data
||
This
->
dynamic_data
->
prop_cnt
<=
idx
)
return
DISP_E_UNKNOWNNAME
;
return
DISP_E_UNKNOWNNAME
;
var
=
&
This
->
dynamic_data
->
props
[
idx
].
var
;
prop
=
This
->
dynamic_data
->
props
+
idx
;
switch
(
wFlags
)
{
switch
(
wFlags
)
{
case
DISPATCH_METHOD
|
DISPATCH_PROPERTYGET
:
case
DISPATCH_METHOD
|
DISPATCH_PROPERTYGET
:
...
@@ -942,8 +993,8 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
...
@@ -942,8 +993,8 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
DISPPARAMS
dp
=
{
NULL
,
&
named_arg
,
0
,
1
};
DISPPARAMS
dp
=
{
NULL
,
&
named_arg
,
0
,
1
};
IDispatchEx
*
dispex
;
IDispatchEx
*
dispex
;
if
(
V_VT
(
var
)
!=
VT_DISPATCH
)
{
if
(
V_VT
(
&
prop
->
var
)
!=
VT_DISPATCH
)
{
FIXME
(
"invoke
vt %d
\n
"
,
V_VT
(
var
));
FIXME
(
"invoke
%s
\n
"
,
debugstr_variant
(
&
prop
->
var
));
return
E_NOTIMPL
;
return
E_NOTIMPL
;
}
}
...
@@ -962,14 +1013,14 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
...
@@ -962,14 +1013,14 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
V_VT
(
dp
.
rgvarg
)
=
VT_DISPATCH
;
V_VT
(
dp
.
rgvarg
)
=
VT_DISPATCH
;
V_DISPATCH
(
dp
.
rgvarg
)
=
(
IDispatch
*
)
DISPATCHEX
(
This
);
V_DISPATCH
(
dp
.
rgvarg
)
=
(
IDispatch
*
)
DISPATCHEX
(
This
);
hres
=
IDispatch_QueryInterface
(
V_DISPATCH
(
var
),
&
IID_IDispatchEx
,
(
void
**
)
&
dispex
);
hres
=
IDispatch_QueryInterface
(
V_DISPATCH
(
&
prop
->
var
),
&
IID_IDispatchEx
,
(
void
**
)
&
dispex
);
TRACE
(
"%s call
\n
"
,
debugstr_w
(
This
->
dynamic_data
->
props
[
idx
].
name
));
TRACE
(
"%s call
\n
"
,
debugstr_w
(
This
->
dynamic_data
->
props
[
idx
].
name
));
if
(
SUCCEEDED
(
hres
))
{
if
(
SUCCEEDED
(
hres
))
{
hres
=
IDispatchEx_InvokeEx
(
dispex
,
DISPID_VALUE
,
lcid
,
wFlags
,
&
dp
,
pvarRes
,
pei
,
pspCaller
);
hres
=
IDispatchEx_InvokeEx
(
dispex
,
DISPID_VALUE
,
lcid
,
wFlags
,
&
dp
,
pvarRes
,
pei
,
pspCaller
);
IDispatchEx_Release
(
dispex
);
IDispatchEx_Release
(
dispex
);
}
else
{
}
else
{
ULONG
err
=
0
;
ULONG
err
=
0
;
hres
=
IDispatch_Invoke
(
V_DISPATCH
(
var
),
DISPID_VALUE
,
&
IID_NULL
,
lcid
,
wFlags
,
pdp
,
pvarRes
,
pei
,
&
err
);
hres
=
IDispatch_Invoke
(
V_DISPATCH
(
&
prop
->
var
),
DISPID_VALUE
,
&
IID_NULL
,
lcid
,
wFlags
,
pdp
,
pvarRes
,
pei
,
&
err
);
}
}
TRACE
(
"%s ret %08x
\n
"
,
debugstr_w
(
This
->
dynamic_data
->
props
[
idx
].
name
),
hres
);
TRACE
(
"%s ret %08x
\n
"
,
debugstr_w
(
This
->
dynamic_data
->
props
[
idx
].
name
),
hres
);
...
@@ -977,7 +1028,9 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
...
@@ -977,7 +1028,9 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
return
hres
;
return
hres
;
}
}
case
DISPATCH_PROPERTYGET
:
case
DISPATCH_PROPERTYGET
:
return
VariantCopy
(
pvarRes
,
var
);
if
(
prop
->
flags
&
DYNPROP_DELETED
)
return
DISP_E_UNKNOWNNAME
;
return
VariantCopy
(
pvarRes
,
&
prop
->
var
);
case
DISPATCH_PROPERTYPUT
|
DISPATCH_PROPERTYPUTREF
:
case
DISPATCH_PROPERTYPUT
|
DISPATCH_PROPERTYPUTREF
:
case
DISPATCH_PROPERTYPUT
:
case
DISPATCH_PROPERTYPUT
:
if
(
pdp
->
cArgs
!=
1
||
(
pdp
->
cNamedArgs
==
1
&&
*
pdp
->
rgdispidNamedArgs
!=
DISPID_PROPERTYPUT
)
if
(
pdp
->
cArgs
!=
1
||
(
pdp
->
cNamedArgs
==
1
&&
*
pdp
->
rgdispidNamedArgs
!=
DISPID_PROPERTYPUT
)
...
@@ -987,8 +1040,13 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
...
@@ -987,8 +1040,13 @@ static HRESULT WINAPI DispatchEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lc
}
}
TRACE
(
"put %s
\n
"
,
debugstr_variant
(
pdp
->
rgvarg
));
TRACE
(
"put %s
\n
"
,
debugstr_variant
(
pdp
->
rgvarg
));
VariantClear
(
var
);
VariantClear
(
&
prop
->
var
);
return
VariantCopy
(
var
,
pdp
->
rgvarg
);
hres
=
VariantCopy
(
&
prop
->
var
,
pdp
->
rgvarg
);
if
(
FAILED
(
hres
))
return
hres
;
prop
->
flags
&=
~
DYNPROP_DELETED
;
return
S_OK
;
default:
default:
FIXME
(
"unhandled wFlags %x
\n
"
,
wFlags
);
FIXME
(
"unhandled wFlags %x
\n
"
,
wFlags
);
return
E_NOTIMPL
;
return
E_NOTIMPL
;
...
@@ -1073,12 +1131,14 @@ static HRESULT WINAPI DispatchEx_GetNextDispID(IDispatchEx *iface, DWORD grfdex,
...
@@ -1073,12 +1131,14 @@ static HRESULT WINAPI DispatchEx_GetNextDispID(IDispatchEx *iface, DWORD grfdex,
if
(
!
This
->
dynamic_data
||
This
->
dynamic_data
->
prop_cnt
<=
idx
)
if
(
!
This
->
dynamic_data
||
This
->
dynamic_data
->
prop_cnt
<=
idx
)
return
DISP_E_UNKNOWNNAME
;
return
DISP_E_UNKNOWNNAME
;
if
(
idx
+
1
==
This
->
dynamic_data
->
prop_cnt
)
{
while
(
++
idx
<
This
->
dynamic_data
->
prop_cnt
&&
This
->
dynamic_data
->
props
[
idx
].
flags
&
DYNPROP_DELETED
);
if
(
idx
==
This
->
dynamic_data
->
prop_cnt
)
{
*
pid
=
DISPID_STARTENUM
;
*
pid
=
DISPID_STARTENUM
;
return
S_FALSE
;
return
S_FALSE
;
}
}
*
pid
=
id
+
1
;
*
pid
=
DISPID_DYNPROP_0
+
idx
;
return
S_OK
;
return
S_OK
;
}
}
...
...
dlls/mshtml/htmlelem.c
View file @
00293e9b
...
@@ -198,8 +198,10 @@ static HRESULT WINAPI HTMLElement_removeAttribute(IHTMLElement *iface, BSTR strA
...
@@ -198,8 +198,10 @@ static HRESULT WINAPI HTMLElement_removeAttribute(IHTMLElement *iface, BSTR strA
LONG
lFlags
,
VARIANT_BOOL
*
pfSuccess
)
LONG
lFlags
,
VARIANT_BOOL
*
pfSuccess
)
{
{
HTMLElement
*
This
=
HTMLELEM_THIS
(
iface
);
HTMLElement
*
This
=
HTMLELEM_THIS
(
iface
);
FIXME
(
"(%p)->()
\n
"
,
This
);
return
E_NOTIMPL
;
TRACE
(
"(%p)->(%s %x %p)
\n
"
,
This
,
debugstr_w
(
strAttributeName
),
lFlags
,
pfSuccess
);
return
remove_prop
(
&
This
->
node
.
dispex
,
strAttributeName
,
pfSuccess
);
}
}
static
HRESULT
WINAPI
HTMLElement_put_className
(
IHTMLElement
*
iface
,
BSTR
v
)
static
HRESULT
WINAPI
HTMLElement_put_className
(
IHTMLElement
*
iface
,
BSTR
v
)
...
...
dlls/mshtml/mshtml_private.h
View file @
00293e9b
...
@@ -171,6 +171,7 @@ void release_dispex(DispatchEx*);
...
@@ -171,6 +171,7 @@ void release_dispex(DispatchEx*);
BOOL
dispex_query_interface
(
DispatchEx
*
,
REFIID
,
void
**
);
BOOL
dispex_query_interface
(
DispatchEx
*
,
REFIID
,
void
**
);
HRESULT
dispex_get_dprop_ref
(
DispatchEx
*
,
const
WCHAR
*
,
BOOL
,
VARIANT
**
);
HRESULT
dispex_get_dprop_ref
(
DispatchEx
*
,
const
WCHAR
*
,
BOOL
,
VARIANT
**
);
HRESULT
get_dispids
(
tid_t
,
DWORD
*
,
DISPID
**
);
HRESULT
get_dispids
(
tid_t
,
DWORD
*
,
DISPID
**
);
HRESULT
remove_prop
(
DispatchEx
*
,
BSTR
,
VARIANT_BOOL
*
);
typedef
struct
HTMLWindow
HTMLWindow
;
typedef
struct
HTMLWindow
HTMLWindow
;
typedef
struct
HTMLDocumentNode
HTMLDocumentNode
;
typedef
struct
HTMLDocumentNode
HTMLDocumentNode
;
...
...
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