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
41687841
Commit
41687841
authored
May 31, 2015
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jun 01, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
riched20: Properly implement GetClientSite().
parent
b620fb6e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
47 additions
and
37 deletions
+47
-37
richole.c
dlls/riched20/richole.c
+47
-33
richole.c
dlls/riched20/tests/richole.c
+0
-4
No files found.
dlls/riched20/richole.c
View file @
41687841
...
...
@@ -214,8 +214,9 @@ typedef struct IRichEditOleImpl {
ME_TextEditor
*
editor
;
ITextSelectionImpl
*
txtSel
;
IOleClientSiteImpl
*
clientSite
;
struct
list
rangelist
;
struct
list
clientsites
;
}
IRichEditOleImpl
;
struct
reole_child
{
...
...
@@ -255,12 +256,11 @@ typedef struct ITextParaImpl {
}
ITextParaImpl
;
struct
IOleClientSiteImpl
{
struct
reole_child
child
;
IOleClientSite
IOleClientSite_iface
;
IOleWindow
IOleWindow_iface
;
IOleInPlaceSite
IOleInPlaceSite_iface
;
LONG
ref
;
IRichEditOleImpl
*
reOle
;
};
static
inline
IRichEditOleImpl
*
impl_from_IRichEditOle
(
IRichEditOle
*
iface
)
...
...
@@ -940,15 +940,20 @@ static ULONG WINAPI IRichEditOleImpl_inner_fnRelease(IUnknown *iface)
if
(
!
ref
)
{
IOleClientSiteImpl
*
clientsite
;
ITextRangeImpl
*
txtRge
;
TRACE
(
"Destroying %p
\n
"
,
This
);
This
->
txtSel
->
reOle
=
NULL
;
This
->
editor
->
reOle
=
NULL
;
ITextSelection_Release
(
&
This
->
txtSel
->
ITextSelection_iface
);
IOleClientSite_Release
(
&
This
->
clientSite
->
IOleClientSite_iface
);
LIST_FOR_EACH_ENTRY
(
txtRge
,
&
This
->
rangelist
,
ITextRangeImpl
,
child
.
entry
)
txtRge
->
child
.
reole
=
NULL
;
LIST_FOR_EACH_ENTRY
(
clientsite
,
&
This
->
clientsites
,
IOleClientSiteImpl
,
child
.
entry
)
clientsite
->
child
.
reole
=
NULL
;
heap_free
(
This
);
}
return
ref
;
...
...
@@ -1039,34 +1044,43 @@ IOleClientSite_fnQueryInterface(IOleClientSite *me, REFIID riid, LPVOID *ppvObj)
static
ULONG
WINAPI
IOleClientSite_fnAddRef
(
IOleClientSite
*
iface
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
return
InterlockedIncrement
(
&
This
->
ref
);
ULONG
ref
=
InterlockedIncrement
(
&
This
->
ref
);
TRACE
(
"(%p)->(%u)
\n
"
,
This
,
ref
);
return
ref
;
}
static
ULONG
WINAPI
IOleClientSite_fnRelease
(
IOleClientSite
*
iface
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
ULONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
if
(
ref
==
0
)
TRACE
(
"(%p)->(%u)
\n
"
,
This
,
ref
);
if
(
ref
==
0
)
{
if
(
This
->
child
.
reole
)
{
list_remove
(
&
This
->
child
.
entry
);
This
->
child
.
reole
=
NULL
;
}
heap_free
(
This
);
}
return
ref
;
}
static
HRESULT
WINAPI
IOleClientSite_fnSaveObject
(
IOleClientSite
*
iface
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
IOleClientSite_fnGetMoniker
(
IOleClientSite
*
iface
,
DWORD
dwAssign
,
DWORD
dwWhichMoniker
,
IMoniker
**
ppmk
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
...
...
@@ -1077,7 +1091,7 @@ static HRESULT WINAPI IOleClientSite_fnGetContainer(IOleClientSite *iface,
IOleContainer
**
ppContainer
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
...
...
@@ -1087,7 +1101,7 @@ static HRESULT WINAPI IOleClientSite_fnGetContainer(IOleClientSite *iface,
static
HRESULT
WINAPI
IOleClientSite_fnShowObject
(
IOleClientSite
*
iface
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
...
...
@@ -1097,7 +1111,7 @@ static HRESULT WINAPI IOleClientSite_fnShowObject(IOleClientSite *iface)
static
HRESULT
WINAPI
IOleClientSite_fnOnShowWindow
(
IOleClientSite
*
iface
,
BOOL
fShow
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
...
...
@@ -1107,7 +1121,7 @@ static HRESULT WINAPI IOleClientSite_fnOnShowWindow(IOleClientSite *iface, BOOL
static
HRESULT
WINAPI
IOleClientSite_fnRequestNewObjectLayout
(
IOleClientSite
*
iface
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleClientSite
(
iface
);
if
(
!
This
->
reO
le
)
if
(
!
This
->
child
.
reo
le
)
return
CO_E_RELEASED
;
FIXME
(
"stub %p
\n
"
,
iface
);
...
...
@@ -1155,12 +1169,16 @@ static HRESULT WINAPI IOleWindow_fnContextSensitiveHelp(IOleWindow *iface, BOOL
static
HRESULT
WINAPI
IOleWindow_fnGetWindow
(
IOleWindow
*
iface
,
HWND
*
phwnd
)
{
IOleClientSiteImpl
*
This
=
impl_from_IOleWindow
(
iface
);
TRACE
(
"(%p)->(%p)
\n
"
,
This
,
phwnd
);
if
(
!
This
->
child
.
reole
)
return
CO_E_RELEASED
;
if
(
!
phwnd
)
return
E_INVALIDARG
;
*
phwnd
=
This
->
reO
le
->
editor
->
hWnd
;
*
phwnd
=
This
->
child
.
reo
le
->
editor
->
hWnd
;
return
S_OK
;
}
...
...
@@ -1294,34 +1312,35 @@ static const IOleInPlaceSiteVtbl olestvt =
IOleInPlaceSite_fnOnPosRectChange
};
static
IOleClientSiteImpl
*
CreateOleClientSite
(
IRichEditOleImpl
*
reOle
)
static
HRESULT
CreateOleClientSite
(
IRichEditOleImpl
*
reOle
,
IOleClientSite
**
ret
)
{
IOleClientSiteImpl
*
clientSite
=
heap_alloc
(
sizeof
*
clientSite
);
if
(
!
clientSite
)
return
NULL
;
return
E_OUTOFMEMORY
;
clientSite
->
IOleClientSite_iface
.
lpVtbl
=
&
ocst
;
clientSite
->
IOleWindow_iface
.
lpVtbl
=
&
olewinvt
;
clientSite
->
IOleInPlaceSite_iface
.
lpVtbl
=
&
olestvt
;
clientSite
->
ref
=
1
;
clientSite
->
reOle
=
reOle
;
return
clientSite
;
clientSite
->
child
.
reole
=
reOle
;
list_add_head
(
&
reOle
->
clientsites
,
&
clientSite
->
child
.
entry
);
*
ret
=
&
clientSite
->
IOleClientSite_iface
;
return
S_OK
;
}
static
HRESULT
WINAPI
IRichEditOle_fnGetClientSite
(
IRichEditOle
*
me
,
LPOLECLIENTSITE
*
lplpolesite
)
IRichEditOle_fnGetClientSite
(
IRichEditOle
*
me
,
IOleClientSite
**
clientsite
)
{
IRichEditOleImpl
*
This
=
impl_from_IRichEditOle
(
me
);
TRACE
(
"
%p,%p
\n
"
,
This
,
lplpole
site
);
TRACE
(
"
(%p)->(%p)
\n
"
,
This
,
client
site
);
if
(
!
lplpole
site
)
if
(
!
client
site
)
return
E_INVALIDARG
;
*
lplpolesite
=
&
This
->
clientSite
->
IOleClientSite_iface
;
IOleClientSite_AddRef
(
*
lplpolesite
);
return
S_OK
;
return
CreateOleClientSite
(
This
,
clientsite
);
}
static
HRESULT
WINAPI
...
...
@@ -4964,15 +4983,10 @@ LRESULT CreateIRichEditOle(IUnknown *outer_unk, ME_TextEditor *editor, LPVOID *p
heap_free
(
reo
);
return
0
;
}
reo
->
clientSite
=
CreateOleClientSite
(
reo
);
if
(
!
reo
->
clientSite
)
{
ITextSelection_Release
(
&
reo
->
txtSel
->
ITextSelection_iface
);
heap_free
(
reo
);
return
0
;
}
TRACE
(
"Created %p
\n
"
,
reo
);
list_init
(
&
reo
->
rangelist
);
list_init
(
&
reo
->
clientsites
);
if
(
outer_unk
)
reo
->
outer_unk
=
outer_unk
;
else
...
...
dlls/riched20/tests/richole.c
View file @
41687841
...
...
@@ -1487,8 +1487,6 @@ static void test_GetClientSite(void)
create_interfaces
(
&
w
,
&
reOle
,
&
txtDoc
,
NULL
);
hres
=
IRichEditOle_GetClientSite
(
reOle
,
&
clientSite
);
ok
(
hres
==
S_OK
,
"IRichEditOle_QueryInterface: 0x%08x
\n
"
,
hres
);
todo_wine
EXPECT_REF
(
clientSite
,
1
);
hres
=
IOleClientSite_QueryInterface
(
clientSite
,
&
IID_IRichEditOle
,
(
void
**
)
&
reOle1
);
...
...
@@ -1496,14 +1494,12 @@ todo_wine
hres
=
IRichEditOle_GetClientSite
(
reOle
,
&
clientSite1
);
ok
(
hres
==
S_OK
,
"got 0x%08x
\n
"
,
hres
);
todo_wine
ok
(
clientSite
!=
clientSite1
,
"got %p, %p
\n
"
,
clientSite
,
clientSite1
);
IOleClientSite_Release
(
clientSite1
);
hres
=
IOleClientSite_QueryInterface
(
clientSite
,
&
IID_IOleClientSite
,
(
void
**
)
&
clientSite1
);
ok
(
hres
==
S_OK
,
"IOleClientSite_QueryInterface: 0x%08x
\n
"
,
hres
);
ok
(
clientSite
==
clientSite1
,
"Should not return a new pointer.
\n
"
);
todo_wine
EXPECT_REF
(
clientSite
,
2
);
/* IOleWindow interface */
...
...
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