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
00ee406e
Commit
00ee406e
authored
Nov 08, 2010
by
Jacek Caban
Committed by
Alexandre Julliard
Nov 08, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mshtml: Added IOmNavigator::get_plugins implementation.
parent
645f34dd
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
219 additions
and
3 deletions
+219
-3
dispex.c
dlls/mshtml/dispex.c
+2
-0
mshtml_private.h
dlls/mshtml/mshtml_private.h
+2
-0
omnavigator.c
dlls/mshtml/omnavigator.c
+172
-2
dom.c
dlls/mshtml/tests/dom.c
+22
-0
mshtml.idl
include/mshtml.idl
+21
-1
No files found.
dlls/mshtml/dispex.c
View file @
00ee406e
...
@@ -85,6 +85,7 @@ static struct list dispex_data_list = LIST_INIT(dispex_data_list);
...
@@ -85,6 +85,7 @@ static struct list dispex_data_list = LIST_INIT(dispex_data_list);
static
REFIID
tid_ids
[]
=
{
static
REFIID
tid_ids
[]
=
{
&
IID_NULL
,
&
IID_NULL
,
&
DIID_DispCEventObj
,
&
DIID_DispCEventObj
,
&
DIID_DispCPlugins
,
&
DIID_DispDOMChildrenCollection
,
&
DIID_DispDOMChildrenCollection
,
&
DIID_DispHTMLAnchorElement
,
&
DIID_DispHTMLAnchorElement
,
&
DIID_DispHTMLBody
,
&
DIID_DispHTMLBody
,
...
@@ -150,6 +151,7 @@ static REFIID tid_ids[] = {
...
@@ -150,6 +151,7 @@ static REFIID tid_ids[] = {
&
IID_IHTMLLocation
,
&
IID_IHTMLLocation
,
&
IID_IHTMLObjectElement
,
&
IID_IHTMLObjectElement
,
&
IID_IHTMLOptionElement
,
&
IID_IHTMLOptionElement
,
&
IID_IHTMLPluginsCollection
,
&
IID_IHTMLRect
,
&
IID_IHTMLRect
,
&
IID_IHTMLScreen
,
&
IID_IHTMLScreen
,
&
IID_IHTMLScriptElement
,
&
IID_IHTMLScriptElement
,
...
...
dlls/mshtml/mshtml_private.h
View file @
00ee406e
...
@@ -67,6 +67,7 @@ typedef struct event_target_t event_target_t;
...
@@ -67,6 +67,7 @@ typedef struct event_target_t event_target_t;
typedef
enum
{
typedef
enum
{
NULL_tid
,
NULL_tid
,
DispCEventObj_tid
,
DispCEventObj_tid
,
DispCPlugins_tid
,
DispDOMChildrenCollection_tid
,
DispDOMChildrenCollection_tid
,
DispHTMLAnchorElement_tid
,
DispHTMLAnchorElement_tid
,
DispHTMLBody_tid
,
DispHTMLBody_tid
,
...
@@ -132,6 +133,7 @@ typedef enum {
...
@@ -132,6 +133,7 @@ typedef enum {
IHTMLLocation_tid
,
IHTMLLocation_tid
,
IHTMLObjectElement_tid
,
IHTMLObjectElement_tid
,
IHTMLOptionElement_tid
,
IHTMLOptionElement_tid
,
IHTMLPluginsCollection_tid
,
IHTMLRect_tid
,
IHTMLRect_tid
,
IHTMLScreen_tid
,
IHTMLScreen_tid
,
IHTMLScriptElement_tid
,
IHTMLScriptElement_tid
,
...
...
dlls/mshtml/omnavigator.c
View file @
00ee406e
...
@@ -31,15 +31,168 @@
...
@@ -31,15 +31,168 @@
WINE_DEFAULT_DEBUG_CHANNEL
(
mshtml
);
WINE_DEFAULT_DEBUG_CHANNEL
(
mshtml
);
typedef
struct
HTMLPluginsCollection
HTMLPluginsCollection
;
typedef
struct
{
typedef
struct
{
DispatchEx
dispex
;
DispatchEx
dispex
;
const
IOmNavigatorVtbl
*
lpIOmNavigatorVtbl
;
const
IOmNavigatorVtbl
*
lpIOmNavigatorVtbl
;
LONG
ref
;
LONG
ref
;
HTMLPluginsCollection
*
plugins
;
}
OmNavigator
;
}
OmNavigator
;
#define OMNAVIGATOR(x) ((IOmNavigator*) &(x)->lpIOmNavigatorVtbl)
#define OMNAVIGATOR(x) ((IOmNavigator*) &(x)->lpIOmNavigatorVtbl)
struct
HTMLPluginsCollection
{
DispatchEx
dispex
;
const
IHTMLPluginsCollectionVtbl
*
lpIHTMLPluginsCollectionVtbl
;
LONG
ref
;
OmNavigator
*
navigator
;
};
#define HTMLPLUGINSCOL(x) ((IHTMLPluginsCollection*) &(x)->lpIHTMLPluginsCollectionVtbl)
#define HTMLPLUGINCOL_THIS(iface) DEFINE_THIS(HTMLPluginsCollection, IHTMLPluginsCollection, iface)
static
HRESULT
WINAPI
HTMLPluginsCollection_QueryInterface
(
IHTMLPluginsCollection
*
iface
,
REFIID
riid
,
void
**
ppv
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
if
(
IsEqualGUID
(
&
IID_IUnknown
,
riid
))
{
TRACE
(
"(%p)->(IID_IUnknown %p)
\n
"
,
This
,
ppv
);
*
ppv
=
HTMLPLUGINSCOL
(
This
);
}
else
if
(
IsEqualGUID
(
&
IID_IHTMLPluginsCollection
,
riid
))
{
TRACE
(
"(%p)->(IID_IHTMLPluginCollection %p)
\n
"
,
This
,
ppv
);
*
ppv
=
HTMLPLUGINSCOL
(
This
);
}
else
if
(
dispex_query_interface
(
&
This
->
dispex
,
riid
,
ppv
))
{
return
*
ppv
?
S_OK
:
E_NOINTERFACE
;
}
else
{
*
ppv
=
NULL
;
WARN
(
"(%p)->(%s %p)
\n
"
,
This
,
debugstr_guid
(
riid
),
ppv
);
return
E_NOINTERFACE
;
}
IUnknown_AddRef
((
IUnknown
*
)
*
ppv
);
return
S_OK
;
}
static
ULONG
WINAPI
HTMLPluginsCollection_AddRef
(
IHTMLPluginsCollection
*
iface
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
LONG
ref
=
InterlockedIncrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
return
ref
;
}
static
ULONG
WINAPI
HTMLPluginsCollection_Release
(
IHTMLPluginsCollection
*
iface
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
LONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
if
(
!
ref
)
{
if
(
This
->
navigator
)
This
->
navigator
->
plugins
=
NULL
;
release_dispex
(
&
This
->
dispex
);
heap_free
(
This
);
}
return
ref
;
}
static
HRESULT
WINAPI
HTMLPluginsCollection_GetTypeInfoCount
(
IHTMLPluginsCollection
*
iface
,
UINT
*
pctinfo
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
return
IDispatchEx_GetTypeInfoCount
(
DISPATCHEX
(
&
This
->
dispex
),
pctinfo
);
}
static
HRESULT
WINAPI
HTMLPluginsCollection_GetTypeInfo
(
IHTMLPluginsCollection
*
iface
,
UINT
iTInfo
,
LCID
lcid
,
ITypeInfo
**
ppTInfo
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
return
IDispatchEx_GetTypeInfo
(
DISPATCHEX
(
&
This
->
dispex
),
iTInfo
,
lcid
,
ppTInfo
);
}
static
HRESULT
WINAPI
HTMLPluginsCollection_GetIDsOfNames
(
IHTMLPluginsCollection
*
iface
,
REFIID
riid
,
LPOLESTR
*
rgszNames
,
UINT
cNames
,
LCID
lcid
,
DISPID
*
rgDispId
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
return
IDispatchEx_GetIDsOfNames
(
DISPATCHEX
(
&
This
->
dispex
),
riid
,
rgszNames
,
cNames
,
lcid
,
rgDispId
);
}
static
HRESULT
WINAPI
HTMLPluginsCollection_Invoke
(
IHTMLPluginsCollection
*
iface
,
DISPID
dispIdMember
,
REFIID
riid
,
LCID
lcid
,
WORD
wFlags
,
DISPPARAMS
*
pDispParams
,
VARIANT
*
pVarResult
,
EXCEPINFO
*
pExcepInfo
,
UINT
*
puArgErr
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
return
IDispatchEx_Invoke
(
DISPATCHEX
(
&
This
->
dispex
),
dispIdMember
,
riid
,
lcid
,
wFlags
,
pDispParams
,
pVarResult
,
pExcepInfo
,
puArgErr
);
}
static
HRESULT
WINAPI
HTMLPluginsCollection_get_length
(
IHTMLPluginsCollection
*
iface
,
LONG
*
p
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
FIXME
(
"(%p)->(%p)
\n
"
,
This
,
p
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
HTMLPluginsCollection_refresh
(
IHTMLPluginsCollection
*
iface
,
VARIANT_BOOL
reload
)
{
HTMLPluginsCollection
*
This
=
HTMLPLUGINCOL_THIS
(
iface
);
FIXME
(
"(%p)->(%x)
\n
"
,
This
,
reload
);
return
E_NOTIMPL
;
}
#undef HTMLPLUGINSCOL_THIS
static
const
IHTMLPluginsCollectionVtbl
HTMLPluginsCollectionVtbl
=
{
HTMLPluginsCollection_QueryInterface
,
HTMLPluginsCollection_AddRef
,
HTMLPluginsCollection_Release
,
HTMLPluginsCollection_GetTypeInfoCount
,
HTMLPluginsCollection_GetTypeInfo
,
HTMLPluginsCollection_GetIDsOfNames
,
HTMLPluginsCollection_Invoke
,
HTMLPluginsCollection_get_length
,
HTMLPluginsCollection_refresh
};
static
const
tid_t
HTMLPluginsCollection_iface_tids
[]
=
{
IHTMLPluginsCollection_tid
,
0
};
static
dispex_static_data_t
HTMLPluginsCollection_dispex
=
{
NULL
,
DispCPlugins_tid
,
NULL
,
HTMLPluginsCollection_iface_tids
};
static
HRESULT
create_plugins_collection
(
OmNavigator
*
navigator
,
HTMLPluginsCollection
**
ret
)
{
HTMLPluginsCollection
*
col
;
col
=
heap_alloc_zero
(
sizeof
(
*
col
));
if
(
!
col
)
return
E_OUTOFMEMORY
;
col
->
lpIHTMLPluginsCollectionVtbl
=
&
HTMLPluginsCollectionVtbl
;
col
->
ref
=
1
;
col
->
navigator
=
navigator
;
init_dispex
(
&
col
->
dispex
,
(
IUnknown
*
)
HTMLPLUGINSCOL
(
col
),
&
HTMLPluginsCollection_dispex
);
*
ret
=
col
;
return
S_OK
;
}
#define OMNAVIGATOR_THIS(iface) DEFINE_THIS(OmNavigator, IOmNavigator, iface)
#define OMNAVIGATOR_THIS(iface) DEFINE_THIS(OmNavigator, IOmNavigator, iface)
static
HRESULT
WINAPI
OmNavigator_QueryInterface
(
IOmNavigator
*
iface
,
REFIID
riid
,
void
**
ppv
)
static
HRESULT
WINAPI
OmNavigator_QueryInterface
(
IOmNavigator
*
iface
,
REFIID
riid
,
void
**
ppv
)
...
@@ -85,6 +238,10 @@ static ULONG WINAPI OmNavigator_Release(IOmNavigator *iface)
...
@@ -85,6 +238,10 @@ static ULONG WINAPI OmNavigator_Release(IOmNavigator *iface)
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
TRACE
(
"(%p) ref=%d
\n
"
,
This
,
ref
);
if
(
!
ref
)
{
if
(
!
ref
)
{
if
(
This
->
plugins
)
{
This
->
plugins
->
navigator
=
NULL
;
IHTMLPluginsCollection_Release
(
HTMLPLUGINSCOL
(
This
->
plugins
));
}
release_dispex
(
&
This
->
dispex
);
release_dispex
(
&
This
->
dispex
);
heap_free
(
This
);
heap_free
(
This
);
}
}
...
@@ -232,8 +389,21 @@ static HRESULT WINAPI OmNavigator_get_mimeTypes(IOmNavigator *iface, IHTMLMimeTy
...
@@ -232,8 +389,21 @@ static HRESULT WINAPI OmNavigator_get_mimeTypes(IOmNavigator *iface, IHTMLMimeTy
static
HRESULT
WINAPI
OmNavigator_get_plugins
(
IOmNavigator
*
iface
,
IHTMLPluginsCollection
**
p
)
static
HRESULT
WINAPI
OmNavigator_get_plugins
(
IOmNavigator
*
iface
,
IHTMLPluginsCollection
**
p
)
{
{
OmNavigator
*
This
=
OMNAVIGATOR_THIS
(
iface
);
OmNavigator
*
This
=
OMNAVIGATOR_THIS
(
iface
);
FIXME
(
"(%p)->(%p)
\n
"
,
This
,
p
);
return
E_NOTIMPL
;
TRACE
(
"(%p)->(%p)
\n
"
,
This
,
p
);
if
(
!
This
->
plugins
)
{
HRESULT
hres
;
hres
=
create_plugins_collection
(
This
,
&
This
->
plugins
);
if
(
FAILED
(
hres
))
return
hres
;
}
else
{
IHTMLPluginsCollection_AddRef
(
HTMLPLUGINSCOL
(
This
->
plugins
));
}
*
p
=
HTMLPLUGINSCOL
(
This
->
plugins
);
return
S_OK
;
}
}
static
HRESULT
WINAPI
OmNavigator_get_cookieEnabled
(
IOmNavigator
*
iface
,
VARIANT_BOOL
*
p
)
static
HRESULT
WINAPI
OmNavigator_get_cookieEnabled
(
IOmNavigator
*
iface
,
VARIANT_BOOL
*
p
)
...
...
dlls/mshtml/tests/dom.c
View file @
00ee406e
...
@@ -3590,6 +3590,26 @@ static void test_location(IHTMLDocument2 *doc)
...
@@ -3590,6 +3590,26 @@ static void test_location(IHTMLDocument2 *doc)
ok
(
!
ref
,
"location chould be destroyed here
\n
"
);
ok
(
!
ref
,
"location chould be destroyed here
\n
"
);
}
}
static
void
test_plugins_col
(
IOmNavigator
*
nav
)
{
IHTMLPluginsCollection
*
col
,
*
col2
;
ULONG
ref
;
HRESULT
hres
;
hres
=
IOmNavigator_get_plugins
(
nav
,
&
col
);
ok
(
hres
==
S_OK
,
"get_plugins failed: %08x
\n
"
,
hres
);
hres
=
IOmNavigator_get_plugins
(
nav
,
&
col2
);
ok
(
hres
==
S_OK
,
"get_plugins failed: %08x
\n
"
,
hres
);
ok
(
iface_cmp
((
IUnknown
*
)
col
,
(
IUnknown
*
)
col2
),
"col != col2
\n
"
);
IHTMLPluginsCollection_Release
(
col2
);
test_disp2
((
IUnknown
*
)
col
,
&
DIID_DispCPlugins
,
&
IID_IHTMLPluginsCollection
,
"[object]"
);
ref
=
IHTMLPluginsCollection_Release
(
col
);
ok
(
!
ref
,
"ref=%d
\n
"
,
ref
);
}
static
void
test_navigator
(
IHTMLDocument2
*
doc
)
static
void
test_navigator
(
IHTMLDocument2
*
doc
)
{
{
IHTMLWindow2
*
window
;
IHTMLWindow2
*
window
;
...
@@ -3673,6 +3693,8 @@ static void test_navigator(IHTMLDocument2 *doc)
...
@@ -3673,6 +3693,8 @@ static void test_navigator(IHTMLDocument2 *doc)
skip
(
"nonstandard user agent
\n
"
);
skip
(
"nonstandard user agent
\n
"
);
}
}
test_plugins_col
(
navigator
);
ref
=
IOmNavigator_Release
(
navigator
);
ref
=
IOmNavigator_Release
(
navigator
);
ok
(
!
ref
,
"navigator should be destroyed here
\n
"
);
ok
(
!
ref
,
"navigator should be destroyed here
\n
"
);
}
}
...
...
include/mshtml.idl
View file @
00ee406e
...
@@ -9146,12 +9146,32 @@ interface IHTMLPluginsCollection : IDispatch
...
@@ -9146,12 +9146,32 @@ interface IHTMLPluginsCollection : IDispatch
}
}
[
[
hidden
,
uuid
(
3050
f54a
-
98b5
-
11
cf
-
bb82
-
00
aa00bdce0b
)
]
dispinterface
DispCPlugins
{
properties
:
methods
:
[
propget
,
id
(
DISPID_IHTMLPLUGINSCOLLECTION_LENGTH
)
]
long
length
()
;
[
id
(
DISPID_IHTMLPLUGINSCOLLECTION_REFRESH
)
]
void
refresh
(
[
defaultvalue
(
0
),
in
]
VARIANT_BOOL
reload
)
;
[
propget
,
id
(
DISPID_IHTMLDOMCONSTRUCTOR_CONSTRUCTOR
),
hidden
]
IDispatch
*
constructor
()
;
}
[
noncreatable
,
noncreatable
,
uuid
(
3050
f3ff
-
98b5
-
11
cf
-
bb82
-
00
aa00bdce0b
)
uuid
(
3050
f3ff
-
98b5
-
11
cf
-
bb82
-
00
aa00bdce0b
)
]
]
coclass
CPlugins
coclass
CPlugins
{
{
[
default
]
interface
IHTMLPluginsCollection
;
[
default
]
dispinterface
DispCPlugins
;
interface
IHTMLPluginsCollection
;
interface
IHTMLDOMConstructor
;
}
}
/*****************************************************************************
/*****************************************************************************
...
...
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